Qt学习之Qt基础入门(中)

1. 前言

上一篇博客,总结了Qt的一些基础用法,这篇博客继续跟视频学习Qt的常用方法

Qt入门系列:
Qt学习之C++基础
Qt学习之Qt安装
Qt学习之Qt基础入门(上)
Qt学习之Qt基础入门(中)
Qt学习之Qt基础入门(下)

本文原创,创作不易,转载请注明!!!
本文链接
个人博客: https://ronglin.fun/archives/220
PDF链接:见博客网站
CSDN: https://blog.csdn.net/RongLin02/article/details/120661304**

2. QMainWindow

QMainWindow作为一个主窗口,有很多方便的控件可以用

2.1. 菜单栏

菜单栏最多只有一个

QMenuBar * bar = MenuBar();
this->setMenuBar( bar )
QMenu * fileMenu = bar -> addMenu(“文件”)   创建菜单
QAction * newAction =  fileMenu ->addAction(“新建”); 创建菜单项
//添加分割线
fileMenu->addSeparator();

2.2. 工具栏

可以有多个

QToolBar * toolbar = new QToolBar(this);
addToolBar( 默认停靠区域, toolbar ); //例如:Qt::LeftToolBarArea

可以设置后期停靠区域,设置浮动,设置移动,添加菜单项 或者添加 小控件等等

2.3. 状态栏

最多一个

QStatusBar * stBar = statusBar();
setStatusBar(stBar);    //设置到窗口中
stBar->addWidget(label);    //放左侧信息
stBar->addPermanentWidget(label2);     //放右侧信息

2.4. 铆接部件

浮动窗口 可以多个
QDockWidget
addDockWidget( 默认停靠区域,浮动窗口指针)
设置后期停靠区域

2.5. 设置核心部件

只能一个

this->setCentralWidget(edit);

以上这些在ui中均已经创建完毕,如果想要灵活使用,可以查询API

3. 资源文件

首先要将图片文件拷贝到项目位置下,我这里在项目根目录创建一个image文件夹,里边放入了一张图片
Qt学习之Qt基础入门(中)_第1张图片
然后在开发工具中,右键项目->添加新文件 –> Qt - >Qt recourse File
Qt学习之Qt基础入门(中)_第2张图片

然后起名字,叫res,然后路径也选择项目根目录
Qt学习之Qt基础入门(中)_第3张图片
然后它会生成一个res.qrc的资源文件
然后对着res.qrc右键 -> open in editor -> 编辑资源
在右侧,添加前缀 我这里前缀起名/
前缀添加完毕后,再点击 添加文件,然后选择要添加的图片等资源文件,可以多选,然后再 右键项目 -> 重新构建
之后如果工程中出现图片,则说明导入完成
Qt学习之Qt基础入门(中)_第4张图片
资源文件导入完毕,使用的时候可以这样使用“ : + 前缀名 + 文件名 ” 例如

this->setWindowIcon(QIcon(":/image/test.png"));

这样就能在项目中使用导入的资源了,例如这个方法就是设置程序的图标

4. 对话框

对话框是一个特别常见的界面,比如当用户退出程序的时候,会弹出来一个对话框询问是否要退出等等,下面介绍常用的对话框。

4.1. 分类

常见对话框一共用两种分类,一个是模态对话框,一个是非模态对话框,模态对话框弹出时,只能对本对话框操作,不能对其他窗口操作,而模态对话框可以对其他窗口操作

4.1.1. 模态对话框

不可以对其他窗口进行操作,其他窗口为阻塞状态
代码见下注释区,效果如图
Qt学习之Qt基础入门(中)_第5张图片

.1.2. 非模态对话框
可以对其他窗口进行操作
代码见下,效果如图
Qt学习之Qt基础入门(中)_第6张图片

4.1.2. 实例代码

注意非模态对话框,为了防止一闪而过,要创建到堆区
同时如果实现上图的效果,要在ui中拖动一个pushButton到主界面中
然后用connect函数实现这个按钮的功能,用Lambda表达式快速实现

#include "mainwindow.h"
#include "ui_mainwindow.h"
#include 
#include 

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    connect(ui->pushButton,&QPushButton::clicked,[=](){
//        QDialog dlg(this);
//        dlg.setWindowTitle("模态对话框");
//        dlg.resize(300,100);
//        dlg.show();

        QDialog* dlg = new QDialog(this);
        dlg->setWindowTitle("非模态对话框");
        dlg->resize(300,100);
        dlg->show();
    });
}
MainWindow::~MainWindow()
{
    delete ui;
}

4.2. 标准对话框

4.2.1. 总述

所谓标准对话框,是 Qt 内置的一系列对话框,用于简化开发。事实上,有很多对话框都是通用的,比如打开文件、设置颜色、打印设置等。这些对话框在所有程序中几乎相同,因此没有必要在每一个程序中都自己实现这么一个对话框。
Qt 的内置对话框大致分为以下几类:

