1

有两个上下文菜单。要打开所需的上下文菜单,请单击鼠标右键。如果 IsData 为真,则 ContextMenu1 将打开;如果 IsData 为 false,则 ContextMenu2 将打开。该问题将在 XAML 中展开。

DataTemplate 中有两个静态上下文菜单。一个上下文菜单如何使用它们?此块完全设置模板上下文菜单。选择哪个,取决于条件。

<DataTemplate x:Key="ContextMenuControlTemplate">
    <DataTemplate.Resources>

        <ContextMenu x:Key="ContextMenuSet">
            <MenuItem>
                <MenuItem.Header>
                    <StackPanel Orientation="Horizontal">
                        <Image Width="15" Height="15" Source="{DynamicResource img_icon}"/>
                        <TextBlock HorizontalAlignment="Center" VerticalAlignment="Center" Text="  Add item" />

                    </StackPanel>
                </MenuItem.Header>
                <MenuItem.Icon>
                    <RadioButton IsChecked="True"/>
                </MenuItem.Icon>
            </MenuItem>
            <MenuItem Header="Remove"></MenuItem>
        </ContextMenu>

        <ContextMenu x:Key="ContextMenuDel">
            <MenuItem Header=" Del all"></MenuItem>
        </ContextMenu>

    </DataTemplate.Resources>

    <ContextMenu x:Name="contextMenuForItems"/>

    <DataTemplate.Triggers>

        <DataTrigger Binding="{Binding Data.IsData}" Value="true">
            <Setter TargetName="contextMenuForItems" Property="ContextMenu" Value="{StaticResource ContextMenuSet}" />
        </DataTrigger>

        <DataTrigger Binding="{Binding Data.IsData}" Value="false">
            <Setter TargetName="contextMenuForItems" Property="ContextMenu" Value="{StaticResource ContextMenuDel}" />
        </DataTrigger>

    </DataTemplate.Triggers>
</DataTemplate>

而这里的块正在尝试使用我们建立的上下文菜单。一个问题就在这里面。

                        <DataTemplate>
                            <DockPanel>
                                <ContextMenu>
                                <DataTemplate>
                                        <ContentControl Content="{Binding Data.IsData}"
                                    ContentTemplate="{StaticResource ContextMenuControlTemplate}"
                                     />
                                </DataTemplate>
                                </ContextMenu>
                            </DockPanel>
                        </DataTemplate>
4

1 回答 1

0

我使用了解决方法。我制作了一份复杂的菜单。并且删除了一些缺少的 MenuItem。请参阅关键字 Visibility 和 booleanToVisibilityConverter。我的例子如下。

                                <DockPanel.ContextMenu>
                                    <ContextMenu>
                                        <MenuItem IsEnabled="False" Visibility="{Binding Data.IsData, Converter={StaticResource booleanToVisibilityConverter2}}">
                                            <MenuItem.Header>
                                                <StackPanel Orientation="Horizontal">
                                                    <Image Width="15" Height="15" Source="{DynamicResource img_icon}"/>
                                                    <TextBlock HorizontalAlignment="Center" VerticalAlignment="Center" Text="  Add item" />

                                                </StackPanel>
                                            </MenuItem.Header>
                                            <MenuItem.Icon>
                                                <RadioButton IsChecked="True"/>
                                            </MenuItem.Icon>
                                        </MenuItem>
                                        <MenuItem Click="MenuItem_Click"  Header="Remove" Visibility="{Binding Data.IsData, Converter={StaticResource booleanToVisibilityConverter2}}" />
                                        <MenuItem Click="MenuItem_Click" Header="Del all" Visibility="{Binding Data.IsData, Converter={StaticResource booleanToVisibilityConverter2}, ConverterParameter=InvertCollapse}" />
                                    </ContextMenu>
                                </DockPanel.ContextMenu>

booleanToVisibilityConverter2 是 BooleanToVisibilityConverter 的包装器,它具有其他属性。

于 2012-08-16T15:50:21.597 回答