我能想到的唯一可能性是,使用样式表将边框半径设置为单选指示器大小的一半,以获得一个“圆圈”。
您可以根据当前样式使用默认的单选指示器大小:
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))
您甚至可以获得inner使用一个小技巧来画圆:一个径向渐变,它有一个与边界成一定比例的“边界”:
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'
))