【QT5】<总览三> QT常用控件

news2024/11/20 15:21:52

文章目录

前言

一、QWidget---界面

二、QPushButton---按钮

三、QRadioButton---单选按钮

四、QCheckBox---多选、三选按钮

五、margin&padding---边距控制

六、QHBoxLayout---水平布局

七、QVBoxLayout---垂直布局

八、QGridLayout---网格布局

九、QSplitter---分裂器

十、QSpacerItem---隔离弹簧

十一、QLineEdit---用户输入框

十二、QDialog---对话框

十三、QScrollArea---界面滚动

十四、QTabWidget---面板切换

十五、QListWidge---列表界面


前言

承接【QT5】<总览二> QT信号槽、对象树及样式表。若存在版权问题,请联系作者删除!


一、QWidget---界面

1. 介绍:是所有用户界面对象的父类。例如:QLabel、QPushButton等。常用于做顶层窗口或子部件。

2. 使用示例:


二、QPushButton---按钮

1. 作用:按钮,可以检测用户的点击而进行相关操作。当选中checkable属性时,能够作为一种按压式的开关按钮。

2. 四种信号函数:

void clicked(bool checked=false)点击并松手
void pressed()点击按钮
void released()松开按钮
void toggled(bool checked)按压式开关,第一次点击为true,第二次点击为false。使用时需要添加"ui->pushButton->setCheckable(true);"语句

3. 设计一个灵活的按钮:

需求:该按钮有个默认状态的皮肤;当鼠标划过时切换为另一个状态;当鼠标点击时切换为另一个状态;当鼠标点击一次后划过时切换为另一个状态。

步骤一:获取素材并导入QT中:

步骤二:在ui设计器中将pushButton拖拽至界面,并且设置好合适的大小:

步骤三:写qss文件,将四种状态的图片加载:

运行结果:

【注意】若运行QT时加载不出图片,要注意是否修改了原图片的格式!


三、QRadioButton---单选按钮

1. 作用:单选按钮。将一些QRadioButton按钮添加到一个组后,与其他组的按钮就隔离开,同时该组内的QRadioButton按钮只能单选。(多选我们一般用QCheckBox)

2. 案例演示:

【1】需求:设计两组单选按钮,分别选择性别和科目。两组按钮分别选中后右击以添加到独立的两个按钮组,以隔绝开选择。

【2】核心板块:

①ui设计:

②样式表文件:

QLabel {font-size: 30px}

QRadioButton::indicator:checked#radioButton {border-image: url(:/images/check.png);}
QRadioButton::indicator:unchecked#radioButton {border-image: url(:/images/uncheck.png);}
QRadioButton::indicator:checked#radioButton_2 {border-image: url(:/images/check.png);}
QRadioButton::indicator:unchecked#radioButton_2 {border-image: url(:/images/uncheck.png);}

QRadioButton::indicator#radioButton_3 {width: 0px;}
QRadioButton::checked#radioButton_3 {background-color: rgb(107, 173, 87); border-radius: 8px; color: White;}
QRadioButton::unchecked#radioButton_3 {background-color: Yellow; border-radius: 8px;}

QRadioButton::indicator#radioButton_4 {width: 0px;}
QRadioButton::checked#radioButton_4 {background-color: rgb(107, 173, 87); border-radius: 8px; color: White;}
QRadioButton::unchecked#radioButton_4 {background-color: Yellow; border-radius: 8px;}

QRadioButton::indicator#radioButton_5 {width: 0px;}
QRadioButton::checked#radioButton_5 {background-color: rgb(107, 173, 87); border-radius: 8px; color: White;}
QRadioButton::unchecked#radioButton_5 {background-color: Yellow; border-radius: 8px;}

QRadioButton::indicator#radioButton_6 {width: 0px;}
QRadioButton::checked#radioButton_6 {background-color: rgb(107, 173, 87); border-radius: 8px; color: White;}
QRadioButton::unchecked#radioButton_6 {background-color: Yellow; border-radius: 8px;}

【3】运行结果:


四、QCheckBox---多选、三选按钮

1. 作用:多选、三态选择按钮。

2. 三态设定:针对一个选项有选中半选未选中,需要将QCheckBox属性中的trstate勾选,如下图:

3. 多选设定:针对一个组,可以同时选择多个选项,需要将按钮组的exclusive取消勾选,如下图:

