我有进度条,我使用 Qt StyleSheet 来圆他的角。 问题是当指标没有达到 20% 标记时,它的一侧没有圆整。
我附上了屏幕截图以使其更清晰。
我想这与我的 Qt 样式表有关。
u"QProgressBar:horizontal
{\n
border-radius: 15px;\n
background: white;\n
}\n"
"QProgressBar::chunk:horizontal
{\n
background-color: #7A859B;\n
border-radius :15px;\n
}\n"
答案 0 :(得分:0)
问题是将边框半径设置为大小小于边框半径之和(正常情况下为直径)的矩形,用于绘制框架的画家路径变为矩形,由于绘制圆弧的方式。
不幸的是,没有使用样式表的直接解决方案,我能想到的唯一选择是子类化并覆盖paintEvent,然后“欺骗”样式使其认为当前值高于实际值。< /p>
在下面的示例中,我正在计算小值所需的最小宽度(我假设为 0),然后根据当前值评估条形的可能大小,然后计算新的“虚拟”值基于上述可能的大小。
这样,最小值永远是一个圆,它的宽度也会相应增加。
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 个像素的差异)。