我在我的WPF应用中使用ExpressionDark
主题,它具有MenuItems
的自定义样式。
如果MenuItem
被禁用,则应使用灰色样式来反映这一点,它适用于MenuItems
控件内的Menu
:
但它对MenuItems
中的ContextMenu
不起作用(禁用复制)
我已经将问题跟踪到TextBlock样式,如果我删除这个样式它适用于ContextMenu,但其他样式随着它被删除
<Style TargetType="{x:Type TextBlock}">
<Setter Property="Foreground" Value="{DynamicResource TextBrush}" />
</Style>
编辑:如果我使用MenuItem
或我的自定义GestureMenuItem
并不重要,但重要的是如果我使用_ char或不是密钥快捷方式)如果我删除_那么样式在MainMenu
中也不起作用。
MenuItem
的相关风格:
<Trigger Property="IsEnabled" Value="false">
<Setter Property="Foreground" Value="{DynamicResource {x:Static SystemColors.GrayTextBrushKey}}" />
</Trigger>
找到源代码here。相关的ContextMenu
XAML:
<TextBox x:Name="Text"
Height="Auto"
TextWrapping="Wrap"
VerticalScrollBarVisibility="Visible"
AcceptsReturn="True"
IsReadOnly="true">
<TextBox.ContextMenu>
<ContextMenu>
<MenuItem Header="Copy" Command="Copy">
<MenuItem.Icon>
<Image Source="{StaticResource IconCopy}"/>
</MenuItem.Icon>
</MenuItem>
<Separator></Separator>
<MenuItem cal:Message.Attach="Clear()" Header="Clear All">
<MenuItem.Icon>
<Image Source="{StaticResource IconDelete}"/>
</MenuItem.Icon>
</MenuItem>
</ContextMenu>
</TextBox.ContextMenu>
</TextBox>
工作主菜单中的 MenuItems
(GestureMenuItem
继承MenuItem
并使用相同的样式):
<Menu IsMainMenu="True">
<Menu.Resources>
<Image x:Key="ViewIcon" x:Shared="false"
Source="{Binding Path=Icon}" />
</Menu.Resources>
<!-- Items here removed to shorten XAML -->
<MenuItem Header="_Script">
<common:GestureMenuItem x:Name="RunScript" Header="_Run script" Key="F5">
<MenuItem.Icon>
<Image Source="{StaticResource IconPlay}"/>
</MenuItem.Icon>
</common:GestureMenuItem>
<common:GestureMenuItem x:Name="StopScript" Header="_Stop script" Key="F5" Modifiers="Shift">
<MenuItem.Icon>
<Image Source="{StaticResource IconStop}"/>
</MenuItem.Icon>
</common:GestureMenuItem>
</MenuItem>
<!-- Items here removed to shorten XAML -->
</Menu>
手势项风格:
<Style TargetType="{x:Type Caliburn:GestureMenuItem}" BasedOn="{StaticResource {x:Type MenuItem}}">
</Style>
我想出了一个解决方案,它不会给出完全相同的风格,但它有效,我应该去吗?
<Trigger Property="IsEnabled" Value="False">
<Setter Property="Opacity" Value="0.5"/>
</Trigger>
这个解决方案的手势文字和图标都是灰色的,所以它可能是一个比将Forecolor设置为灰色更好的解决方案:
答案 0 :(得分:3)
我通过用Opacity属性setter替换Forecolor属性setter来解决它,这也会影响手势文本和图标,这也是默认样式的方式
<Trigger Property="IsEnabled" Value="False">
<Setter Property="Opacity" Value="0.3"/>
</Trigger>
答案 1 :(得分:0)
我发现针对InputGestureText和Header的ContentPresenters分别更有效率。在我的案例中定位整个MenuItem会导致透明的MenuItems。我已经展示了如何解决以下问题:
<Trigger Property="IsEnabled" Value="False">
<Setter TargetName="HeaderHost" Property="Opacity" Value="0.3"/>
<Setter TargetName="IGTHost" Property="Opacity" Value="0.3"/>
</Trigger>