如何在 pyqt 中使 QRadioButton 圆圈变粗?
how to make the QRadioButton circle bold in pyqt?
我有一个 qradiobutton,我想像这张图片一样加粗
我试过这段代码,但我得到了一个正方形,我不能 select QradioButton:
import sys
from PyQt5 import QtWidgets
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
from PyQt5.QtCore import *
class main(QMainWindow):
def __init__(self):
super().__init__()
self.setGeometry(50, 50, 600, 500)
self.Qradio = QRadioButton('click', self)
self.Qradio.move(50, 50)
self.Qradio.setStyleSheet(''' QRadioButton::indicator {border : 2px solid black;}''')
if __name__ == "__main__":
app = QApplication(sys.argv)
mai = main()
mai.show()
app.exec()
我能想到的唯一可能性是使用样式表将 border-radius 设置为单选指示器大小的一半,以获得“圆”。
您可以根据当前样式使用默认单选指示器大小:
size = self.style().pixelMetric(QStyle.PM_ExclusiveIndicatorWidth)
self.Qradio.setStyleSheet('''
QRadioButton::indicator {{
border: 2px solid black;
border-radius: {}px;
}}
QRadioButton::indicator:checked {{
background: rgb(64, 64, 64);
}}
'''.format(size // 2))
否则请自行设置,确保根据边框宽度正确计算尺寸:
size = 25
border = 2
self.Qradio.setStyleSheet('''
QRadioButton::indicator {{
border: {border}px solid black;
height: {size}px;
width: {size}px;
border-radius: {radius}px;
}}
QRadioButton::indicator:checked {{
background: rgb(64, 64, 64);
}}
'''.format(size=size - border * 2, border=border, radius=size // 2))
你甚至可以用一个小技巧得到一个内圆:一个径向渐变,它有一个与边界成一定比例的“边界”:
size = 20
border = 2
self.Qradio.setStyleSheet('''
QRadioButton::indicator {{
border: {border}px solid black;
height: {size}px;
width: {size}px;
border-radius: {radius}px;
}}
QRadioButton::indicator:checked {{
background: qradialgradient(
cx:.5, cy:.5, radius: {innerRatio},
fx:.5, fy:.5,
stop:0 {checkColor},
stop:0.45 {checkColor},
stop:0.5 transparent,
stop:1 transparent
);
}}
'''.format(
size=size - border * 2,
border=border,
radius=size // 2,
innerRatio=1 - (border * 2 + 1) / size,
checkColor='#056060'
))
我有一个 qradiobutton,我想像这张图片一样加粗
我试过这段代码,但我得到了一个正方形,我不能 select QradioButton:
import sys
from PyQt5 import QtWidgets
from PyQt5.QtWidgets import *
from PyQt5.QtGui import *
from PyQt5.QtCore import *
class main(QMainWindow):
def __init__(self):
super().__init__()
self.setGeometry(50, 50, 600, 500)
self.Qradio = QRadioButton('click', self)
self.Qradio.move(50, 50)
self.Qradio.setStyleSheet(''' QRadioButton::indicator {border : 2px solid black;}''')
if __name__ == "__main__":
app = QApplication(sys.argv)
mai = main()
mai.show()
app.exec()
我能想到的唯一可能性是使用样式表将 border-radius 设置为单选指示器大小的一半,以获得“圆”。
您可以根据当前样式使用默认单选指示器大小:
size = self.style().pixelMetric(QStyle.PM_ExclusiveIndicatorWidth)
self.Qradio.setStyleSheet('''
QRadioButton::indicator {{
border: 2px solid black;
border-radius: {}px;
}}
QRadioButton::indicator:checked {{
background: rgb(64, 64, 64);
}}
'''.format(size // 2))
否则请自行设置,确保根据边框宽度正确计算尺寸:
size = 25
border = 2
self.Qradio.setStyleSheet('''
QRadioButton::indicator {{
border: {border}px solid black;
height: {size}px;
width: {size}px;
border-radius: {radius}px;
}}
QRadioButton::indicator:checked {{
background: rgb(64, 64, 64);
}}
'''.format(size=size - border * 2, border=border, radius=size // 2))
你甚至可以用一个小技巧得到一个内圆:一个径向渐变,它有一个与边界成一定比例的“边界”:
size = 20
border = 2
self.Qradio.setStyleSheet('''
QRadioButton::indicator {{
border: {border}px solid black;
height: {size}px;
width: {size}px;
border-radius: {radius}px;
}}
QRadioButton::indicator:checked {{
background: qradialgradient(
cx:.5, cy:.5, radius: {innerRatio},
fx:.5, fy:.5,
stop:0 {checkColor},
stop:0.45 {checkColor},
stop:0.5 transparent,
stop:1 transparent
);
}}
'''.format(
size=size - border * 2,
border=border,
radius=size // 2,
innerRatio=1 - (border * 2 + 1) / size,
checkColor='#056060'
))