Model View Tutorial Part3/de: Difference between revisions
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. |
Table of Content
← 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();
}
}