在循环中创建PyQt5按钮:所有按钮触发相同的回调

时间:2018-03-08 23:22:25

标签: python linux pyqt pyqt5 qpushbutton

我应该提一下,我已经读过这些但我仍然无法实现我的目标:

[Using a dictionary in a for loop to create buttons doesn't work

[QtCore.QObject.connect in a loop only affects the last instance

我的目标是制作一个linux'启动器'应用程序。按钮创建,放置等工作就像一个魅力,但有一个问题 - 所有按钮触发相同的回调 - 最后一个要在按钮创建循环中连接。

这是脚本的基本版本,用于说明我正在尝试做的事情:

class App(QMainWindow):

    def launch(self, filepath):
        subprocess.run(filepath)


    def __init__(self):
        super(App, self).__init__()

        for btn in matrix:

            filepath = matrix[btn]['path']
            icon = matrix[btn]['setIcon']
            posx = matrix[btn]['posx']
            posy = matrix[btn]['posy']

            matrix[btn] = QToolButton(self)
            matrix[btn].setIcon(QIcon(icon))
            matrix[btn].setIconSize(QSize(64, 64))
            matrix[btn].resize(100, 100)
            matrix[btn].move(posx, posy)
            matrix[btn].clicked.connect(lambda launch: self.launch(filepath))

        self.initUI()


    def initUI(self):

        self.setGeometry(150, 150, 1250, 650)
        self.setWindowTitle('LinuxLauncher')

        self.show()


    if __name__ == '__main__':

        app = QApplication(sys.argv)
        ex = App()
        sys.exit(app.exec_())

我知道有一个答案,但我已经有好几个小时了 - 我很感激有人可以帮我解决这个问题 - 谢谢!

1 个答案:

答案 0 :(得分:3)

我不明白矩阵是什么类型的结构,但我认为它相当于一个字典列表。

问题是你必须作为参数传递给分配它的lambda函数,点击的信号将一个布尔值作为参数,指示是否选中了按钮(默认情况下,此属性被禁用,以便值为false),您必须添加另一个参数。

class App(QMainWindow):
    def launch(self, filepath):
        subprocess.run(filepath)

    def __init__(self):
        super(App, self).__init__()

        matrix = [{"path": "path1", "setIcon": "icon1", "posx": 0, "posy": 0}, 
        {"path": "path2", "setIcon": "icon2", "posx": 0, "posy": 150},
        {"path": "path3", "setIcon": "icon3", "posx": 0, "posy": 300}]

        for value in matrix:

            filepath = value['path']
            icon =  value['setIcon']
            posx = value['posx']
            posy = value['posy']

            btn = QToolButton(self)
            btn.setIcon(QIcon(icon))
            btn.setIconSize(QSize(64, 64))
            btn.resize(100, 100)
            btn.move(posx, posy)
            btn.clicked.connect(lambda checked, arg=filepath: self.launch(arg))

        self.initUI()

    def initUI(self):
        self.setGeometry(150, 150, 1250, 650)
        self.setWindowTitle('LinuxLauncher')
        self.show()