【笔记】Qt 按钮控件介绍(QPushButton,QCheckBox,QToolButton)

文章目录

      • QAbstractButton 抽象类(父类)
        • QAbstractButton 类中的属性
        • QAbstractButton 类中的函数
        • QAbstractButton 类中的信号
        • QAbstractButton 类中的槽
      • QPushButton 类(标准按钮)
        • QPushButton 类中的属性
        • QPushButton 类中的函数、槽
      • QCheckBox 类(复选按钮)
        • QCheckBox 类的属性
        • QCheckBox 类的函数,信号
      • QToolButton 类(工具按钮)
        • QToolButton 类中的属性
        • QToolButton 类中的函数

QAbstractButton 抽象类(父类)

QAbstractButton 是个抽象类,该类是标准按钮 QPushButton、复选按钮 QCheckBox、单选
按钮 QRadioButton、工具按钮 QToolButton 的父类,该类描述了按钮的一些共同功能,比
如单击按钮发出的信号,按钮的状态等

QAbstractButton 类中的属性
  • autoExclusive:bool 访问函数:bool autoExclusive() const; void setAutoExclusive(bool);
    描述了按钮的自动排他性,若启用了该属性,则属于同一父部件的可选中按钮的行为,
    就好像是在同一排他性组中的按钮一样。除了单选按钮,默认为关闭。

  • autoRepeat:bool 访问函数:bool autoRepeat () const; void setAutoRepeat(bool);
    描述了按钮是否启用自动重复。当按钮处于按下状态(比如按下按钮不放)时,会以固
    定间隔发送 pressed(),released(),clicked()信号。默认为关闭。

  • autoRepeatDelay:int 访问函数:int autoRepeatDelay() const; void setAutoRepeatDelay(int);
    自动重复的初始延迟(毫秒)

  • autoRepeatInterval:int 访问函数:int autoRepeatInterval() const; void setAutoRepeatInterval(int);
    自动重复的时间间隔(毫秒)

  • checkable:bool 访问函数:bool isCheckable() const; void setCheckable(bool);
    按钮是否可选中,默认为可选中

  • checked:bool 访问函数:bool isChecked()const; void setChecked(bool)
    按钮是否被选中(即是否处于选中状态),只有可选中按钮才能被选中。默认未被选中。

  • down:bool 访问函数:bool isDown()const;void setDown(bool);
    按钮是否被按下(即是否处于按下状态)。若此属性为 true,则按钮被按下。若把此属性
    设置为 true,则不会发送 pressed()和 clicked()信号(经测试,仍会发送这些信号)。默认
    为 false。

  • icon:QIcon 访问函数:QIcon icon() const; void setIcon(const QIcon &);
    按钮上显示的图标,

  • iconSize:QSize 访问函数:QSize iconSize() const; void setIconSize(const QSize);
    按钮上显示的图标的大小。默认大小由 GUI 样式定义。这是图标的最大大小,较小
    的图标不会被放大。

  • shortcut :QKeySequence访问函数:QKeySequence shortcut() const; void setShortcut(const QKeySequence&);
    保存与按钮关联的助记符,快捷键。

  • text:QString 访问函数:QString text()const; void setTex t(const QString&);
    按钮上显示的文本。若按钮没有文本,则 text()返回一个空字符串。

  • 示例:按钮的排他性与自动重复

