我正在尝试使用可检查的menuitem。但是复选标记不起作用。
这是代码
<MenuItem Header="Switch to...">
<MenuItem IsCheckable="True" IsChecked="True" Header="Stroke-Based" StaysOpenOnClick="True" />
<MenuItem IsCheckable="True" IsChecked="True" Header="Color-Transfer" StaysOpenOnClick="True" />
</MenuItem>
我在哪里做错了?
最佳答案
Mahapps自定义菜单项存在完全相同的问题。这是我为处理现有菜单项xaml-中的IsChecked触发器而添加的代码
添加此“ CheckMarkPanel”网格,然后删除图标网格。或者,您可以将两者都留着,但我删除了我的。
<Grid Grid.Column="0"
Margin="6,0,6,0"
x:Name="CheckMarkPanel"
VerticalAlignment="Center"
HorizontalAlignment="Center"
Visibility="Collapsed">
<Path x:Name="CheckMarkPath"
Width="7" Height="7"
Visibility="Hidden"
SnapsToDevicePixels="False"
Stroke="#cccccc"
Fill="Green"
StrokeThickness="2"
Data="M 0 0 L 7 7 M 0 7 L 7 0" />
</Grid>
添加这些多触发条件-
<MultiTrigger>
<MultiTrigger.Conditions>
<Condition Property="IsChecked"
Value="true" />
<Condition Property="Role"
Value="SubmenuItem" />
</MultiTrigger.Conditions>
<Setter TargetName="CheckMarkPath"
Property="Visibility"
Value="Visible" />
</MultiTrigger>
<MultiTrigger>
<MultiTrigger.Conditions>
<Condition Property="IsCheckable"
Value="true" />
<Condition Property="Role"
Value="SubmenuItem" />
</MultiTrigger.Conditions>
<Setter TargetName="CheckMarkPanel"
Property="Visibility"
Value="Visible" />
</MultiTrigger>
并折叠CheckMarkPanel对TopLevelHeader / TopLevelItem / subMenutItem的可见性。