【轉載】QT QTableView用法小結

原始日期:ide

2016-08-16 09:28函數

 

來源:http://blog.csdn.net/wang_lichun/article/details/7805253字體

QTableView經常使用於實現數據的表格顯示。下面咱們如何按步驟實現學生信息表格:ui

一 添加表頭.net

    //準備數據模型
    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);blog


二 設置表格屬性排序

    //設置列寬不可變更,即不能經過鼠標拖動增長列寬        
    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);   it

    //設置表格的各列的寬度值        
    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);       io

    //默認顯示行頭,若是你以爲不美觀的話,咱們能夠將隱藏        
    ui->student_tableview->verticalHeader()->hide();      table

    //設置選中時爲整行選中        
    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, 

相關文章
相關標籤/搜索