Qt Widgets——主窗口及其主要组成部分

简介:

Main Window and Related Classes

QAction

动作类,用于当做一个菜单项或工具项插入菜单或工具栏

QActionGroup

动作组,用于管理多个动作,设置它们之间的互斥性等

QWidgetAction

部件动作,继承自QAction,用于将小部件插入菜单或工具栏

QDockWidget

悬浮部件,程序运行后可鼠标拖动的部件

QMainWindow

主窗口,是其它部件的容器

QMdiArea

子区域,加到QMainWindow中,用于放置多个QMdiSubWindow子窗口

QMdiSubWindow

子窗口

QMenu

菜单

QMenuBar

菜单栏,存放多个菜单

QSizeGrip

管理顶层窗口尺寸,一般位于软件的右下角,状态栏最右边,鼠标可拖动它改变窗口大小

QStatusBar

状态栏

QToolBar

工具栏

以QMainWindow为中心,构成了传统界面的各部分,现将它们拖在一起记录。

以rar压缩软件界面为例,各部分组成如下:

最上一行,叫菜单栏,由“文件”、“命令”等菜单组成,“选项”菜单已点击,弹出很多菜单项,Qt中用动作类QAction来表示菜单项。即QAction构成了菜单,菜单构成了菜单条,QAction可加入文字,图片等构成漂亮的菜单项。QDockWidget 悬浮部件较特殊,它在程序运行时,拖动可改变其位置。

——————————————————————————————————————————————————————————————————

建立步骤:

为了构建传统界面,需要在建立工程某步时选择继承类,如下图。

建成后,ui文件如下,“在这里输入”即是要求我们创建菜单,菜单栏下面一层即是默认的工具栏,没有添加动作,所以很细小(最左方有一个小点)

双击“在这里输入后”,可以写入文字,如下图,输入了创建了常用的“文件”。在下方五个按钮处的第一个新建一个动作,可以指定动作的名称,快捷键等,建完后,将它拖动到菜单或工具栏。

以下是效果图:

这时,只要将这个“动作”的“触发”信号连接到某个槽函数后,点击该菜单项或工具栏上的“新建”,就会执行槽函数。

以上就是建立一个传统界面的粗糙步骤

——————————————————————————————————————————————————————————————

QMainWindow

一个 主窗口各部分分布如图:

对比(图中中间白色大框为一个QTableWidget表格小部件):

公有函数分类如下:
复制代码
QMainWindow(QWidget * parent = 0, Qt::WindowFlags flags = 0)  
    ~QMainWindow()  
//设置菜单部分  
void    setMenuBar(QMenuBar * menuBar)//带ui文件默认是有一个菜单条的,如果设置了这个之后,则默认的被覆盖,一个MainWindow只能有一个主菜单处于最上方  
void    setMenuWidget(QWidget * menuBar)//覆盖默认菜单,用一个自定义的部件代替菜单,甚至可以用一个按钮……,比较灵活,看不惯默认菜单的,可试试这个。  
  
//工具栏部分  
void    addToolBar(Qt::ToolBarArea area, QToolBar * toolbar)//添加一个工具条,用枚举值Qt::ToolBarArea(见1)设定停靠区域,由图可见,停靠区分为上下左右四区域。  
void    addToolBar(QToolBar * toolbar)//添加一个工具条(默认紧跟上一个工具条)  
QToolBar *  addToolBar(const QString & title)  
void    addToolBarBreak(Qt::ToolBarArea area = Qt::TopToolBarArea)//添加一个Break(破裂; 间断; 或译为区域),这时,新添加的工具条将不再紧跟前一个工具条,而是另起一行。  
void    insertToolBar(QToolBar * before, QToolBar * toolbar)//在before工具条后加一个  
void    insertToolBarBreak(QToolBar * before)//添加分隔线  
void    removeToolBar(QToolBar * toolbar)  
void    removeToolBarBreak(QToolBar * before)  
void    setToolButtonStyle(Qt::ToolButtonStyle toolButtonStyle)//设置工具条上显示模式,默认只有文件,可设置成图片或文字形式(见2)  
void setIconSize(const QSize & iconSize)//设置工具条上图标大小,在上一个函数设置图标模式后有效  
  
//可停靠窗口部件  
void addDockWidget(Qt::DockWidgetArea area, QDockWidget * dockwidget)//area枚举值见3  
void addDockWidget(Qt::DockWidgetArea area, QDockWidget * dockwidget, Qt::Orientation orientation)  
void removeDockWidget(QDockWidget * dockwidget)  
void setCorner(Qt::Corner corner, Qt::DockWidgetArea area)//让四个角落(corner)中一个区域"归属于"某个区域(area),具体看最下方例子  
void setDockOptions(DockOptions options)//设置停靠选项,比如允许动画或是否允许拖放重合成一个tab选项卡类型的部件,枚举值见4  
void setTabPosition(Qt::DockWidgetAreas areas, QTabWidget::TabPosition tabPosition)//设置形成的tab位置  
void setTabShape(QTabWidget::TabShape tabShape)  
void setDocumentMode(bool enabled)  
void splitDockWidget(QDockWidget * first, QDockWidget * second, Qt::Orientation orientation)//部件拖动至处于同一区域时,默认重合形成tab,利用这个,可将它们分开  
  
