ВК
Владислав К.Sept. 29, 2020, 10:08 a.m.

Как в QTableWidget, состоящей из чекбоксов, в строке таблицы можно было выбрать только один checkbox ?

QTableWidget, QCheckBox

Сделал таблицу состоящую из чекбоксов по уроку https://evileg.com/ru/post/78/
Кто-нибудь знает, как сделать так, чтобы в QTableWidget состоящей из чекбоксов в строке таблицы можно было выбрать только один checkbox ? Т.н. эксклюзивный чекбокс ?
Был бы весьма признателен за работающий пример.
По-хорошему хотелось бы также редактировать таблицу выбирая один чекбокс из списка чекбоксов в строках таблицы.
Можно ли генерировать автоматическое обновление таблицы без промежуточных действий, т.е. как только выбрал чекбокс автоматически выполняется SQL UPDATE таблицы.

Мой код по аналогии со статьей, но с небольшими доработками, здесь приведу отрывок:

#include "mainwindow.h"
#include "ui_mainwindow.h"

MainWindow::MainWindow(QWidget *parent) :
    QMainWindow(parent),
    ui(new Ui::MainWindow)
{
    ui->setupUi(this);

    this->setWindowTitle("Как сделать эксклюзивный чекбокс автобновление таблицы после его выбора");

    db = new DataBase();
    db->connectToDataBase();

    /* Вставка в базу данных записей */
    db->insertIntoTable(QVariantList() << "Тестовая запись №1"                     
                                            << ""                       
                                            << QString::number(false)  
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                        );
    db->insertIntoTable(QVariantList() << "Тестовая запись №2"                      
                                            << ""                      
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                        );
    db->insertIntoTable(QVariantList() << "Тестовая запись №3"                      
                                            << ""                       
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                                            << QString::number(false)   
                        );

    /* Настраиваем внешний вид таблицы
     * с заданием названий колонок, а также
     * Заполняем таблицу записями из базы данных
     * */
    this->createUI(QStringList() << trUtf8("№")
                                 << trUtf8("Текстовое Поле №1")
                                 << trUtf8("Текстовое Поле №2")
                                 << trUtf8("Столбец чекбоксов №1")
                                 << trUtf8("Столбец чекбоксов №2")
                                 << trUtf8("Столбец чекбоксов №3")
                                 << trUtf8("Столбец чекбоксов №4")
                                 << trUtf8("Столбец чекбоксов №5")
                                 << trUtf8("Столбец чекбоксов №6")
                                 << trUtf8("Столбец чекбоксов №7")
                                 << trUtf8("Столбец чекбоксов №8")
                                 << trUtf8("Столбец чекбоксов №9"
                                 << trUtf8("Столбец чекбоксов №10")
                                 << trUtf8("Столбец чекбоксов №11")
                                 << trUtf8("Столбец чекбоксов №12")
               );
}

MainWindow::~MainWindow()
{
    delete ui;
}

/* Настройка интерфейса - заполнение QTableWidget записями из таблицы
 * */
void MainWindow::createUI(const QStringList &headers)
{
    ui->tableWidget->setColumnCount(15); // Указываем число колонок
    ui->tableWidget->setShowGrid(true); // Включаем сетку
    // Разрешаем выделение только одного элемента
    ui->tableWidget->setSelectionMode(QAbstractItemView::SingleSelection);
    // Разрешаем выделение построчно
    ui->tableWidget->setSelectionBehavior(QAbstractItemView::SelectRows);
    // Устанавливаем заголовки колонок
    ui->tableWidget->setHorizontalHeaderLabels(headers);

     // Создаём запрос для для выборки записей из базы данных
    QSqlQuery query("SELECT "
                    DBTABLE ".id, "
                    DBTABLE "." TEXT1 ", "
                    DBTABLE "." TEXT2 ", "
                    DBTABLE "." CHECKBOX1 ", "
                    DBTABLE "." CHECKBOX2 ", "
                    DBTABLE "." CHECKBOX3 ", "
                    DBTABLE "." CHECKBOX4 ", "
                    DBTABLE "." CHECKBOX5 ", "
                    DBTABLE "." CHECKBOX6 ", "
                    DBTABLE "." CHECKBOX7 ", "
                    DBTABLE "." CHECKBOX8 ", "
                    DBTABLE "." CHECKBOX9 ", "
                    DBTABLE "." CHECKBOX10 ", "
                    DBTABLE "." CHECKBOX11 ", "
                    DBTABLE "." CHECKBOX12
                    " FROM " DBTABLE);

    /* Выполняем заполнение QTableWidget записями
     * */
    for(int i = 0; query.next(); i++){
        ui->tableWidget->insertRow(i);
        /* Устанавливаем в первую колонку id забирая его из результата SQL-запроса
         * */
        ui->tableWidget->setItem(i,0, new QTableWidgetItem(query.value(0).toString()));

        // Создаём элементы, который будет выполнять роль чекбоксов
        QTableWidgetItem *item1 = new QTableWidgetItem();
        item1->data(Qt::CheckStateRole);
        item1->setCheckState(Qt::Unchecked);
        QTableWidgetItem *item2 = new QTableWidgetItem();
        item2->data(Qt::CheckStateRole);
        item2->setCheckState(Qt::Unchecked);
        QTableWidgetItem *item3 = new QTableWidgetItem();
        item3->data(Qt::CheckStateRole);
        item3->setCheckState(Qt::Unchecked);
        QTableWidgetItem *item4 = new QTableWidgetItem();
        item4->data(Qt::CheckStateRole);
        item4->setCheckState(Qt::Unchecked);
        QTableWidgetItem *item5 = new QTableWidgetItem();
        item5->data(Qt::CheckStateRole);
        item5->setCheckState(Qt::Unchecked);
        QTableWidgetItem *item6 = new QTableWidgetItem();
        item6->data(Qt::CheckStateRole);
        item6->setCheckState(Qt::Unchecked);
        QTableWidgetItem *item7 = new QTableWidgetItem(); 
        item7->data(Qt::CheckStateRole);
        item7->setCheckState(Qt::Unchecked);
        QTableWidgetItem *item8 = new QTableWidgetItem(); 
        item8->data(Qt::CheckStateRole);
        item8->setCheckState(Qt::Unchecked);
        QTableWidgetItem *item9 = new QTableWidgetItem(); 
        item9->data(Qt::CheckStateRole);
        item9->setCheckState(Qt::Unchecked);
        QTableWidgetItem *item10 = new QTableWidgetItem(); 
        item10->data(Qt::CheckStateRole);
        item10->setCheckState(Qt::Unchecked);
        QTableWidgetItem *item11 = new QTableWidgetItem(); 
        item11->data(Qt::CheckStateRole);
        item11->setCheckState(Qt::Unchecked);
        QTableWidgetItem *item12 = new QTableWidgetItem(); 
        item12->data(Qt::CheckStateRole);
        item12->setCheckState(Qt::Unchecked);
        QTableWidgetItem *item24 = new QTableWidgetItem(); 
        item24->data(Qt::CheckStateRole);
        item24->setCheckState(Qt::Unchecked);

        ui->tableWidget->setItem(i,1, new QTableWidgetItem(query.value(1).toString()));
        ui->tableWidget->setItem(i,2, new QTableWidgetItem(query.value(2).toString()));

        // Устанавливаем чекбоксы в остальные колонки:
        ui->tableWidget->setItem(i,3, item1); 
        ui->tableWidget->setItem(i,4, item2); 
        ui->tableWidget->setItem(i,5, item3); 
        ui->tableWidget->setItem(i,6, item4); 
        ui->tableWidget->setItem(i,7, item5); 
        ui->tableWidget->setItem(i,8, item6); 
        ui->tableWidget->setItem(i,9, item7); 
        ui->tableWidget->setItem(i,10, item8); 
        ui->tableWidget->setItem(i,11, item9); 
        ui->tableWidget->setItem(i,12, item10); 
        ui->tableWidget->setItem(i,13, item11); 
        ui->tableWidget->setItem(i,14, item12); 
        ui->tableWidget->setItem(i,15, item24); 
    }
        ui->tableWidget->resizeColumnsToContents();
}

UPDATED_TODAY)))):
По поводу того, как сделать эксклюзивный чекбокс мысли следующие: Если пользователь задействует любой из находящихся в строке отображаемой
таблицы(QTableView), то перебираются все чекбосы, кроме задействованного эксклюзивного чекбокса и их состояние активности ставится в ->setCheckState(Qt::Unchecked); непонятно как это правильно сделать, а именно как перебрать все элементы таблицы в строке. А может быть вообще все делается проще и не надо тут фантазировать ?

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!