class B : public QPushButton
{Q_OBJECT
public:B(QString s = "", QWidget *p = 0) : QPushButton(s, p) {}// 若重写以下事件处理函数,则使用该类创建的按钮,将不会发送 Qt 内置的信号(比如 clicked()等)// void mousePressEvent(QMouseEvent *e){cout<<"D"<<endl;}
public slots: // 注:qt5.0 之后,可使用普通函数作为槽函数。void f() { qDebug() << "F"; }
};
int main(int a, char *b[])
{QApplication c(a, b);// myWidget w;// w.show();QWidget w;B *pb1 = new B("AAA", &w);B *pb11 = new B("AAA1", &w);QCheckBox *pb2 = new QCheckBox("BBB", &w);QCheckBox *pb3 = new QCheckBox("CCC", &w);QCheckBox *pb4 = new QCheckBox("DDD", &w);QRadioButton *pb5 = new QRadioButton("EEE", &w);QRadioButton *pb6 = new QRadioButton("FFF", &w); // 单选按钮默认具有排他性。QCheckBox *pb7 = new QCheckBox("GGG", &w);// 布局各部件pb1->move(22, 22);pb11->move(99, 22);pb2->move(22, 77);pb3->move(99, 77);pb4->move(155, 77);pb5->move(22, 122);pb6->move(99, 122);pb7->move(155, 122);pb1->setAutoRepeat(true);         // pb1 开启自动重复pb1->setAutoRepeatDelay(1000);    // 设置初始延迟为 1 秒pb1->setAutoRepeatInterval(2000); // 设置时间间隔为 2 秒// 把按钮 pb1 的 clicked 信号与槽 f 关联。QObject::connect(pb1, &QPushButton::released, pb1, &B::f);pb2->setAutoExclusive(true);pb3->setAutoExclusive(true); // 开启按钮的排他性pb11->setDown(true);         // 设置为按下状态pb7->setCheckable(false);    // 设置为不可选中。w.resize(300, 200);w.show();return c.exec();
}
QAbstractButton 类中的函数
  • QAbstractButton(QWidget *parent=Q_NULLPTR); //构造函数
  • QButtonGroup* group() const
    返回此按钮所属的组,若按钮不是任何 QButtonGroup 的成员,则返回 0。
QAbstractButton 类中的信号
  1. void clicked(bool checked =false)
  • 以下情形会发送此信号
    • 鼠标点击按钮然后释放时,注意:按钮释放时才会发送。
    • 调用 click()或 animateClick()函数时。
    • 按下对应的快捷键或空格键时
    • 当调用 setDown()、setChecked()或 toggle()函数时,不会发送该信号
    • 若按钮是可选中的,当按钮被选中时,参数 checked 为 true,若按钮未被选中,则为 false
    • 需要注意的是 QWidget 类并不发送此信号及 pressed 和 released 信号
  1. void pressed(); 按下按钮时发送此信号
  2. void released(); 释放按钮时发送此信号
  3. void toggled(bool checked);
  • 每当可选中按钮切换状态时,都会发送此信号。若按钮被选中,则参数 checked
    为 true,若按钮被取消选中,则为 false。
  • 按钮状态的改变可能是由于用户操作,click()槽函数或 setChecked()函数被调用的
    结果。
  • 在发出信号前,将更新排他性按钮组中按钮的状态
QAbstractButton 类中的槽
  1. void checkStateSet()
    当使用 setChecked()时,会调用此虚函数,除非它是在 nextCheckState()中调用的。它
    允许子类重置其中间按钮状态。
  2. bool hitButton(const QPoint &pos) const;
    若 pos 位于可单击按钮的矩形内,则返回 true,否则返回 false。可单击区域默认是整
    个部件,子类可重新实现此函数,以提供对不同形状和大小的可单击区域的支持。
  3. void nextCheckState()
    当按钮被单击时,调用此虚函数,该函数允许子类实现中间按钮状态。
  4. void paintEvent(QPaintEvent* e)=0;
    这是个纯虚函数,子类必须重新实现该函数。

QPushButton 类(标准按钮)

在这里插入图片描述

QPushButton 类中的属性
  • autoDefault:bool 访问函数:bool autoDefault() const; void setAutoDefault(bool);
    若此属性为 true,则此按钮是一个自动默认按钮。若按钮的父部件是 QDialog,则此
    属性的默认值为 true,否则为 false。
  • default:bool 访问函数:bool isDefault() const; void setDefault(bool);
    此属性描述了是否为默认按钮。默认为 false。
  • flat:bool 访问函数:bool isFlat() const; void setFlat(bool);
    此属性描述了是否提高按钮的边框。若此属性为 true,大多数样式不会绘制按钮的背景,
    除非按下按钮。也就是说,若该属性为 true,在通常情况下,若不按下按钮,则该按钮
    看起来就像一个标签一样,是平的。
