如何解决如何动态设置 QProgressBar 样式表?
我正在尝试制作一个进度条,它可以根据滑块的值动态更改部分颜色。我现在最接近的是使用:
bar->setStyleSheet(QString("QProgressBar::chunk:vertical {background: qlineargradient(x1:0,y1:0,x2: 0,y2: 1,stop:0 red,stop:0.5 green); border-radius: 9px;}")
+QString("QProgressBar::vertical {border: 1px solid #b4adad; border-radius: 9px; background: #2f2828; padding: 0px; text-align: left; margin-right: 4ex;}"));
我尝试将第二个停止点设置为滑块->值(),这会带走整个样式表,留下一个空白的进度条。 我试过只使用 CSS 代码,这也带走了样式表:
{background: linear-gradient(to bottom,white 0%,blue 25%,blue 100%); border-radius: 9px;}"
我很困惑,因为我可以使用 CSS 来设置背景,但除非我使用 qlineargradient,否则我无法让它工作,这是为什么?需要做什么才能在 Qt 样式表中不受限制地实现 CSS?
是否可以将停止点的值设置为滑块的变化值?
我还尝试在 if 语句中使用 setStyleSheet 函数,以便样式表本身会根据进度条的值而改变:
if (bar->value()<slider->value()) {
然而,这不会动态更改样式表。似乎它在打开应用程序之前运行了一次 if 语句。 QT 是否会在应用程序打开时运行持续运行代码的 while 循环,还是我弄错了?
解决方法
从 https://doc.qt.io/qt-5/qprogressbar.html#valueChanged,有一个信号 void QProgressBar::valueChanged(int value)
,您可以连接到插槽并为 QProgressBar
sylesheet 进行所需的更改,例如:
void MainWindow::on_progressBar_valueChanged(int value)
{
if (value >= 0 && value < 50)
ui->progressBar->setStyleSheet("border: 2px solid grey; border-radius: 5px; text-align: center;");
else if (value >= 50 && value < 75)
ui->progressBar->setStyleSheet("background-color: #05B8CC; width: 20px;");
// and so on ...
}
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。