progressbar is incorrect displayed(进度条显示不正确)
本文介绍了进度条显示不正确的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!
问题描述
我有进度栏,并且我使用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个像素的差异)。
这篇关于进度条显示不正确的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!
沃梦达教程
本文标题为:进度条显示不正确
基础教程推荐
猜你喜欢
- Plotly:如何设置绘图图形的样式,使其不显示缺失日期的间隙? 2022-01-01
- 修改列表中的数据帧不起作用 2022-01-01
- 在同一图形上绘制Bokeh的烛台和音量条 2022-01-01
- 求两个直方图的卷积 2022-01-01
- 包装空间模型 2022-01-01
- PermissionError: pip 从 8.1.1 升级到 8.1.2 2022-01-01
- 使用大型矩阵时禁止 Pycharm 输出中的自动换行符 2022-01-01
- 在Python中从Azure BLOB存储中读取文件 2022-01-01
- PANDA VALUE_COUNTS包含GROUP BY之前的所有值 2022-01-01
- 无法导入 Pytorch [WinError 126] 找不到指定的模块 2022-01-01
