gpt4 book ai didi

c++ - 如何使用Qt实现三态按钮

转载 作者:搜寻专家 更新时间:2023-10-31 02:10:34 25 4
gpt4 key购买 nike

我需要创建一个具有三种状态的按钮:

  • 未点击
  • 中级
  • 点击

我想用这个按钮实现的逻辑是,每当这个按钮被点击时,我希望系统进入中间状态并等待一个事件。

换句话说,当状态转换为 unclicked --> intermediate --> clicked 然后 clicked --> intermediate -->unclicked

Qt 支持实现这种按钮吗?如果是,怎么办?

最佳答案

离你最近的是QCheckBox。它已经有一个属性:QCheckBox::setTristate :

auto yourCheckBoxButton = new QCheckBox("Tristate button");
yourCheckBoxButton->setTristate(true);

您也可以在设计器上执行此操作(它位于属性列表的末尾)。

如果你不想使用QCheckBox,一个样式表和一个每次按下按钮时修改的自定义属性都可以做到:

auto pushButton = new QPushButton("Tristate button");
pushButton->setProperty("state", 0);
pushButton->setProperty("state-step", 1); // change to next state, 1 or -1
pushButton->setStyleSheet("QPushButton[state=\"0\"] { background: red; }"
"QPushButton[state=\"1\"] { background: grey; }"
"QPushButton[state=\"2\"] { background: blue; }");
connect(pushButton, &QPushButton::clicked, [ = ](bool) {
const int state = pushButton->property("state").toInt();
const int step = state == 0 ? 1 :
state == 2 ? -1 : pushButton->property("state-step").toInt();
pushButton->setProperty("state", state + step);
pushButton->setProperty("state-step", step); // update in case it changed

// Changing the property is not enough to choose a new style from the stylesheet,
// it is necessary to force a re-evaluation
pushButton->style()->unpolish(pushButton);
pushButton->style()->polish(pushButton);
});

其他更详细的选项是使用 QProxyStyle或者重新实现 QPushButton 类本身。

关于c++ - 如何使用Qt实现三态按钮,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/45030504/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com