iis服务器助手广告广告
返回顶部
首页 > 资讯 > 后端开发 > Python >wxPython中wx.gird.Gird添加按钮的实现
  • 213
分享到

wxPython中wx.gird.Gird添加按钮的实现

wxPythonwx.gird.GirdwxPythonwx.gird.Gird添加按钮 2023-03-19 17:03:19 213人浏览 薄情痞子

Python 官方文档:入门教程 => 点击学习

摘要

目录前言1、派生按钮渲染器与按钮编辑器2、表格实现3、编辑调试代码:4、完整可运行代码前言 wx.gird.Gird是实现类似excel表格的库,扩展面很广,本文讲述它添加按钮,按钮

前言

wx.gird.Gird是实现类似excel表格的库,扩展面很广,本文讲述它添加按钮,按钮响应的内容

实现效果图如下:

本文基于wxpython 4.2.0版本上开发。需要特别注意,wxPython版本之间基础库的差异巨大。

wx.gird.Gird表格中添加按钮,共分为三部

第一步、使用GridCellRenderer与GridCellEditor派生出表格安置button控件的渲染器与编辑
第二步、wx.gird.Gird表格创建,添加按钮与事件响应
第三步、调试代码与测试功能

1、派生按钮渲染器与按钮编辑器

首先我们需要先实现在两个类,一个是单元格渲染器(wx.grid.GridCellRenderer)派生渲染按钮,一个单元格编辑器(wx.grid.GridCellEditor)派生编辑按钮

代码如下:

import wx.grid


class ButtonRenderer(wx.grid.GridCellRenderer):
    def __init__(self, button):
        wx.grid.GridCellRenderer.__init__(self)  # 初始化GridCellRenderer基类
        self.button = button

    def Draw(self, grid, attr, dc, rect, row, col, isSelected):
        self.button.SetSize(rect)  # 设置按钮大小为单元格大小
        state = wx.CONTROL_SELECTED if isSelected else wx.CONTROL_CURRENT  # 设置按钮状态
        bmp = wx.Bitmap(rect.width, rect.height)  # 创建一个和单元格大小相同的位图
        dc2 = wx.MemoryDC(bmp)  # 创建一个内存设备上下文,用于在位图上绘制
        wx.RendererNative.Get().DrawPushButton(self.button, dc2, (0, 0, rect.width, rect.height), state)  # 在位图上绘制按钮
        dc.Blit(rect.x, rect.y, rect.width, rect.height, dc2, 0, 0, wx.COPY, True)  # 将位图复制到单元格上,覆盖原有的内容

        # 在单元格中绘制标签
        label = grid.GetTable().GetValue(row, col)  # 获取单元格的值
        dc.DrawLabel(label, rect, wx.ALIGN_CENTER)  # 在单元格中居中绘制标签

class ButtonEditor(wx.grid.GridCellEditor):
    def __init__(self, button):
        wx.grid.GridCellEditor.__init__(self)  # 初始化GridCellEditor基类
        self.button = button
        self.SetControl(button)

    def Create(self, parent, id, evtHandler):
        pass

    def BeginEdit(self, row, col, grid):
        pass

    def EndEdit(self, row, col, grid, oldVal):
        pass
  • 这段代码是用于创建一个在表格单元格中显示按钮的自定义表格单元格渲染器(ButtonRenderer)和单元格编辑器(ButtonEditor)。
  • ButtonRenderer的功能是在表格单元格中绘制按钮。它接收一个wx.Button实例,然后在表格单元格内绘制按钮和标签。它重载了Draw方法,该方法接收单元格的位置、大小、单元格的行列信息等参数,通过调用wx.RendererNative.Get().DrawPushButton方法来绘制按钮,然后在单元格中绘制标签。
  • ButtonEditor是用于允许用户编辑表格单元格中的按钮的单元格编辑器。它接收一个wx.Button实例,并在单元格中显示该按钮。它重载了Create、BeginEdit、EndEdit,其中Create方法负责创建一个窗口控件来表示单元格中的编辑器,BeginEdit方法在用户开始编辑单元格时被调用,EndEdit方法在用户完成编辑时被调用

2、表格实现

按照前言的样式,我们需要实现一个3x3的表格
内容是 Name, Age,按钮
使用wx.gird.Gird来实现,按钮部分会使用上面派生的两个类

具体代码如下:

import wx
import wx.grid

# 定义一个包含姓名和年龄的列表,后面作为列表的数据
pn = [['张三', '18'],
        ['李四', '21'],
        ['王五', '39']]

