QAbstractButton是有关“按钮”的基类

描述了一个按钮应该具有的组成。它的公有函数如下:

QAbstractButton(QWidget * parent = )
~QAbstractButton() QIcon icon() const//按钮上的图标
QSize iconSize() const void setAutoExclusive(bool)//自动互斥,设置后,同属一个父对象的按钮将表现为一个选中(checked),另一个自动转为未选,默认false
void setAutoRepeat(bool)
void setAutoRepeatDelay(int)
void setAutoRepeatInterval(int)
void setCheckable(bool)//设置是否可选中
void setDown(bool)//设置是否按钮按下,和checked效果一样,但信号pressed()和clicked()不再发送
void setIcon(const QIcon & icon)//设置图标
void setShortcut(const QKeySequence & key)//设置快捷键
void setText(const QString & text)//设按钮上的文件 QKeySequence shortcut() const
QButtonGroup * group() const//返回按钮所属的组
QString text() const bool isCheckable() const
bool isChecked() const
bool isDown() const bool autoRepeat() const
int autoRepeatDelay() const
int autoRepeatInterval() const
bool autoExclusive() const

windows的checked(如图右)

信号有:

Signals
void clicked(bool checked = false)//点击(按下后放开)
void pressed()//按下
void released()//放开时发送
void toggled(bool checked)

toggled是切换的意思,只有状态变化时触发,对按钮,当它设置checkble为true时,点击后,从未按下的普通状态转变成按下的选中状态,这时将发送toggled信号。

槽函数有:

Public Slots
void animateClick(int msec = )//在按下到松开的时间内,按msec(毫秒)参数计时,不断地重复调用这个槽
void click()
void setChecked(bool)
void setIconSize(const QSize & size)
void toggle()

——————————————————————————————————————————————————————

QPushButton是最为常用的小部件了,它有如下函数:

QPushButton(QWidget * parent = )
QPushButton(const QString & text, QWidget * parent = )
QPushButton(const QIcon & icon, const QString & text, QWidget * parent = )
~QPushButton()
bool autoDefault() const
bool isDefault() const
bool isFlat() const
QMenu * menu() const
void setAutoDefault(bool)
void setDefault(bool)//设置为“默认”时,窗口的默认焦点就在它上面,按Enter键时,相当于点击了它
void setFlat(bool)//平面化,不绘制按钮的背景,设置后,外观与标签相似
void setMenu(QMenu * menu)//将这个按钮转化成一个带有向下小箭头的下拉菜单按钮

信号与槽部分,主要与上述抽象按钮相同。

但它多了以下槽,用于显示菜单

void    showMenu()  

示例及菜单效果如下:

——————————————————————————————————————————————————————

QCommandLinkButton为"命令链接按钮"

用于程序的界面切换,如一般程序安装时的下一步,表示将打开一个新窗口,外观类似于一个Flat按钮,如上图。

函数如下:

QCommandLinkButton(QWidget * parent = )
QCommandLinkButton(const QString & text, QWidget * parent = )
QCommandLinkButton(const QString & text, const QString & description, QWidget * parent = )
~QCommandLinkButton()
QString description() const
void setDescription(const QString & description)//在按钮下方添加描述,按钮尺寸过小时会隐藏

QToolButton为工具按钮,可用于制作一个弹出菜单。

公有函数如下:

(Arrow为箭头,是图标,Qt自带一些常用的图标)

QToolButton(QWidget * parent = )
~QToolButton()
Qt::ArrowType arrowType() const
bool autoRaise() const
QAction * defaultAction() const
QMenu * menu() const
ToolButtonPopupMode popupMode() const//弹出模式
void setArrowType(Qt::ArrowType type)//设置图标
void setAutoRaise(bool enable)//是否自动升高,外观,与扁平Flat相对
void setMenu(QMenu * menu)//添加菜单
void setPopupMode(ToolButtonPopupMode mode)//设置弹出模式,为枚举型
Qt::ToolButtonStyle toolButtonStyle() const

