Виталий Антипов22 січня 2018 р. 19:53
256 строк в модели данных
Здравствуйте! У меня задача отправить данные из sqlite базы в Bars3D. Для этого, по вашим урокам, подготавливаю модель и роли в с++ и отправляю в qml ItemModelBarDataProxy. Все хорошо, когда количество строк меньше 256, но когда больше - на 3D графике только первые 256. console.log(model.rowCount()) = 256, хотя реально 342. Подскажите, как можно выкрутиться из этой ситуации?
listmodel.cpp
ListModel1V::ListModel1V(QObject *parent) : QSqlQueryModel(parent) { this->updateModel(); } // Метод для получения данных из модели QVariant ListModel1V::data(const QModelIndex & index, int role) const { // Определяем номер колонки, адрес так сказать, по номеру роли int columnId = role - Qt::UserRole - 1; // Создаём индекс с помощью новоиспечённого ID колонки QModelIndex modelIndex = this->index(index.row(), columnId); /* И с помощью уже метода data() базового класса * вытаскиваем данные для таблицы из модели * */ return QSqlQueryModel::data(modelIndex, Qt::DisplayRole); } // Метод для получения имен ролей через хешированную таблицу. QHash<int, QByteArray> ListModel1V::roleNames() const { /* То есть сохраняем в хеш-таблицу названия ролей * по их номеру * */ QHash<int, QByteArray> roles; roles[IdRole] = "id"; roles[bazaizm_1vRole] = "bazaizm1v"; roles[bazaizm_dataRole] = "bazaizmdata"; roles[bazaizm_naprRole] = "bazaizmnapr"; return roles; } // Метод обновления таблицы в модели представления данных void ListModel1V::updateModel() { QObject* stack = this->parent()->findChild<QObject*>("stackView"); QString kks_id=(stack->property("baza_id")).toString(); QString rezhim_id=(stack->property("rezhim_id")).toString(); QString rezhim_filter = " and BazaIzmereni.id_Rezhim = " + rezhim_id; if(rezhim_id == ""){ rezhim_filter = ""; } qDebug() << rezhim_id; QSqlQuery query1V; QString select1V = QString ("SELECT COUNT(BazaIzmereni.id) FROM BazaIzmereni WHERE BazaIzmereni.id_Baza = " + kks_id + " and BazaIzmereni.'1В' is not null" + rezhim_filter); if (!query1V.exec(select1V)){ qDebug() << "ошибка: " << query1V.lastError().text(); } query1V.next(); if(query1V.value(0)==0){ select1V = ""; } else { select1V = " SELECT BazaIzmereni.id, IFNULL(BazaIzmereni.'1В', 0), strftime('%d-%m-%Y', Дата)||' '||IFNULL(BazaIzmereni.'Время', 0), '1В', BazaIzmereni.Дата, BazaIzmereni.'Время' FROM BazaIzmereni WHERE BazaIzmereni.id_Baza = " + kks_id + rezhim_filter; }; QSqlQuery query1P; QString select1P = QString ("SELECT COUNT(BazaIzmereni.id) FROM BazaIzmereni WHERE BazaIzmereni.id_Baza = " + kks_id + " and BazaIzmereni.'1П' is not null" + rezhim_filter); if (!query1P.exec(select1P)) qDebug() << "error: " << query1P.lastError().text(); query1P.next(); if(query1P.value(0)==0){ select1P = ""; } else { select1P = " UNION ALL SELECT BazaIzmereni.id, IFNULL(BazaIzmereni.'1П', 0), strftime('%d-%m-%Y', Дата)||' '||IFNULL(BazaIzmereni.'Время', 0), '1П', BazaIzmereni.Дата, BazaIzmereni.'Время' FROM BazaIzmereni WHERE BazaIzmereni.id_Baza = " + kks_id + rezhim_filter; }; //...............................здесь однотипный код............................................ QSqlQuery query8O; QString select8O = QString ("SELECT COUNT(BazaIzmereni.id) FROM BazaIzmereni WHERE BazaIzmereni.id_Baza = " + kks_id + " and BazaIzmereni.'8О' is not null" + rezhim_filter); if (!query8O.exec(select8O)) qDebug() << "error: " << query8O.lastError().text(); query8O.next(); if(query8O.value(0)==0){ select8O = ""; } else { select8O = " UNION ALL SELECT BazaIzmereni.id, IFNULL(BazaIzmereni.'8О', 0), strftime('%d-%m-%Y', Дата)||' '||IFNULL(BazaIzmereni.'Время', 0), '8О', BazaIzmereni.Дата, BazaIzmereni.'Время' FROM BazaIzmereni WHERE BazaIzmereni.id_Baza = " + kks_id + rezhim_filter; }; //Обновление производится SQL-запросом к базе данных this->setQuery(select1V + select1P + select1O + select2V + select2P + select2O + select3V + select3P + select3O + select4V + select4P + select4O + select5V + select5P + select5O + select6V + select6P + select6O + select7V + select7P + select7O + select8V + select8P + select8O + " order by 5 asc, 6 asc"); } // Получение id из строки в модели представления данных int ListModel1V::getId(int row) { return this->data(this->index(row, 0), IdRole).toInt(); }OpenBO.qml
ColorGradient { id: surfaceGradient ColorGradientStop { id: startGradient; position: 0.0; color: "green" } ColorGradientStop { id: middleGradient; position: 0.75; color: "yellow" } ColorGradientStop { id: finishGradient; position: 1.0; color: "red" } } Bars3D { id: barGraph Material.theme: Material.Light anchors.fill: parent barThickness: 2 antialiasing: true reflection: true theme: Theme3D { type: Theme3D.ThemeQt font.family: "STCaiyun" font.pointSize: 25 colorStyle: Theme3D.ColorStyleRangeGradient baseGradients: [surfaceGradient] windowColor: "white" labelBackgroundEnabled: false backgroundEnabled: true backgroundColor: "transparent" gridEnabled: true gridLineColor: "black" labelTextColor: "blue" multiHighlightColor: "red" singleHighlightColor: "white" } selectionMode: AbstractGraph3D.SelectionItemAndRow | AbstractGraph3D.SelectionSlice scene.activeCamera.cameraPreset: Camera3D.CameraPresetIsometricLeftHigh Bar3DSeries { id: station1 name: "Station 1" ItemModelBarDataProxy { id: proxy itemModel: model_1V rowRole: "bazaizmnapr" columnRole: "bazaizmdata" valueRole: "bazaizm1v" } onSelectedBarChanged: { rec_prim_izmer.visible = true list1.currentIndex = list1.count -1 - parseInt([position.y]) newindex = list1.currentIndex item4.editEntry(newindex) barGraph.selectionMode = AbstractGraph3D.SelectionItemAndRow | AbstractGraph3D.SelectionSlice console.log(list1.currentIndex) } } Component.onCompleted: { console.log(model_1V.rowCount()) //qml: 256 } } }
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.Вам це подобається? Поділіться в соціальних мережах!
AD
- Akiv Doros
- 11 листопада 2024 р. 11:58
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:50бали,
- Рейтинг балів-4
m
- molni99
- 25 жовтня 2024 р. 22:37
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:80бали,
- Рейтинг балів4
m
- molni99
- 25 жовтня 2024 р. 22:29
C++ - Тест 004. Указатели, Массивы и Циклы
- Результат:20бали,
- Рейтинг балів-10
Останні коментарі
ИМ
Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
Игорь Максимов22 листопада 2024 р. 08:51
Evgenii Legotckoi31 жовтня 2024 р. 11:37
Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
ИМ
Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
Игорь Максимов05 жовтня 2024 р. 04:51
QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
Тепер обговоріть на форумі
Evgenii Legotckoi24 червня 2024 р. 12:11
t
google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
tonypeachey115 листопада 2024 р. 03:04
NSProject04 червня 2022 р. 00:49
IscanderChe31 жовтня 2024 р. 12:43
Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…
Извиняюсь, нашел ответ тут http://www.qtcentre.org/threads/54533-QSqlQueryModel-%E2%80%98s-method-rowcount()-return-256
Внесу дополнение. Правильнее заменить if на while: