本文介绍了进度条显示不正确的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有进度栏,并且我使用Qt样式表来绕过他的角落。问题是,当指标还没有达到20%的关口时,它不会被一侧舍入。

我附上截图是为了让它更清楚。

我猜这与我的Qt样式表有关。

u"QProgressBar:horizontal 
{

    border-radius: 15px;

    background: white;

}
"
"QProgressBar::chunk:horizontal 
{

    background-color: #7A859B;

    border-radius :15px;

}
"

推荐答案

问题是,如果将边框半径设置为大小小于边框半径之和的矩形(在正常情况下为直径),则用于绘制框架的绘制路径将变为矩形,这取决于绘制圆弧的方式。

遗憾的是,没有使用样式表的直接解决方案,我能想到的唯一选择就是子类化并重写playtEvent,然后使用样式使其认为当前值高于实际值。

在下面的示例中,我计算了较小值(假设为0)所需的最小宽度,然后根据当前值计算条形图的可能大小,然后根据上面可能的大小计算新的虚拟&q;值。

这样,最小值将始终为圆形,并相应地增加其宽度。

class Progress(QtWidgets.QProgressBar):
    def paintEvent(self, event):
        qp = QtWidgets.QStylePainter(self)
        opt = QtWidgets.QStyleOptionProgressBar()
        self.initStyleOption(opt)
        rect = self.style().subElementRect(QtWidgets.QStyle.SE_ProgressBarContents, opt, self)
        minSize = rect.height()
        grooveSize = rect.width() - minSize - 1
        valueRange = self.maximum() - self.minimum()
        offset = self.value() / valueRange * grooveSize
        newValue = (minSize + 1 + offset) / rect.width() * valueRange
        if int(newValue) != newValue:
            newValue = min(self.maximum(), newValue + 1)
        opt.progress = newValue
        qp.drawControl(QtWidgets.QStyle.CE_ProgressBar, opt)
请注意,这是一个非常简单的实现,它不检查范围是否有效,也不考虑方向和反转位置。在某些情况下,它可能根据大小显示为一个小矩形(我可能在某个地方放错了1个像素的差异)。

这篇关于进度条显示不正确的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!

10-29 16:41