Юрий
ЮрийSept. 1, 2017, 5:14 p.m.

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

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

We recommend hosting TIMEWEB
We recommend hosting TIMEWEB
Stable hosting, on which the social network EVILEG is located. For projects on Django we recommend VDS hosting.

Do you like it? Share on social networks!

19
Evgenii Legotckoi
  • Sept. 2, 2017, 5:34 a.m.

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

    Юрий
    • Sept. 4, 2017, 12:38 a.m.

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

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

      Заполнение 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
        • Sept. 4, 2017, 1:20 a.m.
        • (edited)

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

        Посмотрите статью с использованием QDataWidgetMapper .
          Юрий
          • Sept. 4, 2017, 1:36 a.m.

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

            Evgenii Legotckoi
            • Sept. 4, 2017, 1:52 a.m.

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

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

              Сделал так

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


                Юрий
                • Sept. 4, 2017, 5:06 a.m.

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


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

                  Evgenii Legotckoi
                  • Sept. 4, 2017, 5:15 a.m.

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

                  connect(&mapper,SIGNAL(currentIndexChanged(int)),this, SLOT(mapper_currentIndexChanged(int)));
                    Юрий
                    • Sept. 4, 2017, 5:35 a.m.

                    Вот так

                    mapper = new QDataWidgetMapper();
                    mapper->setModel(model_type);
                    
                      Evgenii Legotckoi
                      • Sept. 4, 2017, 5:57 a.m.
                      • (edited)

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

                        Юрий
                        • Sept. 4, 2017, 6:02 a.m.

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

                        QObject::connect: No such signal QObject::dataChanged(QModelIndex,QModelIndex,QVector<int>)
                          Evgenii Legotckoi
                          • Sept. 4, 2017, 6:14 a.m.

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

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

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

                            mapper->addMapping(ui->comboBox_type,1, "currentIndex");
                            и еще есть "currentTetxt"
                              Evgenii Legotckoi
                              • Sept. 4, 2017, 3:25 p.m.

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

                                Юрий
                                • Sept. 4, 2017, 5:21 p.m.
                                    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
                                  • Sept. 5, 2017, 2:34 a.m.
                                  • The answer was marked as a solution.

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

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

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

                                      Юрий
                                      • Sept. 7, 2017, 1:05 p.m.

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

                                      Храню все в 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());
                                      Спасибо.

                                        Comments

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

                                        C ++ - Test 004. Pointers, Arrays and Loops

                                        • Result:50points,
                                        • Rating points-4
                                        m

                                        C ++ - Test 004. Pointers, Arrays and Loops

                                        • Result:80points,
                                        • Rating points4
                                        m

                                        C ++ - Test 004. Pointers, Arrays and Loops

                                        • Result:20points,
                                        • Rating points-10
                                        Last comments
                                        i
                                        innorwallNov. 14, 2024, 12:07 p.m.
                                        Circuit switching and packet data transmission networks Angioedema 1 priligy dapoxetine
                                        i
                                        innorwallNov. 14, 2024, 11:42 a.m.
                                        How to Copy Files in Linux If only females relatives with DZ offspring were considered these percentages were 23 order priligy online uk
                                        i
                                        innorwallNov. 14, 2024, 9:09 a.m.
                                        Qt/C++ - Tutorial 068. Hello World using the CMAKE build system in CLion ditropan pristiq dosing With the Yankees leading, 4 3, Rivera jogged in from the bullpen to a standing ovation as he prepared for his final appearance in Chicago buy priligy pakistan
                                        i
                                        innorwallNov. 14, 2024, 4:05 a.m.
                                        EVILEG-CORE. Using Google reCAPTCHA 2001; 98 29 34 priligy buy
                                        i
                                        innorwallNov. 14, 2024, 4 a.m.
                                        PyQt5 - Lesson 007. Works with QML QtQuick (Signals and slots) priligy 30mg Am J Obstet Gynecol 171 1488 505
                                        Now discuss on the forum
                                        i
                                        innorwallNov. 14, 2024, 3:39 a.m.
                                        добавить qlineseries в функции priligy amazon canada 93 GREB1 protein GREB1 AB011147 6
                                        i
                                        innorwallNov. 11, 2024, 10:55 a.m.
                                        Всё ещё разбираюсь с кешем. 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
                                        9AnonimOct. 25, 2024, 9:10 a.m.
                                        Машина тьюринга // Начальное состояние 0 0, ,<,1 // Переход в состояние 1 при пустом символе 0,0,>,0 // Остаемся в состоянии 0, двигаясь вправо при встрече 0 0,1,>…

                                        Follow us in social networks