从可变按钮数PyQ获取颜色

2024-04-25 22:26:10 发布

您现在位置:Python中文网/ 问答频道 /正文

我正试图得到球员的名字和颜色,他们在项目的下一步选择。获得名字很容易,但是颜色有点麻烦。
我不知道如何获得选定的颜色,并应用它的按钮使用QColorDialog。最终的目标是得到一个结构,玩家的名字与他们选择的颜色相关联。
以下是我所拥有的:

from PyQt5.QtWidgets import (
    QLineEdit,
    QWidget,
    QApplication,
    QLabel,
    QMainWindow,
    QGridLayout,
    QColorDialog,
    QPushButton,
    QVBoxLayout,
    QHBoxLayout,
)
import sys

class NamesPlayers(QMainWindow):
    """ name screen, ask the names of the players """

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

        self.layout_widget = QWidget()

        self.player_names = []
        self.player_colors = []

        main_layout = QVBoxLayout()
        names_layout = QGridLayout()
        button_layout = QHBoxLayout()

        button_list = []

        for i in range(nb_players):
            label = QLabel("Name :")
            player_name = QLineEdit()
            color_button = QPushButton("Color")
            color_button.setStyleSheet("background-color: white")
            names_layout.addWidget(label, i, 0)
            names_layout.addWidget(player_name, i, 1)
            names_layout.addWidget(color_button, i, 2)
            button_list.append(color_button)
            self.player_names.append(player_name)
            self.player_colors.append(color_button.styleSheet())

        self.confirm_button = QPushButton("Confirm")

        button_layout.addWidget(self.confirm_button)

        main_layout.addLayout(names_layout)
        main_layout.addLayout(button_layout)

        for button in button_list:
            button.clicked.connect(self.open_colordialog)

        self.layout_widget.setLayout(main_layout)

        self.setCentralWidget(self.layout_widget)

    def open_colordialog(self):
        color_dialog = QColorDialog()
        color_dialog.exec_()

if __name__ == "__main__":
    app = QApplication(sys.argv)
    window = NamesPlayers(4)
    window.show()
    app.exec_()

我想我的主要问题是,颜色的按钮数量可能不同,当我点击这些按钮时,QColorDialog的地址总是一样的,这不是我想要的

感谢您的帮助


Tags: nameselfnames颜色mainbutton名字按钮
1条回答
网友
1楼 · 发布于 2024-04-25 22:26:10

一种可能的解决方案是使用sender()方法按下按钮:

import sys

from PyQt5 import QtCore, QtWidgets


class NamesPlayers(QtWidgets.QMainWindow):
    """ name screen, ask the names of the players """

    def __init__(self, nb_players, parent=None):
        super().__init__(parent)

        names_layout = QtWidgets.QGridLayout()

        for i in range(nb_players):
            label = QtWidgets.QLabel("Name :")
            player_name = QtWidgets.QLineEdit()

            color_button = QtWidgets.QPushButton("Color")
            color_button.setStyleSheet("background-color: white")
            color_button.clicked.connect(self.open_colordialog)

            names_layout.addWidget(label, i, 0)
            names_layout.addWidget(player_name, i, 1)
            names_layout.addWidget(color_button, i, 2)

        self.confirm_button = QtWidgets.QPushButton("Confirm")

        central_widget = QtWidgets.QWidget()
        main_layout = QtWidgets.QVBoxLayout(central_widget)
        button_layout = QtWidgets.QHBoxLayout()
        button_layout.addWidget(self.confirm_button)
        main_layout.addLayout(names_layout)
        main_layout.addLayout(button_layout)
        self.setCentralWidget(central_widget)

    @QtCore.pyqtSlot()
    def open_colordialog(self):
        button = self.sender()
        color_dialog = QtWidgets.QColorDialog()
        if color_dialog.exec_() == QtWidgets.QColorDialog.Accepted:
            button.setStyleSheet(
                "background-color: {}".format(color_dialog.selectedColor().name())
            )
        button.clearFocus()


if __name__ == "__main__":
    app = QtWidgets.QApplication(sys.argv)
    window = NamesPlayers(4)
    window.show()
    sys.exit(app.exec_())

另一种可能的解决方案是按下按钮(使用this answer中指示的方法):

from functools import partial
# ...
for i in range(nb_players):
    # ...
    color_button = QtWidgets.QPushButton("Color")
    color_button.setStyleSheet("background-color: white")
    color_button.clicked.connect(partial(self.open_colordialog, color_button))
    # or
    # color_button.clicked.connect(lambda *args, btn=color_button: self.open_colordialog(btn))
def open_colordialog(self, button):
    color_dialog = QtWidgets.QColorDialog()
    if color_dialog.exec_() == QtWidgets.QColorDialog.Accepted:
        button.setStyleSheet(
            "background-color: {}".format(color_dialog.selectedColor().name())
        )
    button.clearFocus()

相关问题 更多 >