Python wxPython库Core组件BoxSizer用法示例


Posted in Python onSeptember 03, 2018

本文实例讲述了Python wxPython库Core组件BoxSizer用法。分享给大家供大家参考,具体如下:

wx.BoxSizer:

box = wx.BoxSizer(integer orient)

The orientation can be wx.VERTICAL or wx.HORIZONTAL

box.Add(wx.Window window, integer proportion=0, integer flag = 0, integer border = 0)

参数解读:

1、proportion:

proportion参数定义了构件在既定方向上所占空间的比例,是相对的,相对于其他组件
举个例子:我们有三个按钮,proportion的值分别是0,1,2。三个按钮被放置到水平方向的sizer当中,Button with proportion 0 will not change at all。但是, Button with proportion 2将会比the one with proportion 1大两倍在水平位置上。

# -*- coding:utf-8 -*-
import wx
class Border(wx.Frame):
  def __init__(self, parent, id, title):
    wx.Frame.__init__(self, parent, id, '3water.com - BoxSizer', size=(350, 200))
    panel = wx.Panel(self, -1,size=(350,200))
    panel.SetBackgroundColour('white')
    boxsizer1 = wx.BoxSizer(wx.VERTICAL)
    btn1 = wx.Button(panel, -1, 'Botton1')
    btn2 = wx.Button(panel, -1, 'Botton2')
    btn3 = wx.Button(panel, -1, 'Botton3')
    boxsizer1.Add(btn1, proportion=0, flag=wx.EXPAND, border=0)
    boxsizer1.Add(btn2, proportion=1, flag=wx.ALL, border=0)
    boxsizer1.Add(btn3, proportion=2, flag=wx.ALL, border=0)
    self.SetSizer(boxsizer1)
    self.Centre()
    self.Show(True)
app = wx.App()
Border(None, -1, '')
app.MainLoop()

运行结果:

Python wxPython库Core组件BoxSizer用法示例

通过这个例子可以观察出proportion参数的作用

2、flag:

flag参数可以使用 '|'来产生组合的多个flags。

flag参数定义了两个主要的行为:

第一个参数是窗口的边框:这个参数决定了边框的宽度,在此决定窗口某一侧添加边框的事件。

另一个参数决定了sizer事件的行为,当sizer改变时,空间的分配。并且分配的多少依赖于特定种类的sizer被使用。

3、border:设置边界宽度

Determines the border width, if the flag parameter is set to include any border flag

最后特别说明:

flag和border参数两者结合起来使用的。

vbox.Add(midPan, 1, wx.EXPAND | wx.ALL, 20)

flag=wx.EXPAND | wx.ALL,border=20---------这代表的是midPan这个组件将充分的利用空间,但是会从四周预留出来20px作为border。所以如果说使用了wx.EXPAND flag,而没有设定border,那么我们的组件将充分的利用分配的空间。

最后,我们也能去定义调整我们的组件。但是这种调整是指在sizer分配给当前构件的空间之内的一种调整。

We do it with the following flags :

wx.ALIGN_LEFT
wx.ALIGN_RIGHT
wx.ALIGN_TOP
wx.ALIGN_BOTTOM
wx.ALIGN_CENTER_VERTICAL
wx.ALIGN_CENTER_HORIZONTAL
wx.ALIGN_CENTER

看下面一个例子:

hbox5 = wx.BoxSizer(wx.HORIZONTAL)
btn1 = wx.Button(panel, -1, 'Ok', size=(70, 30))
hbox5.Add(btn1, 0)
btn2 = wx.Button(panel, -1, 'Close', size=(70, 30))
hbox5.Add(btn2, 0, wx.LEFT | wx.BOTTOM , 5)
vbox.Add(hbox5, 0, wx.ALIGN_RIGHT | wx.RIGHT, 10)

这个例子将已有的hbox5放置到vbox当总,而wx.ALIGN_RIGHT所起到的作用就是在hbox5这个sizer当中的横向往右放置的调整

下面是常用的flag参数:

1、These flags are used to specify which side(s) of the sizer item that the border width will apply to.

wx.TOP wx.BOTTOM wx.LEFT wx.RIGHT wx.ALL

2、The item will be expanded to fill the space allotted to the item.

wx.EXPAND

还有两个没有列出来,如果用到的话,可以查帮助文档