4. 常用信号函数:stateChanged(int)。当参数为0时,表示未选;参数为1时,表示半选;参数为2时,表示选中。

5. 三态选择时的样式表:

QCheckBox::indicator:unchecked {...}//未选中
QCheckBox::indicator:indeterminate{...}//半选中
QCheckBox::indicator:checked {...}//选中

五、margin&padding---边距控制

1. 概念:

  • margin:一个控件的边框到另一个控件的边框的距离,属于容器外部距离(外边距)
  • padding:自身边框到自身内部另一个容器边框之间的距离,属于容器内距离(内边距)

2. 常用的样式表:

QPushButton{
	margin: 0px;            //上下左右的外边距
	margin-top: 100px;      //顶部的外边距
	margin-bottom: 50px;    //底部的外边距
	margin-left: 5px;       //左边的外边距
	margin-right: 10px;     //右边的外边距

    border-width: 5px;      //描边上下左右的宽度5px
	border-color: black;    //描边的颜色
	border-style: solid;    //描边风格:solid为实心填充

    padding-top: 100px;     //内边距:距离容器顶部其他部分
	padding-bottom: 100px;  //内边距:距离容器底部其他部分
}

六、QHBoxLayout---水平布局

1. 作用:水平布局,联合控制多个控件的水平布局。

2. 重要属性:

  • layoutSpacing:控制控件间距离
  • layoutStretch:控制控件的拉伸因子
  • sizePolicy:控制大小策略

3. 实例说明:

运行时发现:扩大或缩小界面,这些控件不会跟着变化。要想跟着变化,需要在widget.cpp的构造函数中添加"this->setLayout(ui->horizontalLayout);"。


七、QVBoxLayout---垂直布局

垂直布局:与水平布局QHBoxLayout类似,只是换成了垂直方向。水平布局和垂直布局都可以多层嵌套使用,用于规范界面和保证缩放界面的比例关系。


八、QGridLayout---网格布局

1. 作用:网格布局(栅格布局)

2. 说明:与水平、垂直类似,只是以网格的形式来规范控件。


九、QSplitter---分裂器

1. 作用:分裂器。使一个界面中间的线条左右/上下拖动来控制分界面的大小。

2. 重要属性:

  • orientation:设置水平或垂直方向。
  • opaqueResize:为true时,实时更新子控件大小;为false时,拖动时显示灰色线条,拖动到位并释放鼠标后再显示分割线条。
  • handleWidth:设置分割线的宽度。
  • childrenCollapsible:勾选后用户可以将子部件的大小调整为0.

3. 注意事项:

  • 若不想拖动时将子部件拖至0,不仅需要取消勾选childrenCollapsible,还需要设置子部件的最小宽度/高度。
  • 若想让QSplitter和子控件随着屏幕大小而改变,可以将整个QSplitter塞到水平布局QHBoxLayout,然后在构造函数中设置相关布局。


十、QSpacerItem---隔离弹簧

1. 作用:隔离弹簧。配合布局使用,控制控件之间的距离。

2. 注意事项:

  • 在ui设计器里会有弹簧的样子出现,但实际运行则不会显示。

十一、QLineEdit---用户输入框

1. 作用:用户键盘输入控件。

2. 实例演示:

【1】需求:制作一个仿QQ登录界面。

【2】核心部分展示:

①ui设计器:

②演示表文件:

QPushButton#pushButton {
    border-image: url(:/down.png);
}

QPushButton#pushButton_2 {
    border-image: url(:/right.png);
}

QWidget#Widget {
    background-color: White;
}

QWidget#widget1 {
    background-color: Grey;
}

QWidget#widget1_2 {
    background-color: Grey;
}

QLineEdit {
    border: none;
}

【3】运行展示:


十二、QDialog---对话框

1. 作用:对话框。

2. 创建及使用:

//头文件中声明
QDialog *diaglog;

//源文件中构造器中实例化
dialog = new QDialog(this);

//弹出后不可再点击原先界面
dialog->setModal(true);

//显示对话框
dialog->show();

//设置无边框
dialog->setWindowFlag(Qt::FramelessWindowHint);

//设置透明,可用于上层圆角控件显示
dialog->setAttribute(Qt::WA_TranslucentBackground);

3. 制作支付对话框:

【1】注意:创建项目时以QDialog为父类。