QPushButton 类中的函数、槽
  • QPushButton (QWidget* parent = Q_NULLPTR);//构造函数
    QPushButton (const QString &text , QWidget* parent = Q_NULLPTR)
    QPushButton (const QIcon &icon , const QString &text , QWidget* parent = Q_NULLPTR)
  • QMenu* menu() const;
    返回与此按钮相关的弹出菜单,若未设置弹出菜单,则返回 0。菜单详见相关章节
  • void setMenu (QMenu * menu);
    将弹出菜单 menu 与按钮关联,这会使按钮成为菜单按钮。
  • void showMenu(); //槽
    显示(弹出)与此按钮相关联的弹出菜单,若没有菜单,则什么也不做。在用户关闭弹
    出菜单之前,该函数不会返回。

QCheckBox 类(复选按钮)

在这里插入图片描述

QCheckBox 类的属性
  • tristate:bool 访问函数:bool isTristate() const; void setTristate(bool y=true);
    该属性保存复选按钮是否为三态按钮,默认为 false。注意:属性的设置函数 setTristate
    只能设置此按钮具有三态按钮的形式,但不能使该按钮呈现出第三种状态,即按钮前
    面的小方框内不会有小黑方框的填充,但点击该按钮,会在三种状态间变换。设置按
    钮的状态应使用下面介绍的成员函数 setCheckState()。
QCheckBox 类的函数,信号
  • QCheckBox(QWidget* parent = Q_NULLPTR); //构造函数
    QCheckBox(const QString &text , QWidget* parent = Q_NULLPTR);
  • Qt::CheckState checkState() const; //返回复选框的选中状态。
  • void setCheckState(Qt::CheckState state);
    设置复选按钮的状态为 state ,该函数可设置复选按钮的三种状态,
    QAbstractButton::setChecked()只能设置两种状态。
    Qt::CheckState 枚举(无标志)
枚举成员说明
Qt::Unchecked0未选中
Qt::PartiallyChecked1部分被选中,项目中的子项目被选中(非全部),则项目就是部分状态
Qt::Checked2选中
  • void stateChanged(int state); //信号
    当复选按钮的状态发生变化时发送该信号。若复选按钮具有三态形式,则按钮会在“选
    中、未选中、部分选中”三种状态间变化,只要这三种状态变化都会发送该信号,但
    QAbstractButton::toggled()信号在三种状态间变化时,则不一定会发送。

QToolButton 类(工具按钮)

在这里插入图片描述

QToolButton 类中的属性

arrowType:Qt::ArrowType
访问函数:Qt::ArrowType arrowType() const;void setArrowType(Qt::ArrowType type);
此属性描述了是否显示一个箭头作为工具按钮的图标,默认为 Qt::NoArrow
autoRaise:bool
访问函数:bool autoRaise() const; void setAutoRaise(bool enable);
此属性描述了是否启用自动提升,默认为禁用(即为 false)。
popupMode:ToolButtonPopupMode
访问函数:ToolButtonPopupMode popupMode() const;
void setPopupMode(ToolButtonPopupMode mode);
此属性描述了弹出菜单的使用方式,默认为 QToolButton::DelayedPopup

枚举成员说明
QToolButton::DelayedPopup0按住工具按钮一段时间后显示菜单超时时间取决于样式
QToolButton::MenuButtonPopup1显示一个特殊的箭头,表示该工具按钮存在菜单,按下箭头时,会显示菜单
QToolButton::InstantPopup2按下工具按钮时,立即显示菜单。在此模式下,按钮本身的 action 不会被触发

toolButtonStyle:Qt::ToolButtonStyle
访问函数:Qt::ToolButtonStyle toolButtonStyle() const;
void setToolButtonStyle(Qt::ToolButtonStyle style); //槽
此属性描述了工具按钮图标和文本的显示方式,即仅显示文本、图标、还是图标和文本一起显示。 默认为 Qt::ToolButtonIconOnly (即仅显示图标)
QToolButton会自动把setToolButtonStyle()槽函数连接到QMainWindow中的相关信号。

QToolButton 类中的函数

