1

パスを含むコントロールテンプレートがあります(他のコントロール以外)。コントロールのサイズを変更するときに、パスのサイズを変更する必要があります。パスを表すポイントとサイズは、コントロールサイズの相対的な割合として表すことができます。

テンプレートの抜粋は次のとおりです。

<Path Stroke="Gray" StrokeThickness="5">
    <Path.Data>
        <PathGeometry>
            <PathFigure StartPoint="{TemplateBinding Start}" >
                <ArcSegment Point="{TemplateBinding End}" Size="{TemplateBinding Size}" RotationAngle="0" IsLargeArc="True" />
            </PathFigure>
        </PathGeometry>
    </Path.Data>
</Path>

StartとEndはPoint型のDependencyPropertiesであり、SizeはSize型のDependencyPropertyです。

私が現在行っているのは、FrameworkElement.SizeChangedイベントをリッスンしています。

void OperationModeIndicator_SizeChanged( object sender, SizeChangedEventArgs e )
{
    this.Size = new Size( e.NewSize.Width * 0.45f, e.NewSize.Height * 0.45f );
    this.Start = new Point( e.NewSize.Width * 0.35f, e.NewSize.Height * 0.1f );
    this.End = new Point( e.NewSize.Width * 0.65f, e.NewSize.Height * 0.1f );
}

問題は次のとおりです。パスのプロパティを親コントロールのサイズにバインドする別の(よりエレガントな)方法はありますか?

4

1 に答える 1

1

あなたが持っているものはおそらくこれを達成するための最良の方法です。

もう1つの方法は、WidthPercentageとHeightPercentageの2つのパブリックプロパティを公開するカスタムIMultiValueConverterを作成することです。次に、テンプレート化された親のActualWidth/ActualHeightにバインドできます。

public class MyConverter : IMultiValueConverter {

    public double HeightPercentage { get; set; }
    public double WidthPercentage { get; set; }

    public object Convert(object[] values, Type targetType, object parameter, CultureInfo culture) {
        // TODO: Validate values size and types

        return new Point(((double)values[0]) * this.WidthPercentage, ((double)values[1]) * this.HeightPercentage);
    }

    public object[] ConvertBack(object value, Type[] targetTypes, object parameter, CultureInfo culture) {
        // No-op or throw
    }

}

どちらを使用しますか:

<local:MyConverter x:Key="StartPointConverter"
    WidthPercentage="0.35" HeightPercentage="0.1" />

<!-- ... -->

<PathFigure>
    <PathFigure.StartPoint>
        <MultiBinding Converter="{StaticResource StartPointConverter}">
            <Binding RelativeSource="{RelativeSource TemplatedParent}" Path="ActualWidth" />
            <Binding RelativeSource="{RelativeSource TemplatedParent}" Path="ActualHeight" />
        </MultiBinding>
    </PathFigure.StartPoint>
    <!-- ... -->
</PathFigure>
于 2011-05-20T11:50:17.097 に答える