【我是小标题:使用QToolButton实现radio button功能。】

QRadioButton是什么? 
  下图是Windows系统中典型的radio button显示效果。 
   
  QRadioButton是一个可以switch on或off的按钮,对应的状态为checked和unchecked。一组QRadioButton通常用于表示程序中“多选一”的选择,例如单项选择题。在一组radio buttons中,同一时刻只能有一个button处于checked状态,如果用户选择了其他button,原先被选中的button将变为unchecked。 
  和QpushButton一样,QRadioButton类提供了一个text label和一个small icon,其中text可以在构造函数中设置,也可以通过setText()方法设置,但是icon只能通过setIcon()方法设置,还可以通过在text中某个字母前加“&”符号来指定快捷键,例如:

QRadioButton *button = new QRadioButton("Search from the &cursor", this);

上面例子的快捷键为“Alt + c”。

分组 
  上面其实已经提到过,“同一个父窗体”或“一个button group”,这就是分组。如果没有进行分组,则默认拥有相同父窗体的radio buttons都将具有相互排他性,所以如果你想在一个窗体中表达多组radio buttons的效果,需要显式地对它们进行分组,可以使用QGroupBox或者QButtonGroup。建议使用QButtonGroup,因为它仅仅是一个容器,不会有任何视觉表现,并且对于包含在它里面的子buttons,QButtonGroup提供比QGroupBox方便的信号槽操作。

信号 
  QRadioButton的信号继承自QAbstractButton,一般我们比较关注的是toggled()和clicked(), 
  需要注意的是,radio button无论是被switch on还是off,它都会发送一个toggled(bool)信号,其中包含一个bool型参数用于记录此次发生的是被switch on还是off,所以如果你想根据radio button的状态变化来处理一些事的话,就需要connect它们。 
  当然,如果组内有很多个radio buttons,并且你又想跟踪toggled或clicked的状态,你不需要一个个来connect,因为一旦使用QButtonGroup来管理,完全可以用buttonToggled()和buttonClicked()来处理组内所有buttons的toggled()和clicked()信号。

方法 
  在QButtonGroup中添加一个button可以使用addButton()方法,删除一个button可以使用removeButton()方法。如果这个button group是exclusive的,还可以通过checkedButton()方法来找到当前处于checked状态的button。可以通过button()方法找到该button group中的某一个button,以及通过buttons()方法获得该button group中的buttons列表。

属性 
  接下来,我们需要关注一个名为autoExclusive的bool型属性,它是QAbstractButton类的属性,该属性用于控制一个button是否具有排他性(auto-exclusivity),可以通过autoExclusive() 方法进行查询,通过setAutoExclusive(bool)方法进行设置。 
  如果autoExclusive为true,属于同一个父窗体的所有checkable按钮的行为将表现得与它们被放在一个exclusive的button group中一样,任何时刻都只能有一个按钮处于checked状态。不过别担心, autoExclusive属性的缺省值为false(除了QRadioButton)。 
  还要注意的是,如果buttons已经放在了一个button group,那么autoExclusive属性将失效。 
  QButtonGroup默认是exclusive的,所以只要它的组内的所有buttons是checkable的,不管是不是QRadioButton,都将表现得与QRadioButton一样。最后如果你创建了一个exclusive的button group,最好为它设置一个初选项,否则组内将没有任何一个button被选中,这不太符合“one of many”的设计吧。

示例 
  以下示例代码,包括普通QRadioButton的用法以及用QToolButton模拟的单选按钮组,相关代码解释请看注释。(因为QRadioButton只提供了一个small icon,但是我们希望可以更加个性化,所以尝试用QToolButton来实现) 
   
【mainwidget.h】文件

