는 QStringListModel
는 문자열 목록, 문자열이 아니 트리를 제공합니다. 그것은 어떤 식 으로든 문자열을 해석하지 않습니다.
QStandardItemModel
을 다시 사용할 수 있습니다. QStandardItem
이미 트리 노드입니다. 다음과 같은 클래스는 QStandardItemModel
으로 경로를 삽입 할 수 있습니다.
class TreeManipulator {
Q_DISABLE_COPY(TreeManipulator)
static QChar const m_sep;
QMap<QString, QStandardItem*> m_items;
QStandardItem * m_root;
QString normalizedPath(const QString & path) {
QStringList p(path.split(m_sep, QString::SkipEmptyParts));
return p.join(sep);
}
QStandardItem * find(QStandardItem * item, const QString & child) {
for (int i = 0; i < item->rowCount(); ++i)
if (item->child(i)->text() == child) return item->child(i);
return nullptr;
}
public:
explicit TreeManipulator(QStandardItem * root) : m_root(root) {}
explicit TreeManipulator(QStandardItemModel * model) :
m_root(model->invisibleRootItem()) {}
QStandardItem * find(QString path) const {
path = normalizedPath(path);
if (m_items.contains(path)) return m_items[path];
return nullptr;
}
QStandardItem * addItem(QString path) {
QStandardItem * item = m_root;
QStringList p(path.split(m_sep, QString::SkipEmptyParts));
path = normalizedPath(path);
if (m_items.contains(path)) return m_items[path];
while (!p.isEmpty()) {
QString elt = p.takeFirst();
QStandardItem * child = find(item, elt);
if (!child)
item.appendRow((child = new QStandardItem(elt)));
item = child;
}
m_items.insert(path, item);
return item;
}
};
QChar const TreeManipulator::m_sep(QLatin1Char('/'));
항상 코드를 공유하십시오. – lpapp
@LaszloPapp QTreeView :: setModel (QStringListModel (mylistofstrings))은 모든 것이 있습니다. 별로 유익하지 않은가? – johndoe