弹出模式有如下

enum    ToolButtonPopupMode { DelayedPopup, MenuButtonPopup, InstantPopup }  

DelayedPopup为延迟弹出(默认),持续按下一定时间后弹出菜单;MenuButtonPopup, 在按钮右方显示一个小箭头,按下后就弹出;InstantPopup,点击后即刻弹出
setArrowType可设置图标(无图标与上下左右箭头)下方示例即使用了向左箭头:

Constant Value
Qt::NoArrow 0
Qt::UpArrow 1
Qt::DownArrow 2
Qt::LeftArrow 3
Qt::RightArrow 4

示例代码如下

//工具按钮制作弹出菜单
QMenu *menu=new QMenu();
menu->addMenu(tr(""));
menu->addMenu(tr(""));
menu->addMenu(tr(""));
ui->toolButton->setArrowType(Qt::LeftArrow);
ui->toolButton->setPopupMode(QToolButton::MenuButtonPopup);
ui->toolButton->setMenu(menu);

效果如下:

它还有如下槽函数:

void    setDefaultAction(QAction * action)
void setToolButtonStyle(Qt::ToolButtonStyle style)// 用于设置样式,如显示文本的位置等
void showMenu()
Constant Value Description
Qt::ToolButtonIconOnly 0 只显示图标
Qt::ToolButtonTextOnly 1 只显示文本
Qt::ToolButtonTextBesideIcon 2 文本显示在图标旁
Qt::ToolButtonTextUnderIcon 3 文本显示在图标下方
Qt::ToolButtonFollowStyle 4 Follow the style.

——————————————————————————————————————————————————————

QRadioButton(单选按钮)与QCheckBox(复选框)

用于用户对多个选项的选择,正如它们的名字一个,它们分别一般用于多个中选其中一个及多个中选择多个。

如果多个QRadioButton处于同一个父对象中,他们会互斥,也就是说只能选中其中的一个;而QCheckBox则不一样,它们默认是可多选的,除非设置互斥。

它们外观如下(左方为单选按钮):

使用时,主要用if检查它们是否被选中(checked)

if(RadioButton1->isChecked)

{

}

也可以使用从它们父对象中继承来的下列槽函数:

void    clicked(bool checked = false)
void toggled(bool checked)

QCheckBox支持三种状态的变化,所谓三态,即除了未选中及选中外还有第三种状态,官网叫做PartiallyChecked(部分选中)。

它的函数如下:

QCheckBox(QWidget * parent = )
QCheckBox(const QString & text, QWidget * parent = )
~QCheckBox()
Qt::CheckState checkState() const//判断所处的状态
bool isTristate() const
void setCheckState(Qt::CheckState state)//设置处于三态中的一态
void setTristate(bool y = true)//设置三态的支持,默认不支持

判断所处的状态,Qt::CheckState的值有如下:

Qt::Unchecked 0 未选中
Qt::PartiallyChecked 1 部分选中
Qt::Checked 2 选中

第三态外观如下:

