Qt模块化笔记之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)

QByteArray saveState(int version = 0) const bool restoreDockWidget(QDockWidget * dockwidget)

//其它 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 0x01animated相同
QMainWindow::AllowNestedDocks 0x02dockNestingEnabled相同
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的形状配置保存

#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;
}



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值