【2】ui设计器:由于QDialog无法通过border-radius来设置圆角边框,因此将QDialog设置为透明并且上层使用QFrame。

【3】主要的控件样式表:

①按钮:两个按钮的样式表类似,只是圆角的位置不同,因此只展示左边按钮的样式表。设置按钮圆角及边缘线宽度和实线类型,设置按压按钮时颜色变为灰色。

QPushButton {
	color: rgb(30, 144, 255);
	border-top: 1px;
	border-right: 1px;
	border-style: solid;
	border-color: Grey;
}

QPushButton:pressed {
	background-color: Grey;
	border-bottom-left-radius: 25px;
}

②QFrame:设置圆角以及背景为白色。

QFrame {
	border-radius: 25px;
	background-color: White;
}

【4】运行结果:由于我们设定了“取消”和“确定”按钮的槽,使其在点击后就会关闭当前对话框。


十三、QScrollArea---界面滚动

1. 作用:界面滚动。

2. 注意事项:

  • 只有当QScrollArea的宽度或高度超出原有界面时,才会出现横向或纵向滚动条。
  • 若不想使用滚动条,可以将下图中的属性设置为“关”。

3. 实例演示:

【1】需求:设计一个能滚动的界面,且只有滚动条,没有上下的按键。

【2】ui设计器:

【3】QScrollArea控件的样式表:①修改了滑块的颜色、宽度;②取消了上下两个按键;③鼠标停留则滑块颜色加深。

QScrollBar:vertical {
     background-color: White;
	 width: 20px;
 }

 QScrollBar::handle:vertical {
    background: rgba(200,200,200,50%);
	border-radius: 10px;
 }

 QScrollBar::handle:vertical:hover {
    background: rgba(200,200,200,90%);
	border-radius: 10px;
 }

 QScrollBar::add-line:vertical {
    width: 0px;
	height: 0px;
 }

 QScrollBar::sub-line:vertical {
    width: 0px;
	height: 0px;
 }

十四、QTabWidget---面板切换

1. 作用:面板切换。

2. 实例演示:

【1】需求:与QListWidget配合,在QListWidget中点击对应项,QTabWidget跳转界面。

【2】ui设计器:

【3】关键控件的样式表:

①QListWidget:设置了背景色、取消了外边框、设置了选中项时的背景和字体颜色。

 QListView {
	background-color: rgba(170,170,170, 50%);
	color: black;
	border: none;
}

QListView::item:selected {
	background-color: White;
	color: black;
}

②QTabWidget:隐藏了默认的标签,取消了外边框。

QTabBar::tab {
	width: 0px;
	height: 0px;
}

QTabWidget{
		border: none;
}

【4】注意问题:运行时默认会有一个蓝色框选中QListWidget的第一个项。要取消这样的选中,需要在属性focusPolicy中选择NoFocus。


十五、QListWidge---列表界面

1. 作用:列表界面。列表中的项可以动态增加、删除等操作。

2. 常用函数:

//假设创建了QListWidget对象listWidget
//新增项
listWidget->addItem("张三");
listWidget->addItem("李四");
listWidget->addItem("王五");

//删除项
listWidget->takeItem(0);

//插入项,在前面插入
listWidget->insertItem(0, "张三");

//槽currentRowChanged(int currentRow)中获取列表项目编号和内容
listWidget->item(currentRow)->text()

3. 仿QQ好友列表制作:

【1】ui设计器:

①qqItem.ui:由三部分组成,左边将两个QLabel放置于QWidget上,用于显示头像和手机图标;右边的QLabel显示网名。

②widget.ui:显示主要的QListWidget界面。

【2】主要技术点:新建qqitem.ui和qqitem.cpp,将qqitem对象放置于QWidget的项当中。

qqitem.cpp中的构造函数:

QQitem::QQitem(QString path, bool isShow, QString name, QWidget *parent) :
    QWidget(parent),
    ui(new Ui::QQitem)
{
    ui->setupUi(this);
    //加载头像
    QImage image(path);
    ui->head->setPixmap(QPixmap::fromImage(image.scaled(ui->head->width(), ui->head->height())));
    //加载手机图标
    QImage image2(":/phone.png");
    ui->phone->setPixmap(QPixmap::fromImage(image2.scaled(ui->phone->width(), ui->phone->height())));
    ui->phone->setVisible(isShow);
    //加载名字
    ui->name->setText(name);
}

