Qt 是一个跨平台C++图形界面开发库,利用Qt可以快速开发跨平台窗体应用程序,在Qt中我们可以通过拖拽的方式将不同组件放到指定的位置,实现图形化开发极大的方便了开发效率,本章将重点介绍QRadioButton
单选框组件以及与之交互的QButtonGroup
类的常用方法及灵活运用。
QRadioButton
是Qt框架中的一个部件(Widget),用于提供单选按钮的界面元素。单选按钮允许用户从多个互斥的选项中选择一个,通常用于表示一组相关但互斥的选项。
以下是QRadioButton
的一些常用方法,以表格形式概述:
方法 | 描述 |
---|---|
QRadioButton(QWidget *parent = nullptr) | 构造函数,创建一个单选按钮,可指定父部件。 |
setText(const QString &text) | 设置单选按钮的文本标签。 |
text() const | 获取单选按钮的文本标签。 |
setChecked(bool checked) | 设置单选按钮的选中状态,true 表示选中,false 表示未选中。 |
isChecked() const | 判断单选按钮是否处于选中状态。 |
setAutoExclusive(bool enabled) | 设置是否自动将同一组中的其他单选按钮设为未选中状态。 |
setObjectName(const QString &name) | 设置对象名称,用于样式表等。 |
setCheckedState(Qt::CheckState state) | 设置单选按钮的选中状态,可选值有Qt::Checked 、Qt::Unchecked 和Qt::PartiallyChecked 。 |
checkState() const | 获取单选按钮的选中状态,返回Qt::Checked 、Qt::Unchecked 或Qt::PartiallyChecked 。 |
toggled(bool checked) | 信号,当单选按钮的选中状态发生改变时触发。参数checked 表示是否选中。 |
click() | 模拟点击单选按钮,触发点击事件。 |
setDisabled(bool disable) | 设置单选按钮是否被禁用,true 表示禁用,false 表示启用。 |
setEnabled(bool enable) | 设置单选按钮是否启用,true 表示启用,false 表示禁用。 |
blockSignals(bool block) | 阻塞或解除阻塞信号与槽的连接,用于在某些操作时临时禁用信号槽。 |
这些方法提供了对QRadioButton
的一些基本操作,包括设置文本、选中状态、信号与槽等。通过这些方法,可以在应用程序中方便地创建和控制单选按钮。总而言之,QRadioButton
是一种简单而有效的界面元素,用于在多个互斥的选项中进行单一选择。
谈到QRadioButton
组件就不得不提起QButtonGroup
类,因为这两者通常是需要组合在一起使用的,一般来说QButtonGroup
用于管理一组按钮,通常是单选按钮(QRadioButton
)或复选按钮(QCheckBox
)。它为这组按钮提供了一些便捷的方法,方便进行管理和操作。
首先我们需要在mainwindow.h
头文件中手动增加一个槽函数的声明,该槽函数用于触发后的处理工作。
private slots:
void MySlots();
其次在主程序mainwindow.cpp
中我们通过new QBUttonGroup
新建一个按钮组,并将其加入到group_sex
组内,创建信号和槽的绑定,将信号全部绑定到MySlots()
槽函数上,如下所示;
#include "mainwindow.h"
#include "ui_mainwindow.h"
#include <QMessageBox>
#include <QButtonGroup>
#include <iostream>
// 定义全局组变量
QButtonGroup *group_sex;
MainWindow::MainWindow(QWidget *parent): QMainWindow(parent), ui(new Ui::MainWindow)
{
ui->setupUi(this);
// 将RadioButton放入ButtonGroup组中
group_sex = new QButtonGroup(this);
group_sex->addButton(ui->radioButton_male,0);
group_sex->addButton(ui->radioButton_female,1);
group_sex->addButton(ui->radioButton_unknown,2);
// 设置默认选中
ui->radioButton_unknown->setChecked(true);
// 绑定信号和槽
connect(ui->radioButton_male,SIGNAL(clicked(bool)),this,SLOT(MySlots()));
connect(ui->radioButton_female,SIGNAL(clicked(bool)),this,SLOT(MySlots()));
connect(ui->radioButton_unknown,SIGNAL(clicked(bool)),this,SLOT(MySlots()));
}
MainWindow::~MainWindow()
{
delete ui;
}
// 手动创建一个槽函数
void MainWindow::MySlots()
{
switch(group_sex->checkedId())
{
case 0:
std::cout << "male" << std::endl;
QMessageBox::information(nullptr, "信息", "用户选中了男", QMessageBox::Ok);
break;
case 1:
std::cout << "female" << std::endl;
QMessageBox::information(nullptr, "信息", "用户选中了女", QMessageBox::Ok);
break;
case 2:
std::cout << "unknown" << std::endl;
QMessageBox::information(nullptr, "信息", "用户选中了未知", QMessageBox::Ok);
break;
}
}
当程序运行后,读者可自行选择不同的单选框,此时会弹出不同的提示信息,如下图;
当然如果读者不想使用QButtonGroup
对单选框进行分组操作,同样可以实现判断选中状态,通过依次检查isChecked()
单选框的状态即可实现,但是此类方式并不推荐使用。
void MainWindow::on_pushButton_clicked()
{
if(ui->radioButton_male->isChecked() == true)
{
std::cout << "选中男" << std::endl;
}
if(ui->radioButton_female->isChecked() == true)
{
std::cout << "选中女" << std::endl;
}
if(ui->radioButton_unknown->isChecked() == true)
{
std::cout << "选中未知" << std::endl;
}
}