wpf treeview 新增右键菜单

<TreeView.ItemContainerStyle>
<Style TargetType="{x:Type TreeViewItem}">
<EventSetter Event="TreeViewItem.PreviewMouseRightButtonDown" Handler="TreeViewItem_PreviewMouseRightButtonDown"/>
</Style>
</TreeView.ItemContainerStyle>

 

private void TreeViewItem_PreviewMouseRightButtonDown(object sender, MouseButtonEventArgs e)
{
var treeViewItem = VisualUpwardSearch<TreeViewItem>(e.OriginalSource as DependencyObject) as TreeViewItem;
if (treeViewItem != null)
{
treeViewItem.Focus();
e.Handled = true;
CreateContextMenu(treeViewItem);
}
}

 

static DependencyObject VisualUpwardSearch<T>(DependencyObject source)
{
while (source != null && source.GetType() != typeof(T))
source = VisualTreeHelper.GetParent(source);

return source;
}

private void CreateContextMenu(TreeViewItem item)
{
ContextMenu contextMenu = new ContextMenu();
MenuItem menuAddItem = new MenuItem();
menuAddItem.Header = "添加";
menuAddItem.Click += (sender, e) =>
{
item.IsSelected = true;
txtInput = new TextBoxInput();
txtInput.Show();
txtInput.SetTreeViewItem(CustomTreeView, item, 1);//自己的业务代码
};
contextMenu.Items.Add(menuAddItem);

MenuItem menuEditItem = new MenuItem();
menuEditItem.Header = "修改";
menuEditItem.Click += (sender, e) =>
{
item.IsSelected = true;
txtInput = new TextBoxInput();
txtInput.Show();
txtInput.SetTreeViewItem(CustomTreeView, item, 2);//自己的业务代码
};
contextMenu.Items.Add(menuEditItem);

MenuItem menuDelItem = new MenuItem();
menuDelItem.Header = "删除";
menuDelItem.Click += (sender, e) =>
{
if (item != null)
{
DeleteNode(item);//自己的业务代码
}
};
contextMenu.Items.Add(menuDelItem);

this.CustomTreeView.ContextMenu = contextMenu;
}

posted @   $一线码农$  阅读(396)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
点击右上角即可分享
微信分享提示