QT界面开发--我的第一个windows窗体【菜单栏、工具栏、状态栏、铆接部件、文本编辑器、按钮、主界面】

news2025/1/10 14:07:40

经过前面的铺垫,今天我们就开始我们图形化界面之旅了,我们的第一个窗体主要包括:菜单栏、状态栏、工具栏、铆接部件、还有Qt提供的一些主窗体的API。

第一部分:主界面(QMainWindow)

当创建好项目后,我们直接运行,看一下运行结果:

86a3d50e8d294b42afe094155642af4e.png

你会发现,这个界面是小小的一坨,看起来一点也不舒服,那我们就可以使用resize()方法来更改界面尺寸。代码如下:

MainWindow::MainWindow(QWidget *parent)
    : QMainWindow(parent)
{
    this->resize(600,400);//将界面尺寸设置为600*400
}

008d1d1b075045a2b59c475f92e574b7.png

 此时大小的问题我们解决了,如果我们不想这个尺寸被更改,我们可以使用,将窗体的尺寸固定

setFixedSize(this->size());//将当前大小固定

 然后还有一个问题就是这个窗体的标题不是我们想要的,我们如何改成我们想要的标题呢?

setWindowTitle("Stark系统");//设置窗体标题

49c227f1ed4f4b269226aa131d7fd591.png

设置之后,界面就是现在的效果了。更多内容可以查看Qt自带的帮助文档。

6bc7600bca2543b8b2ee911ee95b8ad3.png

第二部分:菜单栏 (QMenuBar)

菜单栏(QMenuBar)是用于在应用程序的窗口顶部显式菜单的组件。一般一个窗口最多拥有一个菜单栏。我们的菜单栏的设置需要有以下几个步骤:

1.在主窗口创建菜单栏

如果我们选择使用 QMenuBar * mBar=new QMenuBar(this); 的话,设置出来的菜单栏没有任何设置,非常的丑陋,要我们亲自去设计也可以,那就非常麻烦,所以Qt就为我们提供了一套方法:

    // //第一步:创建菜单栏并接收
    QMenuBar * menuBar = menuBar();
    // //第二步:将菜单栏设置到该窗口内
    setMenuBar(menuBar);

设置好后点击运行,没有出现任何改变,不要慌张,不要着急,这是因为菜单栏中什么也没有。我们需要添加菜单项在菜单栏中。

2.添加菜单到菜单栏 

使用QMenu来创建菜单,然后将其添加到菜单栏。主要的流程如下:

    // //第三步:创建菜单项
    QMenu * fileMenu=new QMenu("文件");
    QMenu * editMenu=new QMenu("编辑");
    QMenu * helpMenu=new QMenu("帮助");
    // //第四步:将菜单项加到菜单栏中
    menuBar->addMenu(fileMenu);
    menuBar->addMenu(editMenu);
    menuBar->addMenu(helpMenu);

这样的话,我们就创立了三个菜单项:文件、编辑、帮助。并添加到了菜单栏menuBar中 。此时看一下运行的效果是怎样的:

916fe8d36a59446d99c7cdf726aa084f.png

ok,此时窗体中就有了一个菜单栏,其中的菜单项根据你的实际需求进行添加。我们可以对比一下Qt的菜单栏:

9ca4f8dd71914672a6165c5e4f798983.png

 Qt界面提供了九个菜单项。每个菜单项下又有一些子项,这些子项是什么?这些子项被称为动作。类型是QAction。

3.添加动作到菜单

我们可以声明几个动作来放到文件菜单下:

    // //第五步;创建活动项
    QAction * newAction=new QAction("新建文件");
    QAction * openAction=new QAction("打开文件");
    QAction * saveAction=new QAction("保存文件");
    // //第六步:将活动项加到菜单项下
    fileMenu->addAction(newAction);
    fileMenu->addAction(openAction);
    fileMenu->addAction(saveAction);

此时我们的【文件】菜单下就有了新建文件、打开文件、保存文件三个动作。这些动作实际起作用其实就需要我们使用connect来进行组件之间的信号与槽的关联。

