【qt】最快的开发界面效率——混合编程

2024-05-13 05:28

本文主要是介绍【qt】最快的开发界面效率——混合编程,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

混合编程

  • 一.准备工作
    • 1.创建项目
    • 2.添加项目资源
  • 二.ui界面设计
    • 1.menuBar菜单栏
    • 2.action ▲
    • 3.toolBar工具栏
    • 4.中心组件
  • 三.代码界面设计
    • 1.toolBar添加组件
    • 2.statusBar状态栏添加组件
  • 四.完成界面的功能
    • 1.对action配置信号槽
    • 2.对action转到信号槽
    • 3.代码添加的组件手动关联槽函数
  • 五.补充
    • 1.样式选择问题
    • 2.复制粘贴剪切可选
    • 3.图标
  • 六.总结

前言:为了让大家直观的感受到混合编程的界面设计,这里以做一个项目来,边做边学。

目标图:
在这里插入图片描述
可以实现相应的功能哦,接下来我们开干!

一.准备工作

1.创建项目

因为我们的项目是有菜单栏工具栏状态栏的所以说我们要选择mainwindow为基类。
在这里插入图片描述

2.添加项目资源

我们这个项目可以看到有图片的显示,因此我们要先添加资源。

需要资源的可以dd我

在这里插入图片描述
选择Qt里的Qt Resource File
在这里插入图片描述
就会出现这样
在这里插入图片描述
然后点击Add Prefix进行分组:

在这里插入图片描述
然后点击Add Files添加资源
在这里插入图片描述
咱们的资源就添加好了!

二.ui界面设计

1.menuBar菜单栏

打开设计器,菜单栏在界面的左上角这里
在这里插入图片描述
可以输入名字,输完姚点击回车,才可保存!
在这里插入图片描述
接下来可以填入选项
这里不能输入汉字,但是可以粘贴进去
也可以把类型的放在一起添加分隔符
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
我们可以先看一下运行效果:
在这里插入图片描述

2.action ▲

这个时候我们会发现,下面出现了许多的action
在这里插入图片描述
action是一个可用于菜单栏、工具栏和其他地方的可执行操作的对象.相当于我们可以从这里对刚刚写的菜单在这里进行操作!
双击action可以对这些属性进行操作!
在这里插入图片描述
我们可以把对象名字改成我们容易看得懂的。
然后把我们的图标资源添加上。
Shortcut可以设置我们的快捷键。
在这里插入图片描述
然后把下面的action都进行修改!
注意对于粗体斜体下划线是复选,可以打开也可以不打开。
所以姚将Checkable选上。
在这里插入图片描述
这就全部添加完了
在这里插入图片描述
这是我们创建菜单时,自动创建的action
我们也可以先创建action然后拖到相应的栏。
在这里插入图片描述
我们可以看看效果:
在这里插入图片描述
有图片了,哈哈是不是很高兴,嘿嘿嘿。

3.toolBar工具栏

在界面的右边可以看到我们界面当前有的东西
在这里插入图片描述
默认是没有工具栏的,所有我们要进行手动的添加

右击MainWindow,添加工具栏

在这里插入图片描述
这个时候就有工具栏了
在这里插入图片描述

界面上的工具栏在这里:
在这里插入图片描述
然后我们可以将刚刚的action拖到工具栏中
也可以右键添加分隔符
在这里插入图片描述

在这里插入图片描述
这就拖完了,但是没有文字,我们可以先在右边的工具栏里的属性中找到toolButtonStyle进行设置
在这里插入图片描述
选择
在这里插入图片描述
就会出现:
在这里插入图片描述

然后添加一个文本编辑器组件

运行结果:
在这里插入图片描述

4.中心组件

看到我们的运行结果就感到很丑陋,文本编辑器都不能随着窗口的变化而变化。
这个时候我们就姚开始加布局的操作了。
选择整个窗口,添加水平布局。
在这里插入图片描述
此时我们中心组件就是文本编辑器了
在这里插入图片描述
可以自适应大小了,但是有边距
在这里插入图片描述
可以在centralwidget里面的Layout里把边距都设置为0
在这里插入图片描述
此时的运行结果:
在这里插入图片描述
完美,下面的是状态栏,不是边距。

三.代码界面设计

1.toolBar添加组件

现在距离我们的界面目标还差工具栏里面的字体大小和字体选择,这两个组件是QSpinBoxQFontComboBox是不能够直接拖放到工具栏的,因此我们只能使用代码去进行操作。
对于用代码写界面还是老样子
先定义指针,注意头文件

