ДК
Джон Кофи9 апреля 2020 г. 3:31

QSqlTableModel + QTableView + Drag&Drop

QSqlDatabase, Drag and Drop, QSqlTableModel, Qt, QTableView

Привет. Делаю реализацию перемещения строк на QTableView с моделью QSqlTableModel. Буду в этой теме спрашивать нужное.
Пока такой вопрос при создании модели: как мне узнать rowCount?

int SqlTableModelDrAndDr::rowCount(const QModelIndex &parent) const
{
    return ??
}

пока оставил

return QSqlQueryModel::rowCount();
Рекомендуем хостинг TIMEWEB
Рекомендуем хостинг TIMEWEB
Стабильный хостинг, на котором располагается социальная сеть EVILEG. Для проектов на Django рекомендуем VDS хостинг.

Вам это нравится? Поделитесь в социальных сетях!

2
ДК
  • 11 апреля 2020 г. 12:18
  • (ред.)

всё никак не получается, хочу на выходных победить это дело. Сейчас поведение такое- могу взять строку, когда её дропаю создается в пустая строка ниже последней, ничего никуда не перемещается, всё остаётся на своих местах. Подскажите, какие методы обычно переопределяются для dr&dr? Я уже обчитался литературы, документации, хотя QAbstr... модельные классы и так не плохо знаю. Сейчас решил что в моем случае хватает переопределения методов flags(...), supportedDropActions(); и dropMimeData(...) .

Qt::ItemFlags SqlTableModelDrAndDr::flags(const QModelIndex &index) const
{
    Qt::ItemFlags defaultFlags = QSqlTableModel::flags(index);
    if (index.isValid())
        return Qt::ItemIsDragEnabled | Qt::ItemIsDropEnabled | defaultFlags;
    else
        return Qt::ItemIsDropEnabled | defaultFlags;
}

Qt::DropActions SqlTableModelDrAndDr::supportedDropActions() const
{
    return Qt::MoveAction | Qt::CopyAction;
}

bool SqlTableModelDrAndDr::dropMimeData(const QMimeData *data, Qt::DropAction action, int row,
                                        int column, const QModelIndex &parent)
{
    if (!canDropMimeData(data, action, row, column, parent))
            return false;
    if (action == Qt::IgnoreAction)
            return true;

    int beginRow;

    if (row != -1)
        beginRow = row;
    else if (parent.isValid())
        beginRow = parent.row();
    else
        beginRow = rowCount(QModelIndex());

    QByteArray encodedData = data->data("application/x-qabstractitemmodeldatalist");
    QDataStream stream(&encodedData, QIODevice::ReadOnly);
    QStringList newItems;
    int rows = 0;

    while (!stream.atEnd()) {
        QString text;
        stream >> text;
        newItems << text;
        ++rows;
    }

    rows = 1;
    qDebug() << "row insert:" << insertRows(beginRow, rows, QModelIndex());
    int i = 0;
    foreach (const QString &text, newItems) {
    QModelIndex idx = index(beginRow, i++, QModelIndex());
        setData(idx, text);
        beginRow++;
    }
    return true;
}

на вьюхе так:

ui->_reportsTableView->setDragDropMode(QAbstractItemView::DragDropMode::DragDrop);
ui->_reportsTableView->setDragEnabled(true);
ui->_reportsTableView->setAcceptDrops(true);
ui->_reportsTableView->setDropIndicatorShown(true);
ui->_reportsTableView->viewport()->setAcceptDrops(true);
ui->_reportsTableView->setDefaultDropAction(Qt::MoveAction);
ui->_reportsTableView->setDragDropOverwriteMode(false);