除此以外,我们还可以添加分隔符、子菜单:

    //第七步:添加分隔符与子菜单
    fileMenu->addSeparator();
    fileMenu->addMenu(new QMenu("无效项"));

此时我们的运行观察结果:

c7128ce138dc4b4ca1838f8ba82e7914.png

ok,越来越像样了。

在这里,我们需要注意的是,千万不要忘了引用头文件

#include <QMenuBar>
#include <QMenu>
#include <QAction>

实际上我们只需要引用第一个就可以了。

第三部分:工具栏(QToolBar)

工具栏(QToolBar)是一个可用于放置常用操作和功能按钮的界面组件,通常位于主窗口的顶部或侧边。工具栏可以显著提高用户体验,是的常用功能更易访问。

万事开头都是头文件:这次我们需要添加#include <QToolBar>

1.在主窗口创建工具栏

添加工具栏时我们直接使用new即可:

    //第一步:创建工具栏并接收
    QToolBar * toolBar=new QToolBar();

    //第二步:添加工具栏至该窗口
    //addToolBar(toolBar);
    addToolBar(Qt::ToolBarArea::LeftToolBarArea,toolBar);//设置默认停靠区域:左部
    //addToolBar(Qt::ToolBarArea::TopToolBarArea,tbar2);//设置默认停靠区域:顶部
    toolBar->setMovable(false);//固定区域,不可移动
    //tbar2->setFloatable(false);//不可悬浮,必须停靠某个区域

在第二步中我们可以看到我们使用的是addToolBar将工具栏toolBar添加到该窗口,这是因为,窗口中理论上最多只有一个菜单栏,所以使用set设置,工具栏可以有多个,所以使用add,这是非常讲究的。对于该接口,如果我们只传工具栏对象指针,默认将工具栏停靠在窗口上方,但我们可以多传一个参数来确定工具栏的默认停靠位置:

Qt::ToolBarArea::LeftToolBarArea,代表默认停靠在窗口的左侧,对应的还有上、下、右。为什么称为默认停靠区域呢?显然,工具栏可以拖拽,浮动。我们可以选择不让他浮动在窗口,必须停靠在窗口的一边,这个是QToolBar的接口:setFloatable(false),将浮动的(Floatable)属性设置(set)为false,也就是不可浮动。我们也可以选择不允许移动该工具栏:setMovable(false)。

2.添加动作到工具栏

工具栏上可以拥有一些动作,这些动作其实就是菜单下的动作,只不过这些动作比较常用,我们就将其单独列到工具栏,方便用户交互。当然,我们也可以添加一些菜单栏中的菜单中所没有的动作,这不违反语法和规定,这是允许的。下面我们看一下如何添加动作呢?其实与在菜单中添加动作一样(你可以理解为:一个菜单项就是一个折叠起来的工具栏)。

    //第三步:添加工具栏选项
    QAction* debugAction=new QAction("调试");
    QAction* helpAction=new QAction("帮助");
    //第四步:将选项加载至工具栏
    toolBar->addAction(debugAction);
    toolBar->addAction(helpAction);

此时来看一下运行效果:

dc80d8fd5fd34ceeb21bb6dc3cf3d83e.png

 当然,工具栏中也可以添加一些分隔符和一些像按钮一样的组件:

    toolBar->addSeparator();
    QPushButton *exitBtn = new QPushButton("退出",this);
    toolBar->addWidget(exitBtn);

再看效果图:

3b6ac7d26ce0424db93f5ff2a0dccf39.png

分隔符的存在是为了将不同的功能进行划分,而按钮的存在其实与动作的效果类似,只是进行connect时访问的信号不同,例如:

    //点击自添加退出按钮后,关闭窗口
    connect(exitBtn,&QPushButton::clicked,this,&QWidget::close);
    
    QMessageBox * msg=new QMessageBox(this);
    msg->setWindowTitle("提示");
    msg->setText("功能丰富,随便用。");
    
    //引发动作后,将弹出消息提示框
    connect(helpAction,&QAction::triggered,msg,&QWidget::show);

