0

单击按钮时,我更改了图像,就好像它被选中了一样...

在此处输入图像描述

为了进行此更改,我为每个人保留默认图像并仅更改按下的按钮,但这 3 行导致程序延迟 2 秒

main_app.ui.btn_tela_atividade_clique_na_imagem.setStyleSheet(style + "clique na figura off.png);}")
main_app.ui.btn_tela_atividade_clique_na_letra.setStyleSheet(style + "clique na letra que falta off.png);}")  
main_app.ui.btn_tela_atividade_digt_nome_imagem.setStyleSheet(style + "digite o nome da figura off.png);}")

这是函数的调用方式

主文件

def atv_escolhida(self, nome_atividade):    
        self.atividades.atividade_escolhida_fun(self, nome_atividade)

atividades.py

def atividade_escolhida_fun(self, main_app, nome_atividade):
        # main_app = self da classe main.py
        # self.set_atividade_escolhida(nome_atividade)
        self.atividade_escolhida = nome_atividade

        style = """
        QPushButton:hover {
            border: 2px solid rgb(0, 0, 0);
        }
        QPushButton{
            border-image: url(:/atvimg/app_imagens/"""

        # TODO verificar isso
        main_app.ui.btn_tela_atividade_clique_na_imagem.setStyleSheet(style + "clique na figura off.png);}")
        main_app.ui.btn_tela_atividade_clique_na_letra.setStyleSheet(style + "clique na letra que falta off.png);}")  
        main_app.ui.btn_tela_atividade_digt_nome_imagem.setStyleSheet(style + "digite o nome da figura off.png);}")
        
        if(nome_atividade == "tela_atividade_digt_nome_imagem"):
            main_app.ui.btn_tela_atividade_digt_nome_imagem.setStyleSheet(style + "digite o nome da figura on.png);}")
        elif(nome_atividade == "tela_atividade_clique_na_imagem"):
            main_app.ui.btn_tela_atividade_clique_na_imagem.setStyleSheet(style + "clique na figura on.png);}")
        elif(nome_atividade == "tela_atividade_clique_na_letra"):
            main_app.ui.btn_tela_atividade_clique_na_letra.setStyleSheet(style + "clique na letra que falta on.png);}")
4

1 回答 1

0

相反,重新分配样式表,您可以使用具有两个(或多个)特定小部件外观的固定样式表,具体取决于QObject. widget.setProperty(propName, propValue)用和改变动态属性style.unpolish(widget)style.polish(widget)。这可以解决延迟问题。我用background-color而不是图像来展示概念。请采纳给border-image自己。

from PyQt5 import QtWidgets

class View(QtWidgets.QWidget):
    def __init__(self, parent = None):
        super().__init__(parent)
        layout = QtWidgets.QVBoxLayout()
        buttons = []
        for i in range(3):
            name = "button{}".format(i+1)
            button = QtWidgets.QPushButton()
            button.setObjectName(name)
            layout.addWidget(button)
            button.setProperty("selected", False)
            button.setSizePolicy(QtWidgets.QSizePolicy.Preferred, QtWidgets.QSizePolicy.Preferred)
            button.clicked.connect(lambda on, i=i: self.setSelected(i))
            buttons.append(button)
        self._buttons = buttons
        self.setLayout(layout)
        self.setStyleSheet("""
        QPushButton:hover { border: 2px solid rgb(0, 0, 0);}
        #button1[selected="false"] {background-color: #cccccc;}
        #button2[selected="false"] {background-color: #cccccc;}
        #button3[selected="false"] {background-color: #cccccc;}

        #button1[selected="true"] {background-color: #ccccff;}
        #button2[selected="true"] {background-color: #ccffcc;}
        #button3[selected="true"] {background-color: #ffcccc;}
        """)

    def setSelected(self, i):
        style = self.style()
        for j, button in enumerate(self._buttons):
            button.setProperty("selected", i == j)
            style.unpolish(button)
            style.polish(button)

if __name__ == "__main__":
    app = QtWidgets.QApplication([])
    view = View()
    view.show()
    app.exec()
于 2021-05-02T20:30:23.250 回答