【Qt 常用控件】按钮类(QPushButton、QRadioButton、QCheckBox)

devtools/2025/1/18 17:19:17/

按钮控件继承自抽象类QAbstractButton。

抽象类不允许实例化对象,内部定义纯虚函数。只能通过子类继承,重写纯虚函数的方式使用。

1. QPushButton

1.1 QAbstractButton中和QPushButton相关的属性

text按钮显示文本
icon按钮图标
iconSize按钮图标尺寸
shortCut按钮对应快捷键
autoRepeat点击鼠标是否重复触发按钮。true,点击一次,连续触发。false,点击一次,触发一次
autoRepeatDelay连续触发的延迟时间。点击过多少时间后,开始重复触发
autoRepaetInterval重复触发的周期

示例1:带图标的按钮 setIcon(QIcon)

图片等外部资源,优先考虑保存到qrc,除非这个资源太大了。

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);//创建图标对象QIcon icon(":/icon.png");ui->pushButton->setIcon(icon);ui->pushButton->setIconSize(QSize(50,50));
}Widget::~Widget()
{delete ui;
}

示例2:给按钮添加快捷键 setShortCut(QKeySequence)

参数:QKeySequence类型,表示一组按键序列。

构造QKeySequence的两种方式

单按键:

组合按键:


  • 单个按键作为快捷键