QColorDialog:		选择颜色;
QFileDialog:			选择文件或者目录;
QFontDialog:			选择字体;
QInputDialog:		允许用户输入一个值,并将其值返回;
QMessageBox:			模态对话框,用于显示信息、询问问题等;
QPageSetupDialog:	为打印机提供纸张相关的选项;
QPrintDialog:		打印机配置;
QPrintPreviewDialog:打印预览;
QProgressDialog:		显示操作过程。

4.2.2. 消息对话框

模态对话框,消息对话框的创建,要用QMessageBox的静态成员函数,在API中可以看到,一共有4种消息对话框,这四种对话框的返回值是StandardButton类型,可以利用返回值判断用户点击了哪个按钮
Qt学习之Qt基础入门(中)_第7张图片

4.2.2.1. 错误对话框

效果如左上

//函数
StandardButton critical(QWidget *parent, const QString &title, const QString &text, StandardButtons buttons = Ok, StandardButton defaultButton = NoButton)

//用法
QMessageBox::critical(this,"错误对话框","这是一个critical对话框");

4.2.2.2. 信息对话框

效果如右上

//函数
StandardButton information(QWidget *parent, const QString &title, const QString &text, StandardButtons buttons = Ok, StandardButton defaultButton = NoButton)

//用法
QMessageBox::information(this,"信息对话框","这是一个information对话框")

可以看到,在构造函数中,还有两个参数,一个是StandardButtons,就是信息对话框里边ok的那个,还有参数一个是defaultButton,是默认光标所在的按钮。

4.2.2.3. 提问对话框

效果如左下

StandardButton question(QWidget *parent, const QString &title, const QString &text, StandardButtons buttons = StandardButtons( Yes | No ), StandardButton defaultButton = NoButton)

//用法
QMessageBox::question(this,"提问对话框","这是一个question对话框");

第四个参数有些特别,用到了 | 符号,实际可以这样用QMessageBox::Save|QMessageBox::Close表示同时显示两个按钮,一个是保存,一个是关闭,这两个在QMessageBox中都有定义

4.2.2.4. 警告对话框

效果如右下

StandardButton warning(QWidget *parent, const QString &title, const QString &text, StandardButtons buttons = Ok, StandardButton defaultButton = NoButton)

//用法
QMessageBox::warning(this,"警告对话框","这是一个warning对话框");

5. 界面布局

界面布局主要就是在ui设置,尤其是在可视化界面中拖动图标设置。
利用布局方式 给窗口进行美化

5.1. 布局方法

比如,我们在界面中,选中两个按钮,(摁住Ctrl键,再点击另一个控件可实现多选),然后点击上方的垂直布局,然后就发现两个按钮上下排列,并且1:1对齐了
Qt学习之Qt基础入门(中)_第8张图片
一共有多种对齐方式:水平布局、垂直布局、栅格布局
如果设置的布局不喜欢,可以右键->打破布局
如果默认窗口和控件之间 有间隙,可以调整在右下角的layoutLeftMargin属性
同时也可以利用弹簧进行布局,在Spacers,下有垂直弹簧和水平弹簧,可以自动填充

5.2. 按比例布局

有的时候,一个布局中存在多个控件,我们希望组件按照一定的比例排布而不是默认,这样的话,我们在布局 完成后,在右侧点击QVBoxLayout类,然后在右侧下方,有一个layoutStretch属性,里边有几个值,如果这个布局中有3个控件就有3个值,如果是有四个控件就有4个值,按照下图为例,我有三个控件,一个是QFrame一个QListView,一个是pushButton,我想让他们按照3:5:1的比例排布,就设置3,5,1,效果如图。
Qt学习之Qt基础入门(中)_第9张图片
这个功能特别好用,尤其是在界面可变大小的程序中,当用户拉伸界面的时候,我们希望我们的程序内部的控件仍然按照比例缩放,这时候就可用这个方法设置了。

6. 控件

控件有太多了,在ui界面中已经显示了很多,如果不太清楚它的用法,去查询API也能大概搞懂,这里只是大概过一下。

6.1. 按钮组

QPushButton是一个常用按钮
QToolButton是一个工具按钮 用于显示图片,如图想显示文字,修改风格:toolButtonStyle , 凸起风格autoRaise
radioButton是一个单选按钮,设置默认ui->radioButton->setChecked(true);
checkbox多选按钮,监听状态,2 选中 1 半选 0 未选中

关于后两个按钮多说一嘴,因为选项都是一组的,尤其是在radioButton中,我们希望一组选项中只有一个选中,那么就可以把备选选项都拖入一个GroupBox中,然后这样就会默认一个GroupBox中是同一组,同一组中的选项就只能选择一个了。如下图:
Qt学习之Qt基础入门(中)_第10张图片

6.2. QListWidget 列表容器

