Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/.net/24.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
.net 如何为XAML中的不同控件使用自定义样式_.net_Wpf_Templates_Xaml_Styles - Fatal编程技术网

.net 如何为XAML中的不同控件使用自定义样式

.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}

我已经为ressource dic中的按钮编写了自定义样式。我的问题是,是否可以对不同的按钮使用这种样式?这意味着我需要通过调用样式来设置参数以切换图片目标。(怎么做?)

窗口:

<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
}