Проблемы редактирования DOM модели, Доработка модели к редактируемой |
Здравствуйте, гость ( Вход | Регистрация )
Проблемы редактирования DOM модели, Доработка модели к редактируемой |
JohnZ |
26.11.2014, 13:46
Сообщение
#1
|
Участник Группа: Участник Сообщений: 139 Регистрация: 19.7.2014 Пользователь №: 4190 Спасибо сказали: 10 раз(а) Репутация: 0 |
В прицепе мин. проект, демонстрирующий проблемы редактирования.
ехе-шник там-же ... Проблемы в диалоге редактирования таблицы (через модель !). Для того, чтобы к нему добраться, нужно в открытом конфиге (прилагается) пройти по дереву от корня /->metadata->catalogues-> далее выбрать любой справочник ( catalogue ) и в нём DblClick на таблице ( element ). Появится диалог редактирования таблицы. Вопросы ... 1. В диалоге реализовано удаление поля, кнопка Del. Сделано по подобию примера editabletreemodel. После удаления, в bool DomItem::removeChildrens(int position, int count) добавлена очистка хэш-а childItems.clear(), т.к. без этого нет отоббражения действия в TreeView-e за диалогом, при развёрнутом дереве полей таблицы. В принципе к функции удаления претензий нет, работает отлично, но правомочна-ли очистка хэш-а в плане утечек памяти ? Ведь указатели на DomItem-ы хранятся только в хэше, а операция QHash::clear() для QHash<int,DomItem*> childItems; не чистит хранимые указатели на DomItem *, которые созданы операцией new !? Если это действительно так, подскажите плз правильную реализацию ... 2. Реализация добавления поля аналогична удалению, в проект не ложил, т.к. там понятно, через отдельный диалог. Проблема в реализации bool swapChildrens(int pos1, int pos2); Для добавления и удаления поля в модели есть соотв-щие ф-ции
и
Но в модели нет функций beginSwapRows(parent, position, position + 1); endSwapRows(); Как это можно реализовать (с отображением в TreeView-e), как в случае с удалением ? 3. Почему при открытии диалога, строка выбора в TreeView-e скачет хз куда ? Странно это потому, что в оригинальном проекте, когда TreeView является MdiChild-ом, такого не наблюдается ... Это так, из спортивного интереса :-) Заранее благодарен за помощь.
Прикрепленные файлы
|
|
|
lanz |
27.11.2014, 21:38
Сообщение
#2
|
Старейший участник Группа: Участник Сообщений: 690 Регистрация: 28.12.2012 Пользователь №: 3660 Спасибо сказали: 113 раз(а) Репутация: 8 |
после закрытия диалога. Если он есть, то изменения видны даже ЗА диалогом ! Тут проблема в том что после удаления из списка(в модели списка) элементы идут так: 1234 -> 123 (и это какой бы мы элемент ни удалили) А в хэшк зависит от того какой элемент мы удаляем 1234 -> 123 (если 4) 1234 -> 234 (если 1) и т.д. Поэтому переформирование хэша помогает. Почему работало когда ты закрывал диалог: шло обновление и он перебирал все строки. Когда доходил до той которой нет, весь хэш обновлялся и дальше шло все по порядку. Выброси хэш, сразу станет сильно легче Цитата А вот тут поподробнее можно ? Начиная с какой версии QT есть такая фича ? (у меня 4.5.3) Примерчик _редактируемой_ DOM-модели в TreeView есть ? Хотя это и повлечёт солидную переделку проекта, но я за упрощение ! Подскажи где копать, т.е. что брать за основу ? (по аналогии с simpledommodel) Совсем с нуля опять начинать не хоцца ... Имел ввиду QDomNode и сотоварищей. Ты же по сути строишь дублирующую структуру. Цитата beginMoveRows - Дык это начиная с 4.6.0. Видимо придётся переходить на 4.6.х Жаль ... Можно просто вызвать dataChanged для этих двух строк, эффект будет тот же самый. Цитата Спишем на глюк QTreeView в SDI У меня пятый кутэ, поэтому всякие могут быть разночтения. Сложно отделить такие детали. |
|
|
Текстовая версия | Сейчас: 2.12.2024, 3:14 |