Widget.cpp中的构造函数:

Widget::Widget(QWidget *parent)
    : QWidget(parent)
    , ui(new Ui::Widget)
{
    ui->setupUi(this);
    this->setLayout(ui->verticalLayout);

    //创建QQItem对象
    QQitem *qq0 = new QQitem(":/wsl.png", true, "小清新");
    QQitem *qq1 = new QQitem(":/hqr.jpg", true, "Emiya Shirou");

    //加入listWidget中
    QListWidgetItem *item0 = new QListWidgetItem;
    QListWidgetItem *item1 = new QListWidgetItem;
    ui->listWidget->addItem(item0);
    ui->listWidget->addItem(item1);
    ui->listWidget->setItemWidget(item0, qq0);
    ui->listWidget->setItemWidget(item1, qq1);
}

【3】注意事项:qqitem.ui中设计其长度时需要注意与QListWidget保持一致,否则加载不了!

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

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

相关文章

【简单讲解TalkingData的数据统计】

🎥博主:程序员不想YY啊 💫CSDN优质创作者,CSDN实力新星,CSDN博客专家 🤗点赞🎈收藏⭐再看💫养成习惯 ✨希望本文对您有所裨益,如有不足之处,欢迎在评论区提出…

基于51单片机的智能晾衣架设计资料

第三章:硬件单元电路 经过上述分析明确了本次设计的主要目标,为了实现晾衣自身能够完成对外界数据的采集与分析,集成控制环节我们采用了ATMEL公司生产的AT89C52单片机,与市面上的其他嵌入式控制单元相比较在体积与功耗方面都相当出色。此次设计主要突破在于设计合理的控制电…

Go微服务: 基于rocketmq:5.2.0搭建RocketMQ环境,以及示例参考

概述 参考最新官方文档:https://rocketmq.apache.org/zh/docs/quickStart/03quickstartWithDockercompose以及:https://rocketmq.apache.org/zh/docs/deploymentOperations/04Dashboard综合以上两个文档来搭建环境 搭建RocketMQ环境 1 ) 基于 docker-c…

Springboot框架开发与实用篇之热部署 2024详解

开发与实用 手动启动热部署 热部署(Hot Deployment)指的是在应用程序正在运行的情况下,对其进行更新或修改并将这些变更应用到正在运行的应用程序中的过程。通常情况下,传统的部署方式需要停止应用程序、部署更新,然…

Prompt 指南之零样本与少样本提示,超详细解析!

前言 我将在本文中为你带来另外 2 种提示技术,它们分别是: 零样本提示(Zero-shot Prompting)少样本提示(Few-shot Prompting) shot 即代表示例 这两种技术利用 LLM 的强大预训练知识,通过最小…

【MyBatis】零基础从入门到进阶(源码级深入详解)

1 MyBatis概述 1.1 框架 ● 在⽂献中看到的framework被翻译为框架 ● Java常⽤框架: ○ SSM三⼤框架:Spring SpringMVC MyBatis ○ SpringBoot ○ SpringCloud ○ 等。。 ● 框架其实就是对通用代码的封装,提前写好了⼀堆通用…

上位机图像处理和嵌入式模块部署(f407 mcu中的单独上位机烧录方法)

【 声明:版权所有,欢迎转载,请勿用于商业用途。 联系信箱:feixiaoxing 163.com】 前面我们说过,stm32有三种烧录方法,一种是st-link v2,一种是dap,一种是j-link。不过我们在实际操作…

LLaMA-Factory实战推理

LLaMA-Factory官网:https://github.com/hiyouga/LLaMA-Factory 安装环境 git clone https://github.com/hiyouga/LLaMA-Factory.git cd LLaMA-Factory/ conda create -n py310 python3.10 conda activate py310按照llama-factory要求的标准格式组织数据集&#xff…

【UML用户指南】-01-UML基本元素的介绍(一)

