Qt 是一個跨平臺C++圖形界面開發庫,利用Qt可以快速開發跨平臺窗體應用程式,在Qt中我們可以通過拖拽的方式將不同組件放到指定的位置,實現圖形化開發極大的方便了開發效率,本章將重點介紹`QRadioButton`單選框組件以及與之交互的`QButtonGroup`類的常用方法及靈活運用。`QRad... ...
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;
}
}
文章出處:https://www.cnblogs.com/LyShark/p/17895152.html
本博客所有文章除特別聲明外,均採用 BY-NC-SA 許可協議。轉載請註明出處!