首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >更改image样式表映像时延迟2秒

更改image样式表映像时延迟2秒
EN

Stack Overflow用户
提问于 2021-05-02 07:27:33
回答 1查看 56关注 0票数 0

单击按钮时,我会更改图像,就好像它已被选中一样。

要进行此更改,我让每个人都使用默认图像,只需更改按下的按钮,但这3行代码会导致程序延迟2秒

代码语言:javascript
复制
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);}")

下面是该函数的调用方式

main.py

代码语言:javascript
复制
def atv_escolhida(self, nome_atividade):    
        self.atividades.atividade_escolhida_fun(self, nome_atividade)

atividades.py

代码语言:javascript
复制
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);}")
EN

回答 1

Stack Overflow用户

发布于 2021-05-03 04:30:23

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

代码语言:javascript
复制
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()
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67351706

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档