# 定义一个继承自 wx.grid.Grid 的类 MyGrid
class MyGrid(wx.grid.Grid):
    def __init__(self, parent):
        
        # 调用 wx.grid.Grid 的初始化函数
        wx.grid.Grid.__init__(self, parent, -1)
        # 创建一个 3 行 3 列的网格
        self.CreateGrid(3, 3)
        # 设置第一列的标题为 "Name"
        self.SetColLabelValue(0, "Name")
        # 设置第二列的标题为 "Age"
        self.SetColLabelValue(1, "Age")
        # 设置第三列为空,即没有标题
        self.SetColLabelValue(2, "")

        # 在第3列的每一行中添加一个按钮
        for i in range(self.GetNumberRows()):
            #将第一列  Name  与 第二列 Age 填充 姓名与年龄
            self.SetCellValue(i, 0, pn[i][0])
            self.SetCellValue(i, 1, pn[i][1])   
            
            
            btn = wx.Button(self, id=i, label="Delete")   # 创建一个名为 "Delete" 的按钮,并绑定到 id=i 上
            
            #这两行用上了前面派生的类
            self.SetCellRenderer(i, 2, ButtonRenderer(btn))  # 在第 i 行的第 2 列中设置单元格渲染器为 ButtonRenderer(btn)
            self.SetCellEditor(i, 2, ButtonEditor(btn))   # 在第 i 行的第 2 列中设置单元格编辑器为 ButtonEditor(btn)
            
            
            self.SetCellValue(i, 2, "Delete")    # 在第 i 行的第 2 列中设置单元格值为 "Delete"  ,这一句没有,会有显示缺陷,可自
            btn.Bind(wx.EVT_BUTTON, self.OnDeleteButtonClick)  # 给按钮绑定一个事件处理函数 OndeletePlan

    # 定义一个按钮点击事件处理函数
    def OnDeleteButtonClick(self, event):
        # 获取按钮所在的单元格的行号,其实是按钮的ID编号
        row = event.GetId()    
        # 获取单元格编辑器中的按钮
        aa: wx.Button = self.GetCellEditor(row, 2).button
        # 解除按钮的事件绑定,这个事件不解除,无法删除这一行数据
        aa.Unbind(wx.EVT_BUTTON)
        # 删除该行
        self.DeleteRows(row)   

3、编辑调试代码:

调试代码如下:

    class MyFrame(wx.Frame):
        def __init__(self):
            wx.Frame.__init__(self, None, title="My Grid")
            # 创建一个MyGrid对象, 上面实现的
            self.grid = MyGrid(self)
            sizer = wx.BoxSizer(wx.VERTICAL)
            sizer.Add(self.grid, 1, wx.EXPAND | wx.ALL, 5)
            self.SetSizer(sizer)
            self.Fit()

    # 运行标配
    if __name__ == "__main__":
        frame = MyFrame()
        frame.Show()
        app.MainLoop()

4、完整可运行代码

下面贴出完整的代码

#!/usr/bin/env python
# -*- coding: utf-8 -*-
# @Time    : 2023/3/16 22:44
# @Author  : 魂尾
# @File    : 05在gird中添加删除按钮.py
# @Description : 一个3x3的表格,可以通过Delete按钮删除对应行
import wx
import wx.grid
# 定义一个包含姓名和年龄的列表,后面作为列表的数据
pn = [['张三', '18'],
      ['李四', '21'],
      ['王五', '39']]
class ButtonRenderer(wx.grid.GridCellRenderer):
    def __init__(self, button):
        wx.grid.GridCellRenderer.__init__(self)  # 初始化GridCellRenderer基类
        self.button = button
    def Draw(self, grid, attr, dc, rect, row, col, isSelected):
        self.button.SetSize(rect)  # 设置按钮大小为单元格大小
        state = wx.CONTROL_SELECTED if isSelected else wx.CONTROL_CURRENT  # 设置按钮状态
        bmp = wx.Bitmap(rect.width, rect.height)  # 创建一个和单元格大小相同的位图
        dc2 = wx.MemoryDC(bmp)  # 创建一个内存设备上下文,用于在位图上绘制
        wx.RendererNative.Get().DrawPushButton(self.button, dc2, (0, 0, rect.width, rect.height), state)  # 在位图上绘制按钮
        dc.Blit(rect.x, rect.y, rect.width, rect.height, dc2, 0, 0, wx.COPY, True)  # 将位图复制到单元格上,覆盖原有的内容
        # 在单元格中绘制标签
        label = grid.GetTable().GetValue(row, col)  # 获取单元格的值
        dc.DrawLabel(label, rect, wx.ALIGN_CENTER)  # 在单元格中居中绘制标签
