QT提供的默认部件基类包括QMainWindow、QWidget、和QDialog这三种,这三个部件基类也是用的最多的。
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枚举值指定,窗体状态如下表所示
QWidget类关系图
Qt::WindowFlags参数值
Qt:WindowFlags |
释义 |
Qt::Widget |
QWidget构造函数的默认值,如果新的窗口部件没有父窗口部件,则它是一个独立的窗口,否则就是一个子窗口部件。另请参见Qt :: Window和Qt :: SubWindow。 |
Qt::Window |
无论是否有父窗口部件,新窗口部件都是一个窗口,通常有一个窗口边框和一个标题栏 。请注意,如果部件没有父控件,则无法取消设置此标记(即如果存在父控件,则可以取消此标记,否则,必须存在此标记用以标识此控件是个独立窗口)。 |
Qt:: Dialog |
新窗口部件是一个对话框,它是QDialog构造函数的默认值。如果要将其用作模态对话框,则应从另一个窗口启动它,或者如果有父窗口,则与QWidget::windowModality属性一起使用。如果将其设置为模态,则对话框将阻止应用程序中的其他顶级窗口获取任何输入。我们将具有父级的顶级窗口称为辅助窗口。 |
Qt::Sheet |
新窗口部件是一个Macintosh表单(sheet) 。由于使用工作表意味着窗口模态,推荐的方法是使用QWidget :: setWindowModality()或QDialog :: open()。 |
Qt:: Drawer |
新窗口部件是一个Macintosh抽屉(drawer) |
Qt::Popup |
新窗口部件是一个弹出式顶层窗口 |
Qt::Tool |
新窗口部件是一个工具(tool)窗口,它通常是一个用于显示工具按钮的小窗口。如果一个工具窗口有父窗口部件,则它将显示在父窗口的部件上面,否则相当于使用了Qt::WindowStaysOnTopHint提示。如果窗口系统支持它,工具窗口可以用更轻的框架装饰。它也可以与Qt :: FramelessWindowHint结合使用。 |
Qt::ToolTip |
表示窗口小部件是工具提示。 这在内部用于实现工具提示,没有标题栏和窗口边框。 |
Qt:: Desktop |
新窗口部件是桌面,它是QDesktopWidget构造函数的默认值 |
Qt::SplashScreen |
新窗口部件是一个欢迎窗口,它是SplashScreen构造函数的默认值。 |
Qt::SubWindow |
新窗口部件是一个子窗口,而无论窗口部件是否有父窗口部件。此外,Qt还定义了一些控制窗口外观的窗口提示(这些窗口提示仅对顶层窗口有效) |
Qt::ForeignWindow |
指示此窗口对象是表示由另一个进程创建的本机平台窗口或手动使用本机代码的句柄。 |
Qt::CoverWindow |
表示该窗口代表一个封面窗口,例如,当应用程序在BlackBerry平台上最小化时显示。 |
Qt::MSWindowFiredSizeDialogHint |
为Windows系统上的窗口装饰一个窄的对话框边框,通常这个提示用于固定大小的对话框 |
Qt::MSWindowOwnDC |
为Windows系统上的窗口添加自身的显示上下文菜单 |
Qt::BypassWindowManagerHint |
此标志可用于向平台插件指示应禁用“所有”窗口管理器协议。 此标志的行为会有所不同,具体取决于运行应用程序的操作系统以及正在运行的窗口管理器。 该标志可用于获取没有配置集的本机窗口。 |
Qt::X11BypassWindowManagerHint |
完全忽视窗口管理器,它的作用是产生一个根本不被管理的无窗口边框的窗口(此时,用户无法使用键盘进行输入,除非手动调用QWidget::activateWindow()函数) |
Qt::FramelessWindowHint: |
产生一个无窗口边框的窗口,此时用户无法移动该窗口和改变它的大小 |
Qt::NoDropShadowWindowHint |
在支持平台上禁用窗口投影 |
Qt::CustomizeWindowHint |
关闭默认的窗口标题提示 |
Qt::WindowTitleHint |
为窗口装饰一个标题栏 |
Qt::WindowSystemMenuHint |
为窗口添加一个窗口系统系统菜单,并尽可能地添加一个关闭按钮 |
Qt::WindowMinimizeButtonHint |
为窗口添加一个“最小化”按钮 |
Qt::WindowMaximizeButtonHint |
为窗口添加一个“最大化”按钮 |
Qt::WindowCloseButtonHint |
为窗口添加一个“关闭”按钮 |
Qt::WindowMinMaxButtonHint |
为窗口添加一个“最小化”按钮 和一个“最大化”按钮 |
Qt::WindowContextHelpButtonHint |
为窗口添加一个“上下文帮助”按钮 |
Qt::WindowStaysOnTopHint |
告知窗口系统,该窗口应该停留在所有其他窗口的上面 |
Qt::WindowType_Mask |
一个用于提示窗口标识的窗口类型部分的掩码 |
例如创建两个窗体,一个是默认窗体,另一个是无窗口边框、对话框样式窗体
#include
#include
int main(int argc,char* argv[]){
QApplication app(argc,argv);
QWidget widget;
widget.setWindowTitle("widget窗体");
widget.show();
QWidget widget1(0,Qt::FramelessWindowHint | Qt::Dialog);
widget1.setWindowTitle("widget窗体");
widget1.show();
return app.exec();
}
运行结果
默认窗体样式
无边框、对话框样式
通过resize函数设置窗体大小
resize可以直接传入宽和高的大小,也可也传一个QSize类
#include
#include
#include
int main(int argc,char* argv[]){
QApplication app(argc,argv);
QWidget widget;
widget.setWindowTitle("widget窗体");
//设置窗体大小宽800,高400
widget.resize(QSize(800,400));
widget.show();
return app.exec();
}
运行结果:
通过move函数移动窗体位置
move可以直接传入移到位置,也可以传入一个QPoint类
#include
#include
#include
int main(int argc,char* argv[]){
QApplication app(argc,argv);
QWidget widget;
widget.setWindowTitle("widget窗体");
//设置窗体大小宽800,高400
widget.resize(QSize(800,400));
//窗体初始位置为(0,0)
widget.move(QPoint(0,0));
widget.show();
return app.exec();
}
运行结果:
通过.x和.y函数获得窗体的屏幕位置
#include
#include
#include
#include
int main(int argc,char* argv[]){
QApplication app(argc,argv);
QWidget widget;
widget.setWindowTitle("widget窗体");
//设置窗体大小
widget.resize(QSize(800,400));
//设置窗体位置
widget.move(50,100);
widget.show();
//显示窗体位置
qDebug()<<"x:"<
运行结果:
通过.width和.height函数获取窗体的大小
#include
#include
#include
#include
int main(int argc,char* argv[]){
QApplication app(argc,argv);
QWidget widget;
widget.setWindowTitle("widget窗体");
//设置窗体大小
widget.resize(QSize(800,400));
//设置窗体位置
widget.move(50,100);
widget.show();
//显示窗体位置
qDebug()<<"x:"<
运行结果:
也可也通过.gemo
#include
#include
#include
#include
int main(int argc,char* argv[]){
QApplication app(argc,argv);
QWidget widget;
widget.setWindowTitle("widget窗体");
//设置窗体大小
widget.resize(QSize(800,400));
//设置窗体位置
widget.move(50,90);
widget.show();
//显示窗体大小
qDebug()<<"Qrect:"<
运行结果:
拉伸因子描述了各个部件在进行拉伸时,部件间以指定的比例进行拉伸,如水平布局的三个按钮其拉伸因子分别设为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 |
Preferred |
可以变大缩小,尺寸可变范围:≥minimumSizeHint |
Expanding |
可以变大缩小,尺寸可变范围:≥minimumSizeHint,且部件有优先扩展权 (注:优先扩展权表部件将尽可能多的占用空间,如Preferred与Expanding同时存在则优先分配空间给Expanding) |
MinimumExpanding |
尺寸可以拉伸,尺寸可变范围:≥minimumSizeHint,且部件有优先扩展权 |
Ignored |
任意变大缩小,尺寸可变范围:≥minimumSizeHint (若minimumSizeHint为0,则可缩小至0,此时部件不可见) |
属性值 |
作用 |
NoFocus |
无法通过点击和键盘获得焦点 |
TabFocus |
鼠标无法获得焦点,Tab键获得焦点 |
ClickFocus |
鼠标点击获得焦点,Tab键无法获得焦点 |
StrongFocus |
鼠标和Tab键都可以获得焦点 |
WheelFocus |
通过滚轮获得焦点 |
属性值 |
作用 |
NoContextMenu |
部件无菜单,菜单处理延迟到部件父亲 |
PreventContextMenu |
部件无菜单,菜单处理不延迟到父亲,而是传递到本身。 |
DefaultContextMenu |
调用部件的contextMenuEvent方法,默认处理方式为忽略上下文事件。 |
ActionsContextMenu |
部件菜单由 actions定义构成 |
CustomContextMenu |
部件菜单自定义,发送customContextMenuRequested信号 |
QDialog是各种对话框的基类,其继承自QWidget,对话框有两种表现形式:模态对话框、非模态对话框。模态对话框就是阻塞同一应用程序中其它可视窗口的输入的对话框。用户必须完成当前对话框中的交互操作并且关闭窗口后才能操作应用程序中的其它窗口。模式对话框有它们自己的本地事件循环。exec()方法可使窗口以模态方式运行。当用户关闭这个对话框,exec()将提供一个可用的返回值并且这时流程控制继续从调用exec()的地方进行。通常,我们连接默认按钮,例如“OK”到accept()槽并且把“Cancel”连接到reject()槽,来使对话框关闭并且返回适当的值。另外我们也可以连接done()槽,传递给它Accepted或Rejected。
模态窗口运行效果:
w1是模态窗口,w3是非模态窗口;w3需要等w1操作结束后才能使用
模态窗口运行方法:
(1)调用exec()方法,如
QDialog dlg;
dlg.exec();
(2)调用setModal()方法设置模态,如
QDialog dlg;
dlg.setModal(true);
dlg.show();
(3)调用继承的setWindowModality( )帆帆设置
Dialog w1;
w1.setWindowModality(Qt::ApplicationModal);
w1.show();
阻塞方式 |
阻塞效果 |
Qt::ApplicationModal |
阻塞应用程序的所有窗口 |
Qt::WindowModal |
阻塞阻塞父窗口、祖先窗口及它们的子窗口 |
Qt::NoModal |
不阻塞,默认值 |