QListWidgetItem * item     //显示一行内容
ui->listWidget ->addItem ( item )
item->setTextAlignment(Qt::AlignHCenter);    //设置居中方式

可以利用addItems一次性添加整个诗内容,用法如下

//利用listWidget写诗
//    QListWidgetItem * item = new QListWidgetItem("锄禾日当午");
//    //将一行诗放入到listWidget控件中
//    ui->listWidget->addItem(item);
//    item->setTextAlignment(Qt::AlignHCenter);

    //QStringList   QList
    QStringList list ;
    list << "锄禾日当午" << "旱地和下土" << "谁知盘中餐"<< "粒粒皆辛苦";
    ui->listWidget->addItems(list);

6.3. QTreeWidget 树控件

要先设置头,然后创建一个根节点,添加根节点 到 树控件上,之后再往根节点上添加子节点

用法如下:

//treeWidget树控件使用

    //设置水平头
    ui->treeWidget->setHeaderLabels(QStringList()<< "英雄"<< "英雄介绍");

    QTreeWidgetItem * liItem = new QTreeWidgetItem(QStringList()<< "力量");
    QTreeWidgetItem * minItem = new QTreeWidgetItem(QStringList()<< "敏捷");
    QTreeWidgetItem * zhiItem = new QTreeWidgetItem(QStringList()<< "智力");
    //加载顶层的节点
    ui->treeWidget->addTopLevelItem(liItem);
    ui->treeWidget->addTopLevelItem(minItem);
    ui->treeWidget->addTopLevelItem(zhiItem);

    //追加子节点
    QStringList heroL1;
    heroL1 << "刚被猪" << "前排坦克,能在吸收伤害的同时造成可观的范围输出";
    QTreeWidgetItem * l1 = new QTreeWidgetItem(heroL1);
    liItem->addChild(l1);

6.4. QTableWidget 表格控件

要设置列数,设置水平表头,设置行数,同时设置正文

//TableWidget控件
    //设置列数
    ui->tableWidget->setColumnCount(3);

    //设置水平表头
    ui->tableWidget->setHorizontalHeaderLabels(QStringList()<<"姓名"<< "性别"<< "年龄");

    //设置行数
    ui->tableWidget->setRowCount(5);

    //设置正文
    //ui->tableWidget->setItem(0,0, new QTableWidgetItem("亚瑟"));
    QStringList nameList;
    nameList<< "亚瑟"<< "赵云"<< "张飞"<< "关羽" << "花木兰";

    QList sexList;
    sexList << "男"<< "男"<< "男"<< "男"<< "女";

    for(int i = 0 ; i < 5 ;i ++)
    {
        int col = 0;
        ui->tableWidget->setItem(i,col++, new QTableWidgetItem(nameList[i]));
        ui->tableWidget->setItem(i,col++, new QTableWidgetItem(sexList.at(i)));
        //int 转 QString
        ui->tableWidget->setItem(i,col++, new QTableWidgetItem( QString::number(i+18)));
    }

6.5. 其他控件介绍

stackedWidget 栈控件

ui->stackedWidget->setCurrentIndex(1);

下拉框

ui->comboBox->addItem("奔驰");

QLabel 显示图片

ui->lbl_Image->setPixmap(QPixmap(":/Image/butterfly.png"))

QLabel显示动图 gif图片

ui->lbl_movie->setMovie(movie);
movie->start();

以上控件用法见下:

    //栈控件使用
    //设置默认定位 scrollArea
    ui->stackedWidget->setCurrentIndex(1);

    //scrollArea按钮
    connect(ui->btn_scrollArea,&QPushButton::clicked,[=](){
        ui->stackedWidget->setCurrentIndex(1);
    });

    //toolBox按钮
    connect(ui->btn_ToolBox,&QPushButton::clicked,[=](){
        ui->stackedWidget->setCurrentIndex(2);
    });

    //TabWidget按钮
    connect(ui->btn_TabWidget,&QPushButton::clicked,[=](){
        ui->stackedWidget->setCurrentIndex(0);
    });

    //下拉框
    ui->comboBox->addItem("奔驰");
    ui->comboBox->addItem("宝马");
    ui->comboBox->addItem("拖拉机");

    //点击按钮 选中拖拉机选项
    connect(ui->btn_select,&QPushButton::clicked,[=](){
        //ui->comboBox->setCurrentIndex(2);
        ui->comboBox->setCurrentText("拖拉机");
    });

    //利用QLabel显示图片
    ui->lbl_Image->setPixmap(QPixmap(":/Image/butterfly.png"));

    //利用QLabel显示 gif动态图片
    QMovie * movie = new QMovie(":/Image/mario.gif");
    ui->lbl_movie->setMovie(movie);
    //播放动图
    movie->start();

7. 总结

这篇博客主要总结ui界面的设计,其实在API中都有教程,这里只是过一下。
未完待续,=w=

你可能感兴趣的:(Qt,qt)