利用wxpython开辟跨平台桌面应用,基类对话框窗体的封装处置惩罚 ...

打印 上一主题 下一主题

主题 846|帖子 846|积分 2538

在开辟桌面界面的时间,往往都需要对一些通用的窗体进行一些抽象封装处置惩罚,以便统一界面效果,以及继续一些通用的处置惩罚过程,镌汰重复编码。本篇随笔介绍利用wxpython开辟跨平台桌面应用,基类对话框窗体的封装处置惩罚,介绍基于 wx.lib.sized_controls.SizedDialog 对话框类的基类封装,以便简化子类代码,以及实现一些丰富的编辑界面效果。
1、基类对话框的界面效果

我借用我之前在Winform界面开辟的时间,对基类窗体的一些做法,如下是之前Winform界面的一些效果。
如对于一般的数据录入或者查询界面,如下效果所示。

这里可以看到,一般的数据处置惩罚界面,都有一些统一的图标设置、校验过程处置惩罚、以及提供一些通用的按钮以便进行数据的保存。
该对话框基类的设计视图,我们在其中添加了3个按钮(常用的添加、保存、关闭按钮),并封装一些通用对话框的处置惩罚函数,可以简化很多代码。
 

2、利用wxpython开辟的界面处置惩罚

在 wxPython 开辟中,对基类对话框进行封装是一个常见的做法,同样可以提高代码的可复用性和可维护性。
起首,你可以定义一个基类对话框,包含一些通用的功能和属性,比方标题、尺寸和常用控件。这个类可以继续自 wx.Dialog 或者其他对话框类,如可以调节大小的 wx.lib.sized_controls.SizedDialog 对话框类。
然后,创建一个具体的对话框类,继续自 BaseDialog。在这个类中实现 create_ui 方法,设置特定的控件和布局。
封装基类对话框可以帮助你创建结构化、可维护的用户界面。通过继续和重用代码,你可以提高开辟效率,并确保应用的一致性。
如我们常规的对话框编辑数据界面,大概如下所示。

 这个界面是到场的表单处置惩罚界面效果,而且对话框假如继续自wx.lib.sized_controls.SizedDialog 对话框类,那么对话框可以自由拖动大小,配合缩放可达到比较好的效果。
假如我们对话框不考虑继续自定义基类的情况下,那么代码如下所示
  1. class MyDialog(sc.SizedDialog):
  2.     def __init__(self, parent = None, id = wx.ID_ANY ):
  3.         sc.SizedDialog.__init__(self, parent = parent, id=id,
  4.             title=u"测试可以滚动的SizedDialog对话框",
  5.             style=wx.DEFAULT_DIALOG_STYLE| wx.RESIZE_BORDER )
  6.    
  7.         #获得主内容面板
  8.         cpane = self.GetContentsPane()
  9.         #构建一个可滚动的面板,并设置拉伸属性
  10.         pane = sc.SizedScrolledPanel(cpane, wx.ID_ANY)
  11.         pane.SetSizerProps(expand=True, proportion=1)
  12.         pane.SetSizerType("form") # 设置为表单布局,默认2列
  13.         #添加主要内容区域
  14.          。。。。。。。
  15.         # 添加对话框按钮:OK、Cancel
  16.         self.SetButtonSizer(self.CreateStdDialogButtonSizer(wx.OK | wx.CANCEL))
  17.         self.Layout()
  18.         self.Centre(wx.BOTH)
  19.         self.MinSize = (300, 200)
  20.         self.SetSize((400, 300))
复制代码
上面代码,可以看到,其中的SizedDialog 对话框类提供了一个获得主面板并设置表单布局类型的处置惩罚,我们重要基于这个主面板来创建控件即可,创建控件代码不需要太多的布局参数设置,处置惩罚比较简单,如下所示
  1.          # row 1      
  2.         wx.StaticText(pane, -1, "姓名")
  3.         textCtrl = wx.TextCtrl(pane, -1, "请输入姓名")
  4.         textCtrl.SetSizerProps(expand=True)
  5.         # row 2
  6.         wx.StaticText(pane, -1, "Email邮箱")
  7.         emailCtrl = wx.TextCtrl(pane, -1, "")
  8.         emailCtrl.SetSizerProps(expand=True)
复制代码
我们这样就可以按顺序(Form类型的布局默认统共2列)添加即可。
另外,我们看到,对话框的按钮也是很简单的一行代码实现从前需要多行代码处置惩罚的效果。
  1.         # 添加对话框按钮:OK、Cancel
  2.         self.SetButtonSizer(self.CreateStdDialogButtonSizer(wx.OK | wx.CANCEL))