//设置中间部件  
void setCentralWidget(QWidget * widget)  
QWidget * centralWidget() const  
  
//添加状态栏  
void setStatusBar(QStatusBar * statusbar)  
  
//保存窗口形状信息  
bool restoreState(const QByteArray & state, int version = 0)  
<p>QByteArray saveState(int version = 0) const  
bool restoreDockWidget(QDockWidget * dockwidget)  
  
</p>//其它  
Qt::DockWidgetArea  corner(Qt::Corner corner) const  
virtual QMenu * createPopupMenu()  
DockOptions dockOptions() const  
Qt::DockWidgetArea  dockWidgetArea(QDockWidget * dockwidget) const  
bool    documentMode() const  
QSize   iconSize() const  
bool    isAnimated() const  
bool    isDockNestingEnabled() const  
QMenuBar *  menuBar() const  
QWidget *   menuWidget() const  
QStatusBar *    statusBar() const  
QTabWidget::TabPosition tabPosition(Qt::DockWidgetArea area) const  
QTabWidget::TabShape    tabShape() const  
QList<QDockWidget *>  tabifiedDockWidgets(QDockWidget * dockwidget) const  
void    tabifyDockWidget(QDockWidget * first, QDockWidget * second)  
QWidget *   takeCentralWidget()  
Qt::ToolBarArea toolBarArea(QToolBar * toolbar) const  
bool    toolBarBreak(QToolBar * toolbar) const  
Qt::ToolButtonStyle toolButtonStyle() const  
复制代码

1,enum Qt::ToolBarArea

Constant Value
Qt::LeftToolBarArea 0x1
Qt::RightToolBarArea 0x2
Qt::TopToolBarArea 0x4
Qt::BottomToolBarArea 0x8
Qt::AllToolBarAreas ToolBarArea_Mask
Qt::NoToolBarArea 0

2,enum Qt::ToolButtonStyle

Constant Value Description
Qt::ToolButtonIconOnly 0 只显示图标
Qt::ToolButtonTextOnly 1 Only display the text.
Qt::ToolButtonTextBesideIcon 2 The text appears beside the icon.
Qt::ToolButtonTextUnderIcon 3 文本显示在图标下方
Qt::ToolButtonFollowStyle 4 Follow the style.

3,enum Qt::DockWidgetArea
flags Qt::DockWidgetAreas

Constant Value
Qt::LeftDockWidgetArea 0x1
Qt::RightDockWidgetArea 0x2
Qt::TopDockWidgetArea 0x4
Qt::BottomDockWidgetArea 0x8
Qt::AllDockWidgetAreas DockWidgetArea_Mask
Qt::NoDockWidgetArea 0

4,enum QMainWindow::DockOption
flags QMainWindow::DockOptions

Constant Value Description
QMainWindow::AnimatedDocks 0x01 animated相同
QMainWindow::AllowNestedDocks 0x02 dockNestingEnabled相同
QMainWindow::AllowTabbedDocks 0x04 允许形成下方有tapBar的重合部件
QMainWindow::ForceTabbedDocks 0x08 Each dock area contains a single stack of tabbed dock widgets. In other words, dock widgets cannot be placed next to each other in a dock area. If this option is set, AllowNestedDocks has no effect.
QMainWindow::VerticalTabs 0x10 设置tabBar在竖直左方位置(默认在下方)

以rar压缩软件为例,用代码写出界面主要部分:

以下代码只是用于理解,是很不合理的。主要测试各部分小部件的位置,外观等,以及mainwidow的形状配置保存

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QAction>
#include <QMenu>
#include <QIcon>
#include <QSize>
#include <QLabel>
#include <QDockWidget>
#include <QTableWidget>
#include <QSettings>
 
