如何将ControlTemplate Enabled属性绑定到WPF XAML中的Opacity

时间:2009-04-27 08:01:11

标签: c# wpf xaml controltemplate opacity

在XAML内部的WPF中,如何扩展ControlTemplate,当应用于按钮并且按钮被禁用时,它会在禁用时淡化为0.5不透明度,并且一旦启用就会淡化回1.0不透明度。

当禁用父级时,此视觉效果也应该起作用。

1 个答案:

答案 0 :(得分:8)

您不需要ControlTemplate。你可以用风格完成这个。以下按钮样式应用于所有按钮。当IsEnabled为true时,它将Opacity设置为0.5,并在触发条件不再适用时自动将其返回到1。如果您在样式中应用ControlTemplate,则可以将此触发器添加到该样式。由于继承了IsEnabled,因此父进程被禁用时也可以使用它。

<Window.Resources>
    <Style TargetType="{x:Type Button}">
        <Style.Triggers>
            <Trigger Property="Control.IsEnabled" Value="false">
                <Setter Property="Control.Opacity" Value="0.5" />
            </Trigger>
        </Style.Triggers>
    </Style>
</Window.Resources>

或者您是否特别需要ControlTemplate解决方案?

<强>更新

我认为TemplateBinding不支持Converter,所以如果你想在ControlTemplate中这样做,你需要在逻辑树中使用类似下面的Binding语句。

Opacity={Binding Path=IsEnabled, 
         RelativeSource={RelativeSource TemplatedParent}, 
         Converter={StaticResource BoolToDoubleConverter}}

其中BoolToDoubleConverter是一个IValueConverter,它返回1表示true,0.5表示false。如果你可以使用样式,我仍然会推荐样式方法。我相信更简单。