我们点击按钮时,触发的信号是点击:clicked。而动作不同,我们触发的信号是引发:triggered。

此外,二者也有其他的区别,比如按钮可以设置更的属性动作设置不了,类似背景色等的东西。

我们试着运行一下,测试效果:

17e2e1fbae0a4a838a1ca4c4fa42c819.png

点击退出后,窗口确实随之关闭了。

第四部分:状态栏(QStatusBar)

状态栏 (QStatusBar) 是一个用于显示应用程序当前状态的信息的组件,通常位于主窗口的底部。状态栏可以用来显示消息、进度信息或应用程序的状态等。一般一个窗口最多拥有一个状态栏。

创建状态栏的基本步骤:

前提:引用头文件:#include <QStatusBar>

1.在主窗口创建状态栏

创建状态栏也是new出来的。由于状态栏一般只有一个,所以我们添加的方法是set而非add。

    //第一步:建立状态栏
    QStatusBar * stBar=new QStatusBar();
    //第二步:设置到窗口
    setStatusBar(stBar);

 2.添加标签到状态栏

我们添加一个提示信息的标签,这是一个固定的信息,除非后续我们使用setText("");为标签的Text属性进行修改,我们的标签文本内容就是固定的了。创建时也是new,添加时我们使用添加组件的方法addWidget即可,将label组件加入即可。默认将标签设置到状态栏左侧,可以额外传入一个int类型的参数e4589aaa4e6a4b6cab041092962a4cc5.png。进行拉伸的话,默认的位置就会发生变动。如果使用addPermanentWidget方法,默认位置则是右侧,也可以传入int类型的参数,效果与前者相反。

    //第三步:添加标签
    QLabel * label_hint=new QLabel("系统提示信息:");

    //第四步:设置标签位置
    stBar->addWidget(label_hint);//默认放到左侧
    //stBar->addPermanentWidget(label_hint);//默认放到右侧

当然,我们也可以添加其它的小部件:如进度条、按钮等。

3.添加消息到状态栏

我们可以使用showMessage方法向状态栏显示一条消息:

stBar->showMessage("欢迎使用Stark系统!", 5000); // 消息显示5秒 

37135c559b3649a28761dd02eabd9f3e.png

 第四部分:文本编辑器

在窗口中心设置一个文本编辑器。

    //设置中心部件
    QTextEdit *textEdit=new QTextEdit(this);
    setCentralWidget(textEdit);

 af2abb38009f41abade6eb085efedef1.png

此时我们就可以在窗口内输入一些信息,如果我们对【保存文件】动作和 保存文本信息 进行信号与槽的连接的话,我们就实现了一个简单的word编辑器,当然了我们还需要对文本进行字体大小、色彩、背景、等东西进行修改才能逐步完善。但此时,我们已经有很大的进步了。

 第五部分:铆接部件

    QDockWidget *dockWidget=new QDockWidget("这是一个浮动窗口",this);
    addDockWidget(Qt::BottomDockWidgetArea,dockWidget);//默认停靠下方
    dockWidget->setAllowedAreas(Qt::BottomDockWidgetArea|Qt::TopDockWidgetArea);//只能上下停靠
    //dockWidget->setAcceptDrops(false);//不接受拖拽

 铆接部件是一个浮动窗口

ee002bff562c412db6ab95f9a63b11a9.png

如果在浮动窗口中加入一些功能,是不是感觉布局与VS有点像了呢?当然了,只是现在界面外表低配,只有实现connect以及自定义或提供的一些方法信号才能实现更强大的功能。


感谢观看

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/2227741.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Docker镜像的创建、修改与导出

Docker镜像的创建、修改与导出 前言一、创建Docker镜像1. 基于已有镜像创建方法一:修改现有镜像方法二:使用Dockerfile通过源码编译安装nginx二、修改Docker镜像1. 基于已有镜像创建新镜像方法一:修改现有镜像2. 使用`docker commit`命令创建新镜像方法一:提交正在运行的容…

