.net 如何为XAML中的不同控件使用自定义样式
我已经为ressource dic中的按钮编写了自定义样式。我的问题是,是否可以对不同的按钮使用这种样式?这意味着我需要通过调用样式来设置参数以切换图片目标。(怎么做?) 窗口:.net 如何为XAML中的不同控件使用自定义样式,.net,wpf,templates,xaml,styles,.net,Wpf,Templates,Xaml,Styles,我已经为ressource dic中的按钮编写了自定义样式。我的问题是,是否可以对不同的按钮使用这种样式?这意味着我需要通过调用样式来设置参数以切换图片目标。(怎么做?) 窗口: <Button .... Style="{DynamicResource downloadButtonStyle}" IsEnabled="True" /> 资源中心: <Style x:Key="downloadButtonStyle" TargetType="{x:Type Button}
<Button .... Style="{DynamicResource downloadButtonStyle}" IsEnabled="True" />
资源中心:
<Style x:Key="downloadButtonStyle" TargetType="{x:Type Button}">
<Setter Property="IsEnabled" Value="True" />
<Setter Property="Template">
<Setter.Value>
<ControlTemplate>
<Image x:Name="PART_img" Source="/FtpUploadClient;component/media/box_48.png"/>
<ControlTemplate.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<Setter TargetName="PART_img" Property="Source" Value="/FtpUploadClient;component/media/box_download_48.png" />
</Trigger>
<Trigger Property="IsEnabled" Value="False">
<Setter TargetName="PART_img" Property="Source" Value="/FtpUploadClient;component/media/box_deactivated_48.png" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
</Setter.Value>
</Setter>
</Style>
您可以使用附加属性。这将使您能够为每个
按钮
实例指定模板内的图像
的源
<Button Style="{DynamicResource downloadButtonStyle}"
ex:ButtonExtension.DefaultImageSource="DefaultImageSource"
ex:ButtonExtension.MouseOverImageSource="MouseOverImageSource"
ex:ButtonExtension.DisabledImageSource="DisabledImageSource" />
钮扣张力
<ControlTemplate>
<Image x:Name="PART_img" Source="{Binding RelativeSource={RelativeSource TemplatedParent},
Path=(ex:ButtonExtension.DefaultImageSource)}"/
<ControlTemplate.Triggers>
<Trigger Property="IsMouseOver" Value="True">
<Setter TargetName="PART_img" Property="Source" Value="{Binding RelativeSource={RelativeSource TemplatedParent},
Path=(ex:ButtonExtension.MouseOverImageSource)}" />
</Trigger>
<Trigger Property="IsEnabled" Value="False">
<Setter TargetName="PART_img" Property="Source" Value="{Binding RelativeSource={RelativeSource TemplatedParent},
Path=(ex:ButtonExtension.DisabledImageSource)}" />
</Trigger>
</ControlTemplate.Triggers>
</ControlTemplate>
public class ButtonExtension
{
public static DependencyProperty DefaultImageSourceProperty =
DependencyProperty.RegisterAttached("DefaultImageSource",
typeof(ImageSource),
typeof(ButtonExtension),
new PropertyMetadata(null));
public static ImageSource GetImageSource(DependencyObject target)
{
return (ImageSource)target.GetValue(DefaultImageSourceProperty);
}
public static void SetImageSource(DependencyObject target, ImageSource value)
{
target.SetValue(DefaultImageSourceProperty, value);
}
// Repeat for MouseOverImageSource and DisabledImageSource
}