class ButtonEditor(wx.grid.GridCellEditor):
    def __init__(self, button):
        wx.grid.GridCellEditor.__init__(self)  # 初始化GridCellEditor基类
        self.button = button
        self.SetControl(button)
    def Create(self, parent, id, evtHandler):
        pass
    def BeginEdit(self, row, col, grid):
        pass
    def EndEdit(self, row, col, grid, oldVal):
        pass
# 定义一个继承自 wx.grid.Grid 的类 MyGrid
class MyGrid(wx.grid.Grid):
    def __init__(self, parent):
        # 调用 wx.grid.Grid 的初始化函数
        wx.grid.Grid.__init__(self, parent, -1)
        # 创建一个 3 行 3 列的网格
        self.CreateGrid(3, 3)
        # 设置第一列的标题为 "Name"
        self.SetColLabelValue(0, "Name")
        # 设置第二列的标题为 "Age"
        self.SetColLabelValue(1, "Age")
        # 设置第三列为空,即没有标题
        self.SetColLabelValue(2, "")
        # 在第3列的每一行中添加一个按钮
        for i in range(self.GetNumberRows()):
            # 将第一列  Name  与 第二列 Age 填充 姓名与年龄
            self.SetCellValue(i, 0, pn[i][0])
            self.SetCellValue(i, 1, pn[i][1])
            btn = wx.Button(self, id=i, label="Delete")  # 创建一个名为 "Delete" 的按钮,并绑定到 id=i 上
            # 这两行用上了前面派生的类
            self.SetCellRenderer(i, 2, ButtonRenderer(btn))  # 在第 i 行的第 2 列中设置单元格渲染器为 ButtonRenderer(btn)
            self.SetCellEditor(i, 2, ButtonEditor(btn))  # 在第 i 行的第 2 列中设置单元格编辑器为 ButtonEditor(btn)
            self.SetCellValue(i, 2, "Delete")  # 在第 i 行的第 2 列中设置单元格值为 "Delete"  ,这一句没有,会有显示缺陷,可自
            btn.Bind(wx.EVT_BUTTON, self.OnDeleteButtonClick)  # 给按钮绑定一个事件处理函数 OndeletePlan
    # 定义一个按钮点击事件处理函数
    def OnDeleteButtonClick(self, event):
        # 获取按钮所在的单元格的行号,其实是按钮的ID编号
        row = event.GetId()
        # 获取单元格编辑器中的按钮
        aa: wx.Button = self.GetCellEditor(row, 2).button
        # 解除按钮的事件绑定,这个事件不解除,无法删除这一行数据
        aa.Unbind(wx.EVT_BUTTON)
        # 删除该行
        self.DeleteRows(row)
class MyFrame(wx.Frame):
    def __init__(self):
        wx.Frame.__init__(self, None, title="My Grid")
        self.grid = MyGrid(self)
        sizer = wx.BoxSizer(wx.VERTICAL)
        sizer.Add(self.grid, 1, wx.EXPAND | wx.ALL, 5)
        self.SetSizer(sizer)
        self.Fit()
if __name__ == "__main__":
    app = wx.App()
    frame = MyFrame()
    frame.Show()
    app.MainLoop()

到此这篇关于wxPython中wx.gird.Gird添加按钮的实现的文章就介绍到这了,更多相关wxPython wx.gird.Gird添加按钮内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: wxPython中wx.gird.Gird添加按钮的实现

