上下文菜单和树视图
本文关键字:视图 菜单 上下文 | 更新日期: 2023-09-27 18:02:30
我如何创建一个上下文菜单,将显示当用户右键单击我的树视图的一个元素?
我想获得被点击的项目的名称,这怎么可能?
这是我的树视图:
<TreeView Name="tvwResultados"
MouseMove="DataGrid_MouseMove"
MouseLeftButtonDown="DataGrid_PreviewMouseLeftButtonDown"
ItemTemplate="{StaticResource empresaTemplate}"
ItemsSource="{Binding Empresas}"
Padding="0,6,0,6"
Background="Black"
BorderBrush="Gray"
BorderThickness="1">
<TreeView.ItemContainerStyle>
<Style TargetType="{x:Type TreeViewItem}">
<Setter Property="BorderThickness" Value="1" />
<Setter Property="Padding" Value="4,2,4,2" />
<Style.Triggers>
<Trigger Property="IsSelected" Value="True">
<Setter Property="BorderBrush" Value="Gray" />
</Trigger>
</Style.Triggers>
</Style>
</TreeView.ItemContainerStyle>
<TreeView.Resources>
<SolidColorBrush x:Key="{x:Static SystemColors.HighlightBrushKey}" Color="#171717" />
<SolidColorBrush x:Key="{x:Static SystemColors.HighlightTextBrushKey}" Color="Silver" />
<SolidColorBrush x:Key="{x:Static SystemColors.ControlBrushKey}" Color="#333333" />
<SolidColorBrush x:Key="{x:Static SystemColors.ControlTextBrushKey}" Color="Silver" />
<SolidColorBrush x:Key="{x:Static SystemColors.InactiveSelectionHighlightBrushKey}" Color="Gray" />
<SolidColorBrush x:Key="{x:Static SystemColors.InactiveSelectionHighlightTextBrushKey}" Color="Silver" />
</TreeView.Resources>
</TreeView>
根据许多因素,有几种方法可以将ContextMenu
添加到TreeViewItems
中。例如,每个TreeViewItem
对应的ContextMenu
是否相同?MenuItems
从何而来?
一个解决方案是将ContextMenu
添加到ItemContainerStyle
。您可以将ContextMenu
定义为Window
中的资源或任何顶级控件,例如:
<Window.Resources>
<ContextMenu x:Key="TreeItemMenu">
<MenuItem Header="Menu Item 1" Click="MenuItem_Click_1"/>
<MenuItem Header="Menu Item 2" Click="MenuItem_Click_2"/>
</ContextMenu>
</Window.Resources>
然后你可以更新你的ItemContainerStyle
来使用这个ContextMenu
,像这样:
<TreeView.ItemContainerStyle>
<Style TargetType="{x:Type TreeViewItem}">
<Setter Property="BorderThickness" Value="1" />
<Setter Property="Padding" Value="4,2,4,2" />
<Setter Property="ContextMenu" Value="{DynamicResource TreeItemMenu}"/>
<Style.Triggers>
<Trigger Property="IsSelected" Value="True">
<Setter Property="BorderBrush" Value="Gray" />
</Trigger>
</Style.Triggers>
</Style>
</TreeView.ItemContainerStyle>
要获取被单击的Item,需要单独处理它。您可以使用EventSetter
将事件附加到每个TreeViewItem
,然后跟踪最后单击的项目,如下所示:
把这个添加到
样式的setter中<EventSetter Event="MouseRightButtonDown" Handler="OnTreeItemClicked"/>
然后在后面的代码中:
private void OnTreeItemClicked(object sender, MouseButtonEventArgs e)
{
_item = sender as TreeViewItem;
if (_item != null)
{
string header = _item.Header.ToString();
}
}
这将向每个TreeViewItem
添加相同的ContextMenu
,并对MenuItems
进行硬编码,但是它演示了如何添加ContextMenu
。你当然可以更灵活/动态/高级,但这应该是你开始的基础。
更容易…将工具箱中的ContextMenuStrip添加到设计视图中。添加您想要的菜单选项(如果您想重命名名称,或者将其留在ContextMenuStrip1)。然后你所要做的就是在设计模式下选择TreeView,属性,并设置上下文菜单。