我正在尝试更改实现 CornerRadius DependencyProperty 的派生按钮的 FocusVisualStyle。一切都适用于按钮样式,但我不知道如何将 CornerRadius 值发送到 FocusVisualStyle。
这是我当前的 FocusVisualStyle 代码:
<Style x:Key="FocusVisualStyle">
<Setter Property="Control.Template">
<Setter.Value>
<ControlTemplate>
<Border BorderBrush="{StaticResource MyFocusBorderBrush}"
BorderThickness="1"
CornerRadius="{Binding CornerRadius, RelativeSource={RelativeSource FindAncestor, AncestorType={x:Type local:MyButton}}}"
SnapsToDevicePixels="True"
UseLayoutRounding="True"/>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
我也尝试过这种形式的绑定:
CornerRadius="{Binding CornerRadius, RelativeSource={RelativeSource TemplatedParent}}"
你能帮忙的话,我会很高兴 :)
编辑:根据要求,这将是我的所有代码:
我的按钮.cs:
public class MyButton : Button
{
public int CornerRadius
{
get { return (int)GetValue(CornerRadiusProperty); }
set { SetValue(CornerRadiusProperty, value); }
}
// DependencyProperty as the backing store for CornerRadius
public static readonly DependencyProperty CornerRadiusProperty = DependencyProperty.Register(
"CornerRadius",
typeof(int),
typeof(MyButton),
new PropertyMetadata(3)
);
static MyButton()
{
DefaultStyleKeyProperty.OverrideMetadata(typeof(MyButton), new FrameworkPropertyMetadata(typeof(MyButton)));
}
}
主题\Generic.xaml:
<Style x:Key="FocusVisualStyle">
<Setter Property="Control.Template">
<Setter.Value>
<ControlTemplate>
<Border BorderBrush="Red"
BorderThickness="1"
CornerRadius="{Binding CornerRadius, ElementName=background}"
SnapsToDevicePixels="True"
UseLayoutRounding="True" />
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
<Style TargetType="{x:Type local:MyButton}">
<Setter Property="Content" Value="MyButton"/>
<Setter Property="Background" Value="DarkGray"/>
<Setter Property="Foreground" Value="White"/>
<Setter Property="Height" Value="20"/>
<Setter Property="FocusVisualStyle" Value="{StaticResource FocusVisualStyle}"/>
<Setter Property="Template">
<Setter.Value>
<ControlTemplate TargetType="{x:Type local:MyButton}">
<Border x:Name="background"
Background="{TemplateBinding Background}"
BorderThickness="{TemplateBinding BorderThickness}"
CornerRadius="{Binding CornerRadius, RelativeSource={RelativeSource TemplatedParent}}">
<ContentPresenter VerticalAlignment="Center"
HorizontalAlignment="Center" />
</Border>
<ControlTemplate.Triggers>
<Trigger Property="IsMouseOver"
Value="True">
<Setter TargetName="background"
Property="Background"
Value="Gray" />
</Trigger>
<Trigger Property="IsPressed"
Value="True">
<Setter TargetName="background"
Property="Background"
Value="Black" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
编辑:考虑到我从来没有找到一个好的解决方案,这就是我解决它的方法:
public MyButton()
{
Loaded += (s, e) =>
{
string styleStr = "<Style xmlns='http://schemas.microsoft.com/winfx/2006/xaml/presentation'>" +
"<Setter Property = \"Control.Template\"> " +
"<Setter.Value> " +
"<ControlTemplate> " +
"<Rectangle Margin = \"-2\" " +
"Stroke = \"" + Resource<SolidColorBrush>.GetColor("MaxFocusBorder") + "\" " +
"StrokeThickness = \"1\" " +
"StrokeDashArray = \"1 2\" " +
"RadiusX = \"" + CornerRadius + "\" " +
"RadiusY = \"" + CornerRadius + "\" " +
"SnapsToDevicePixels = \"True\" " +
"UseLayoutRounding = \"True\" /> " +
"</ControlTemplate> " +
" </Setter.Value> " +
"</Setter> " +
"</Style>";
FocusVisualStyle = (Style)XamlReader.Parse(styleStr);
};
}