1.默认部件基类
-
QT提供的默认部件基类包括QMainWindow、QWidget、和QDialog这三种,这三个部件基类也是用的最多的。 -
QMainWindow是带有菜单栏、工具栏、状态栏的主窗口类,它有自己单独的布局。布局有一个中心区域,通常是标准的Qt部件,也可以是定制部件,且必须有一个中心小部件。setCentralWidget()方法可设置中心部件。 -
QWidget类是所有部件对象的基类,被称为基础窗口部件,继承关系详看QWidget类关系图。QWidget提供自我绘制和处理用户输入等基本功能,如接收鼠标、键盘和其它事件,并且在屏幕上绘制自己的表现。每一个窗口部件都是矩形,并且它们按Z轴顺序排列的。一个窗口部件可以被它的父窗口部件或者它前面的窗口部件盖住一部分。一个没有父窗口部件的窗口部件一直是顶级窗口部件。非顶级窗口部件是父窗口的子部件。QWidget构造函数有两个参数:QWidget *parent = 0,Qt::WindowFlags f = 0。parent即父窗口,默认为0,即没有父窗口,是顶级窗口,如果指定parent值则当前窗体将会是一个子部件。Qt::WindowFlags是Qt::WindowType枚举值的组合,用来设置窗口的属性,f = 0表默认为Qt::Widget风格,其余窗口属性详见附件表一。setWindowState()可设置窗体的状态,参数由Qt::WindowStates枚举值指定, 窗体状态如下表所示
窗体状态 | 作用 |
---|
Qt::WindowNoState | 窗体为正常状态 | Qt::WindowMinimized | 窗体最小化 | Qt::WindowMaximized | 窗体最大化 | Qt::WindowActive | 窗体为活动窗体 (有多个打开的窗口时, 活动窗口位于最上层) | Qt::WindowFullScreen | 窗体全屏显示 |
? ?
QWidget设计模式属性设置:
窗体尺寸 | 作用 |
---|
enabled | 启用或禁用widget,默认启用。 | geometry | 获取widget的位置和尺寸。 | sizePolicy | 设置widget在水平和垂直方向的伸缩策略以及伸缩因子 | resize(300, 200) | 设置窗体为宽300, 高200 | move(50,90) | 移动窗体坐标到x:50, y:90 | height() | 获取当前窗体的高度 | width() | 获取当前窗体的宽度 | x() | 获取窗体的x坐标 | y() | 获取窗体的y坐标 |
- sizePolicy 设置widget在水平和垂直方向的伸缩策略以及伸缩因子(Stretch Factors),所谓伸缩策略实际就是widget对待部件大小提示的策略,需结合布局管理器一起使用。伸缩策略可通过调用setSizePolicy()方法设置,大小提示可通过sizeHint()函数返回值获取,也可重载sizeHint()方法进行重置。
- 拉伸因子描述了各个部件在进行拉伸时,部件间以指定的比例进行拉伸,如水平布局的三个按钮其拉伸因子分别设为1,2,3则表示该3个按钮将会以1:2:3的比例进行拉伸。注意:1.当主窗口的大小不能按计算出来的比例容纳下所有子部件时,子部件不一定会按设计好的比例进行排列。
大小策略与拉伸因子之间的关系: 若部件的拉伸因子大于0,则按照拉伸因子的比例分配空间;若拉伸因子为0,则只有在其他部件不需要空间时才会获得空间;也就是说若一些部件拉伸因子大于0,而一些部件拉伸因子为0,则只有拉伸因子大于0的部件会被拉伸,而拉伸因子为0的部件不会被拉伸。若所有部件的拉伸因子都为0,则按照大小策略的规则对部件进行拉伸。注意:2.若部件的大小策略为Fixed,则即使设置了拉伸因子,该部件也不会被拉伸。故拉伸因子会使大小策略不起作用或失效(除了Fixed策略外)
属性值 | 作用 |
---|
Fixed | 尺寸不能改变,尺寸为sizeHint大小 | Minimum | 尺寸可以拉伸,尺寸可变范围:≥sizeHint | Maximum | 尺寸可以缩小,尺寸可变范围:minimumSizeHint ~ sizeHint | Expanding | 可以变大缩小,尺寸可变范围:≥minimumSizeHint,且部件有优先扩展权(注:优先扩展权表部件将尽可能多的占用空间,如Preferred与Expanding同时存在则优先分配空间给Expanding) | MinimumExpanding | 尺寸可以拉伸,尺寸可变范围:≥minimumSizeHint,且部件有优先扩展权 | Ignored | 任意变大缩小,尺寸可变范围:≥minimumSizeHint(若minimumSizeHint为0,则可缩小至0,此时部件不可见) |
? ?
属性值 | 作用 |
---|
minimumSize | 设置部件的最小尺寸,伸缩时不可继续缩小。 | maximumSize | 设置部件的最大尺寸,伸缩时不可继续变大。 | palette | 画板,设置部件的基本样式。 | mouseTracking | 鼠标跟踪,鼠标离开部件范围后,部件仍可以接收到mousemove等事件。 | tabletTracking | 平板或手机的陀螺仪、加速度传感器跟踪。 | focusPolicy | 焦点策略,按钮可以通过NoFocus使虚线消失,lineedit这类文本编辑框必须能获得焦点。 |
? ?
属性值 | 作用 |
---|
NoFocus | 无法通过点击和键盘获得焦点 | TabFocus | 鼠标无法获得焦点,Tab键获得焦点 | ClickFocus | 鼠标点击获得焦点,Tab键无法获得焦点 | StrongFocus | 鼠标和Tab键都可以获得焦点 | WheelFocus | 通过滚轮获得焦点 |
? ?
属性值 | 作用 |
---|
contextMenuPolicy | 上下文菜单策略,指定菜单的显示方式。 | NoContextMenu | 部件无菜单,菜单处理延迟到部件父亲 | PreventContextMenu | 部件无菜单,菜单处理不延迟到父亲,而是传递到本身。 | DefaultContextMenu | 调用部件的contextMenuEvent方法,默认处理方式为忽略上下文事件。 | ActionsContextMenu | 部件菜单由 actions定义构成 | CustomContextMenu | 部件菜单自定义,发送customContextMenuRequested信号 |
? ?
属性值 | 作用 |
---|
acceptDrops | 设置部件是否接受拖拽事件,默认启用。 | toolTip | 设置部件的提示,鼠标悬浮时会显示。 | toolTipDuration | 设置widgettoolTip的显示持续时间,毫秒为单位,默认为-1,会一直显示。 | statusTip | 设置部件的状态提示,当窗口有statusBar时会显示在上面。 | whatsThis | 某些窗口会有whatsThis按钮,选中后点击其他按钮会显示帮助信息 | accessibleName | 辅助功能客户端应用程序所使用的控件名称。 | accessibleDescription | 主要用来为视力较差或盲人用户,提供更大的上下文,也可以使用上下文搜索或其他应用程序。 | layoutDirection widget | 布局的方向,LeftToRight,RightToLeft,LayoutDirectionAuto,字面意思 | autoFillBackground | 设置widget背景是否被画板颜色自动填充,默认不勾选 | styleSheet | 设置widget的qss样式表 | locale | 设置widget的区域和语言,在将时间等信息转成字符串后,年月日几个字会显示不同语言 | inputMethodHint | 设置widget输入时的屏幕键盘模式,有纯数字、纯字母等多种模式,用在手机端 |
|