#ifndef MAINWIDGET_H
#define MAINWIDGET_H #include <QWidget>
#include <QRadioButton>
#include <QButtonGroup>
#include <QToolButton>
#include <QLabel> class MainWidget : public QWidget {
Q_OBJECT public:
MainWidget(QWidget *parent = );
~MainWidget(); // 设备操作模式类型(用于表示普通QButtonGroup)
typedef enum {
OM_Auto,
OM_Manual,
OM_ManualFullSpeed
}operatingModeTypes; // 动物选项类型(用于表示QToolButton模拟的单选按钮)
typedef enum {
AN_PIG,
AN_MONKEY,
AN_CAT
}animalTypes; private slots:
void operatingModeButtonsToggled(int, bool);
void operatingModeButtonsClicked(int); void customButtonsToggled(int, bool);
void customButtonsClicked(int); private:
// 设备操作模式组
QButtonGroup *operatingModeGroup;
QRadioButton *autoBtn;
QRadioButton *manualBtn;
QRadioButton *manualFullSpeedBtn; // 电源开关组
QButtonGroup *powerGroup;
QRadioButton *powerOnBtn;
QRadioButton *powerOffBtn; // 动物选项组
QButtonGroup *customGroup;
QStringList animalStrList; // 记录动物名称
QLabel *curAnimalLabel; // 显式当前选中的动物名称
}; #endif // MAINWIDGET_H

【mainwidget.cpp】文件

#include "mainwidget.h"
#include <QVBoxLayout>
#include <QHBoxLayout> // 保存customGroup中checked和unchecked按钮的样式
QString toolBtnCheckedStyleSheet("border-style: solid; ");
QString toolBtnUncheckedStyleSheet("border-style: solid; "); MainWidget::MainWidget(QWidget *parent)
: QWidget(parent)
{
setWindowTitle(tr("QRadioButtonTest"));
setFixedSize(, ); /* ******* 普通RadioButton ******* */
autoBtn = new QRadioButton(tr("Auto"));
manualBtn = new QRadioButton(tr("Manual"));
manualFullSpeedBtn = new QRadioButton(tr("Manual Full Speed")); operatingModeGroup = new QButtonGroup(this);
operatingModeGroup->addButton(autoBtn, OM_Auto);
operatingModeGroup->addButton(manualBtn, OM_Manual);
operatingModeGroup->addButton(manualFullSpeedBtn, OM_ManualFullSpeed);
autoBtn->setChecked(true); // 为operatingModeGroup组设置初选项 /* ******* 添加Icon的RadioButton ******* */
powerOnBtn = new QRadioButton(tr("Power ON"));
powerOnBtn->setIcon(QIcon(":/images/power_on.png"));
powerOffBtn = new QRadioButton(tr("Power OFF"));
powerOffBtn->setIcon(QIcon(":/images/power_off.png")); powerGroup = new QButtonGroup(this);
powerGroup->addButton(powerOnBtn);
powerGroup->addButton(powerOffBtn);
powerOffBtn->setChecked(true); // 为powerGroup组设置初选项 /* ******* 自定义RadioButton ******* */
QSize size(, );
animalStrList<<"pig"<<"monkey"<<"cat"; customGroup = new QButtonGroup(this);
customGroup->setExclusive(true);
curAnimalLabel = new QLabel;
QHBoxLayout *customBtnBarLayout = new QHBoxLayout; for(int i=; i<; i++)
{
QToolButton *customBtn = new QToolButton;
customGroup->addButton(customBtn, AN_PIG+i); // 将自定义的button加入customGroup中,并为其设置id customBtn->setToolButtonStyle(Qt::ToolButtonTextUnderIcon); //文字处于图片下方
QPixmap pixmap(QString(":/images/%1.jpg").arg(animalStrList.at(i)));
customBtn->setIcon(pixmap); // 为按钮设置图标
customBtn->setIconSize(size); // 设置图片大小
customBtn->setFixedSize(size.width()+, size.height()+); // 设置按钮大小
customBtn->setText(animalStrList.at(i)); // 设置提示文字
customBtn->setCheckable(true);
customBtn->setChecked(false);
customBtn->setStyleSheet(toolBtnUncheckedStyleSheet); // 所有按钮初始状态为unchecked customBtnBarLayout->addWidget(customBtn); // 添加到布局
}
customGroup->button(AN_PIG)->setChecked(true); // 为customGroup组设置初选项
customGroup->button(AN_PIG)->setStyleSheet(toolBtnCheckedStyleSheet); // 修改被checked按钮的样式
curAnimalLabel->setText(QString(tr("当前选择:"))+animalStrList.at(customGroup->checkedId())); // 创建布局
QVBoxLayout *mainLayout = new QVBoxLayout;
mainLayout->addWidget(autoBtn);
mainLayout->addWidget(manualBtn);
mainLayout->addWidget(manualFullSpeedBtn);
mainLayout->addStretch();
mainLayout->addWidget(powerOnBtn);
mainLayout->addWidget(powerOffBtn);
mainLayout->addStretch();
mainLayout->addWidget(curAnimalLabel);
mainLayout->addLayout(customBtnBarLayout);
setLayout(mainLayout); // 连接信号
connect(operatingModeGroup, SIGNAL(buttonToggled(int,bool)), this, SLOT(operatingModeButtonsToggled(int,bool)));
connect(operatingModeGroup, SIGNAL(buttonClicked(int)), this, SLOT(operatingModeButtonsClicked(int)));
connect(customGroup, SIGNAL(buttonClicked(int)), this, SLOT(customButtonsClicked(int)));
connect(customGroup, SIGNAL(buttonToggled(int,bool)), this, SLOT(customButtonsToggled(int,bool)));
} MainWidget::~MainWidget()
{ } void MainWidget::operatingModeButtonsToggled(int id, bool status)
{
int tmp = operatingModeGroup->checkedId();
QString str = operatingModeGroup->checkedButton()->text();
QByteArray byteArray = str.toLocal8Bit();
qDebug("flag = %d, status = %d, tmp = %d, checked = %s", id, status, tmp, byteArray.data());
} void MainWidget::operatingModeButtonsClicked(int id)
{
qDebug("Clicked: %d", id);
} void MainWidget::customButtonsToggled(int id, bool state)
{
if(state == false)
{ // 修改被unchecked按钮的样式
customGroup->button(id)->setStyleSheet(toolBtnUncheckedStyleSheet);
}else
{ // 修改被checked按钮的样式
customGroup->checkedButton()->setStyleSheet(toolBtnCheckedStyleSheet);
}
} void MainWidget::customButtonsClicked(int id)
{
curAnimalLabel->setText(QString(tr("当前选择:"))+animalStrList.at(id));
}

