目录
- 0.按钮状态说明
- 1.Push Button
- 2.Radio Button
- 3.Check Box
- 4.Tool Button
0.按钮状态说明
clicked
:⼀次 ⿏标按下+⿏标释放 触发pressed
:鼠标按下时触发released
:鼠标释放时触发toggled
:checked
属性改变时触发
1.Push Button
-
QPushButton
表⽰⼀个按钮 -
QPushButton
继承自QAbstractButton
,该类是一个抽象类,是其他按钮的父类
-
属性:
QAbstractButton
作为QWidget
的⼦类,也继承了QWidget
的属性- 之前介绍的
QWidget
⾥的属性⽤法,对于QAbstractButton
同样适⽤ - 因此以下仅列出
QAbstractButton
独有的属性
- 之前介绍的
QAbstractButton
中,和QPushButton
相关性较⼤的属性text
:按钮中的文本icon
:按钮中的图标iconSize
:按钮中图标的尺寸shortCut
:按钮对应的快捷键- 使用
setShortcut()
给按钮设置快捷键 - 参数是一个
QKeySequence
对象,表示一个案件序列,支持组合键- 构造函数参数,可以直接使⽤
"ctrl+c"
这样的按键名字符串表⽰ - 也可以使⽤预定义好的常量(形如
Qt::CTRL + Qt::Key_C
)表⽰
- 构造函数参数,可以直接使⽤
- 使用
autoRepeat
:当⿏标左键按住不放时,按钮是否会重复触发- 如果设为
true
,则会持续产⽣⿏标点击事件 - 如果设为
false
,则必须释放⿏标,再次按下⿏标时才能产⽣点击事件
- 如果设为
autoRepeatDelay
:重复触发的延时时间,按住按钮多久之后,开始重复触发autoRepeatInterval
:重复触发的周期
-
事实上,
QPushButton
的核⼼功能都是QAbstractButton
提供的,⾃⾝提供的属性都⽐较简单default
和audoDefault
影响的是按下Enter时⾃动点击哪个按钮的⾏为flat
把按钮设置为扁平的样式
-
示例:
// 设置图标 ui->pushButton_target->setIcon(QIcon(":/dog.png")); ui->pushButton_target->setIconSize(QSize(100, 100)); ui->pushButton_up->setIcon(QIcon(":/caret-up.png")); ui->pushButton_down->setIcon(QIcon(":/caret-down.png")); ui->pushButton_left->setIcon(QIcon(":/caret-left.png")); ui->pushButton_right->setIcon(QIcon(":/caret-right.png")); // 设置快捷键 ui->pushButton_up->setShortcut(QKeySequence("w")); ui->pushButton_down->setShortcut(QKeySequence("s")); ui->pushButton_left->setShortcut(QKeySequence("a")); ui->pushButton_right->setShortcut(QKeySequence("d")); // 设置快捷键也可以写作 // ui->pushButton_up->setShortcut(QKeySequence(Qt::Key_W)); // ui->pushButton_down->setShortcut(QKeySequence(Qt::Key_S)); // ui->pushButton_left->setShortcut(QKeySequence(Qt::Key_A)); // ui->pushButton_right->setShortcut(QKeySequence(Qt::Key_D));
2.Radio Button
QRadioButton
是单选按钮,可以在多个选项中选择⼀个- 属性:
- 作为
QAbstractButton
和QWidget
的⼦类,上⾯介绍的属性和⽤法,对于QRadioButton
同样适⽤ QAbstractButton
中和QRadioButton
关系较⼤的属性checkable
:能否被选中checked
:是否已经被选中,checkable
是checked
的前提条件autoExclusive
:是否排他- 选中⼀个按钮之后是否会取消其他按钮的选中
- 对于
QRadioButton
来说默认是排他的 - 可以通过
QButtonGroup
类对按钮进行分组,使用addButton()
来加入按钮,即可设置每一组按钮内部排他,但是组合组之间不排他
- 作为
3.Check Box
QCheckBox
表⽰复选按钮,可以允许选中多个- 属性:
- 和
QCheckBox
最相关的属性也是checkable
和checked
,都是继承自QAbstractButton
- 至于
QCheckBox
独有的属性tristate
,用来实现"三态复选框"
- 和
4.Tool Button
QToolButton
的⼤部分功能,和QPushButton
是⼀致的- 但是
QToolButton
主要应⽤在⼯具栏,菜单等场景
- 但是