crossplatform.ru

Здравствуйте, гость ( Вход | Регистрация )

> Выбор строки после редактирования, QSqlQueryModel + QSortFilterProxyModel + QTableView
512es
  опции профиля:
сообщение 1.12.2009, 15:05
Сообщение #1


Участник
**

Группа: Участник
Сообщений: 135
Регистрация: 31.10.2008
Пользователь №: 407

Спасибо сказали: 5 раз(а)




Репутация:   0  


Всем привет!

Много гуглил, искал решение, чего только не перепробовал. Но проблему так и не удалось решить:
На основе примера *\qt\examples\sql\querymodel\editablesqlmodel.cpp сделал редактируемую QSqlQueryModel, и прикрутил к ней QSortFilterProxyModel.
Вот кусок кода, по которому видно, что я уже перепробовал:
bool cliviewModel::setData(const QModelIndex &index, const QVariant &value, int  role)
{
     if (!index.column()) return false;
     QModelIndex primaryKeyIndex = QSqlQueryModel::index(index.row(), 0);
     int id = data(primaryKeyIndex,0).toInt();
//     clear();
     qDebug() << index.row() << sortingModell->mapFromSource(index).row();
     bool ok=0;
     QSqlQuery query;
     query.prepare("UPDATE clients SET " + colums.value(index.column()) + " = ? WHERE client_id = ?");
     query.addBindValue(value.toString());
     query.addBindValue(id);
     ok = query.exec();
     if (ok) {
         setQuery(lastQuery);
         while (canFetchMore()) fetchMore();
//         eatMouseEvent = 1;
   //      QMap<int, QVariant> itemData;
   //      itemData.insert(Qt::DisplayRole, value);
   //      QAbstractItemModel::setItemData(index,itemData);
   //      emit(dataChanged(index, index));
         emit signalGoToClientById(index);
//         qDebug() << setData(index, QString(tr("Исходящий")), Qt::DisplayRole);
     }
     return ok;
}


Задача: после редактирования ячейки обновить отображаемые данные в таблице и оставить выбранной ячейкой ту, которую мы редактировали.

Для этой цели вызываю сигнал emit signalGoToClientById(index), который соединён со слотом:
void CliView::slotGoToEdited(const QModelIndex &current)
{
    QModelIndex cur = modell->sortingModell->mapFromSource(current);
    scrollTo(cur,QAbstractItemView::EnsureVisible);
    setCurrentIndex(cur);
}


Оно работает, но если я выхожу из редактирования кликом мышки, то после того как выставить нужную ячейку, курсор переходит на ту строку, куда я кликнул.

Помогите люди добрые, наверняка вы уже сталкивались с этой же проблемой..

Сообщение отредактировал 512es - 1.12.2009, 15:07
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение
 
Начать новую тему
Ответов
Litkevich Yuriy
  опции профиля:
сообщение 1.12.2009, 15:49
Сообщение #2


разработчик РЭА
*******

Группа: Сомодератор
Сообщений: 9669
Регистрация: 9.1.2008
Из: Тюмень
Пользователь №: 64

Спасибо сказали: 807 раз(а)




Репутация:   94  


Цитата(512es @ 1.12.2009, 18:05) *
после редактирования ячейки обновить отображаемые данные в таблице и оставить выбранной ячейкой ту, которую мы редактировали.
тут нужна оговорка, "если эта ячейка ещё существует" т.к. в ощем случае её мог удалить другой пользователь.

Модельные индексы непостоянны, т.е. они имеют свойство менять своё значение (показывать в другое место). Попробуй запоминать "постоянный модельный индекс" (QPersistentModelIndex) и по нему восстанавливать выделение
Перейти в начало страницы
 
Быстрая цитата+Цитировать сообщение

Сообщений в этой теме


Быстрый ответОтветить в данную темуНачать новую тему
Теги
Нет тегов для показа


6 чел. читают эту тему (гостей: 6, скрытых пользователей: 0)
Пользователей: 0




RSS Текстовая версия Сейчас: 12.12.2024, 11:38