实战wxPython:009 - 布局管理简介及绝对位置布局

文章介绍了GUI程序窗口界面中的布局管理,对比了绝对定位布局和相对布局的优缺点。在wxPython中,绝对布局可能导致窗口大小变化时部件不适应,而尺寸调节器如wx.BoxSizer等能解决这一问题。文中提供了一个使用绝对布局的示例,强调在大多数情况下应使用尺寸调节器进行布局管理。
摘要由CSDN通过智能技术生成

一个典型的GUI程序的窗口界面中,一般是由各种控件(或者部件)组成,这些部件一般都会按一定的布局呈现在窗口中。布局方式可以分为绝对定位布局和相对定位布局,绝对定位布局中的控件不会随窗口的大小变化而做调整,相对布局则会根据窗口的尺寸对其中的控件布局进行调整,以更好地适应窗口的变化。在比较久远的一些GUI框架中,一般只支持绝对定位布局,比如微软的MFC框架,只支持绝对定位布局。绝对布局虽然使用方便,但有很大的局限性。一般现代GUI框架,无论是微软的.Net 框架,Andriod SDK 里的布局,wxWidgets, Qt等C++ 框架,都提供了布局管理功能,来提供更灵活的窗口布局。

PyQt5是QT5的Python封装,wxPython是wxWidgets的Python封装,因此你无论是在PyQt5还是在wxPython中,都提供了管理应用程序布局的功能模块。在wxPython中,可以使用绝对定位或者使用sizer来进行布局管理。

绝对定位布局

绝对布局是指在窗口中以像素为单位指定每个部件的位置和大小。绝对定位布局有几个明显的缺点:

  • 如果我们调整窗口大小,部件的大小和位置不会改变。
  • 在不同平台上,应用程序看起来都不同。
  • 在应用程序中更改字体可能会破坏布局。
  • 如果决定更改布局,则必须完全重做布局,这样做既繁琐又耗时,更容易出错。

在一些简单的测试程序,使用绝对布局可以快速演示某个功能,但是在大多数情况下,都使用sizer来进行布局管理。

尺寸调节器

尺寸调节器解决了绝对定位布局中提到的所有这些问题。wxPython提供了以下调节器:

  • wx.BoxSizer
  • wx.StaticBoxSizer
  • wx.GridSizer
  • wx.FlexGridSizer
  • wx.GridBagSizer

使用尺寸调节器,我们可以在wxPython中实现满足各种要求的布局,在后续的文章中将对其做更详细的介绍。

绝对布局演示

在绝对布局示例中,我们在窗口中使用wx.StaticBitmap加载几幅图像,使用绝对位置放置在窗口中。当我们调整窗口的大小的时候,可以看到,图像的位置并不随窗口的尺寸变化而做调整,以适应窗口的变化。完整代码如下:

import wx
import os
 
class Example(wx.Frame):
    def __init__(self, *args, **kwargs):
        super(Example, self).__init__(*args, **kwargs)
        
        self.SetTitle('实战wxPython: 绝对位置布局演示')
        self.SetSize(480, 360)
        
        self.InitUi()
        
        self.Centre()
        
    def InitUi(self):
        self.panel = wx.Panel(self)
        self.panel.SetBackgroundColour("gray")
        self.LoadImages()
        
        self.pythonLogo.SetPosition((10, 10))
        self.wxpythonLogo.SetPosition((100, 10))
        self.wxwidgetsLogo.SetPosition((20, 200))
        
    def LoadImages(self):
        imgPath = os.path.dirname(__file__)
        self.pythonLogo = wx.StaticBitmap(self.panel, wx.ID_ANY, 
                                          wx.Bitmap(imgPath + '/python-logo.png', wx.BITMAP_TYPE_ANY))
        self.wxpythonLogo = wx.StaticBitmap(self.panel, wx.ID_ANY, 
                                          wx.Bitmap(imgPath + '/wxpython.png', wx.BITMAP_TYPE_ANY))
        self.wxwidgetsLogo = wx.StaticBitmap(self.panel, wx.ID_ANY, 
                                          wx.Bitmap(imgPath + '/wxwidgets-logo.png', wx.BITMAP_TYPE_ANY))
        
        
def main():
    app = wx.App()
    window = Example(None)
    window.Show()
    app.MainLoop()
    
if __name__ == '__main__':
    main()

运行效果如下图所示:

 wxPython绝对布局演示

本文知识点

  • GUI程序为什么需要布局;
  • 了解wxPython中的布局管理;
  • 认识静态图像控件wx.StaticBitmap;
  • 使用绝对定位布局。

前一篇:实战wxPython:008 - 为应用添加工具栏

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值