Я хочу использовать GeometryDrawing как значок кнопки внутри ControlTemplate, и я хочу, чтобы его свойство Brush
было привязано к свойству кнопки Foreground
, но оно не работает. С другой стороны, если я установлю Brush явно, это сработает.TemplateBinding не работает внутри DrawingImage в стиле кнопки
Вот мой (нерабочий) Код:
<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>
Ну, по какой-то странной причине, 'Brush = "{Binding Foreground, RelativeSource = {RelativeSource TemplatedParent}}" работает. Это относительно хорошо документировано в других ответах. Может, по крайней мере, кто-то это уточнит? Я был бы рад принять ответ с полезной информацией ... – heltonbiker