ДК
Джон КофиСәуір 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);
    

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

      Пікірлер

      Тек рұқсаты бар пайдаланушылар ғана пікір қалдыра алады.
      Кіріңіз немесе Тіркеліңіз
      Г

      C++ - Тест 001. Первая программа и типы данных

      • Нәтиже:66ұпай,
      • Бағалау ұпайлары-1
      t

      C++ - Тест 001. Первая программа и типы данных

      • Нәтиже:33ұпай,
      • Бағалау ұпайлары-10
      t

      Qt - Тест 001. Сигналы и слоты

      • Нәтиже:52ұпай,
      • Бағалау ұпайлары-4
      Соңғы пікірлер
      G
      GoattRockҚыр. 3, 2024, 1:50 Т.Қ.
      Linux жүйесінде файлдарды қалай көшіруге болады Задумывались когда-нибудь о том, как мы привыкли доверять свои вещи службам грузоперевозок? Сейчас такие услуги стали неотъемлемой частью нашей жизни, особенно когда речь идет о переездах между …
      d
      dblas5Шілде 5, 2024, 11:02 Т.Ж.
      QML - Сабақ 016. SQLite деректер қоры және онымен QML Qt-та жұмыс істеу Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
      k
      kmssrАқп. 8, 2024, 6:43 Т.Қ.
      Qt Linux - Сабақ 001. Linux астында Autorun Qt қолданбасы как сделать автозапуск для флэтпака, который не даёт создавать файлы в ~/.config - вот это вопрос ))
      АК
      Анатолий КононенкоАқп. 5, 2024, 1:50 Т.Ж.
      Qt WinAPI - Сабақ 007. Qt ішінде ICMP Ping арқылы жұмыс істеу Без строки #include <QRegularExpressionValidator> в заголовочном файле не работает валидатор.
      Енді форумда талқылаңыз
      Evgenii Legotckoi
      Evgenii LegotckoiМаусым 24, 2024, 3:11 Т.Қ.
      добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
      F
      FynjyШілде 22, 2024, 4:15 Т.Ж.
      при создании qml проекта Kits есть но недоступны для выбора Поставил Qt Creator 11.0.2. Qt 6.4.3 При создании проекта Qml не могу выбрать Kits, они все недоступны, хотя настроены и при создании обычного Qt Widget приложения их можно выбрать. В чем может …
      BlinCT
      BlinCTМаусым 25, 2024, 1 Т.Ж.
      Нарисовать кривую в qml Всем привет. Имеется Лист листов с тосками, точки получаны интерполяцией Лагранжа. Вопрос, как этими точками нарисовать кривую? ChartView отпадает сразу, в qt6.7 появился новый элемент…
      BlinCT
      BlinCTМамыр 5, 2024, 5:46 Т.Ж.
      Написать свой GraphsView Всем привет. В Qt есть давольно старый обьект дял работы с графиками ChartsView и есть в 6.7 новый но очень сырой и со слабым функционалом GraphsView. По этой причине я хочу написать х…
      Evgenii Legotckoi
      Evgenii LegotckoiМамыр 2, 2024, 2:07 Т.Қ.
      Мобильное приложение на C++Qt и бэкенд к нему на Django Rest Framework Добрый день. По моему мнению - да, но то, что будет касаться вызовов к функционалу Андроида, может создать огромные трудности.

      Бізді әлеуметтік желілерде бақылаңыз