当前位置: 首页 > article >正文

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

按钮控件继承自抽象类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.获取geometry
    QRect 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.获取geometry
    QRect 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.获取geometry
    QRect 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.获取geometry
    QRect 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()
{
    //点击确认后,获取复选按钮选择的内容,设置到label
    QString 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);
}


http://www.kler.cn/a/506509.html

相关文章:

  • 【Rust自学】12.4. 重构 Pt.2:错误处理
  • Java中如何实现对象的深拷贝和浅拷贝?
  • 传统摄像头普通形态的系统连接方式
  • 工作记录小点
  • 【NLP】语言模型的发展历程 (1)
  • 《HTML在网络安全中的多面应用:从防范攻击到安全审查》
  • 基于 requests 依赖包的 Python 爬虫实战
  • Linux第一课:LinuxC基础 学习记录day11
  • Docker 镜像制作原理 做一个自己的docker镜像
  • 【安卓开发】【Android】总结:安卓技能树
  • 如何学习Transformer架构
  • 目标检测中的Bounding Box(边界框)介绍:定义以及不同表示方式
  • 【MySQL】高级查询技巧 JOIN、GROUP BY、ORDER BY、UNION 应用案列解析
  • Java全栈项目-办公自动化OA系统
  • 计算机网络 (41)文件传送协议
  • 【Linux探索学习】第二十六弹——进程通信:深入理解Linux中的进程通信
  • 网关相关知识
  • 计算机网络 网络层 2
  • PyCharm与GitHub完美对接: 详细步骤指南
  • 基于YOLOv8的卫星图像中船只检测系统
  • 用行动回应“实体清单”,智谱发布了一系列新模型
  • Python 如何操作 PDF 文件?
  • 2025-01-16 思考-人生下半场的归途-那温和的良夜
  • 运行fastGPT 第四步 配置ONE API 添加模型
  • 干货答疑分享记录:as导入问题,LSP含义,分屏进入SplashScreen
  • windows 电源选项卓越性能开启