#include "widget.h"
#include "ui_widget.h"
#include<QDebug>Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);//设置按钮图标ui->pushButton_right->setIcon(QIcon(":/right.png"));ui->pushButton_right->setIconSize(QSize(50,50));ui->pushButton_left->setIcon(QIcon(":/left.png"));ui->pushButton_left->setIconSize(QSize(50,50));ui->pushButton_up->setIcon(QIcon(":/up.png"));ui->pushButton_up->setIconSize(QSize(50,50));ui->pushButton_down->setIcon(QIcon(":/down.png"));ui->pushButton_down->setIconSize(QSize(50,50));//设置按钮快捷键ui->pushButton_up->setShortcut(QKeySequence("w"));ui->pushButton_down->setShortcut(QKeySequence("s"));ui->pushButton_left->setShortcut(QKeySequence("a"));ui->pushButton_right->setShortcut(QKeySequence("d"));}Widget::~Widget()
{delete ui;
}void Widget::on_pushButton_up_clicked()
{//1.获取geometryQRect rect=ui->pushButton_target->geometry();qDebug()<<rect;//2.设置geometry
//    rect.setY(rect.y()-5);//    ui->pushButton_target->setGeometry(rect);ui->pushButton_target->setGeometry(rect.x(),rect.y()-5,rect.width(),rect.height());}void Widget::on_pushButton_down_clicked()
{//1.获取geometryQRect rect=ui->pushButton_target->geometry();qDebug()<<rect;//2.设置geometry
//    rect.setY(rect.y()+5);
//    ui->pushButton_target->setGeometry(rect);ui->pushButton_target->setGeometry(rect.x(),rect.y()+5,rect.width(),rect.height());
}void Widget::on_pushButton_left_clicked()
{//1.获取geometryQRect rect=ui->pushButton_target->geometry();qDebug()<<rect;//2.设置geometry
//    rect.setX(rect.x()-5);//    ui->pushButton_target->setGeometry(rect);ui->pushButton_target->setGeometry(rect.x()-5,rect.y(),rect.width(),rect.height());}void Widget::on_pushButton_right_clicked()
{//1.获取geometryQRect rect=ui->pushButton_target->geometry();qDebug()<<rect;//2.设置geometry
//    rect.setX(rect.x()+5);//    ui->pushButton_target->setGeometry(rect);ui->pushButton_target->setGeometry(rect.x()+5,rect.y(),rect.width(),rect.height());}

  • 组合按键作为快捷键

推荐使用枚举类型,编译器会对类型进行检查,防止拼写出错。


鼠标点击和快捷键点击的区别

点击+释放(点击一次):鼠标和快捷键都只触发一次点击事件。

点击,不释放(长按):鼠标只触发一次快捷键 默认 重复触发,直到 释放快捷键。

想要鼠标按下期间(不释放),能够自动重复触发点击信号,设置autoRepeat

2. QRadioButton 单选按钮

2.1 QAbstractButton中和QRadioButton中相关的属性

checkable按钮是否能选中
checked

按钮的选中状态,checkable是可以checked的前提。

可以用来设置默认选中的按钮。

autoExclusive

是否排他。

选中一个选项后,是否会取消其他选中的按钮。

对QRadioButton,这是个单选按钮,此属性默认是 排他的。

例1:使用单选按钮,选择性别,并设置默认选项

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);//设置默认选项ui->radioButton_male->setChecked(true);ui->label->setText("您选择的性别为:男");
}Widget::~Widget()
{delete ui;
}void Widget::on_radioButton_male_clicked()
{ui->label->setText("您选择的性别为:男");
}void Widget::on_radioButton_female_clicked()
{ui->label->setText("您选择的性别为:女");
}void Widget::on_radioButton_other_clicked()
{ui->label->setText("您选择的性别为:其他");
}

例2:禁用按钮

    ui->radioButton_other->setCheckable(false);//setCheckable按钮禁用,但是依旧会触发点击事件ui->radioButton_other->setEnabled(false);//Qwidget的属性,enabled,禁用控件,且不触发点击事件ui->radioButton_other->setDisabled(true);

3. 按钮信号

clicked:点击鼠标触发(按下+释放鼠标)

pressed:按下鼠标时触发

released:释放鼠标时触发

toggled:按钮状态切换时触发该信号

例1:观察各个信号的触发方式

toggled信号,在被选中时,状态发生切换。点击其他单选按钮,因为排他属性,按钮的选中状态发生改变,变为false,又一次触发状态切换信号。

QButtonGroup单选按钮分组

 QButtonGroup* groupbuger=new QButtonGroup(this);groupbuger->addButton(ui->radioButton_burger1);

例2:实现简单的模拟点餐

点餐的三个部分:1.汉堡2.小食3.饮料

#include "widget.h"
#include "ui_widget.h"
#include<QButtonGroup>Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);//对单选项分组QButtonGroup* groupbuger=new QButtonGroup(this);QButtonGroup* groupchips=new QButtonGroup(this);QButtonGroup* groupdrink=new QButtonGroup(this);//添加groupbuger->addButton(ui->radioButton_burger1);groupbuger->addButton(ui->radioButton_burger2);groupbuger->addButton(ui->radioButton_burger3);groupchips->addButton(ui->radioButton_chips1);groupchips->addButton(ui->radioButton_chips2);groupchips->addButton(ui->radioButton_chips3);groupdrink->addButton(ui->radioButton_drink1);groupdrink->addButton(ui->radioButton_drink1);}Widget::~Widget()
{delete ui;
}

4.QCheckBox 复选按钮

4.1 属性

  • QCheckButton中和QRadioButton中相关的属性
checkable按钮是否能选中
checked

按钮的选中状态,checkable是可以checked的前提。

可以用来设置默认选中的按钮。

  • QCheckBox内置属性
tristate实现“三态复选框”

不咋用,暂时不学

例:通过PushButton按钮,获取复选项内容、刷新Label

#include "widget.h"
#include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget)
{ui->setupUi(this);
}Widget::~Widget()
{delete ui;
}void Widget::on_pushButton_clicked()
{//点击确认后,获取复选按钮选择的内容,设置到labelQString result="今天你的安排是:";if(ui->checkBox_date->isChecked()==true){result+=ui->checkBox_date->text();result+=" ";}if(ui->checkBox_rest->isChecked()==true){result+=ui->checkBox_rest->text();result+=" ";}if(ui->checkBox_learn->isChecked()==true){result+=ui->checkBox_learn->text();result+=" ";}ui->label->setText(result);
}

5.QToolButton

QtoolButton的大部分功能,和QPushButton是一致的,但是QToolButton主要应用在工具栏、菜单等场景。


http://www.ppmy.cn/devtools/151611.html

相关文章

STM32 FreeRTOS中断管理

目录 FreeRTOS的中断管理 1、STM32中断优先级管理 2、FreeRTOS任务优先级管理 3、寄存器和内存映射寄存器 4、BASEPRI寄存器 5、FreeRTOS与STM32中断管理结合使用 vPortRaiseBASEPRI vPortSetBASEPRI 6、FromISR后缀 7、在中断服务函数中调用FreeRTOS的API函数需注意 F…

【Axure】1500+实用图标库

most Icon 是基于工作中常用的图标进行整理的一款高度灵活的矢量图标库&#xff08;非字体图标&#xff0c;不需要安装字体&#xff09;&#xff0c;并在 axure 内可以右键转换成图形并修改颜色&#xff0c;轻松调整图标的尺寸、色调、光影效果以及背景填充等各项属性。 它在 …

【Golang 面试题】每日 3 题(三十二)

✍个人博客&#xff1a;Pandaconda-CSDN博客 &#x1f4e3;专栏地址&#xff1a;http://t.csdnimg.cn/UWz06 &#x1f4da;专栏简介&#xff1a;在这个专栏中&#xff0c;我将会分享 Golang 面试中常见的面试题给大家~ ❤️如果有收获的话&#xff0c;欢迎点赞&#x1f44d;收藏…

基于微信小程序的校园运动场地预约系统设计与实现

一.前言 选题背景&#xff1a; 随着社会的进步和人们生活水平的提高&#xff0c;健康意识逐渐增强&#xff0c;越来越多的人开始关注和参与体育运动。在校园中&#xff0c;学生们也积极参与各种体育活动&#xff0c;以提升身体素质和促进全面发展。然而&#xff0c;由于校园运动…

Linux一键巡检

文章目录 一、巡检内容 二、巡检结果展示 三、巡检脚本 四、执行脚本 五、查看巡检报告 六、设置定时任务 一、巡检内容 [1] 系统基本信息 [2] CPU 信息 [3] 内存使用情况 [4] 磁盘使用情况 [5] 网络配置和连接 [6] 服务状态检查 [7] 安全检查 [8] 登录记录 [9] 系统日志…

CSS的发展历程

本篇文章仅作为娱乐科普&#xff0c;如有错误&#xff0c;欢迎各位指正 目录 本篇文章仅作为娱乐科普&#xff0c;如有错误&#xff0c;欢迎各位指正 一、CSS的起源 二、CSS的发展 1、CSS1 2、CSS2 3、CSS2.1 4、CSS3 一、CSS的起源 在CSS出现之前&#xff0c;网页的设…

Spring MVC复杂数据绑定-绑定数组

【图书介绍】《SpringSpring MVCMyBatis从零开始学&#xff08;视频教学版&#xff09;&#xff08;第3版&#xff09;》_【新华文轩】springspring mvcmybatis从零开始学(视频教学版) 第3版 正版-CSDN博客 《SpringSpring MVCMyBatis从零开始学(视频教学版)&#xff08;第3版…

VS Code--常用的插件

原文网址&#xff1a;VS Code--常用的插件_IT利刃出鞘的博客-CSDN博客 简介 本文介绍VS Code&#xff08;Visual Studio Code&#xff09;常用的插件。 插件的配置 默认情况下&#xff0c;插件会放到这里&#xff1a;C:\Users\xxx\.vscode\extensions 修改插件位置的方法 …