【问题标题】:how to make the QRadioButton circle bold in pyqt?如何在pyqt中使QRadioButton圆圈变​​粗?
【发布时间】:2021-05-27 03:38:27
【问题描述】:

我有一个 qradiobutton,我想像这张图片一样加粗

我尝试了这段代码,但我得到了一个正方形,我无法选择 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()

【问题讨论】:

    标签: python pyqt pyqt5


    【解决方案1】:

    我能想到的唯一可能是,使用样式表,将边框半径设置为单选指示器大小的一半,以获得“圆形”。

    您可以根据当前样式使用默认的单选指标大小:

            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'
            ))
    

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2021-10-15
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多