日韩av黄I国产麻豆传媒I国产91av视频在线观看I日韩一区二区三区在线看I美女国产在线I麻豆视频国产在线观看I成人黄色短片

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) >

QT学习笔记之QTableView设置属性的方法

發(fā)布時(shí)間:2025/3/20 65 豆豆
生活随笔 收集整理的這篇文章主要介紹了 QT学习笔记之QTableView设置属性的方法 小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

寫在前面

這是在網(wǎng)上找到的,因?yàn)槌u的人太多,我也不知道原創(chuàng)是誰(shuí)了,不好意思貼出原博客的地址了,博主請(qǐng)?jiān)徫?#xff01;!

方法

一 添加表頭//準(zhǔn)備數(shù)據(jù)模型QStandardItemModel *student_model = new QStandardItemModel();student_model->setHorizontalHeaderItem(0, new QStandardItem(QObject::tr("Name")));student_model->setHorizontalHeaderItem(1, new QStandardItem(QObject::tr("NO.")));student_model->setHorizontalHeaderItem(2, new QStandardItem(QObject::tr("Sex")));student_model->setHorizontalHeaderItem(3, new QStandardItem(QObject::tr("Age")));student_model->setHorizontalHeaderItem(4, new QStandardItem(QObject::tr("College")));//利用setModel()方法將數(shù)據(jù)模型與QTableView綁定ui->student_tableview->setModel(student_model); 二 設(shè)置表格屬性//設(shè)置列寬不可變動(dòng),即不能通過鼠標(biāo)拖動(dòng)增加列寬 ui->student_tableview->horizontalHeader()->setResizeMode(0, QHeaderView::Fixed); ui->student_tableview->horizontalHeader()->setResizeMode(1, QHeaderView::Fixed); ui->student_tableview->horizontalHeader()->setResizeMode(2, QHeaderView::Fixed); ui->student_tableview->horizontalHeader()->setResizeMode(3, QHeaderView::Fixed); ui->student_tableview->horizontalHeader()->setResizeMode(4, QHeaderView::Fixed); //設(shè)置表格的各列的寬度值 ui->student_tableview->setColumnWidth(0,100); ui->student_tableview->setColumnWidth(1,100); ui->student_tableview->setColumnWidth(2,100); ui->student_tableview->setColumnWidth(3,100); ui->student_tableview->setColumnWidth(4,100); //默認(rèn)顯示行頭,如果你覺得不美觀的話,我們可以將隱藏 ui->student_tableview->verticalHeader()->hide(); //設(shè)置選中時(shí)為整行選中 ui->student_tableview->setSelectionBehavior(QAbstractItemView::SelectRows); //設(shè)置表格的單元為只讀屬性,即不能編輯 ui->student_tableview->setEditTriggers(QAbstractItemView::NoEditTriggers); //如果你用在QTableView中使用右鍵菜單,需啟用該屬性 ui->tstudent_tableview->setContextMenuPolicy(Qt::CustomContextMenu); 三 動(dòng)態(tài)添加行 在表格中添加行時(shí),我們只需要在model中插入數(shù)據(jù)即可,一旦model中的數(shù)據(jù)發(fā)生變化,QTabelView顯示就會(huì)做相應(yīng)的變動(dòng) //在第一行添加學(xué)生張三的個(gè)人信息(setItem函數(shù)的第一個(gè)參數(shù)表示行號(hào),第二個(gè)表示列號(hào),第三個(gè)為要顯示的數(shù)據(jù))student_model->setItem(0, 0, new QStandardItem(“張三"));student_model->setItem(0, 1, new QStandardItem("20120202"));student_model->setItem(0, 2, new QStandardItem(""));student_model->setItem(0, 3, new QStandardItem("18"));student_model->setItem(0, 4, new QStandardItem("土木學(xué)院")); 四 設(shè)置數(shù)據(jù)顯示的樣式//設(shè)置單元格文本居中,張三的數(shù)據(jù)設(shè)置為居中顯示student_model->item(0, 0)->setTextAlignment(Qt::AlignCenter);student_model->item(0, 1)->setTextAlignment(Qt::AlignCenter);student_model->item(0, 2)->setTextAlignment(Qt::AlignCenter);student_model->item(0, 3)->setTextAlignment(Qt::AlignCenter);student_model->item(0, 4)->setTextAlignment(Qt::AlignCenter);//設(shè)置單元格文本顏色,張三的數(shù)據(jù)設(shè)置為紅色student_model->item(0, 0)->setForeground(QBrush(QColor(255, 0, 0))); student_model->item(0, 1)->setForeground(QBrush(QColor(255, 0, 0))); student_model->item(0, 2)->setForeground(QBrush(QColor(255, 0, 0))); student_model->item(0, 3)->setForeground(QBrush(QColor(255, 0, 0))); student_model->item(0, 4)->setForeground(QBrush(QColor(255, 0, 0))); //將字體加粗student_model->item(0, 0)->setFont( QFont( "Times", 10, QFont::Black ) );student_model->item(0, 1)->setFont( QFont( "Times", 10, QFont::Black ) );student_model->item(0, 2)->setFont( QFont( "Times", 10, QFont::Black ) );student_model->item(0, 3)->setFont( QFont( "Times", 10, QFont::Black ) );student_model->item(0, 4)->setFont( QFont( "Times", 10, QFont::Black ) );//設(shè)置排序方式,按年齡降序顯示student_model->sort(3, Qt::DescendingOrder);