1
Evgenii Legotckoi
  • Oct. 7, 2020, 5:32 p.m.

Наверное, лучше всё-таки вам посмотреть в сторону QSqlTableModel и использовать QTableView вместо QTableWidget.
В том случае можно будет у модели переопределить метод setData и внутри него переустанавливать все остальные чекбоксы.
Единственное, возможно, что нужно будет переопределить метод flags, чтобы сообщить модели, что это всё checkable колонки.

    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. 13, 2024, 11:03 p.m.
    How to make game using Qt - Lesson 3. Interaction with other objects what is priligy tablets What happens during the LASIK surgery process
    i
    innorwallNov. 13, 2024, 8:09 p.m.
    Using variables declared in CMakeLists.txt inside C ++ files where can i buy priligy online safely Tom Platz How about things like we read about in the magazines like roid rage and does that really
    i
    innorwallNov. 11, 2024, 10:12 p.m.
    Django - Tutorial 055. How to write auto populate field functionality Freckles because of several brand names retin a, atralin buy generic priligy
    i
    innorwallNov. 11, 2024, 6:23 p.m.
    QML - Tutorial 035. Using enumerations in QML without 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
    innorwallNov. 11, 2024, 3:50 p.m.
    Qt/C++ - Lesson 052. Customization Qt Audio player in the style of 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…
    Now discuss on the forum
    i
    innorwallNov. 14, 2024, 12:39 a.m.
    добавить qlineseries в функции Listen intently to what Jerry says about Conditional Acceptance because that s the bargaining chip in the song and dance you will have to engage in to protect yourself and your family from AMI S…
    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