本文介绍了进度条显示不正确的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有进度栏,并且我使用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个像素的差异)。 这篇关于进度条显示不正确的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持!