Qt Widgets——抽象按钮及其继承类的更多相关文章

  1. Qt Widgets——抽象滑块及其继承类

    三个可视类的默认外观分别如下(win7):它们的滑块都处于最小值0处. 理解QAbstractSlider时 可将它想成就是QScrollBar(该小部件的外观比较多地拥有QAbstractSlide ...

  2. Qt Widgets——抽象旋转框及其继承类

    默认外观分别如下(win7,与上述顺序对应): 可看出,都是由一个可编辑的文本框及右端小箭头组成 QAbstractSpinBox 属性简单解释如下: Properties accelerated : ...

  3. Qt Widgets、QML、Qt Quick的区别

    Qt Widgets.QML.Qt Quick的区别 简述 看了之前关于 QML 的一些介绍,很多人难免会有一些疑惑: Q1:QML 和 Qt Quick 之间有什么区别? Q2:QtQuick 1. ...

  4. Qt Widgets——主窗口及其主要组成部分

    Main Window and Related Classes QAction 动作类,用于当做一个菜单项或工具项插入菜单或工具栏 QActionGroup 动作组,用于管理多个动作,设置它们之间的互 ...

  5. QEvent整理归纳:140种类型,29个继承类,7个函数,3种事件来源

    140种事件类型: QEvent::None QEvent::AccessibilityDescription QEvent::AccessibilityHelp QEvent::Accessibil ...

  6. Asp.net MVC中三大描述对象之ActionDescriptor 以及继承类ReflectedControllerDescriptor

    ActionDescriptor抽象类中几个基本的属性: ControllerName:被描述的Controller名称,去除后缀Controller的名称.例如:HomeController则为Ho ...

  7. 【QT相关】Qt Widgets Module

    Qt Widgets Module:提供了一些列UI元素. 使用: //头文件包含 #include <QtWidgets> //链接模式,在.pro文件中添加行: QT += widge ...

  8. Qt4项目迁移到Qt5问题:greaterThan(QT_MAJOR_VERSION, 4): QT += widgets .

    文章来源:http://blog.csdn.net/ccf19881030/article/details/18220447 问题一:错误:C1083: 无法打开包括文件:"QApplica ...

  9. python定义接口继承类

    zxq547 python定义接口继承类invalid syntax解决办法 1 2 3 4 5 6 7 class s_all(metaclass=abc.ABCMeta):     #python ...

随机推荐

  1. vs编译出现 fatal error LNK1281:无法生成 SAFESEH 映像

    问题: 在vs编译中我们有时候常常会见到这样的错误,无法生成 SAFESEH 映像,镜像安全问题 解决方法: 1.打开该项目的"属性页"对话框. 2.单击"链接器&quo ...

  2. 小程序之取标签中内容 例如view,text

    // index.wxml页面 data-url为自定义 {{}}中内容可为后台请求到的数据 也可为固定内容例如:data-text="哈哈哈" data-url="ht ...

  3. 前端分页插件bootstrapPaginator的使用

     引入bootstrap-paginator.js <table class="table table-striped table-bordered table-hover dataT ...

  4. C#:CsvReader读取.CSV文件(转换成DataTable)

    原文引用:https://www.codeproject.com/Articles/9258/A-Fast-CSV-Reader using LumenWorks.Framework.IO.Csv; ...

  5. 安装logstash和logstash-input-jdbc

    一.安装logstash 1.mac 下直接 brew install logstash 二.安装logstash-input-jdbc 直接在logstash的安装目录bin下运行 ./logsta ...

  6. 设计模式(三)Singleton Pattern单例设计模式

    1.饿汉式 public class SingletonDemo { private static SingletonDemo s=new SingletonDemo(); private Singl ...

  7. 《剑指offer》第四十七题(礼物的最大价值)

    // 面试题47:礼物的最大价值 // 题目:在一个m×n的棋盘的每一格都放有一个礼物,每个礼物都有一定的价值 // (价值大于0).你可以从棋盘的左上角开始拿格子里的礼物,并每次向左或 // 者向下 ...

  8. 约瑟夫环(Joseph)的高级版(面向事件及“伪链表””)

    约瑟夫环问题: 在一间房间总共有n个人(下标0-n-1),只能有最后一个人活命. 按照如下规则去杀人: 所有人围成一圈 顺时针报数,每次报到q的人将被杀掉 被杀掉的人将从房间内被移走 然后从被杀掉的下 ...

  9. ThinkPHP实用项

    跟踪信息 – 两种模式 – Sql调试 – 性能调试

  10. idea javamaven项目 连接sqlserver 数据库方法

    这里用的是c3p0连接数据库 1.pom文件写法: <!-- 数据库连接池 --> <dependency> <groupId>com.mchange</gr ...