QToolButton(QWidget* parent = Q_NULLPTR);
构造函数,需要注意的是,不能通过构造函数为工具按钮设置文本和图标。
QAction* defaultAction() const; //返回默认 QAction
QMenu* menu() const; //返回与此按钮关联的菜单,若没有菜单则返回 0。
void setDefaultAction(QAction* action) //槽
设置默认动作(action)为 action,若该按钮具有默认动作,则 action 定义按钮的属性,比如文本、图标等。
void setMenu(QMenu* menu); 设置与该按钮相关联的菜单,菜单的所有权不会传递到该按钮。
void showMenu() //槽
显示(弹出)与此按钮相关联的弹出式菜单,若没有这样的菜单,则什么也不做,在用户关闭该菜单之前,此函数不会返回。
void triggered(QAction * action) //信号
当触发给定的动作 action 时,发送此信号。该操作还可以与用户界面的其他部分相关联,比如菜单项、键盘快捷键等,以这种方式共享动作,可使用户界面操作更一致。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/14693.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Html中,想利用JS引入Jquery文件;$.getScript()无效

在使用$.getScript()时&#xff0c;会爆出错误&#xff1a;ReferenceError: $ is not defined &#xff0c;这是因为没有在JS文件前引入Jquery。 那么可以这样使用&#xff1a;(这个方式只适合放在页面代码最后面使用) (function () {var script window.document.createEleme…

Kettle简介

一、Kettle简介 Kettle是一个开源的ETL&#xff08;Extract-Transform-Load的缩写&#xff0c;即数据抽取、转换、装载的过程&#xff09;项目。 项目名很有意思&#xff0c;水壶。按项目负责人Matt的说法&#xff1a;把各种数据放到一个壶里&#xff0c;然后呢&#xff0c;以…

ComfyUI 本地部署指南:概念、部署过程、生成图片、共享 WebUI 模型

本文收录于《AI绘画从入门到精通》专栏&#xff0c;专栏总目录&#xff1a;点这里&#xff0c;订阅后可阅读专栏内所有文章。 大家好&#xff0c;我是水滴~~ 本文主要讲解 ComfyUI 的本地部署指南&#xff0c;内容主要包括&#xff1a;ComfyUI 的概念、ComfyUI 本地部署过程、使…

inventor 2021 Inventor 无法访问您的许可。网络许可不可用 也会出现在其他软件上

错误提示一般如下图 Inventor 无法访问您的许可。 无法访问您的许可 最常见的原因有: 未连接到 Internet许可服务器不工作许可服务器找不到有效许可 您可以执行以下操作: 检查是否连接到 Intemnet停止/重新启动许可服务器 如需进一步帮助&#xff0c;您可以: -与 CAD或IT管理…

【全开源】班级管家微信小程序(FastAdmin+ThinkPHP)

班级管家微信小程序 班级管家微信小程序&#xff0c;作为一款专注于家校沟通、作业管理、成绩发布等方面的工具&#xff0c;凭借其丰富的特色功能和显著的优势&#xff0c;已经成为广大教师、家长和学生日常学习生活中不可或缺的一部分。 一、特色功能 家校沟通便捷&#xff…

Vue3实现简单的瀑布流效果,可抽离成组件直接使用

先来看下效果图&#xff1a; 瀑布流中的内容可进行自定义&#xff0c;这里的示例图是通过不同背景颜色的展示进行区分&#xff0c;每个瀑布流中添加了自定义图片和文字描述。 实现方式&#xff1a; 1.建立子组件&#xff08;可单独抽离&#xff09;写出瀑布流的样式 文件名为…

数据结构之时间复杂度和空间复杂度的相关计算

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a;数据结构&#xff08;Java版&#xff09; 目录 时间复杂度 概念 大O的渐进表示法 相关练习 例1&#xff1a; 例2&#xff1a; 例3&am…

重磅推荐!四信AI智能一体屏系列全网上线

近年来&#xff0c;随着物联网、云计算、人工智能等新兴技术快速发展&#xff0c;制造、能源、交通、零售、医疗等行业设备需要更高程度的自动化控制。 传统的计算机和控制设备早已无法满足如今高性能复杂任务的要求&#xff0c;越来越多主流行业的项目落地依靠工控机&#xff…

Stanford-Coursera 算法Week1 笔记

题外话&#xff1a;全文免费放心食用&#xff0c;作者在此求个 三连关注 1. Integer Multiplication&#xff08;引入&#xff09; &#xff08;很小的时候我们就学过&#xff1a;两个数字相乘的算法——将输入(两个数字)转换为输出(它们的乘积)的一组定义良好的规则&#xf…

