python3:wxpython分割窗、通过菜单项切换左面板树形控件

 

1. 功能概述

    这里简单介绍下,通过分割窗垂直分割出两块区域,并绑定两个面板,左面板绑定3个树形控件,初始隐藏。然后添加菜单,绑定事件,通过点击菜单来切换树形控件的显示

2. 效果图

                 

3. 下面是代码

import wx
import wx.lib.agw.customtreectrl as CT


class MyFrame(wx.Frame):
    def __init__(self, parent, id, title, pos, size):
        # 初始化父类
        super().__init__(parent, id, title, pos, size)
        # 添加菜单栏及菜单
        self.menuBar = wx.MenuBar()
        self.file1 = wx.Menu()
        self.file2 = wx.Menu()
        # 添加菜单到菜单栏
        self.menuBar.Append(self.file1, "File")
        self.menuBar.Append(self.file2, "关于")
        # (id, 菜单项名称, 状态栏说明)  id=-1表示取一个新的id
        self.menu1 = self.file1.Append(-1, "树1", "树1...")
        self.menu2 = self.file1.Append(-1, "树2", "树2...")
        self.menu3 = self.file1.Append(-1, "树3", "树3...")
        # 显示菜单栏
        self.SetMenuBar(self.menuBar)
        # 显示状态栏(位置在框架最下方)
        self.status_bar = self.CreateStatusBar()
        # 创建分割窗,定义左右两个面板
        self.splitter = wx.SplitterWindow(self, -1)
        self.left_panel = wx.Panel(self.splitter)
        self.right_panel = wx.Panel(self.splitter)
        self.splitter.SplitVertically(self.left_panel, self.right_panel, 240)
        # 定义右面板白色背景色
        self.right_panel.SetBackgroundColour("white")
        # 创建3个树形控件
        self.tree1 = self.create_tree("tree_1", 7)
        self.tree2 = self.create_tree("tree_2", 5)
        self.tree3 = self.create_tree("tree_3", 12)
        # 将3个树形控件都放在左面板上,并用BoxSizer管理
        self.panel(self.tree1)
        self.panel(self.tree2)
        self.panel(self.tree3)
        # 初始隐藏3个树形控件
        #self.tree1.Hide()
        self.tree2.Hide()
        self.tree3.Hide()
        # 为三个菜单项绑定事件
        self.Bind(wx.EVT_MENU, self.OnMenu1, self.menu1)
        self.Bind(wx.EVT_MENU, self.OnMenu2, self.menu2)
        self.Bind(wx.EVT_MENU, self.OnMenu3, self.menu3)

    # 菜单触发的动作
    def OnMenu1(self, event):
        self.tree2.Hide()
        self.tree3.Hide()
        self.tree1.Show()

    def OnMenu2(self, event):
        self.tree1.Hide()
        self.tree3.Hide()
        self.tree2.Show()

    def OnMenu3(self, event):
        self.tree1.Hide()
        self.tree2.Hide()
        self.tree3.Show()

    def create_tree(self, name, num):
        custom_tree = CT.CustomTreeCtrl(parent=self.left_panel, pos=(0, 0), size=(240, 400),
                                            agwStyle=wx.TR_DEFAULT_STYLE)
        # 树形控件根(ct_type=1显示复选框)
        root = custom_tree.AddRoot(name, ct_type=1)
        custom_tree.CheckItem(root)
        # 定义图标
        il = wx.ImageList(16, 16)
        fldridx = il.Add(wx.ArtProvider.GetBitmap(wx.ART_FOLDER, wx.ART_OTHER, (16, 16)))
        fileidx = il.Add(wx.ArtProvider.GetBitmap(wx.ART_NORMAL_FILE, wx.ART_OTHER, (16, 16)))
        custom_tree.SetImageList(il)
        # 给根项添加图标
        custom_tree.SetItemImage(root, fldridx, wx.TreeItemIcon_Normal)
        # 创建子项
        for i in range(0, num):
            mid_name = "item_" + str(i)
            item = custom_tree.AppendItem(root, mid_name, ct_type=1)
            custom_tree.SetItemImage(item, fldridx, wx.TreeItemIcon_Normal)
            for j in range(0, 3):
                sub_name = "sub_file_" + str(j)
                sub_item = custom_tree.AppendItem(item, sub_name, ct_type=1)
                custom_tree.SetItemImage(sub_item, fileidx, wx.TreeItemIcon_Normal)
        # 展开根项
        custom_tree.Expand(root)
        return custom_tree

    def panel(self, control):
        vbox_left = wx.BoxSizer(wx.VERTICAL)
        self.left_panel.SetSizer(vbox_left)
        vbox_left.Add(control, 1, flag=wx.EXPAND | wx.ALL, border=5)


if __name__ == '__main__':

    app = wx.App()
    frame = MyFrame(parent=None, id=-1, title="test", pos=(600, 200), size=(600, 480))
    frame.Show()
    app.MainLoop()

4.  扩展

     在右边板上可以添加,一些按钮,文本框来丰富小工具的功能;还有树形控件的响应事件,通过选中不同复选框来进行不同动作或输出等,这里就不再多述

 

 

  • 3
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值