自己的試驗(yàn)品

自己根據(jù)需求以及上述的幫助寫了個(gè)功能塊,可以借大家參考下
這是截圖:

以下是這部分的代碼:

//這里根據(jù)房間狀態(tài)的不同分別顯示不同的顏色 //設(shè)置單元格的顏色 void setRowColor(int index, int status, QStandardItemModel* itemModel) {if (status == -1){itemModel->item(index, 0)->setBackground(QBrush(QColor(200,200,169)));itemModel->item(index, 0)->setForeground(QBrush(Qt::white));itemModel->item(index, 1)->setBackground(QBrush(QColor(200, 200, 169)));itemModel->item(index, 1)->setForeground(QBrush(Qt::white));itemModel->item(index, 2)->setBackground(QBrush(QColor(200, 200, 169)));itemModel->item(index, 2)->setForeground(QBrush(Qt::white));itemModel->item(index, 3)->setBackground(QBrush(QColor(200, 200, 169)));itemModel->item(index, 3)->setForeground(QBrush(Qt::white));}if (status == 0){itemModel->item(index, 0)->setBackground(QBrush(QColor(131, 175, 155)));itemModel->item(index, 0)->setForeground(QBrush(Qt::white));itemModel->item(index, 1)->setBackground(QBrush(QColor(131, 175, 155)));itemModel->item(index, 1)->setForeground(QBrush(Qt::white));itemModel->item(index, 2)->setBackground(QBrush(QColor(131, 175, 155)));itemModel->item(index, 2)->setForeground(QBrush(Qt::white));itemModel->item(index, 3)->setBackground(QBrush(QColor(131, 175, 155)));itemModel->item(index, 3)->setForeground(QBrush(Qt::white));}if (status == 1){itemModel->item(index, 0)->setBackground(QBrush(QColor(254, 67, 101)));itemModel->item(index, 0)->setForeground(QBrush(Qt::white));itemModel->item(index, 1)->setBackground(QBrush(QColor(254, 67, 101)));itemModel->item(index, 1)->setForeground(QBrush(Qt::white));itemModel->item(index, 2)->setBackground(QBrush(QColor(254, 67, 101)));itemModel->item(index, 2)->setForeground(QBrush(Qt::white));itemModel->item(index, 3)->setBackground(QBrush(QColor(254, 67, 101)));itemModel->item(index, 3)->setForeground(QBrush(Qt::white));} }

另外,附上QTableView獲取某個(gè)單元格的數(shù)據(jù)的操作:

int curRow=ui->tableView->currentIndex().row(); //選中行 QAbstractItemModel *modessl = ui->tableView->model(); QModelIndex indextemp = modessl->index(curRow,i);//遍歷第一行的所有列 i 是你要取值的列的下標(biāo) //這個(gè)是一個(gè)單元格的值。tostring()----ok QVariant datatemp = modessl->data(indextemp);

再次聲明,這不是我的原創(chuàng),因?yàn)椴恢涝髡咚詻]有貼出原地址,希望大家原諒我沒有貼出原博客的地址!

轉(zhuǎn)載于:https://www.cnblogs.com/WIT-Evan/p/7289753.html

總結(jié)

以上是生活随笔為你收集整理的QT学习笔记之QTableView设置属性的方法的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。