Model View Tutorial Part3/de: Difference between revisions

From Qt Wiki
Jump to navigation Jump to search
No edit summary
(added code-tags for removeColumn)
 
(7 intermediate revisions by 4 users not shown)
Line 1: Line 1:
{{Cleanup | reason=Auto-imported from ExpressionEngine.}}


<div class="factbox right">
===Table of Content===
* [[#47b9334235e29d26578072fe6eef7e16|Hinzufügen / Löschen von Zeilen / Spalten]]
** [[#4a19399335c45516cb8fac63ca96e7d7|beginInsertXXX]]
** [[#5e3056fa751b9ebc031bfe0b67ac079c|beginRemoveXXX]]
** [[#16f280b16988d31e97bba96a001c0f86|addCd]]
** [[#57d78ede9a5ce4423af5b52acaec36ef|removeCd]]
** [[#f4e0b04051ab0453e9e18d0bde082fd9|addColumn]]
** [[#076098a1f83f7c724b7c5f6beda953c9|removeColumn]]
</div>
[http://qt.io/groups/qt_german/wiki/Model-View-Tutorial-Teil2-Delegate-und-View ← Teil 2: Delegate und View]<br />[http://qt.io/groups/qt_german/wiki/Model_View_Tutorial ↑Übersicht Model/View Tutorial:CD Verwaltung↑]<br />[http://qt.io/groups/qt_german/wiki/Model-View-Tutorial-Teil4 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:<br />[[Image:modelview-begin-insert-columns.png|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:<br />[[Image:modelview-begin-remove-columns.png|Qt docu]]
Nach erfolgreichem Löschen in den unterlagerten Daten muss noch entsprechend endRemoveXXX aufgerufen werden.
Im folgenden die Implementierungen:
==addCd==
<code>
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();
}
</code>
==removeCd==
<code>
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();
}
}
</code>
==addColumn==
<code>
bool CdModel::addColumn(const QString& rszColumnName)
{
if(!m_data.columnExists(rszColumnName))
{
beginInsertColumns(QModelIndex(), columnCount(), columnCount());
m_data.addColumn(rszColumnName);
endInsertColumns();
return true;
}
return false;
}
</code>
==removeColumn==
<code>
void CdModel::removeColumn(int nColumn)
{
if((m_columns.count() <= nColumn) && (nColumn < columnCount()))
{
beginRemoveColumns(QModelIndex(), nColumn, nColumn);
m_data.removeColumn(nColumn - m_columns.count());
endRemoveColumns();
}
}
</code>

Latest revision as of 13:10, 1 June 2015

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();
	}
}