QTableWidget控件使用总结

简介:

QTableWidget介绍

QTbaleWidget是QT对话框设计中常用的显示数据表格的控件。

学习QTableWidget就要首先看看QTableView控件(控件也是有”家世“的!就像研究人一样一样的),因为QTableWidget继承于类QTableView。
两者主要区别是QTableView可以使用自定义的数据模型来显示内容(也就意味着使用时先要通过setModel来绑定数据源),而QTableWidget则只能使用标准的数据模型。
QTableWidget单元格数据是QTableWidgetItem对象来实现的(即就是不需要数据源,单元格内的信息需要逐个填充即可)。
这主要由于QTableView类中有setModel成员函数,而到了QTableWidget类中,该成员函数变成了私有。
使用QTableWidget就离不开QTableWidgetItem。

QTableWidgetItem用来表示表格中的其中一个单元格,整个表格都需要用逐个单元格对象QTableWidgetItem构建起来。

QTableWidget使用总结

(1)禁止编辑表格

在默认情况下,表格里的字符是可以更改的。

 比如双击一个单元格,就可以修改原来的内容,如果想禁止用户的这种操作,让这个表格对用户只读,可以这样:

  1. ui.qtablewidget->setEditTriggers(QAbstractItemView::NoEditTriggers);  


(2)设置表格为选择整行

  1. ui.qtablewidget->setSelectionBehavior(QAbstractItemView::SelectRows);   


(3)设置单个选中和多个选中

 单个选中意味着每次只可以选中一个单元格,多个就是相当于可以选择”一片“那种模式。

  1. ui.qtablewidget->setSelectionMode(QAbstractItemView::ExtendedSelection);   


(4)表格表头的显示与隐藏

 对于水平或垂直方向的表头,如果不想显示可以用以下方式进行(隐藏/显示)设置:

  1. ui.qtablewidget->verticalHeader()->setVisible(true);    
  2. ui.qtablewidget->horizontalHeader()->setVisible(false);  


(5)设置具体单元格中字体的对齐方式

  1. ui.qtablewidget->item(0, 0)->setTextAlignment(Qt::AlignHCenter);  


(6)设置具体单元格中字体格式


  1. ui.qtablewidget->item(1, 0)->setBackgroundColor(QColor(0,60,10));     
  2. ui.qtablewidget->item(1, 0)->setTextColor(QColor(200,111,100));   
  3. ui.qtablewidget->item(1, 0)->setFont(QFont("Helvetica"));   


(7)设置具体单元格的值

  1. ui.qtablewidget->setItem(1, 0, new QTableWidgetItem(str));  


(8)把QTableWidgetItem对象内容转换为QString

  1. QString str =ui.qtablewidget->item(0, 0)->data(Qt::DisplayRole).toString();  


(9)具体单元格中添加控件

  1. QComboBox *comBox = new QComboBox();   
  2. comBox->addItem("F");   
  3. comBox->addItem("M");   
  4. ui.qtablewidget->setCellWidget(0,3,comBox);  


(10)合并单元格

  1.  //合并单元格的效果  
  2. ui.qtablewidget->setSpan(2, 2, 3, 2);  
  3. //第一个参数:要改变的单元格行数  
  4. //第二个参数:要改变的单元格列数  
  5. //第三个参数:需要合并的行数  
  6. //第四个参数:需要合并的列数  


(11)具体单元格中插入图片

  1. ui.qtablewidget->setItem(3, 2, new QTableWidgetItem(QIcon("images/music.png"), "Music"));  


(12)设置显示网格

  1. ui.qtablewidget->setShowGrid(true);//显示表格线  


(13)设置滚动条

  1. ui.qtablewidget->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);//去掉水平滚动条  


(14)设置列标签

  1. //初始化界面  
  2. QStringList  HStrList;  
  3. HStrList.push_back(QString("name"));  
  4. HStrList.push_back(QString("id"));  
  5. HStrList.push_back(QString("age"));  
  6. HStrList.push_back(QString("sex"));  
  7. HStrList.push_back(QString("department"));  
  8.     
  9. //设置行列数(只有列存在的前提下,才可以设置列标签)  
  10. int HlableCnt = HStrList.count();  
  11. ui.qtablewidget->setRowCount(10);  
  12. ui.qtablewidget->setColumnCount(HlableCnt);  
  13.   
  14. //设置列标签  
  15. ui.qtablewidget->setHorizontalHeaderLabels(HStrList);  