复制代码
通过这样创建的按钮,默认还具有国际化特性,也就是跟随我们的语言设置,系统自动处置惩罚对应的标题。
假如不设置程序的locale, 那么大概默认是英文的按钮名称,如下所示。

 
假如是设置了为中文语言,那么就是中文的按钮名称,如下所示。
  1. app = wx.App()
  2. # 设置语言
  3. # local = wx.Locale(wx.LANGUAGE_ENGLISH)
  4. local = wx.Locale(wx.LANGUAGE_CHINESE_SIMPLIFIED)
  5. dlg = MyDialog()
  6. dlg.ShowModal()
  7. dlg.Destroy()
  8. app.MainLoop()
复制代码

我们有了上面临话框界面的参考,可以把它大概会重复的代码,通过抽象的方式,提取到一个基类对话框内里,如下所示。
  1. class BaseScrolledDialog(sc.SizedDialog):
  2.     """可以调整大小及滚动的对话框基类"""
  3.     def __init__(self, parent = None, id = wx.ID_ANY, title="",
  4.                  style=wx.DEFAULT_DIALOG_STYLE| wx.RESIZE_BORDER,
  5.                   can_scroll=True ):
  6.         self.can_scroll = can_scroll
  7.         sc.SizedDialog.__init__(self, parent = parent, id=id,
  8.             title = title,
  9.             style= style )
  10.         self.SetMinSize((300, 200))
  11.         main_panel : wx.Panel = None
  12.         #通过can_scroll判断是否使用滚动面板
  13.         cpane = self.GetContentsPane()
  14.         if can_scroll:
  15.             pane = sc.SizedScrolledPanel(cpane, wx.ID_ANY)
  16.             main_panel = pane
  17.         else:
  18.             main_panel = cpane
  19.         self.AddControls(main_panel)
  20.         self.AddDialogButtons()
  21.         self.Layout()
  22.     def AddControls(self, pane: wx.Panel):
  23.         """为主面板添加控件,不含底部对话框按钮"""
  24.         pass
复制代码
也就是提供一个子类对话框,可以重写的AddControls函数用来把焦点放在创建控件上即可,这样可以剔除不关心的内容。
这样我们对话框子类,就只需根据不同的业务添加不同的控件上去即可,其他就不要管了,交给基类去实现即可。
  1. class MyScrolledDialog(BaseScrolledDialog):
  2.     """测试可以滚动的SizedDialog对话框-继承实现"""
  3.     def __init__(self, parent = None, id = wx.ID_ANY, title="测试可以滚动的SizedDialog对话框-继承实现"):
  4.         super().__init__(parent, id, title, can_scroll=True)
  5.         self.SetSize((600, 500))
  6.     def AddControls(self, pane):
  7.         """主面板的控件添加"""
  8.         # row 1
  9.         wx.StaticText(pane, -1, "姓名")
  10.         textCtrl = wx.TextCtrl(pane, -1, "请输入姓名")
  11.         textCtrl.SetSizerProps(expand=True)
  12.         # row 2
  13.         wx.StaticText(pane, -1, "Email邮箱")
  14.         emailCtrl = wx.TextCtrl(pane, -1, "")
  15.         emailCtrl.SetSizerProps(expand=True)
  16.         *******
复制代码
这样同样实现了相同的效果,而且简化了代码。

我们还可以指定对话框的默认位置,让它顶部对齐屏幕的顶部,这样内容显示比较方便。
我们只需在基类窗口的初始化函数内里,设置位置即可。
  1.          # 获取屏幕的大小
  2.         screen_size = wx.GetDisplaySize()
  3.         dialog_width, dialog_height = self.GetSize()
  4.         # 计算顶端对齐的位置
  5.         x_position = (screen_size.x - dialog_width) // 2  # 水平居中
  6.         y_position = 0  # 顶端对齐
  7.         self.SetPosition((x_position, y_position))
复制代码
当然,我们还可以加入对数据验证的一下空壳函数,基类只需要负责定义接口和逻辑处置惩罚,具体的检查细节可以交给子类来实现代码即可。
 

免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!更多信息从访问主页:qidao123.com:ToB企服之家,中国第一个企服评测及商务社交产业平台。

本帖子中包含更多资源

您需要 登录 才可以下载或查看,没有账号?立即注册

x
回复

使用道具 举报

0 个回复

倒序浏览

快速回复

您需要登录后才可以回帖 登录 or 立即注册

本版积分规则

悠扬随风

金牌会员
这个人很懒什么都没写!
快速回复 返回顶部 返回列表