QT学习笔记之QTableView设置属性的方法
生活随笔
收集整理的這篇文章主要介紹了
QT学习笔记之QTableView设置属性的方法
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
寫在前面
這是在網上找到的,因為抄襲的人太多,我也不知道原創是誰了,不好意思貼出原博客的地址了,博主請原諒我!!
方法
一 添加表頭//準備數據模型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()方法將數據模型與QTableView綁定ui->student_tableview->setModel(student_model); 二 設置表格屬性//設置列寬不可變動,即不能通過鼠標拖動增加列寬 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); //設置表格的各列的寬度值 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); //默認顯示行頭,如果你覺得不美觀的話,我們可以將隱藏 ui->student_tableview->verticalHeader()->hide(); //設置選中時為整行選中 ui->student_tableview->setSelectionBehavior(QAbstractItemView::SelectRows); //設置表格的單元為只讀屬性,即不能編輯 ui->student_tableview->setEditTriggers(QAbstractItemView::NoEditTriggers); //如果你用在QTableView中使用右鍵菜單,需啟用該屬性 ui->tstudent_tableview->setContextMenuPolicy(Qt::CustomContextMenu); 三 動態添加行 在表格中添加行時,我們只需要在model中插入數據即可,一旦model中的數據發生變化,QTabelView顯示就會做相應的變動 //在第一行添加學生張三的個人信息(setItem函數的第一個參數表示行號,第二個表示列號,第三個為要顯示的數據)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("土木學院")); 四 設置數據顯示的樣式//設置單元格文本居中,張三的數據設置為居中顯示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);//設置單元格文本顏色,張三的數據設置為紅色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 ) );//設置排序方式,按年齡降序顯示student_model->sort(3, Qt::DescendingOrder);自己的試驗品
自己根據需求以及上述的幫助寫了個功能塊,可以借大家參考下
這是截圖:
以下是這部分的代碼:
//這里根據房間狀態的不同分別顯示不同的顏色 //設置單元格的顏色 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獲取某個單元格的數據的操作:
int curRow=ui->tableView->currentIndex().row(); //選中行 QAbstractItemModel *modessl = ui->tableView->model(); QModelIndex indextemp = modessl->index(curRow,i);//遍歷第一行的所有列 i 是你要取值的列的下標 //這個是一個單元格的值。tostring()----ok QVariant datatemp = modessl->data(indextemp);再次聲明,這不是我的原創,因為不知道原作者所以沒有貼出原地址,希望大家原諒我沒有貼出原博客的地址!
轉載于:https://www.cnblogs.com/WIT-Evan/p/7289753.html
總結
以上是生活随笔為你收集整理的QT学习笔记之QTableView设置属性的方法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: POJ 2785 4 Values wh
- 下一篇: 使用绘图API自定义组件