wxpython 窗口排版- proportion/flag/border参数说明
新学习wxpython,一直纠结于窗口控件的排版,经过几天的查资料、试验,总结如下。
1、需求实例
来个实例,窗口有3行控件
第一行是文本提示(大小不变,文字左对齐,控件居左)。
第二行依次为文本提示(控件居左,大小不变,文字横向左对齐,文字纵向居中对齐,),文本输入框(控件居左,大小横向向右缩放,纵向不缩放),按钮(控件居右,右边固定,大小向左缩放),按钮(控件居右,大小不变)。
第三行多行文本框(控件扩展,大小四个方向扩展,直到占满剩余空间)

图1、窗口缩放前效果

图2、窗口缩放后效果
2、代码
#coding=utf-8 import wx class MyFrame(wx.Frame): def __init__(self, parent, id): wx.Frame.__init__(self, parent, id, u'测试面板Panel', size = (400, 300)) #创建面板 panel = wx.Panel(self) #创建open,save按钮 self.bt_open = wx.Button(panel,label='open') self.bt_save = wx.Button(panel,label='save') #创建文本,左对齐,注意这里style=wx.TE_LEFT,不是wx.ALIGN_LEFT ,表示控件中的输入光标是靠左对齐。 self.st_tips = wx.StaticText(panel ,0,u"请输入文件路径",style=wx.TE_LEFT ) self.st_tips2 = wx.StaticText(panel ,0,u"文件路径:",style=wx.TE_LEFT ) self.text_filename = wx.TextCtrl(panel,style=wx.TE_LEFT) #创建文本内容框,多行,垂直滚动条 self.text_contents = wx.TextCtrl(panel,style=wx.TE_MULTILINE|wx.HSCROLL) #添加容器,容器中控件按横向并排排列 bsizer_top = wx.BoxSizer(wx.VERTICAL) #添加容器,容器中控件按纵向并排排列 bsizer_center = wx.BoxSizer(wx.HORIZONTAL) bsizer_bottom = wx.BoxSizer(wx.HORIZONTAL) #在容器中添加st_tips控件,proportion=0 代表当容器大小变化时,st_tips控件的大小不变 #flag = wx.EXPAND|wx.ALL中,wx.ALL代表在st_tips控件四周都增加宽度为x的空白,x取border参数的值,本例是border=5 # wx.EXPAND代表st_tips控件占满可用空间。 bsizer_top.Add(self.st_tips,proportion=0,flag=wx.EXPAND|wx.ALL, border = 5 ) #proportion=1 代表当容器大小变化时,st_tips2控件的大小变化,变化速度为1 bsizer_center.Add(self.st_tips2,proportion=0,flag=wx.ALL|wx.ALIGN_CENTER_VERTICAL|wx.ALIGN_LEFT,border = 5 ) #proportion=2 代表当容器大小变化时,text_filename控件的大小变化,变化速度为2 bsizer_center.Add(self.text_filename,proportion=2,flag=wx.EXPAND|wx.ALL,border=5) bsizer_center.Add(self.bt_open,proportion=1,flag=wx.ALL,border=5) bsizer_center.Add(self.bt_save,proportion=0,flag=wx.ALL,border=5) bsizer_bottom.Add(self.text_contents,proportion=1 ,flag = wx.EXPAND|wx.ALL,border =5 ) #wx.VERTICAL 横向分割 bsizer_all = wx.BoxSizer(wx.VERTICAL) #添加顶部sizer,proportion=0 代表bsizer_top大小不可变化 bsizer_all.Add(bsizer_top,proportion=0,flag=wx.EXPAND|wx.ALL,border=5) bsizer_all.Add(bsizer_center,proportion=0,flag=wx.EXPAND|wx.ALL,border=5) #添加顶部sizer,proportion=1 代表bsizer_bottom大小变化 bsizer_all.Add(bsizer_bottom,proportion=1,flag=wx.EXPAND|wx.ALL,border=5) self.Bind(wx.EVT_BUTTON,self.onOpen,self.bt_open) #self.Bind(wx.EVT_BUTTON, self.OnCloseMe, button) panel.SetSizer(bsizer_all) def onOpen(self,event): self.text_contents.AppendText(str(self.GetSizeTuple())) self.text_contents.AppendText(str(self.bt_open.GetSizeTuple())) self.text_contents.AppendText(str(self.text_filename.GetSizeTuple())) self.SetSize((700,600)) self.text_contents.AppendText(str(self.GetSizeTuple())) self.text_contents.AppendText(str(self.bt_open.GetSizeTuple())) self.text_contents.AppendText(str(self.text_filename.GetSizeTuple())) if __name__ == '__main__': app = wx.PySimpleApp() frame = MyFrame(parent = None, id = -1) frame.Show() frame.Center() app.MainLoop()
3、总结
1、Box = wx.BoxSizer(integer orient)
orientation参数,代表控件排列方式,wx.VERTICAL 垂直排列 ,wx.HORIZONTAL 水平排列
形象一点就是:前者是三 , 横向3个1, 后者是111,纵向3个1
2、sizer.Add(wx.Window window, integer proportion=0, integer flag = 0, integer border = 0)
window 参数:代表要添加的控件。
roportion参数:所添加控件在定义的定位方式所代表方向上,占据的空间比例。
假设有三个按钮,它们的比例值分别为0、1和2,它们都已添加到一个宽度为30的水平排列wx.BoxSizer,起始宽度都是10。
当sizer的宽度从30变成60时,按钮1的宽度保持不变,仍然是10,按钮2的宽度约为(10+(60-30)*1/(1+2))=30 ,按钮2约为20。
不太严谨说按钮2占有增量部分1/3,按钮3占有增量部分2/3。
border参数:控制所添加控件的边距,就是在部件之间添加一些像素的空白。
border参数与flag参数结合生效,为了应用边框参数,需要在flag参数中定义哪一边使用边框,譬如flag=wx.RIGHT代表右边距为border宽。
flag参数:
如前文所述,flag参数与border参数结合指定边距宽度,包括以下选项:
wx.LEFT ,左边距
wx.RIGHT,右边距
wx.BOTTOM,底边距
wx.TOP,上边距
wx.ALL,上下左右四个边距
可以通过竖线 “|”操作符(operator),比如wx.LEFT | wx.BOTTOM,来联合使用这些标志。
此外,flag参数还可以与proportion参数结合,指定控件本身的对齐(排列)方式,包括以下选项:
wx.ALIGN_LEFT 左边固定,右边扩展(当proportion >0 时,下同)
wx.ALIGN_RIGHT 右边不动
wx.ALIGN_TOP
wx.ALIGN_BOTTOM
wx.ALIGN_CENTER_VERTICAL
wx.ALIGN_CENTER_HORIZONTAL
wx.ALIGN_CENTER
此外,flag参数可以使用wx.EXPAND标志,那么所添加控件将占有sizer定位方向的方向上所有可用的空间。
最后总结一下,很重要:
1、wx.LEFT是指控件边框左边是否留空,该常量的定义在_core.py源文件中,
用法:bsizer_top.Add(self.st_tips,proportion=0,flag=wx.LEFT, border = 5 )
2、 wx.ALIGN_LEFT是控件本身居左对齐,该常量定义也在_core.py源文件中。
用法:bsizer_top.Add(self.st_tips,proportion=0,flag=wx.ALIGN_LEFT|wx.LEFT, border = 5 )
3、wx.TE_LEFT是控件光标居左对齐,该常量定义在_controls.py源文件中。
用法:self.text_ctrl_1 = wx.TextCtrl(self, wx.ID_ANY, "", style= wx.TE_LEFT )
三个写法不一样,功能也不同,但定义值都有,一旦写错很难发现,但会出现奇奇怪怪的问题。
以上。
wxpython 窗口排版- proportion/flag/border参数说明的更多相关文章
- python---基础知识回顾(九)图形用户界面-------WxPython
主要使用wxPython(最成熟的跨平台python GUI工具包) wxPython手册 前戏:基础了解 import wx class MyFrame(wx.Frame): #创建自定义Frame ...
- python之GUI图形用户界面 2014-4-7
#图形用户界面1.下载和安装wxPython2.创建并显示一个框架import wx #导入wxPythonapp=wx.App()win=wx.Frame(None)win.Show() #调用窗口 ...
- [Python] wxPython 基本控件 (转)
转自:http://www.cnblogs.com/wangjian8888/p/6028777.html 一.静态文本控件 wx.StaticText(parent, id, label, pos= ...
- Python图形界面开发—wxPython库的布局管理及页面切换
前言 wxPython是基于Python的跨平台GUI扩展库,对wxWidgets( C++ 编写)封装实现.GUI程序的开发中界面布局是很重要的一个部分,合理的页面布局能够给予用户良好使用体验.虽然 ...
- wxpython 基本的控件 (按钮)
使用按钮工作 在wxPython 中有很多不同类型的按钮.这一节,我们将讨论文本按钮.位图按钮.开关按钮(toggle buttons )和通用(generic )按钮. 如何生成一个按钮? 在第一部 ...
- wxPython中基本控件学习
wxPython工具包提供了多种不同的窗口部件,包括了本章所提到的基本控件.我们涉及静态文本.可编辑的文本.按钮.微调.滑块.复选框.单选按钮.选择器.列表框.组合框和标尺.对于每种窗口部件,我们将提 ...
- Python实例讲解 -- wxpython 基本的控件 (按钮)
使用按钮工作 在wxPython 中有很多不同类型的按钮.这一节,我们将讨论文本按钮.位图按钮.开关按钮(toggle buttons )和通用(generic )按钮. 如何生成一个按钮? 在第一部 ...
- ArcEngine地图窗口指定区域导出指定DPI多格式---delphi/C#实现
delphi/C#实现,其他语言稍微改下就行了.AE的编码各个语言都差不多,这里也没用到某一语言的特性. 函数特点: 1.可以精确导出指定范围的图形要素 2.支持多格式.TIF, .EMF,.GIF, ...
- wxpython 基本的控件 (文本)
wxPython 工具包提供了多种不同的窗口部件,包括了本章所提到的基本控件.我们涉及静态文本.可编辑的文本.按钮.微调.滑块.复选框.单选按钮.选择器.列表框.组合框和标尺.对于每种窗口部件,我们将 ...
随机推荐
- RR和RC复合语句加锁
mysql版本:5.7 RR复合语句: insert/update/delete+select,+号左边是影响数据的排他锁,+号右边是查询(当前读,其实相当于lock in share mode)到数 ...
- lucene源码分析(3)facet实例
简单的facet实例 public class SimpleFacetsExample { private final Directory indexDir = new RAMDirectory(); ...
- 配置jenkins slave 问题,ERROR: Couldn't find any revision to build. Verify the repository and branch configuration for this job.
因为需要需要搭建一套自动化环境的windows电脑作为slave,简单的把原来用来mac上的job配置一模一样的配置了下,运行时遇到如上问题,google半天百思不得其解, 后来尝试把SCM里面的br ...
- 哪个先执行:@PostConstruct和@Bean的initMethod?
结论: /** * step1:执行构造函数 * step2:执行使用@PostConstruct注解修饰的方法[如果有多个,则执行顺序不确定] * step3:执行@Bean注解中initMetho ...
- awk去重以某列重复的行
[root@localhost cc]# cat 2.txt adc 3 5 a d aa 3 adfa d ba 3 adf 去重第一列重复的行: [root@localhost cc]# cat ...
- JavaScript 函数全局变量定义
在 JavaScript 中, 作用域 影响着变量的作用范围.在函数外定义的变量具有 全局 作用域.这意味着,具有全局作用域的变量可以在代码的任何地方被调用. 没有使用var关键字定义的变量,会被自动 ...
- jQuery如何根据元素值删除数组元素
用到的方法$.inArry(); $.inArray( value, array [, fromIndex ] ) value 任意类型 用于查找的值. array Array类型 指定被查找的数组. ...
- Java基础教程(12)--深入理解类
一.方法的返回值 当我们在程序中调用方法时,虚拟机将会跳转到对应的方法中去执行.当以下几种情况发生时,虚拟机将会回到调用方法的语句并继续向下执行: 执行完方法中所有的语句: 遇到return语句: ...
- Hive 编程指南—笔记
1. 基础 1.1 Hive 解决问题的背景? 用户如何从一个现有的数据基础架构转移到 Hadoop 上,而这个基础架构是基于传统的关系数据库和 SQL 的? Hive 提供了一个被称为 HQL 的 ...
- java 获取两个日期之间的所有日期(年月日)
前言:直接上代码 java 获取两个日期之间的所有日期(年月日) /** * 获取两个日期之间的日期,包括开始结束日期 * @param start 开始日期 * @param end 结束日期 * ...