3GPP协议解读_NTN系列(一)_38.811_非地面网络(NTN)的背景、应用场景和信道建模

非地面网络 1. Scope4. 非地面网络背景介绍4.1 5G中的非地面网络4.2 非地面网络在5G中的用例4.3 卫星和空中接入网的架构4.4 卫星和空中接入网终端的特点4.5 空气/星载飞行器特性4.6 NTN的覆盖模式4.7 NTN网络架构选项4.8 频谱 5. 非地面网络应用场景5.1 应用场景概览5.2 属性介…

基于SSM+小程序的智慧旅游平台登录管理系统(旅游2)

&#x1f449;文末查看项目功能视频演示获取源码sql脚本视频导入教程视频 1、项目介绍 旅游平台开发微信小程序功能有管理员和用户。 1、管理员功能有个人中心&#xff0c;用户管理&#xff0c;景点分类管理&#xff0c;旅游景点管理&#xff0c;景点购票管理&#xff0c;景…

函数式接口与回调函数实践

函数式接口与回调函数实践 一、Java 的函数式接口 是指仅包含一个抽象方法的接口&#xff0c;通常用于 lambda 表达式或方法引用。Java 8 引入了很多内置的函数式接口&#xff0c;比如 Runnable、Callable、Predicate、Function、Consumer 等 演示&#xff0c;数据类型转换的函…

小米迎来「新起点」:硬核创新从超越到引领,小米SU7 Ultra 发布

发布 | 大力财经 10月29日&#xff0c;小米15系列暨小米澎湃OS 2新品发布会在北京召开&#xff0c;小米集团创始人、董事长兼CEO雷军宣布了小米汽车原型车在纽北跑出6分46秒874的圈速&#xff0c;登顶“纽北全球最速四门车”的好消息&#xff0c;并领衔发布了小米15系列手机、…

Go语言优秀的web框架推荐-酒香也怕巷子深 好的框架也需要宣传

温馨提示&#xff1a;我们分享的文章是给需要的人&#xff0c;不需要的人请绕过&#xff0c;文明浏览&#xff0c;误恶语伤人&#xff01; 前言 俗话说得好“酒香也怕巷子深”&#xff0c;好的东西不宣传也不能让大家知晓&#xff01;需要的人无法获取好的东西&#xff0c;好…

双十一特辑,解决铲屎官难题——性价比高的宠物空气净化器推荐

谁家好人受得了猫咪这么掉毛啊&#xff01;最近换季&#xff0c;掉毛情况越发严重&#xff0c;家里都快被毛发淹没了。每天下班回来&#xff0c;第一件事就是清扫一地的猫毛。那就算了&#xff0c;一呼吸还收获一鼻子浮毛&#xff0c;又是沉重一击&#xff0c;这日子快要没法过…

如何在 Windows 上安装 Python:一步一步的指南

Python 已成为 当今最受欢迎的编程语言之一&#xff0c;在商业的各个领域中广泛应用。开发者使用 Python 构建应用程序和开发网站&#xff0c;而数据工程师则使用 Python 进行数据分析、统计分析以及构建机器学习模型。 检测是否已安装Python 默认情况下&#xff0c;Windows …

自动驾驶-传感器简述

自动驾驶车辆上的传感器类型包含激光雷达、毫米波雷达、相机、imu、rtk、超声波雷达等&#xff0c;这些传感器用来接收外部世界多姿多彩的信号&#xff0c;根据接收到的信号&#xff0c;车载大脑对信号进行处理&#xff0c;那信号的准确程度就尤为重要。 本文将各个传感器的特性…

文本列的性能优化?深入Oracle全文索引

一.什么是全文索引&#xff1f; 全文索引通过分析和处理文本&#xff0c;将文档中的单词分解为词条&#xff08;tokens&#xff09;&#xff0c;然后存储词条与其所在文档的映射关系。这使得数据库可以快速定位包含特定关键字的记录&#xff0c;而不必对所有文本逐字匹配。 二…

解决IllegalAccessException: java.lang.Class<xxx.xActivity> is not accessible

