コントロールテンプレート内でボタンアイコンとしてジオメトリドローイングを使用し、そのBrush
プロパティをボタンのForeground
プロパティにバインドしたいが、機能しません。一方、ブラシを明示的に設定すると、ブラシが機能します。ポール・フィッシャーの答え -ButtonBindingのDrawingImage内でTemplateBindingが機能しない
<Style x:Key="SimpleButtonStyle" TargetType="{x:Type Button}">
<Setter Property="Background" Value="LightGray"/>
<Setter Property="Foreground" Value="Black"/>
<Setter Property="BorderThickness" Value="2"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type Button}">
<Border x:Name="border"
BorderBrush="{TemplateBinding Foreground}"
BorderThickness="{TemplateBinding BorderThickness}"
Background="{TemplateBinding Background}"
SnapsToDevicePixels="true">
<StackPanel Orientation="Vertical">
<Image x:Name="buttonImage" Height="20" Width="20">
<Image.Source>
<DrawingImage>
<DrawingImage.Drawing>
<!-- line below does not work -->
<GeometryDrawing Brush="{TemplateBinding Foreground}">
<GeometryDrawing.Geometry>
<EllipseGeometry RadiusX="15" RadiusY="15"/>
</GeometryDrawing.Geometry>
</GeometryDrawing>
</DrawingImage.Drawing>
</DrawingImage>
</Image.Source>
</Image>
<ContentPresenter x:Name="contentPresenter"/>
</StackPanel>
</Border>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
まあ、いくつかの奇妙な理由で、 'ブラシのために= "{バインディングフォアグラウンド、RelativeSource = {RelativeSource TemplatedParent}}"が動作します。これは他の回答で比較的よく記録されています。少なくとも誰かがそれについて詳述できますか?私はいくつかの有益な情報で答えを受け入れることをうれしく思っています... – heltonbiker