(15)设置行和列的大小设为与内容相匹配

  1. ui.qtablewidget->resizeColumnsToContents();    
  2. ui.qtablewidget->resizeRowsToContents();    


(16)设置字体


  1. ui.qtablewidget->setFont(font);   //设置字体  

(17)获取某一单元格的内容

  1. <p>QString strText = ui.qtablewidget->item(0, 0)->text();</p>  

(18)清除单元格测内容

  1. ui.tablewidget->clearContents( );   // 清除表项  

(19)删除整个列表

  1. while(ui.tablewidget->rowCount( ) > 0)  
  2. {  
  3.     ui.tablewidget->removeRow(0);    // 删除第0行  
  4. }  

(20)获取选定的行

  1. // QTableWidget选中所有单元格及取消选中所有单元格  
  2. //    ui->allowSelectKeyTableWidget->selectAll();  
  3. //    ui->allowSelectKeyTableWidget->setFocus();  
  4.     introwCount=ui->TableWidget->rowCount();  
  5.     qDebug()<<"rowcount"<<rowCount;  
  6.     intcolCount=ui->TableWidget->columnCount();  
  7.     qDebug()<<"colcount"<<colCount;  
  8.     QTableWidgetSelectionRangerange(0,0,rowCount-1,colCount-1);  
  9.     ui->TableWidget->setRangeSelected(range,true);//false不选中  
  10.     ui->TableWidget->setFocus();  

方法1

  1. QList<QTableWidgetItem*>items=ui->TableWidget->selectedItems();  
  2. intcount=items.count();  
  3. for(inti=0;i<count;i++)  
  4.     {  
  5.        introw=ui->TableWidget->row(items.at(i));//获取选中的行  
  6.        QTableWidgetItem*item=items.at(i);  
  7.        QStringname=item->text();//获取内容  
  8.     }  


方法2

  1. QList<QTableWidgetSelectionRange>ranges=ui->TableWidget->selectedRanges();  
  2.     intcount=ranges.count();  
  3.     for(inti=0;i<count;i++)  
  4.     {  
  5.        inttopRow=ranges.at(i).topRow();  
  6.        intbottomRow=ranges.at(i).bottomRow();  
  7.        for(intj=topRow;j<=bottomRow;j++)  
  8.        {  
  9.           qDebug()<<"selectRow"<<j;  
  10.         }  
  11. }  


转载:http://blog.csdn.net/gatieme/article/details/17991269

目录
相关文章
|
4月前
|
容器
【Qt 学习笔记】Qt常用控件 | 容器类控件 | Tab Widget的使用及说明
【Qt 学习笔记】Qt常用控件 | 容器类控件 | Tab Widget的使用及说明
261 2
|
4月前
【Qt 学习笔记】Qt常用控件 | 输入类控件 | Slider的使用及说明
【Qt 学习笔记】Qt常用控件 | 输入类控件 | Slider的使用及说明
525 2
|
7月前
|
数据库 开发者 Windows
QT 项目视图(QListView&QTreeView&QTableView)和项目部件(QListWidget&QTreeWidget&QTableWidget)详解-2
QT 项目视图(QListView&QTreeView&QTableView)和项目部件(QListWidget&QTreeWidget&QTableWidget)详解
|
7月前
|
XML 设计模式 JSON
QT 项目视图(QListView&QTreeView&QTableView)和项目部件(QListWidget&QTreeWidget&QTableWidget)详解-1
QT 项目视图(QListView&QTreeView&QTableView)和项目部件(QListWidget&QTreeWidget&QTableWidget)详解
|
7月前
【qt】QTableWidget 表格组件1
【qt】QTableWidget 表格组件
62 0
|
7月前
【qt】QTableWidget 表格组件2
【qt】QTableWidget 表格组件
76 0
|
7月前
【qt】QTableWidget 表格组件3
【qt】QTableWidget 表格组件
101 0
|
7月前
[Qt5&控件] 表格列表控件Table Widget的使用
[Qt5&控件] 表格列表控件Table Widget的使用
114 0
21 QT - QLabel控件使用
21 QT - QLabel控件使用
76 0
Qt-网易云音乐界面实现-5 收藏列表,播放列表实现 QListWidget QTableWidget
先上目前完成的内容吧,发现后面越写越多。在看看点击量,心凉凉。
415 0
Qt-网易云音乐界面实现-5 收藏列表,播放列表实现 QListWidget QTableWidget