异常信息 Caused by: java.lang.IllegalAccessException: java.lang.Class<com.xxx.xActivity> is not accessible from java.lang.Class<android.app.AppComponentFactory>at java.lang.Class.newInstance(Native Method)at android.app.AppComponentFactory.inst…

基于spootboot学生选课系统设计与实现

资料下载 https://download.csdn.net/download/qq_63753925/89888794 https://download.csdn.net/download/qq_63753925/89888793 https://download.csdn.net/download/qq_63753925/89885091 https://download.csdn.net/download/qq_63753925/89882320 摘 要 近年来&#xf…

计算机网络IP地址分类,子网掩码,子网划分复习资料

IP 地址的概念 IP 地址是独立于硬件地址的逻辑地址&#xff0c;它是由软件提供的地址。 IP 地址是网络层地址。 IP 编址方案和分类 IP 地址由 32 位二进制数构成&#xff0c;分为前缀(网络地址)和后缀(主机地址) 同一网段中每台计算机的 IP 地址是唯一的网络地址的分配全球…

山海鲸报表VS微软Power BI:哪个报表工具更适合企业?

在当今数据驱动的商业环境中&#xff0c;选择一款合适的报表工具对企业至关重要。山海鲸报表和微软Power BI都是广受欢迎的报表工具&#xff0c;但两者在功能、用户体验和应用场景上各有不同。那么&#xff0c;在实际使用中&#xff0c;究竟哪款工具更能满足企业需求呢&#xf…

【电子通识】四线制电阻屏怎么判断是哪一路出现异常?

在文章【电子通识】四线电阻屏原理中我们聊了一下四线电阻屏触摸的原理,如电阻屏结构、如何计算坐标等方面。 那么在实际的问题分析中,如果是屏硬件问题,那我们如何去判断到底是X还是Y出现异常或是说X+还是X-,是Y+还是Y-出现问题呢? 首先要知道,XY轴为什么会出问题,其实…

Linux基础环境搭建(CentOS7)- 安装Scala和Spark

#Linux基础环境搭建&#xff08;CentOS7&#xff09;- 安装Scala和Spark Linux基础环境搭建&#xff08;CentOS7&#xff09;- 安装Scala和Spark 大家注意以下的环境搭建版本号&#xff0c;如果版本不匹配有可能出现问题&#xff01;&#xff08;spark不要下2.4版本的 会报错…

EPLAN创建宏并自定义部件库详细案例操作(二)

#通过导入EDZ格式部件库的样式,模仿制作一个自定义的部件库# 续 EPLAN创建宏并自定义部件库详细案例操作(一) 需要宏文件(欧姆龙2D/3D),可以在此下载。 https://download.csdn.net/download/weixin_44166380/89933112 三、PLC地址编址 实际上,本操作可以忽略,但是如果…

国产系统安装Oracle报错处理

1.调用图形界面报错&#xff1a;已拒绝X11转移申请 解决方法&#xff1a;修改/etc/ssh_config 和/etc/sshd_config &#xff1a;X11Forwarding yes中和x11里no改为yes 2.开始安装./runInstaller提示 /u01/app/oracle/product/19.3.0.0/db_1/perl/bin/perl: error while loadi…

黑马数据库学习笔记

课程地址 &#xff08;基础篇&#xff09;MySQL的启动 mysql 默认使用 3306 端口 在 centos下&#xff0c;启动 mysql 数据库&#xff1a;service mysqld start; 查看状态/启动/停止/重启&#xff1a;systemctl status/start/stop/restart mysqld; 登录到mysql数据库&…

20241027_北京郊游香山公园

这次是第二次去香山公园&#xff0c;天气不是很晴朗&#xff0c;有雾。 乘坐地铁到的时候&#xff0c;第一趟车&#xff0c;我这么聪明&#xff0c;那肯定是不会坐的&#xff0c;因为没有座位&#xff0c;路程30多分钟&#xff0c;我都20多岁了&#xff0c;身体那肯定顶不住。 …