欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C/C++表格組件Qt?TableWidget應用詳解

 更新時間:2021年12月01日 11:54:58   作者:lyshark  
本文詳細講解了C/C++中使用列表框組件Qt?TableWidget的方法,文中通過示例代碼介紹的非常詳細。對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

TableWidget 表格結構組件,該組件可以看作是TreeWidget樹形組件的高級版,表格組件相比于樹結構組件靈活性更高,不僅提供了輸出展示二維表格功能,還可以直接對表格元素直接進行編輯與修改操作,表格結構分為表頭,表中數(shù)據(jù)兩部分,表格結構可看作一個二維數(shù)組,通過數(shù)組行列即可鎖定特定元素,如下代碼是針對表格結構的基本使用方法,分別實現(xiàn)了表頭數(shù)據(jù)的初始化,元素的插入等基本操作。

在研究Widget組件之前先來熟悉一下View組件,View組件相對Widget組件來說只是不具備編輯功能,其他功能保持一致,View組件支持與數(shù)據(jù)庫建立映射關系,如果表格無需更新則最好可以使用View組件,View組件創(chuàng)建表格代碼如下。

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

#include <iostream>
#include <QStandardItemModel>

QStandardItemModel *model = new QStandardItemModel();

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

    // 初始化tableView表頭
    model->setColumnCount(3);
    model->setHeaderData(0,Qt::Horizontal,QString("賬號"));
    model->setHeaderData(1,Qt::Horizontal,QString("用戶"));
    model->setHeaderData(2,Qt::Horizontal,QString("年齡"));

    ui->tableView->setModel(model);
    ui->tableView->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);  // 表頭居左顯示

    //設置列寬
    ui->tableView->setColumnWidth(0,101);
    ui->tableView->setColumnWidth(1,102);
}

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

// 對表格添加數(shù)據(jù)
// https://www.cnblogs.com/lyshark
void MainWindow::on_pushButton_clicked()
{
    for(int i = 0; i < 5; i++)
    {
        model->setItem(i,0,new QStandardItem("20210506"));

        //設置字符顏色
        model->item(i,0)->setForeground(QBrush(QColor(255, 0, 0)));
        //設置字符位置
        model->item(i,0)->setTextAlignment(Qt::AlignCenter);
        model->setItem(i,1,new QStandardItem(QString("lyshark")));

        model->setItem(i,2,new QStandardItem(QString("24")));
    }
}

代碼運行效果如下:

Widget組件的初始化與View組件基本保持一致,當程序運行時,首先在構造函數(shù)中執(zhí)行以下代碼,對表格進行初始化。

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

    QStringList header;
    header << "姓名" << "性別" << "年齡";

    ui->tableWidget->setColumnCount(header.size());                        // 設置表格的列數(shù)
    ui->tableWidget->setHorizontalHeaderLabels(header);                    // 設置水平頭
    ui->tableWidget->setRowCount(5);                                       // 設置總行數(shù)
    ui->tableWidget->setEditTriggers(QAbstractItemView::NoEditTriggers);   // 設置表結構默認不可編輯

    // 初始化右側的編輯框等屬性
    ui->radioButton->setChecked(true);
    ui->lineEdit_1->setText("");
    ui->lineEdit_2->setText("");

    // 填充數(shù)據(jù)
    QStringList NameList;
    NameList << "lyshark A" << "lyshark B" << "lyshark C";

    QStringList SexList;
    SexList << "男" << "男" << "女";

    qint32 AgeList[3] = {22,23,43};

    // 針對獲取元素使用 NameList[x] 和使用 NameList.at(x)效果相同
    for(int x=0;x< 3;x++)
    {
        int col =0;
        // 添加姓名
        ui->tableWidget->setItem(x,col++,new QTableWidgetItem(NameList[x]));
        // 添加性別
        ui->tableWidget->setItem(x,col++,new QTableWidgetItem(SexList.at(x)));
        // 添加年齡
        ui->tableWidget->setItem(x,col++,new QTableWidgetItem( QString::number(AgeList[x]) ) );
    }
}

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

代碼運行效果如下:

接著就是對Ui中的按鈕增加一些綁定事件,此處我們就通過connect綁定信號,綁定以下這幾個:

  • ?ui->pushButton 綁定添加信號
  • ?ui->pushButton_2 綁定刪除信號
  • ?ui->pushButton_3 綁定獲取單元格信號
  • ?ui->pushButton_4 綁定修改信號

增加添加按鈕信號: 給添加按鈕綁定一個信號槽,點擊按鈕添加

    connect(ui->pushButton,&QPushButton::clicked,[=](){

        QString Uname = ui->lineEdit_1->text();
        QString Usex = "男";
        int Uage = 0;

        if(ui->radioButton->isChecked())
            Usex = "男";
        if(ui->radioButton_2->isChecked())
            Usex = "女";

        Uage =(ui->lineEdit_2->text()).toInt();

        // 添加之前,先判斷Uname是否存在于TableWidget中,如果存在返回0不存在返回1
        bool isEmpty = ui->tableWidget->findItems(Uname,Qt::MatchExactly).empty();
        if(isEmpty)
        {
            ui->tableWidget->insertRow(0);    // 在行首添加一行空列表
            ui->tableWidget->setItem(0,0,new QTableWidgetItem(Uname));
            ui->tableWidget->setItem(0,1,new QTableWidgetItem(Usex));
            ui->tableWidget->setItem(0,2,new QTableWidgetItem( QString::number(Uage)));
        }
    });

