TreeView实现主菜单功能

TreeView实现主菜单功能


    软件在菜单MenuItem中,设置了软件的各项功能,以及启动相应模块。为了加大软件的灵活性,我们还可以将主菜单的项目,转变为TreeView,通过点击TreeView树中叶子(TreeNode),打开相应的模块,达到主菜单的功能。

                                                              
    1、设置全局变量
    Last_Node: TTreeNode;用于保存鼠标点击TreeView1的最后一次节点。这样,只要判断TreeView1.Selected和Last_Node一致,造成同样节点二次点击,才能击发事件的效果。


    2、MenuItemsToListView过程:    
procedure TMDIFrm.MenuItemsToListView(mMenu: TMenuItem; nNode: TTreeNodes;p_node: TTreeNode);
var i: Integer;
    c_node: TTreeNode;
begin
  for i := 0 to mMenu.Count - 1 do                           // 菜单项目循环   
  begin
    if mMenu.Items[i].Caption<>'-' then
    begin
      c_node:= nNode.AddChild(p_node,mMenu.Items[i].Caption);
      c_node.Data:= @mMenu.Items[i].OnClick;                 // Data指针类型,保存菜单事件
    end;
    MenuItemsToListView(mMenu.Items[i],nNode,c_node);        // 递归
  end;
end;


    3、FormCreat事件,读取菜单数据
var parent_node : TTreeNode;
begin
  TreeView1.Items.Clear;
  for i:= 0 to MainMenu1.Items.Count-1 do
  begin
    parent_node := TreeView1.Items.Add(nil,MainMenu1.Items[i].Caption);
    MenuItemsToListView(MainMenu1.Items[i],TreeView1.Items, parent_node);
  end;
end;


    4、TreeView1.OnMouseUp鼠标事件
procedure TMDIFrm.TreeView1MouseUp(Sender: TObject; Button: TMouseButton;Shift: TShiftState; X, Y: Integer);
var pro : TNotifyEvent;
begin
  if TreeView1.Selected=Last_Node then
  begin
    @pro:= TreeView1.Selected.Data;       // 读取事件地址  
    if Assigned(pro) then pro(nil);       // 执行事件
  end;
  Last_Node:=TreeView1.Selected;
end;


    5、如果处于TreeView1节点上,通过按键事件击发事件
   (1)取消TreeView1.OnMouseUp鼠标事件;
   (2)Button事件:
procedure TMDIFrm.Button1Click(Sender: TObject);
var pro : TNotifyEvent;

begin

  if TreeView1.Selected=nil then exit;

  @pro:= TreeView1.Selected.Data;
  if Assigned(pro) then pro(nil);
end;
  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
实现这个功能,可以在TreeView的SelectedItemChanged事件中获取选中的菜单项,并根据该菜单项的标识符加载对应的子窗体。 具体实现步骤如下: 1. 在TreeView中的每个菜单项上添加一个标识符,用于表示该菜单项对应的子窗体名称。 2. 在MainWindow.xaml中添加一个名为"MainFrame"的Grid,用于加载子窗体。 3. 在TreeView的SelectedItemChanged事件中,获取选中的菜单项和其标识符。 4. 根据标识符加载对应的子窗体,并将其添加到MainFrame中。 下面是实现代码示例: 1. 在TreeView中添加菜单项,并设置标识符。 ```xml <TreeView x:Name="MenuTreeView" SelectedItemChanged="MenuTreeView_SelectedItemChanged"> <TreeViewItem Header="菜单1" Tag="Window1"> <TreeViewItem Header="子菜单1.1" Tag="Window2"/> <TreeViewItem Header="子菜单1.2" Tag="Window3"/> </TreeViewItem> <TreeViewItem Header="菜单2" Tag="Window4"> <TreeViewItem Header="子菜单2.1" Tag="Window5"/> <TreeViewItem Header="子菜单2.2" Tag="Window6"/> </TreeViewItem> </TreeView> ``` 2. 在MainWindow.xaml.cs中实现选中菜单项后加载子窗体的逻辑。 ```csharp private void MenuTreeView_SelectedItemChanged(object sender, RoutedPropertyChangedEventArgs<object> e) { // 获取选中的菜单项和其标识符 TreeViewItem selectedItem = (TreeViewItem)e.NewValue; string windowName = selectedItem.Tag.ToString(); // 加载子窗体 Type windowType = Type.GetType("WpfApp1." + windowName); if (windowType != null) { Window window = (Window)Activator.CreateInstance(windowType); window.Owner = this; window.WindowStartupLocation = WindowStartupLocation.CenterOwner; window.ShowInTaskbar = false; window.ShowActivated = true; // 将子窗体添加到MainFrame中 MainFrame.Children.Clear(); MainFrame.Children.Add(window); } } ``` 注意:在上面的示例代码中,我们假设子窗体的类名与标识符相同,并且都在WpfApp1命名空间中。如需使用其他命名空间或类名,请自行修改代码。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值