示例图片 


原文链接: http://www.voidcn.com/article/p-uakncscd-bkp.html

Qt5学习笔记——QRadioButton与QbuttonGroup的更多相关文章

  1. Qt5学习笔记(1)-环境配置(win+64bit+VS2013)

    Qt5学习笔记(1)-环境配置 工欲善其事必先-不装-所以装软件 久不露面,赶紧打下酱油. 下载 地址:http://download.qt.io/ 这个小网页就可以下载到跟Qt有关的几乎所有大部分东 ...

  2. Qt5学习笔记(控件)

    上面的程序仅仅可以显示一个 大概 的界面,对其进行单击等操作,界面仅有一些简单的反应,对应的程序不能得知界面有什么改变(是否进行单击选择,文本框中是否有文字输入) 下面对程序进行完善. T05Cont ...

  3. Qt5学习笔记(基础)

    按钮 #include <QApplication> /*应用程序抽象类*/ #include <QWidget> //窗口类 #include <QPushButton ...

  4. Qt5学习笔记(消息过滤器)

    T06EventFilter.pro HEADERS += \ MyWidget.h SOURCES += \ MyWidget.cpp QT += widgets gui MyWidget.h #i ...

  5. Qt5学习笔记(消息基础)

    #include "MyWidget.h" #include <QApplication> #include <QEvent> #include <Q ...

  6. 我的QT5学习之路(目录)

    说明:本目录内容为自己学习的心得和记录,参考资料来源于网络,学习过程中多方汲取,如有错误,欢迎指正和批评. Qt开发相关文章目录 一.我的Qt学习之路系列 1.[笔记]我的Qt学习之路(一)——浅谈Q ...

  7. ROS学习笔记八:基于Qt搭建ROS开发环境

    1 前言 本文介绍一种Qt下进行ROS开发的完美方案,使用的是ros-industrial的Levi-Armstrong在2015年12月开发的一个Qt插件ros_qtc_plugin,这个插件使得Q ...

  8. Qt学习笔记(2)-利用StackWidget实现选项卡式页面

    学习笔记第二篇,利用Qt实现选项卡式的页面,效果如图1.1-图1.3所示.程序实现的功能是通过点击状态栏实现不同页面的切换,实际上Qt中自带有Tab选项卡式的控件,本文利用StackWidge实现类似 ...

  9. js学习笔记:webpack基础入门(一)

    之前听说过webpack,今天想正式的接触一下,先跟着webpack的官方用户指南走: 在这里有: 如何安装webpack 如何使用webpack 如何使用loader 如何使用webpack的开发者 ...

