[英]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.