繁体   English   中英

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

[英]How to bind ControlTemplate Enabled property to Opacity in WPF XAML

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

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

您不需要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。 如果你可以使用样式,我仍然会推荐样式方法。 我相信更简单。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM