Юрий
Юрий01 вересня 2017 р. 17:14

Как остаться на выбранной позиции при обновление данных в comboBox

На форме имеются несколько combobox и при изменении, добавление в справочник данных необходимо обновлять эти combobox. Как остать на выбранной позиции и обновить данные в combobox. Данные берутся из бд mysql/

Рекомендуємо хостинг TIMEWEB
Рекомендуємо хостинг TIMEWEB
Стабільний хостинг, на якому розміщується соціальна мережа EVILEG. Для проектів на Django радимо VDS хостинг.

Вам це подобається? Поділіться в соціальних мережах!

19
Evgenii Legotckoi
  • 02 вересня 2017 р. 05:34

Что значит остаться на выбранной позиции?
Не видя код, проблематично что-то советовать по этому вопрос. Вопрос ситуативен.
По факту можно ответить так. Когда изменяются данные, кидаете сигнала о том, что данные изменились. В обработчике сигнала работаете с ComboBox`ами и прописываете логику по изменению этих комбобоксов с учётом требований.

    Юрий
    • 04 вересня 2017 р. 00:38

    Например, есть список:

    1. Яблоки
    2. Помидоры
    3. Бананы
    Я выбираю 2.помидоры, но когда в этот список добавилось еще одно наименование 4. Абрикосы и combobox обновил данные то переходит на первый пункт.
      Юрий
      • 04 вересня 2017 р. 00:45

      Заполнение combobox

        QSqlQuery * qry_type = new  QSqlQuery (conn.mydb);
        qry_type->prepare("select id_type, name_type from type");
        qry_type->exec();
        ui->comboBox_type->addItem("");
        while (qry_type->next())
        ui->comboBox_type->addItem(qry_type->value(1).toString(), qry_type->value(0).toInt());
      Получаю id записи тип
      void ArrivalDialog::on_comboBox_type_currentIndexChanged(int index)
      {
          type_tech= ui->comboBox_type->itemData(index).toInt();
      }
        Evgenii Legotckoi
        • 04 вересня 2017 р. 01:20
        • (відредаговано)

        Я так понимаю, Вы предварительно где-то очищаете данные в ComboBox, а потом уже заново добавляете полный список. Поэтому у Вас и сбивается индекс. Если не удалять данные, то индекс остаётся прежний.
        Один из вариантов, которые Вы можете использовать, так это сохранять текущий индекс через метод QComboBox::currentIndex() в некоторую переменную, а потом уже устанавливать индекс заново после добавления списка данных.
        А ещё, я мог бы посоветовать Вам использовать модель данных и QDataWidgetMapper . Ведь судя по всему у Вас там некоторая форма ввода используется...

        Посмотрите статью с использованием QDataWidgetMapper .
          Юрий
          • 04 вересня 2017 р. 01:36

          Да я очищаю иначе у меня дублируются записи.  При заполнении combobox из модели, как мне потом получить id записи?

            Evgenii Legotckoi
            • 04 вересня 2017 р. 01:52

            У QDataWidgetMapper также есть метод currentIndex() , который вернёт фактически номер строки в модели данных. Этот номер строки можно использовать через QModelIndex и метод модели data() для получения любой информации из строки в модели данных, в том числе и id в базе данных.

            model->data(model->index(mapper->currentIndex(), someColumn)).toInt();
            Должно получиться что-то типо такого.
            Вообще по возможности используйте модели данных. Поначалу, конечно, мороки много, но потом просто милое дело получается. Всё аккуратно и красиво выходит.
              Юрий
              • 04 вересня 2017 р. 04:56

              Сделал так

              model_type = new QSqlTableModel(this);
              model_type->setTable("type");
              model_type->select();
              ui->comboBox_type->setModel(model_type);
              ui->comboBox_type->setModelColumn(1);


                Юрий
                • 04 вересня 2017 р. 05:06

                Как подключить сигнал?


                 connect(mapper,SIGNAL(currentIndexChanged(int)),this, SLOT(mapper_currentIndexChanged(int)));

                  Evgenii Legotckoi
                  • 04 вересня 2017 р. 05:15

                  mapper создали через выделение памяти в куче? то есть через оператор new ?
                  Если нет, то перед маппером должен быть амперсанд.

                  connect(&mapper,SIGNAL(currentIndexChanged(int)),this, SLOT(mapper_currentIndexChanged(int)));
                    Юрий
                    • 04 вересня 2017 р. 05:35

                    Вот так

                    mapper = new QDataWidgetMapper();
                    mapper->setModel(model_type);
                    
                      Evgenii Legotckoi
                      • 04 вересня 2017 р. 05:57
                      • (відредаговано)

                      Ну тогда подключайте сигнал, как показали. Разве только можно в нотации Qt5 его переписать, через указатели.
                      Хотя, если Вы модель установили прямо в ComboBox, то можно и без маппера обойтись, просто делать update модели, когда добавлены новые данные.

                        Юрий
                        • 04 вересня 2017 р. 06:02

                        Получается он не посылает сигнал?

                        QObject::connect: No such signal QObject::dataChanged(QModelIndex,QModelIndex,QVector<int>)
                          Evgenii Legotckoi
                          • 04 вересня 2017 р. 06:14

                          Это что-то новенькое... не найден сигнал в модели. dataChanged - это сигнал, который объявлен в QAbstractItemModel.

                          Может заголовочники не все подключили?
                            Юрий
                            • 04 вересня 2017 р. 12:01

                            Не понимаю как добавить в combobox

                            mapper->addMapping(ui->comboBox_type,1, "currentIndex");
                            и еще есть "currentTetxt"
                              Evgenii Legotckoi
                              • 04 вересня 2017 р. 15:25

                              Проверьте currentText , возможно проблема в том, что property currentIndex имеет перегруженный сигнал currentIndexChanged.

                                Юрий
                                • 04 вересня 2017 р. 17:21
                                    model_type = new QSqlTableModel(this);
                                    model_type->setTable("type");
                                    model_type->setEditStrategy(QSqlTableModel::OnManualSubmit);
                                    int type_id = model_type->fieldIndex("id_type");
                                    model_type->select();
                                
                                    ui->comboBox_type->setModel(model_type);
                                    ui->comboBox_type->setModelColumn(model_type->fieldIndex("name_type"));
                                
                                    mapper = new QDataWidgetMapper(this);
                                    mapper->setModel(model_type);
                                    mapper->addMapping(ui->lineEdit_type, type_id);
                                Теперь у меня есть id записи  в line_edit. Можно как-то сразу перенести в переменную int?
                                При обновление модели так же выбирается первая строчка.
                                Мне нужно как то хранить индекс записи для вставки после обновления модели
                                ui->comboBox_type->setCurrentIndex(int);

                                  Evgenii Legotckoi
                                  • 05 вересня 2017 р. 02:34
                                  • Відповідь була позначена як рішення.

                                  хм. печально, что не заработало, как предполагалось.

                                  line_edit может вернуть свой текст через метод text(), этот метод возвращает обьект типа QString , который с помощью метода toInt() можно преобразовать в целочисленный тип int .
                                    Юрий
                                    • 07 вересня 2017 р. 05:59

                                    Да это понятно. Просто у меня на форме много combobox-ов.

                                      Юрий
                                      • 07 вересня 2017 р. 13:05

                                      Все сделал.  Применил костыли.

                                      Храню все в line_edit.
                                      ui->comboBox_type->setCurrentIndex(model_type->match(model_type->index(0,0,QModelIndex()),Qt::DisplayRole,ui->lineEdit_type->text().toInt(),1,Qt::MatchExactly).first().row());
                                      Спасибо.

                                        Коментарі

                                        Only authorized users can post comments.
                                        Please, Log in or Sign up
                                        AD

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

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

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

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

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

                                        • Результат:20бали,
                                        • Рейтинг балів-10
                                        Останні коментарі
                                        ИМ
                                        Игорь Максимов22 листопада 2024 р. 11:51
                                        Django - Підручник 017. Налаштуйте сторінку входу до Django Добрый вечер Евгений! Я сделал себе авторизацию аналогичную вашей, все работает, кроме возврата к предидущей странице. Редеректит всегда на главную, хотя в логах сервера вижу запросы на правильн…
                                        Evgenii Legotckoi
                                        Evgenii Legotckoi31 жовтня 2024 р. 14:37
                                        Django - Урок 064. Як написати розширення для Python Markdown Добрый день. Да, можно. Либо через такие же плагины, либо с постобработкой через python библиотеку Beautiful Soup
                                        A
                                        ALO1ZE19 жовтня 2024 р. 08:19
                                        Читалка файлів fb3 на Qt Creator Подскажите как это запустить? Я не шарю в программировании и кодинге. Скачал и установаил Qt, но куча ошибок выдается и не запустить. А очень надо fb3 переконвертировать в html
                                        ИМ
                                        Игорь Максимов05 жовтня 2024 р. 07:51
                                        Django - Урок 064. Як написати розширення для Python Markdown Приветствую Евгений! У меня вопрос. Можно ли вставлять свои классы в разметку редактора markdown? Допустим имея стандартную разметку: <ul> <li></li> <li></l…
                                        d
                                        dblas505 липня 2024 р. 11:02
                                        QML - Урок 016. База даних SQLite та робота з нею в QML Qt Здравствуйте, возникает такая проблема (я новичок): ApplicationWindow неизвестный элемент. (М300) для TextField и Button аналогично. Могу предположить, что из-за более новой верси…
                                        Тепер обговоріть на форумі
                                        Evgenii Legotckoi
                                        Evgenii Legotckoi24 червня 2024 р. 15:11
                                        добавить qlineseries в функции Я тут. Работы оень много. Отправил его в бан.
                                        t
                                        tonypeachey115 листопада 2024 р. 06:04
                                        google domain [url=https://google.com/]domain[/url] domain [http://www.example.com link title]
                                        NSProject
                                        NSProject04 червня 2022 р. 03:49
                                        Всё ещё разбираюсь с кешем. В следствии прочтения данной статьи. Я принял для себя решение сделать кеширование свойств менеджера модели LikeDislike. И так как установка evileg_core для меня не была возможна, ибо он писался…
                                        9
                                        9Anonim25 жовтня 2024 р. 09:10
                                        Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                                        Слідкуйте за нами в соціальних мережах