что надо добавить, какие методы еще переопределить или что не так написано? код тестовый в dropMimeData, есть там лишнее, знаю.

    ДК
    • 12 апреля 2020 г. 12:05
    • (ред.)

    вот так вставляется пустая строка, код мне подсказали. Только при перемещении строки она удаляется и пересоздаётся в БД. Наверное поэтому, вставляется уже пустая строка. Пока думаю поймать момент перед удалением информации и скопировать её с индексом вставки, а потом уже вызвать insertRows с этими данными.

    Qt::ItemFlags SqlTableModelDrAndDr::flags(const QModelIndex &index) const
    {
        Qt::ItemFlags defaultFlags = QSqlTableModel::flags(index);
        if (index.isValid())
            return Qt::ItemIsDragEnabled | Qt::ItemIsDropEnabled | defaultFlags;
        else
            return Qt::ItemIsDropEnabled | defaultFlags;
    }
    
    Qt::DropActions SqlTableModelDrAndDr::supportedDropActions() const
    {
    //    return Qt::MoveAction;
        return Qt::MoveAction | Qt::CopyAction;
    }
    
    bool SqlTableModelDrAndDr::dropMimeData(const QMimeData *data, Qt::DropAction action, int row,
                                            int column, const QModelIndex &parent)
    {
        qDebug() << "dropMimeData" << action << row << column << parent;
        if (!canDropMimeData(data, action, row, column, parent))
            return false;
    
        if (action == Qt::IgnoreAction)
            return true;
    
        int beginRow;
    
        if (row != -1)
            beginRow = row;
        else if (parent.isValid())
            beginRow = parent.row();
        else
            beginRow = rowCount(QModelIndex());
    
        QByteArray encodedData = data->data("application/x-qabstractitemmodeldatalist");
        QDataStream stream(&encodedData, QIODevice::ReadOnly);
        QStringList newItems;
        int rows = 0;
    
        int r;
        stream >> r;
    
        while (!stream.atEnd()) {
            QString text;
            stream >> text;
            newItems << text;
            ++rows;
        }
        qDebug() << beginRow << newItems;
        qDebug() << "row remove:" << r << removeRows(r, 1, QModelIndex());
        submitAll();
        if (beginRow > r)
            --beginRow;
        rows = 1;
        qDebug() << "row insert:" << insertRows(beginRow, rows, QModelIndex());
        int i = 0;
        foreach (const QString &text, newItems) {
            QModelIndex idx = index(beginRow, i++, QModelIndex());
            setData(idx, text);
                //beginRow++;
        }
        return true;
    }
    
    ui->_reportsTableView->setDragDropMode(QAbstractItemView::DragDropMode::InternalMove);
    ui->_reportsTableView->setDragEnabled(true);
    ui->_reportsTableView->setAcceptDrops(true);
    ui->_reportsTableView->setDropIndicatorShown(true);
    ui->_reportsTableView->viewport()->setAcceptDrops(true);
    //    ui->_reportsTableView->setDefaultDropAction(Qt::MoveAction);
    ui->_reportsTableView->setDragDropOverwriteMode(false);
    _reportsSQL->setEditStrategy(SqlTableModelDrAndDr::OnManualSubmit);
    

    *день спустя
    код выше рабочий, у меня просто в бд какие-то проблемы и есть одна колонка, скрыв которую, дроп работает через одно место, если её показывать, то всё отрабатывает, как надо.

      Комментарии

      Только авторизованные пользователи могут публиковать комментарии.
      Пожалуйста, авторизуйтесь или зарегистрируйтесь
      AD

      C++ - Тест 004. Указатели, Массивы и Циклы

      • Результат:50баллов,
      • Очки рейтинга-4
      m
      • molni99
      • 26 октября 2024 г. 1:37

      C++ - Тест 004. Указатели, Массивы и Циклы

      • Результат:80баллов,
      • Очки рейтинга4
      m
      • molni99
      • 26 октября 2024 г. 1:29

      C++ - Тест 004. Указатели, Массивы и Циклы

      • Результат:20баллов,
      • Очки рейтинга-10
      Последние комментарии
      i
      innorwall11 ноября 2024 г. 22:12
      Django - Урок 055. Как написать функционал auto populate field Freckles because of several brand names retin a, atralin buy generic priligy
      i
      innorwall11 ноября 2024 г. 18:23
      QML - Урок 035. Использование перечислений в QML без C++ priligy cvs 24 Together with antibiotics such as amphotericin B 10, griseofulvin 11 and streptomycin 12, chloramphenicol 9 is in the World Health Organisation s List of Essential Medici…
      i
      innorwall11 ноября 2024 г. 15:50
      Qt/C++ - Урок 052. Кастомизация Qt Аудио плеера в стиле AIMP It decreases stress, supports hormone balance, and regulates and increases blood flow to the reproductive organs buy priligy online safe Promising data were reported in a PDX model re…
      i
      innorwall11 ноября 2024 г. 14:19
      Алгоритм сортировки кучей The role of raloxifene in preventing breast cancer priligy precio
      i
      innorwall11 ноября 2024 г. 13:55
      PyQt5 - Урок 006. Работа с QTableWidget buy priligy 60 mg 53 have been reported by Javanovic Santa et al
      Сейчас обсуждают на форуме
      i
      innorwall11 ноября 2024 г. 20:56
      добавить qlineseries в функции buy priligy senior brother Chu He, whom he had known for many years
      i
      innorwall11 ноября 2024 г. 10:55
      Всё ещё разбираюсь с кешем. priligy walgreens levitra dulcolax carbs The third ring was found to be made up of ultra relativistic electrons, which are also present in both the outer and inner rings
      9
      9Anonim25 октября 2024 г. 9:10
      Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
      ИМ
      Игорь Максимов3 октября 2024 г. 4:05
      Реализация навигации по разделам Спасибо Евгений!

      Следите за нами в социальных сетях