如何动态设置 QProgressBar 样式表?

Posted

技术标签:

【中文标题】如何动态设置 QProgressBar 样式表?【英文标题】:How to set QProgressBar stylesheet dynamically? 【发布时间】:2021-04-05 17:45:19 【问题描述】:

我正在尝试制作一个进度条,它可以根据滑块的值动态更改部分颜色。我现在最接近的方法是使用:

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;"));

我尝试将第二个停止点设置为 slider->value(),它会带走整个样式表,留下一个空白的进度条。 我试过只使用 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 循环,该循环会在应用程序打开时连续运行代码还是我弄错了?

【问题讨论】:

【参考方案1】:

来自https://doc.qt.io/qt-5/qprogressbar.html#valueChanged,有一个信号void QProgressBar::valueChanged(int value),您可以连接到一个插槽并为QProgressBar 样式表进行所需的更改,例如:

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 ...

【讨论】:

以上是关于如何动态设置 QProgressBar 样式表?的主要内容,如果未能解决你的问题,请参考以下文章

如何在 QT 中获得具有圆形边缘和圆形进度边缘的 QProgressBar?

27.QT-QProgressBar动态实现多彩进度条(详解)

[Qt]自定义QStyle——实现QProgressBar自定义样式

QT软件开发之基础控件--2.5.2 QProgressBar进度条

加载具有依赖于页面视图的动态值的样式表

HTML JS动态设置CSS样式