最后,有些情况下我们需要添加一些空白的区域到我们的应用当中,可以使用下面的代码:

vbox = wx.BoxSizer(wx.VERTICAL)
vbox.Add((-1, 25))
vbox.Add((-1, 25))---添加了25个像素的空白空间

希望本文所述对大家Python程序设计有所帮助。

Python 相关文章推荐
跟老齐学Python之有容乃大的list(2)
Sep 15 Python
python处理二进制数据的方法
Jun 03 Python
Python使用minidom读写xml的方法
Jun 03 Python
PyCharm使用教程之搭建Python开发环境
Jun 07 Python
Python Xml文件添加字节属性的方法
Mar 31 Python
python之super的使用小结
Aug 13 Python
如何基于python生成list的所有的子集
Nov 11 Python
如何在keras中添加自己的优化器(如adam等)
Jun 19 Python
python 使用三引号时容易犯的小错误
Oct 21 Python
windows安装python超详细图文教程
May 21 Python
教你使用pyinstaller打包Python教程
May 27 Python
Python实战之OpenCV实现猫脸检测
Jun 26 Python
深入浅析Python中list的复制及深拷贝与浅拷贝
Sep 03 #Python
Python wxPython库使用wx.ListBox创建列表框示例
Sep 03 #Python
Python wxPython库消息对话框MessageDialog用法示例
Sep 03 #Python
Python中关键字global和nonlocal的区别详解
Sep 03 #Python
python leetcode 字符串相乘实例详解
Sep 03 #Python
Python模拟自动存取款机的查询、存取款、修改密码等操作
Sep 02 #Python
Python实现多级目录压缩与解压文件的方法
Sep 01 #Python
You might like
PHP下几种删除目录的方法总结
2007/08/19 PHP
教你如何开启shopnc b2b2c 伪静态
2014/10/21 PHP
js+php实现静态页面实时调用用户登陆状态的方法
2015/01/04 PHP
PHP实现的简易版图片相似度比较
2015/01/07 PHP
微信公众平台开发之天气预报功能
2015/08/31 PHP
dojo随手记 gird组件引用
2011/02/24 Javascript
JS正则表达式验证数字代码
2014/01/28 Javascript
jquery的attr方法禁用表单元素禁用输入内容
2014/06/23 Javascript
jQuery插件Validate实现自定义表单验证
2016/01/18 Javascript
jQuery通用的全局遍历方法$.each()用法实例
2016/07/04 Javascript
用js实现简单算法的实例代码
2016/09/24 Javascript
js仿微信语音播放实现思路
2016/12/12 Javascript
详解前端构建工具gulpjs的使用介绍及技巧
2017/01/19 Javascript
jQuery初级教程之网站品牌列表效果
2017/08/02 jQuery
微信小程序switch组件使用详解
2018/01/31 Javascript
React Native自定义控件底部抽屉菜单的示例
2018/02/08 Javascript
nodejs更改项目端口号的方法
2018/05/13 NodeJs
vue v-for 使用问题整理小结
2019/08/04 Javascript
解决layui 三级联动下拉框更新时回显的问题
2019/09/03 Javascript
JavaScript实现简单计算器功能
2019/12/19 Javascript
在项目vue中使用echarts的操作步骤
2020/09/07 Javascript
element中table高度自适应的实现
2020/10/21 Javascript
解决vant的Toast组件时提示not defined的问题
2020/11/11 Javascript
vue表单验证之禁止input输入框输入空格
2020/12/03 Vue.js
代码分析Python地图坐标转换
2018/02/08 Python
pycharm运行出现ImportError:No module named的解决方法
2018/10/13 Python
Python对ElasticSearch获取数据及操作
2019/04/24 Python
python中@contextmanager实例用法
2021/02/07 Python
HTML5和以前HTML4的区别整理
2013/10/20 HTML / CSS
Html5 FileReader实现即时上传图片功能实例代码
2014/09/01 HTML / CSS
html5实现完美兼容各大浏览器的播放器
2014/12/26 HTML / CSS
日本化妆品植村秀俄罗斯官方网站:Shu Uemura俄罗斯
2020/02/01 全球购物
总经理职责范文
2013/11/08 职场文书
加多宝凉茶广告词
2014/03/18 职场文书
运动员入场词
2015/07/18 职场文书
小学英语新课改心得体会
2016/01/22 职场文书