QTableView сигнал щелчка никогда не излучал? - PullRequest
0 голосов
/ 11 октября 2018

Я начинаю быть более запутанным.Я не могу заставить QTableView излучать свой сигнал так, как хотел бы.Я сократил свой случай до чего-то менее грязного, и даже в этом случае я не могу получить никаких сигналов при нажатии.

Например, в этом коде слот «onClickedRow» вызывается один раз при запуске приложения (Я не знаю почему), но тогда я могу щелкнуть столько, сколько захочу, и слот никогда не будет называться:

import sys
from PySide2 import QtWidgets, QtCore, QtGui


class Message(QtCore.QAbstractItemModel):
    def __init__(self):
        super().__init__()

        self.messageList = []

    def addMessage(self, typeName, data):
        self.messageList.append({"type": typeName,
                                 "data": data})

    def data(self, index, role):

        if not index.isValid():
            return None

        if role != QtCore.Qt.DisplayRole:
            return None

        item = self.messageList[index.row()]

        if index.column() == 0:
            return str(item["type"])
        else:
            return str(item["data"])

    def headerData(self, section, orientation, role):
        if orientation == QtCore.Qt.Horizontal:
            if role == QtCore.Qt.DisplayRole:
                if section == 0:
                    return "type"
                else:
                    return "data"

        return None

    def parent(self, index):
        if not index.isValid():
            return QtCore.QModelIndex()

        return QtCore.QModelIndex()

    def index(self, row, column, parent):
        if not self.hasIndex(row, column, parent):
            return QtCore.QModelIndex()
        else:
            return self.createIndex(row, column)

    def flags(self, index):
        if not index.isValid():
            return QtCore.Qt.NoItemFlags

        return QtCore.Qt.ItemIsEnabled | QtCore.Qt.ItemIsSelectable

    def columnCount(self, parent):
        return 2

    def rowCount(self, parent):
        return len(self.messageList)


class FormMessageJournal(QtWidgets.QWidget):
    def __init__(self):
        super().__init__()

        self.layout = QtWidgets.QVBoxLayout()

        self.messageTable = QtWidgets.QTableView(self)
        self.messageTable.clicked.connect(self.onClickedRow())
        self.messageList = Message()
        self.messageList.addMessage("Send", "Hello")
        self.messageList.addMessage("Send", "Hello")
        self.messageList.addMessage("Send", "Hello")
        self.messageList.addMessage("Send", "Hello")
        self.messageTable.setModel(self.messageList)
        self.layout.addWidget(self.messageTable)

        self.setLayout(self.layout)

    def onClickedRow(self, index=None):
        print("Click !")


if __name__ == "__main__":
    app = QtWidgets.QApplication([])

    widget = FormMessageJournal()
    widget.show()

    sys.exit(app.exec_())

У меня один такой тип проблем?

1 Ответ

0 голосов
/ 11 октября 2018
self.messageTable.clicked.connect(self.onClickedRow())

Изменить на:

self.messageTable.clicked.connect(self.onClickedRow)
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...