本文链接: https://www.lsjlt.com/news/200439.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • wxPython中wx.gird.Gird添加按钮的实现
    目录前言1、派生按钮渲染器与按钮编辑器2、表格实现3、编辑调试代码:4、完整可运行代码前言 wx.gird.Gird是实现类似excel表格的库,扩展面很广,本文讲述它添加按钮,按钮...
    99+
    2023-03-19
    wxPython wx.gird.Gird wxPython wx.gird.Gird添加按钮
  • wxPython中wx.gird.Gird添加按钮如何实现
    这篇文章主要介绍了wxPython中wx.gird.Gird添加按钮如何实现的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇wxPython中wx.gird.Gird添加按钮如何实现文章都会有所收获,下面我们一起...
    99+
    2023-07-05
  • css中按钮的阴影怎么添加
    这篇文章主要为大家展示了“css中按钮的阴影怎么添加”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“css中按钮的阴影怎么添加”这篇文章吧。   按钮阴影  ...
    99+
    2024-04-02
  • WinForm中怎么添加按钮控件
    在WinForm中添加按钮控件的步骤如下: 打开Visual Studio,在工具箱中找到按钮控件(Button)。 将按钮...
    99+
    2024-04-08
    winform
  • 如何实现jQuery添加删除按钮Click事件
    这篇文章主要为大家展示了“如何实现jQuery添加删除按钮Click事件”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何实现jQuery添加删除按钮Click...
    99+
    2024-04-02
  • Dreamweaver中banner两侧的按钮如何添加
    这篇文章给大家分享的是有关Dreamweaver中banner两侧的按钮如何添加的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Dreamweaver网页中的banner图片需要切换,我们可以添加按钮来切换图片。操...
    99+
    2023-06-08
  • PyQt5中怎么添加按钮和标签
    要在PyQt5中添加按钮和标签,首先需要导入相应的模块: from PyQt5.QtWidgets import QApplicat...
    99+
    2024-03-12
    PyQt5
  • java中添加按钮并添加响应事件的方法(推荐)
    关于Java容器,面板等自行百度学一下吧</pre><pre name="code" class="java">private Button LogInbtn = new Button("登陆"); final st...
    99+
    2023-05-31
    java 按钮 添加事件
  • layui如何实现点击按钮添加可编辑的一行
    小编给大家分享一下layui如何实现点击按钮添加可编辑的一行,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!发现添加了edit:&...
    99+
    2024-04-02
  • WinForm中如何添加一个按钮控件
    要在WinForm中添加一个按钮控件,可以按照以下步骤操作: 打开Visual Studio并创建一个新的WinForm项目。 打...
    99+
    2024-03-12
    WinForm
  • Android标题栏最右边添加按钮的实例
    Android标题栏最右边添加按钮的实例step1:重写activity的onCreateOptionsMenu方法@Override public boolean onCreateOptionsMenu(Menu menu){ Men...
    99+
    2023-05-30
    android 标题 按钮
  • css中如何给按钮添加背景图片
    在css中给按钮设置背景图片的方法:1.创建按钮;2.设置按钮宽高;3.使用使用background属性设置背景图片;在css中给按钮设置背景图片的方法首先,在页面中创建两个按钮,并定义class类用于对比; <body&g...
    99+
    2024-04-02
  • Android 6.0开发中如何实现关机菜单添加重启按钮
    小编给大家分享一下Android 6.0开发中如何实现关机菜单添加重启按钮,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!本文实例讲述了Android 6.0开发实现关机菜单添加重启按钮的方法。分享给大家供大家参考,具体如下...
    99+
    2023-05-30
    android
  • Android编程实现音量按钮添加监听事件的方法
    本文实例讲述了Android编程实现音量按钮添加监听事件的方法。分享给大家供大家参考,具体如下:很多Android应用都应用到音量按钮,比如翻页,调整音乐声音大小等,但是如果没有对音量按钮进行监听,则无法达到预期的效果。如下代码,就是监听A...
    99+
    2023-05-31
    android 音量 监听事件
  • jQuery怎么实现点击一下按钮添加一个段落
    今天小编给大家分享一下jQuery怎么实现点击一下按钮添加一个段落的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面...
    99+
    2024-04-02
  • 在CSS中怎么给按钮添加背景图片
    本篇内容介绍了“在CSS中怎么给按钮添加背景图片”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成! ...
    99+
    2024-04-02
  • Bootstrap中Table如何实现加载按钮功能
    小编给大家分享一下Bootstrap中Table如何实现加载按钮功能,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!1 ...
    99+
    2024-04-02
  • Delphi中怎么添加一个按钮到窗体上
    在Delphi中,可以通过以下步骤来添加一个按钮到窗体上: 打开Delphi集成开发环境(IDE)并创建一个新的VCL Form...
    99+
    2024-03-13
    Delphi
  • jQuery如何实现动态添加、删除按钮及input输入框
    这篇文章给大家分享的是有关jQuery如何实现动态添加、删除按钮及input输入框的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体如下:<html> <hea...
    99+
    2024-04-02
  • vue实现按钮的长按功能
    先给大家介绍下vue实现按钮的长按功能,效果图如下: 实现效果图:   实现思路: 给需要操作的 dom 元素添加touchstart(点击开始)、touchend(点击...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作