#ifndef MAINWINDOW_H
#define MAINWINDOW_H#include <QMainWindow>
#include <QSpinBox>//整数选择
#include <QFontComboBox>//字体选择QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACEclass MainWindow : public QMainWindow
{Q_OBJECTpublic:MainWindow(QWidget *parent = nullptr);~MainWindow();private:Ui::MainWindow *ui;QSpinBox*spinBoxFontSize;QFontComboBox*fontBox;
};
#endif // MAINWINDOW_H

然后对指针进行初始化

void MainWindow::initUI()
{spinBoxFontSize=new QSpinBox;fontBox=new QFontComboBox;spinBoxFontSize->setMinimumWidth(60); //设置字体大小选择的最小宽度spinBoxFontSize->setMinimum(8);//设置字体的最小尺寸spinBoxFontSize->setMaximum(60);//设置字体的最大尺寸spinBoxFontSize->setValue(ui->textEdit->fontPointSize());//开始拿到当前字体的大小ui->toolBar->addWidget(new QLabel("字体大小"));//向工具栏添加标签ui->toolBar->addWidget(spinBoxFontSize);//向工具栏中添加字体的大小选择fontBox->setMinimumWidth(160);//设置字体样式组件的最小宽度ui->toolBar->addSeparator();//添加一个分割符ui->toolBar->addWidget(new QLabel("字体"));//向工具栏中添加字体ui->toolBar->addWidget(fontBox);//向工具栏中添加字体}

同时对组件进行一些基础的属性设置
toolBar->addWiget这就是向工具栏进行添加组件的接口
运行结果:
在这里插入图片描述
OK,在工具栏中就出现了,我们需要的组件了。

2.statusBar状态栏添加组件

接下来就差状态栏的界面了
添加的原理跟工具栏差不多
先定义指针;

#include <QMainWindow>
#include <QSpinBox>//整数选择
#include <QFontComboBox>//字体选择
#include <QLabel>
#include <QProgressBar>//进度条QT_BEGIN_NAMESPACE
namespace Ui { class MainWindow; }
QT_END_NAMESPACEclass MainWindow : public QMainWindow
{Q_OBJECTpublic:MainWindow(QWidget *parent = nullptr);~MainWindow();private:Ui::MainWindow *ui;QSpinBox*spinBoxFontSize;QFontComboBox*fontBox;QLabel*fileName;QProgressBar*progressBar;void initUI();
};

接下来在initUI里面进行初始化

void MainWindow::initUI()
{spinBoxFontSize=new QSpinBox;fontBox=new QFontComboBox;fileName=new QLabel;progressBar=new QProgressBar;spinBoxFontSize->setMinimumWidth(60); //设置字体大小选择的最小宽度spinBoxFontSize->setMinimum(8);//设置字体的最小尺寸spinBoxFontSize->setMaximum(60);//设置字体的最大尺寸spinBoxFontSize->setValue(ui->textEdit->fontPointSize());//开始拿到当前字体的大小ui->toolBar->addWidget(new QLabel("字体大小"));//向工具栏添加标签ui->toolBar->addWidget(spinBoxFontSize);//向工具栏中添加字体的大小选择fontBox->setMinimumWidth(160);//设置字体样式组件的最小宽度ui->toolBar->addSeparator();//添加一个分割符ui->toolBar->addWidget(new QLabel("字体"));//向工具栏中添加字体ui->toolBar->addWidget(fontBox);//向工具栏中添加字体fileName->setMinimumWidth(180);//设置标签的最小宽度fileName->setText("当前文字");ui->statusbar->addWidget(fileName);//将标签添加到状态栏progressBar->setMinimum(8);//设置进度条的最小值,与字体的尺寸相对应progressBar->setMaximum(60);//设置进度条的最大值progressBar->setMinimumWidth(80);//设置进度条的最小宽度progressBar->setMaximumWidth(200);//设置进度条的最大宽度progressBar->setValue(ui->textEdit->fontPointSize());//用字体的大小来设置当前进度条的值ui->statusbar->addWidget(progressBar);//将进度条添加到状态栏}

运行结果:
在这里插入图片描述
OK我们的界面就全部完成了,这就是代码与ui设计器的结合,ok,接下来我们来实现功能!

四.完成界面的功能

1.对action配置信号槽

在这里有一个信号槽编辑器
在这里插入图片描述
这里可以进行信号槽的添加
对于信号和槽函数,qt内部都已经实现好的,才可以在这里直接进行配置。

在这里插入图片描述
这里我们就对剪切复制退出清空粘贴进行了添加
因为这些槽函数对应的接收者有对应的槽函数
对于action有一个共同的信号就是triggered触发器
在这里插入图片描述
运行结果:
在这里插入图片描述
点击清空就没了

在这里插入图片描述

2.对action转到信号槽

OK,接下来,就是我们想要实现的功能,qt组件内部没有对应的函数,那就只能我们手动去写了
但是还是有action的触发器信号
我们可以直接在action上点击转到槽
在这里插入图片描述
对于下划线,粗体,斜体因为有两种状态,我们用triggered(bool)这个信号。
在这里插入图片描述
新建的槽函:

void MainWindow::on_actionNew_triggered()
{ui->textEdit->clear();//将当前的文本清空fileName->setText("当前文件");//文件名也清空
}

打开文件的槽函数:

void MainWindow::on_actionOpen_triggered()
{//打开一个文件并获取路径QString FileName=QFileDialog::getOpenFileName(this,"打开一个文件");if(!FileName.isEmpty())//如果路径不为空{QFile file(FileName);//创建一个文件对象用路径名初始化if(file.open(QIODevice::ReadWrite|QIODevice::Text))//打开文件{QTextStream stream(&file);//创建一个文件流对象while(!stream.atEnd())//如果没有读到结尾{ui->textEdit->append(stream.readLine());//将读的每行添加到文件流中,然后尾部追加到文本编辑器中}fileName->setText("当前文件:"+FileName);//将当前的文件名进行修改}file.close();//关闭文件}}

3个字体样式的槽函数:

void MainWindow::on_actionBold_triggered(bool checked)
{auto format=ui->textEdit->currentCharFormat();//获取光标位置的字体样式format.setFontWeight(checked?QFont::Bold:QFont::Normal);//根据状态修改成粗体样式ui->textEdit->mergeCurrentCharFormat(format);//将修改后样式合并到字体样式中
}void MainWindow::on_actionItalic_triggered(bool checked)
{auto format=ui->textEdit->currentCharFormat();format.setFontItalic(checked);ui->textEdit->mergeCurrentCharFormat(format);
}void MainWindow::on_actionUnderLine_triggered(bool checked)
{auto format=ui->textEdit->currentCharFormat();format.setFontUnderline(checked);ui->textEdit->mergeCurrentCharFormat(format);
}

我注释写的这么详细,我就不讲了,如果有不懂的地方可以问我。
运行效果:
在这里插入图片描述
打开一个文件和3种样式可以完了,你们可以多玩玩,哈哈。

3.代码添加的组件手动关联槽函数

像我们自己手动添加的组件,我们必须要手动的关联和定义槽函数
字体大小和字体的样式本身有信号,所以不用我们进行手动的添加
先定义槽函数:

void on_spinBoxFontSize_valueChanged(int size);
void on_fontBox_currentIndexChanged(const QString & fontStyle);

然后关联:

void MainWindow::initSignalSlots()
{connect(spinBoxFontSize,SIGNAL(valueChanged(int)),this,SLOT(on_spinBoxFontSize_valueChanged(int)));connect(fontBox,SIGNAL(currentIndexChanged(const QString &)),this,SLOT(on_fontBox_currentIndexChanged(const QString &)));
}

最后实现槽函数:

void MainWindow::on_spinBoxFontSize_valueChanged(int size)
{QTextCharFormat format;format.setFontPointSize(size);//根据发来的信号设置文本的大小ui->textEdit->mergeCurrentCharFormat(format);//将字体大小合并到文本progressBar->setValue(size);//设置进度条的值}void MainWindow::on_fontBox_currentIndexChanged(const QString &fontStyle)
{QTextCharFormat format;format.setFontFamily(fontStyle);ui->textEdit->mergeCurrentCharFormat(format);
}

运行效果:
在这里插入图片描述
现在就可以尽情的玩耍了,功能都有了,你也试试看吧!

五.补充

1.样式选择问题

现在还是会有一点小bug,就是如果我点了斜体,粗体,下划线,我选择其他文本文字,他们的状态还是一直点着的。
我们可以用文本编辑器的一个转到槽,有个文本选择改变信号
在这里插入图片描述
实现槽函数:

void MainWindow::on_textEdit_selectionChanged()
{//先获取当前文本格式auto format=ui->textEdit->currentCharFormat();//根据当前的文本判断是否设置了样式ui->actionBold->setChecked(format.font().bold());ui->actionItalic->setChecked(format.fontItalic());ui->actionUnderLine->setChecked(format.fontUnderline());
}

效果:
在这里插入图片描述

2.复制粘贴剪切可选

现在有一个需求就是当我们选择文本才可以复制剪切
文本编辑器也有一个信号就是能否复制
在这里插入图片描述
实现槽函数:

void MainWindow::on_textEdit_copyAvailable(bool b)
{ui->actionCut->setEnabled(b);//如果可以复制就可以使用剪切ui->actionCopy->setEnabled(b);//如果可以复制就复制ui->actionPaste->setEnabled(ui->textEdit->canPaste());//如果可以粘贴的时候就设置可以
}

效果:
现在剪切和复制就用不了了,选中就又可以复制和剪切了。
在这里插入图片描述

3.图标

扩充内容,最后咱们来搞一个图标。
点击这里可以将图片转换成ico图标格式
然后保存到项目同目录下
在pro文件中加一个模块
在这里插入图片描述
等于后面与保存在同目录下的名字相同
在这里插入图片描述
顺便加一个窗口主题名:
在这里插入图片描述

运行结果:
在这里插入图片描述
帅呆了,太酷了!
哎呀,其他功能你们做好了,自己玩,我不想截图了…

六.总结

很明显,ui设计器的开发效率极快,但是有的界面只能用代码实现,如我们这个项目中,向工具栏和状态栏里面添加组件时,只能用代码来实现。
总的来说一句话:能用ui设计器的就尽量用,不能用的就用代码!

花了一天的时间,终于写完了,今天星期天,咱们的设计界面就完结撒花了,真的是太累了。确实接口有点多,容易记混,不过慢慢来,重要的是思想!
OK,就到这里吧!(* ̄︶ ̄)

这篇关于【qt】最快的开发界面效率——混合编程的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/984794

相关文章

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

SpringBoot中六种批量更新Mysql的方式效率对比分析

《SpringBoot中六种批量更新Mysql的方式效率对比分析》文章比较了MySQL大数据量批量更新的多种方法,指出REPLACEINTO和ONDUPLICATEKEY效率最高但存在数据风险,MyB... 目录效率比较测试结构数据库初始化测试数据批量修改方案第一种 for第二种 case when第三种

PowerShell中15个提升运维效率关键命令实战指南

《PowerShell中15个提升运维效率关键命令实战指南》作为网络安全专业人员的必备技能,PowerShell在系统管理、日志分析、威胁检测和自动化响应方面展现出强大能力,下面我们就来看看15个提升... 目录一、PowerShell在网络安全中的战略价值二、网络安全关键场景命令实战1. 系统安全基线核查

Qt使用QSqlDatabase连接MySQL实现增删改查功能

《Qt使用QSqlDatabase连接MySQL实现增删改查功能》这篇文章主要为大家详细介绍了Qt如何使用QSqlDatabase连接MySQL实现增删改查功能,文中的示例代码讲解详细,感兴趣的小伙伴... 目录一、创建数据表二、连接mysql数据库三、封装成一个完整的轻量级 ORM 风格类3.1 表结构

Qt QCustomPlot库简介(最新推荐)

《QtQCustomPlot库简介(最新推荐)》QCustomPlot是一款基于Qt的高性能C++绘图库,专为二维数据可视化设计,它具有轻量级、实时处理百万级数据和多图层支持等特点,适用于科学计算、... 目录核心特性概览核心组件解析1.绘图核心 (QCustomPlot类)2.数据容器 (QCPDataC

Go语言数据库编程GORM 的基本使用详解

《Go语言数据库编程GORM的基本使用详解》GORM是Go语言流行的ORM框架,封装database/sql,支持自动迁移、关联、事务等,提供CRUD、条件查询、钩子函数、日志等功能,简化数据库操作... 目录一、安装与初始化1. 安装 GORM 及数据库驱动2. 建立数据库连接二、定义模型结构体三、自动迁

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

Qt如何实现文本编辑器光标高亮技术

《Qt如何实现文本编辑器光标高亮技术》这篇文章主要为大家详细介绍了Qt如何实现文本编辑器光标高亮技术,文中的示例代码讲解详细,具有一定的借鉴价值,有需要的小伙伴可以了解下... 目录实现代码函数作用概述代码详解 + 注释使用 QTextEdit 的高亮技术(重点)总结用到的关键技术点应用场景举例示例优化建议