随机推荐

  1. 第一节、Alex 讲解 python+mysql 交互;

    Python Mysql 交互 A.Alex 的语法展示: import MySQLdb  try:      conn=MySQL.connect(host='localhost',user='ro ...

  2. 访问url

    你可以通过 args 属性来访问 URL 中提交的参数 ( ?key=value ): searchword = request.args.get('q', '') from flask import ...

  3. Delphi 正则表达式之TPerlRegEx 类的属性与方法(1): 查找

    Delphi 正则表达式之TPerlRegEx 类的属性与方法(1): 查找 //查找是否存在 var   reg: TPerlRegEx; begin   reg := TPerlRegEx.Cre ...

  4. mapreduce 运行-指定各种运行参数

    mapreduce指定参数 mapreduce在运行的时候可以指定各种参数,这样可以根据实际的应用场景做一下相关的调整 1.指定运行时cpu的个数 hadoop jar hadoop-core-0.1 ...

  5. JavaScript的消息机制

    JavaScript本身是单线程的,但它却是事件驱动的.类似Windows窗体应用程序,它也需要消息队列机制来实现.程序的执行并不是连续的,绝大多数时间都在等待消息.每次执行执行程序都是在响应消息,这 ...

  6. Python学习笔记之Python的enumerate函数

    Python 的 enumerate() 函数就像是一个神秘的黑箱,你无法简单地用一句话来概括这个函数的作用与用法. enumerate() 函数属于非常有用的高级用法,而对于这一点,很多初学者甚至中 ...

  7. Hadoop:相关概念

    Hadoop:相关概念 一.Hadoop简介 Hadoop实现了一个分布式文件系统(Hadoop Distributed File System),简称HDFS. 1.特点 (1)HDFS有高容错性的 ...

  8. EasyUI中datagrid双击事件

    EasyUI中datagrid双击事件 在jsp文件底部增加代码: <script type="text/javascript"> //数据表双击事件 $('#tabl ...

  9. Apache 防盗链配置

    盗链 网站内有许多的图片地址,或一些我们可以用到的资源,在这种情况下,我可以通过赋值其他图片链接地址,到我自己的平台上,这样相当于盗取了一张图片的链接,那么盗链会有什么危害呢? 当我们盗取一张图片链接 ...

  10. 20145219 《Java程序设计》实验五 Java网络编程及安全实验报告

    20145219 <Java程序设计>实验五 Java网络编程及安全实验报告 实验内容 1.掌握Socket程序的编写: 2.掌握密码技术的使用: 3.设计安全传输系统. 实验步骤 我和2 ...