Domanda

Sto creando una sottoclasse di QAbstractItemModel da visualizzare in un QTreeView.

Il mio index() e parent() funzione crea l'QModelIndex utilizzando la funzione di QAbstractItemModel ereditato createIndex e fornendo così il row, column e data necessario. Qui, a scopo di test, i dati è una stringa Python.

class TestModel(QAbstractItemModel):
    def __init__(self):
        QAbstractItemModel.__init__(self)

    def index(self, row, column, parent):
        if parent.isValid():
            return self.createIndex(row, column, "bar")
        return self.createIndex(row, column, "foo")

    def parent(self, index):
        if index.isValid():
            if index.data().data() == "bar":                          <--- NEVER TRUE
                return self.createIndex(0, 0, "foo")
        return QModelIndex()

    def rowCount(self, index):
        if index.isValid():
            if index.data().data() == "bar":                          <--- NEVER TRUE
                return 0
        return 1

    def columnCount(self, index):
        return 1

    def data(self, index, role):
        if index.isValid():
            return index.data().data()                                <--- CANNOT DO ANYTHING WITH IT
        return "<None>"

Nell'ambito delle funzioni index(), parent() e data() ho bisogno di miei dati. Essa si presenta come un QVariant. Come faccio ad avere il mio oggetto Python indietro dal QVariant?

È stato utile?

Soluzione 2

La cosa fondamentale è quella di utilizzare internalPointer() direttamente sul QModelIndex, non trattare con il QVariant a tutti.

class TestModel(QAbstractItemModel):
    def __init__(self, plan):
        QAbstractItemModel.__init__(self)

    def index(self, row, column, parent):
        if not parent.isValid():
            return self.createIndex(row, column, "foo")
        return self.createIndex(row, column, "bar")

    def parent(self, index):
         if index.internalPointer() == "bar":
            return self.createIndex(0, 0, "foo")
        return QModelIndex()

    def rowCount(self, index):
        if index.internalPointer() == "bar":
            return 0
        return 1

    def columnCount(self, index):
        return 1

    def data(self, index, role):
        if role == 0:  # Qt.DisplayRole
            return index.internalPointer()
        else:
            return None

Altri suggerimenti

Hai provato questo?

my_python_object = my_qvariant.toPyObject()

http://pyqt.sourceforge.net/Docs/PyQt4/qvariant .html # toPyObject (solo per completezza, ma non c'è molto da vedere ...)

Autorizzato sotto: CC-BY-SA insieme a attribuzione
Non affiliato a StackOverflow
scroll top