网络安全资源和参考指南

由美国国防部&#xff08;DoD&#xff09;发布的《网络安全资源和参考指南》&#xff0c;旨在为美国政府、商业部门以及美国盟友和伙伴之间的安全合作提供有用的、现成的参考资料。文档涵盖了网络安全规范、最佳实践、政策和标准&#xff0c;这些都是由美国联邦政府、国防部以及…

软件测试学习

软件测试学习 编辑时间&#xff1a;2024/5/17 0.理论学习 第一单元 Q开发工程师和测试工程师的关系理解 Q软件测试的目的和原则&#xff0c;识记、理解 为什么要进行软件测试 软件产品最终具备哪些功能由客户需求决定&#xff0c;客户需求如何转化为最终的软件产品要…

Wpf 使用 Prism 实战开发Day23

自定义对话框服务 当原有对话框不能满足需求的时候&#xff0c;可以通过自定义对话框来实现特殊的需求 一.自定义对话框主机服务步骤&#xff1a; 1.建立一个IDialogHostService 接口类&#xff0c;继承自 IDialogService 对话框服务类。并且自定义基类的服务方法。 public …

【嵌入式软件工程师面经】Socket,TCP,HTTP之间的区别

目录&#xff1a; 目录 目录&#xff1a; 一、Socket原理与TCP/IP协议 1.1 Socket概念&#xff1a; 1.2 建立Socket连接&#xff1a; 1.3 SOCKET连接与TCP/IP连接 二、HTTP连接&#xff1a; 2.1 HTTP原理 三、三者的区别和联系 前些天发现了一个巨牛的人工智能学习网站&#xf…

markdown 文件渲染工具推荐 obsidian publish

背景 Markdown 是一种轻量级的标记语言&#xff0c;最开始使用它是觉得码字非常方便&#xff0c;从一开始的 word 排版到 markdown &#xff0c;还不太不习惯&#xff0c;用了 obsidian把一些文字发在网上后&#xff0c;才逐渐发现他的厉害之处。 让人更加专注于内容本身&…

C语言 浮点数 打印的方法

一、方式1 在C语言中&#xff0c;浮点数&#xff08;通常包括 float 和 double 类型&#xff09;的打印是通过标准库中的 printf 函数完成的。为了正确地打印浮点数&#xff0c;需要使用格式说明符来指定如何格式化输出。 #include <stdio.h> int main(void) { floa…

体量小但增速快,国内OTA平台与国际巨头差在哪?

5月3日&#xff0c;Booking、Expedia等国际OTA平台相继发布2024年第一季度财报。5月21日&#xff0c;携程发布2024年第一季度财报。至此&#xff0c;国内外主要OTA平台一季度成绩单均已披露。 受益于全球旅游市场复苏&#xff0c;三家OTA平台一季度营收同比均正向增长。增长之…

03-ArcGIS For JavaScript结合ThreeJS功能

ArcGIS For JavaScript结合ThreeJS功能 概述three.js中功能实现externalRenderers&#xff08;4.28及以下版本&#xff09;RenderNode&#xff08;4.29版本&#xff09; 概述 ArcGIS For Javacript提供了一些对象可以支持加载webgl上下文信息&#xff0c;这里包括webgl编程的代…

基于jeecgboot-vue3的Flowable增加流程支持组件与element-plus组件导入支持

因为这个项目license问题无法开源&#xff0c;更多技术支持与服务请加入我的知识星球。 1、package.json文件需要增加相关流程组件&#xff0c;如下 "dependencies": {"element-plus/icons-vue": "^2.3.1","highlightjs/vue-plugin":…

蔬菜水果店做配送分销小程序的作用是什么

蔬菜水果是人们生活必需&#xff0c;传统为线下市场、超市、路边小摊等场景购买&#xff0c;如今快节奏时代&#xff0c;用户需要更快完成消费、商家也需要摆脱竞争获客转化以及提升自己的运营能力。 蔬菜水果隔三岔五或每天都会购买&#xff0c;老客粘性较高&#xff0c;还需…