MainWindow::MainWindow(QWidget *parent) :
     QMainWindow(parent),
     ui( new  Ui::MainWindow)
{
     ui->setupUi( this );
 
     //菜单栏部分
     QMenu *menu1=ui->menuBar->addMenu( "文件(&F)" );
     QAction *me1_act1=menu1->addAction( "打开压缩文件(O)" );
     me1_act1->setShortcut(QKeySequence(tr( "Ctrl+O" )));
     //connect(me1_act1,SIGNAL(triggered()),……
     QAction *me1_act2=menu1->addAction( "保存压缩文件副本为(V)" );
     me1_act2->setIcon(QIcon( "://img/sava.ico" ));
     menu1->addSeparator();
     QAction *me1_act3=menu1->addAction( "退出(X)" );
     connect(me1_act3,SIGNAL(triggered()), this ,SLOT(close()));
     ui->menuBar->addMenu( "命令(&C)" );
 
     //"文件"菜单部分
     QAction *tb1_act1=ui->mainToolBar->addAction(QIcon( "://img/tool1.ico" ), "添加" );
     ui->mainToolBar->addSeparator();
     QAction *tb1_act2=ui->mainToolBar->addAction(QIcon( "://img/tool2.ico" ), "解压到" );
     setToolButtonStyle(Qt::ToolButtonTextUnderIcon);
     setIconSize(QSize(50,50));
 
     addToolBarBreak();
     toolBar= new  QToolBar;
     toolBar->setObjectName( "tb2" ); //设置对象名,用于保存配置
     toolBar->setToolButtonStyle(Qt::ToolButtonIconOnly);
     toolBar->setIconSize(QSize(20,20));
     addToolBar(toolBar);
     QAction *tb2_act1=toolBar->addAction(QIcon( "://img/sharp.ico" ), "" );
 
     //添加中间主部件
     QTableWidget *tb1= new  QTableWidget;
     setCentralWidget(tb1);
 
     //添加悬浮部件
     QDockWidget *dock1=  new  QDockWidget( "上侧部件" );
     addDockWidget(Qt::TopDockWidgetArea,dock1);
     QDockWidget *dock2_1=  new  QDockWidget( "左侧部件1" );
     addDockWidget(Qt::LeftDockWidgetArea,dock2_1);
     QDockWidget *dock2_2=  new  QDockWidget( "左侧部件2" );
     addDockWidget(Qt::LeftDockWidgetArea,dock2_2);
     splitDockWidget(dock2_1,dock2_2,Qt::Horizontal);
     QDockWidget *dock3=  new  QDockWidget( "右侧部件" );
     dock3->setFeatures(QDockWidget::DockWidgetVerticalTitleBar|QDockWidget::DockWidgetMovable);
     addDockWidget(Qt::RightDockWidgetArea,dock3);
     QDockWidget *dock4=  new  QDockWidget( "下侧部件" );
     addDockWidget(Qt::BottomDockWidgetArea,dock4);
     //setCorner(Qt::BottomLeftCorner,Qt::LeftDockWidgetArea);//让左下角区域归于左边停靠区域
     dock1->setObjectName( "dock1" );
     dock2_1->setObjectName( "dock2_1" );
     dock2_2->setObjectName( "dock2_2" );
     dock3->setObjectName( "dock3" );
     dock4->setObjectName( "dock4" );
 
     //状态栏部分
     QLabel *lbl1= new  QLabel( "无状态" );
     ui->statusBar->addWidget(lbl1);
 
     //读取窗口及部件形状与状态
     readSettings();
 
}
void  MainWindow::closeEvent(QCloseEvent * event )
{
     QSettings settings( "大中华有限公司" "测试软件名" );
     settings.setValue( "geometry" , saveGeometry());
     settings.setValue( "windowState" , saveState());
     settings.sync();
}
void  MainWindow::readSettings()
{
     QSettings settings( "大中华有限公司" "测试软件名" );
     restoreGeometry(settings.value( "geometry" ).toByteArray());
     restoreState(settings.value( "windowState" ).toByteArray());
}
 
 
MainWindow::~MainWindow()
{
     delete ui;
}

  

本文转自夜&枫博客园博客,原文链接:http://www.cnblogs.com/newstart/p/4476141.html,如需转载请自行联系原作者
相关文章
|
2月前
|
算法 API C++
【Qt UI】QT 窗口/控件置顶方法详解
【Qt UI】QT 窗口/控件置顶方法详解
59 0
|
4月前
Qt 布局管理之 停靠窗口QDockWidget
Qt 布局管理之 停靠窗口QDockWidget
74 0
|
4月前
Qt 布局管理之分割窗口
Qt 布局管理之分割窗口
36 0
|
6月前
08 QT - Qt窗口坐标体系
08 QT - Qt窗口坐标体系
24 0
|
Windows
关于 Qt设置置顶窗口,透明部分显示黑色底色(已设置透明窗口) 的解决方法
关于 Qt设置置顶窗口,透明部分显示黑色底色(已设置透明窗口) 的解决方法
关于 Qt设置置顶窗口,透明部分显示黑色底色(已设置透明窗口) 的解决方法
|
计算机视觉
Qt实用技巧:实现不规则窗口的鼠标消息穿透,包括穿透到桌面和穿透到父窗口
Qt实用技巧:实现不规则窗口的鼠标消息穿透,包括穿透到桌面和穿透到父窗口
Qt实用技巧:实现不规则窗口的鼠标消息穿透,包括穿透到桌面和穿透到父窗口
|
1月前
QT取消标题栏,如何实现窗口移动
QT取消标题栏,如何实现窗口移动
|
2月前
|
测试技术 API UED
【Qt 应用开发 】初步理解 Qt窗口中的模态性应用
【Qt 应用开发 】初步理解 Qt窗口中的模态性应用
72 1
|
4月前
Qt 控件大小随着窗口的大小而变化设置
Qt 控件大小随着窗口的大小而变化设置
63 0
|
4月前
|
Linux
Qt实现多文档窗口
Qt实现多文档窗口

推荐镜像

更多