增加刪除按鈕信號: 點擊按鈕刪除選中行

    connect(ui->pushButton_2,&QPushButton::clicked,[=](){
        bool isEmpty = ui->tableWidget->findItems(ui->lineEdit_1->text(),Qt::MatchExactly).empty();
        if(!isEmpty)
        {
            // 定位到所在行行號
            int row = ui->tableWidget->findItems(ui->lineEdit_1->text(),Qt::MatchExactly).first()->row();
            // 釋放資源
            ui->tableWidget->removeRow(row);
        }
    });

增加釋放單元格按鈕信號: 獲取當前選中單元,并釋放當前單格

    connect(ui->pushButton_3,&QPushButton::clicked,[=](){
        int row = ui->tableWidget->currentRow();
        std::cout << row << std::endl;

        QTableWidgetItem *table =  ui->tableWidget->currentItem();
        delete(table);
    });

增加修改單元格按鈕信號: 添加修改指定內(nèi)容的處理流程

    connect(ui->pushButton_4,&QPushButton::clicked,[=](){
        QTableWidgetItem *cellItem;

        // 取出當前選中行
        int curr_row = ui->tableWidget->currentRow();

        // 循環(huán)列數(shù)
        // https://www.cnblogs.com/lyshark
        for(int col=0; col<ui->tableWidget->columnCount(); col++)
        {
            // 尋找到當前列的指針
            cellItem = ui->tableWidget->item(curr_row,col);

            // 循環(huán)輸出列名稱
            std::cout << cellItem->text().toStdString().data() << std::endl;

            // 先來處理第一個姓名,讀出來并寫回到列表第0列
            if(col == 0)
                cellItem->setText(ui->lineEdit_1->text());

            // 判斷性別,并分別寫回到第1列
            if(col == 1)
            {
                if(ui->radioButton->isChecked())
                    cellItem->setText("男");
                if(ui->radioButton_2->isChecked())
                    cellItem->setText("女");
            }

            // 判斷年齡,并寫回到第3列
            if(col == 2)
                cellItem->setText(ui->lineEdit_2->text());
        }
    });

信號綁定后,代碼運行效果如下:

到此這篇關于C/C++表格組件Qt?TableWidget應用詳解的文章就介紹到這了。希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • C++?JSON庫?nlohmann::basic_json::array?的用法示例詳解

    C++?JSON庫?nlohmann::basic_json::array?的用法示例詳解

    nlohmann::json是一個C++的JSON庫,它提供了一種容易和直觀的方法來處理JSON數(shù)據(jù),nlohmann::json::array()是用來創(chuàng)建一個JSON數(shù)組的方法,這篇文章主要介紹了C++ JSON庫nlohmann::basic_json::array的用法,需要的朋友可以參考下
    2023-06-06
  • C語言深入探究程序的編譯之預處理

    C語言深入探究程序的編譯之預處理

    在C語言的程序中包括各種以符號#開頭的編譯指令,這些指令稱為預處理命令。預處理命令屬于C語言編譯器,而不是C語言的組成部分,通過預處理命令可擴展C語言程序設計的環(huán)境
    2022-05-05
  • C/C++ 中memset() 函數(shù)詳解及其作用介紹

    C/C++ 中memset() 函數(shù)詳解及其作用介紹

    這篇文章主要介紹了C/C++ 中memset() 函數(shù)詳解及其作用介紹,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-07-07
  • Clion下載安裝使用的詳細教程(Win+MinGW)

    Clion下載安裝使用的詳細教程(Win+MinGW)

    這篇文章主要介紹了Clion下載安裝使用教程(Win+MinGW),本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-08-08
  • C++語言const 關鍵字使用方法圖文詳解

    C++語言const 關鍵字使用方法圖文詳解

    在類中,如果你不希望某些數(shù)據(jù)被修改,可以使用const關鍵字加以限定。const 可以用來修飾成員變量、成員函數(shù)以及對象
    2020-01-01
  • Qt跨平臺窗口選擇功能的實現(xiàn)過程

    Qt跨平臺窗口選擇功能的實現(xiàn)過程

    很多時候為了方便軟件的使用,我們需要讓編寫的界面程序顯示在最上層,這時候就需要對窗口屬性進行調(diào)整,下面這篇文章主要給大家介紹了關于Qt跨平臺窗口選擇功能的實現(xiàn)過程,需要的朋友可以參考下
    2022-12-12
  • C++自定義API函數(shù)實現(xiàn)大數(shù)相乘算法

    C++自定義API函數(shù)實現(xiàn)大數(shù)相乘算法

    這篇文章主要為大家詳細介紹了C++自定義API函數(shù)實現(xiàn)大數(shù)相乘算法,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • C語言實現(xiàn)簡單計算器程序

    C語言實現(xiàn)簡單計算器程序

    這篇文章主要為大家詳細介紹了C語言實現(xiàn)簡單計算器程序,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2020-02-02
  • 詳解C++中new運算符和delete運算符的使用

    詳解C++中new運算符和delete運算符的使用

    這篇文章主要介紹了C++中new運算符和delete運算符的使用,文章來自于微軟開發(fā)者文檔,因而根據(jù)Visual C++的一些特性來進行講解,需要的朋友可以參考下
    2016-01-01
  • Qt 儀表盤的實現(xiàn)示例

    Qt 儀表盤的實現(xiàn)示例

    儀表盤在很多汽車和物聯(lián)網(wǎng)相關的系統(tǒng)中很常用,本文就來介紹一下Qt 儀表盤的實現(xiàn)示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12

最新評論