Featured image of post Qt QPushButton clicked信号浅析

Qt QPushButton clicked信号浅析

通常,使用 Qt 的 QPushButton clicked 点击信号时未带参数,简要分析信号中的 checked 参数的触发场景和作用

前言

Qt 的 QPushButton clicked 信号原型:

1
void clicked(bool checked = false);

通常,使用 Qt 的 QPushButton clicked 点击信号时,会以如下方式使用:

1
2
3
connect(ui->pushButton, &QPushButton::clicked, this, [](){
    qDebug()<<"clicked";
});

也就是不带 clicked() 信号参数。而今天,简单分析一下,void clicked(bool checked = false) 信号中的 checked 参数的触发场景和作用。

分析

信号解释:

1
void clicked(bool checked = false);

按钮被激活(即,鼠标光标在按钮内部时按下然后释放),快捷键被输入,或者调用了 click()animateClick() 方法。值得注意的是,如果你调用了 setDown()setChecked()toggle(),则不会发出此信号。

如果按钮是可勾选的,如果按钮被选中,则 checkedtrue;如果按钮未被选中,则 checkedfalse。也就是说,当QPushButton setCheckable()设置为true时,才能使得checkedtrue

1
2
3
4
ui->pushButton->setCheckable(true);
connect(ui->pushButton, &QPushButton::clicked, this, [](auto checked){
    qDebug()<<checked;
});

设置setCheckable()设置为true后,第一次点击,checked将为true, 按钮变为蓝色,第二次则为false

总结

所以,如果要使用clicked(bool checked = false) 信号中的 checked 参数,需要设置 setCheckable(true)

Licensed under CC BY-NC-SA 4.0