目录 1、UML的词汇表 2、UML的4种事物 2.1、结构事物 1)类 2)接口 3)协作 4)用例(use case) 5)主动类(active class) 6)构件(component&a…

计算机组成原理一轮

目录 一、计算机系统概论 组成 概念 二、计算机的运算方法 二进制和八进制、二进制和八进制间的转换 任意进制数转换为十进制数 十进制转二进制 移码 定点数的移位运算 定点数的加减运算 定点数的乘除运算 相乘 相除 溢出的判别方法 采用一位符号位 采用双符号…

LabVIEW调用第三方硬件DLL常见问题及开发流程

在LabVIEW中调用第三方硬件DLL时,除了技术问题,还涉及开发流程、资料获取及与厂家的沟通协调。常见问题包括函数接口不兼容、数据类型转换错误、内存管理问题、线程安全性等。解决这些问题需确保函数声明准确、数据类型匹配、正确的内存管理及线程保护。…

vue3学习(七)

前言 接上一篇学习笔记,今天主要是分享上次学习完了,还没来得及记录,趁今天晚上换换脑子的时间记录下。 今天主要是记录的vuex文件的拆分,因为毕竟如果只在一个index.js文件写,文件会随着业务的复杂性上升&…

Wi-Fi 6E vs. Wi-Fi 7: Which is the Best Fit for Your Infrastructure?

Wi-Fi 6E vs. Wi-Fi 7: Which is the Best Fit for Your Infrastructure? With the rapid advancement of wireless technology, organizations face a critical decision: should they adopt Wi-Fi 6E now or wait for Wi-Fi 7? This decision impacts various aspects of …

NSSCTF中的popchains、level-up、 What is Web、 Interesting_http、 BabyUpload

目录 [NISACTF 2022]popchains [NISACTF 2022]level-up [HNCTF 2022 Week1]What is Web [HNCTF 2022 Week1]Interesting_http [GXYCTF 2019]BabyUpload 今日总结&#xff1a; [NISACTF 2022]popchains 审计可以构造pop链的代码 <php class Road_is_Long{public $…

2-1RT-Thread线程管理-笔记

2-1RT-Thread线程管理-笔记 其中系统线程由内核创建&#xff0c;如main函数和空闲线程都属于系统线程&#xff0c;而用户线程是由应用程序所创建的。 对于资源较大的MCU可以适当设计较大的线程栈&#xff0c;也可以在初始化时设置一个具体的数值&#xff0c;如1K或2K字节。…

CSS学习|css三种导入方式、基本选择器、层次选择器、结构伪类选择器、属性选择器、字体样式、文本样式

第一个css程序 css程序都是在style标签中书写 打开该网页&#xff0c;可以看到h1标签中的我是标题被渲染成了红色 可以在同级目录下创建一个css目录&#xff0c;专门存放css文件&#xff0c;可以和html分开编写 然后在html页面中&#xff0c;利用link标签以及css文件地址&…

王学岗鸿蒙开发(北向)——————(二)TS基本语法详解

1&#xff0c;Ts(TypeScript)语法相当于JAVAScript类型&#xff0c;鸿蒙arkTs是基于TS语言的,当然artTs也融合了其它的语言。 2&#xff0c;本篇文章是基于n9版本。注意,有些语法是已经不能用的。 3&#xff0c; 4&#xff0c;变量:用来存储数据,数字字母组成&#xff0c;数字不…

web学习笔记(六十三)

目录 1.钩子函数onActivated和onDeactivated 1.1 onActivated 1.2 onDeactivated 2. KeepAlive补充 2.1 include 和 exclude 2.2 的作用是什么? 2.3 组件包含什么prop属性及作用&#xff1f; 2.4 对应那两个生命周期&#xff1f;生命周期什么时机执行&#xff1f; 2.5 …

重庆耶非凡科技有限公司的选品师项目加盟靠谱吗?

在当今电子商务的浪潮中&#xff0c;选品师的角色愈发重要。而重庆耶非凡科技有限公司以其独特的选品师项目&#xff0c;在行业内引起了广泛关注。对于想要加盟该项目的人来说&#xff0c;项目的靠谱性无疑是首要考虑的问题。 首先&#xff0c;我们来看看耶非凡科技有限公司的背…

CGS与MGS的矩阵正交化-C语言实现

格拉姆-施密特正交化和改进的格拉姆-施密特正交化 格拉姆-施密特正交化CGS 数学公式 代码实现&#xff1a; 过程版 矩阵运算实现的难点在于每次运算都是一个向量&#xff0c;需要for循环进行&#xff0c;会带来运算时在代码中的复杂&#xff0c;进而难以理解代码的过程 Q矩阵…