我正在尝试使用可检查的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的可见性。

10-06 12:05