Model View Tutorial Part3/de

From Qt Wiki
Jump to navigation Jump to search
The printable version is no longer supported and may have rendering errors. Please update your browser bookmarks and please use the default browser print function instead.
This article may require cleanup to meet the Qt Wiki's quality standards. Reason: Auto-imported from ExpressionEngine.
Please improve this article if you can. Remove the {{cleanup}} tag and add this page to Updated pages list after it's clean.

← Teil 2: Delegate und View
↑Übersicht Model/View Tutorial:CD Verwaltung↑
Teil 4: Copy / Paste und Drag and Drop →

Hinzufügen / Löschen von Zeilen / Spalten

Wenn Zeilen oder Spalten zu einem Model hinzugefügt werden, muss bevore die Daten verändert werden die Methode beginInsertRows/beginInsertColumns und nach Änderung der Daten endInsertRows/endInsertColumns aufgerufen werden. Synchron dazu muss beim Löschen von Zeilen / Spalten beginRemoveRows/beginRemoveColumns und endRemoveRos/endRemoveColumns aufgerufen werden.

In unserem Datenmodell gibt es dafür 4 Methoden:

  • void addCd();
  • void removeCd(const QModelIndex& index);
  • bool addColumn(const QString& rszColumnName);
  • void removeColumn(int nColumn);

ichtig ist, das das Ändern der Daten von beginXXX endXXX umklammert ist, damit die Views in diesem Zeitraum issen, dass sie nicht auf diese Daten zugreifen dürfen.

beginInsertXXX

Egal ob Spalten oder Zeilen eingefügt werden sollen, die Logik ist dieselbe:

Die Methoden syntax ist: beginInsertXXX(parent, start, end)

  • parent spezifiziert das Eltern element, bei einer Tabelle ist das immer ein ungültiger Model Index
  • start ist der erste neue Index, im Beispiel unten 4
  • end ist der letzte neue Index, in unserem Beispiel 6

Hier ein Beispiel aus der Qt-Dokumentation:
Qt docu

Nach erfolgreichem Einfügen in die unterlagerten Daten muss noch entsprechend endInsertXXX aufgerufen werden.

beginRemoveXXX

Egal ob Spalten oder Zeilen gelöscht werden sollen, die Logik ist dieselbe:

Die Methoden syntax ist: beginRemoveXXX(parent, start, end)

  • parent spezifiziert das Eltern element, bei einer Tabelle ist das immer ein ungültiger Model Index
  • start ist der erste zu löschende Index, im Beispiel unten 4
  • end ist der letzte zu löschende Index, in unserem Beispiel 6

Hier ein Beispiel aus der Qt-Dokumentation:
Qt docu

Nach erfolgreichem Löschen in den unterlagerten Daten muss noch entsprechend endRemoveXXX aufgerufen werden.

Im folgenden die Implementierungen:

addCd

void CdModel::addCd()
{
    beginInsertRows(QModelIndex(), m_data.size(), m_data.size());
    CdDisk newDisk;
    newDisk.m_author = tr("<unknown>");
    newDisk.m_genre = tr("<unknown>");
    newDisk.m_title = tr("<unknown>");
    newDisk.m_year = 0;
    m_data.addCD(newDisk);
    endInsertRows();
}

removeCd

void CdModel::removeCd(const QModelIndex& index)
{
	if(index.isValid() && (0 <= index.row()) && (index.row() < rowCount()))
	{
		beginRemoveRows(QModelIndex(), index.row(), index.row());
		m_data.removeCD(index.row());
		endRemoveRows();
	}
}

addColumn

bool CdModel::addColumn(const QString& rszColumnName)
{
	if(!m_data.columnExists(rszColumnName))
	{
		beginInsertColumns(QModelIndex(), columnCount(), columnCount());
		m_data.addColumn(rszColumnName);
		endInsertColumns();
		return true;
	}
	return false;
}

removeColumn

void CdModel::removeColumn(int nColumn)
{
	if((m_columns.count() <= nColumn) && (nColumn < columnCount()))
	{
		beginRemoveColumns(QModelIndex(), nColumn, nColumn);
		m_data.removeColumn(nColumn - m_columns.count());
		endRemoveColumns();
	}
}