QTableWidget控件学习

内容是从网上找的,放到这备查。函数

【1】QTableWidget简介学习

QTableWidget是QT对话框设计中经常使用的显示数据表格的控件。字体

学习QTableWidget就要首先看看QTableView控件(控件也是有”家世“的!就像研究人同样同样的),由于QTableWidget继承于类QTableView。ui

二者主要区别是QTableView能够使用自定义的数据模型来显示内容(也就意味着使用时先要经过setModel来绑定数据源),而QTableWidget则只能使用标准的数据模型。spa

QTableWidget单元格数据是QTableWidgetItem对象来实现的(即就是不须要数据源,单元格内的信息须要逐个填充便可)。设计

这主要因为QTableView类中有setModel成员函数,而到了QTableWidget类中,该成员函数变成了私有。code

使用QTableWidget就离不开QTableWidgetItem。QTableWidgetItem用来表示表格中的其中一个单元格,整个表格都须要用逐个单元格对象QTableWidgetItem构建起来。对象

【2】QTableWidget控件属性blog

(1)禁止编辑表格继承

在默认状况下,表格里的字符是能够更改的。

好比双击一个单元格,就能够修改原来的内容,若是想禁止用户的这种操做,让这个表格对用户只读,能够这样:

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

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

1 /*设置表格为整行选中*/
2 ui.qtablewidget->setSelectionBehavior(QAbstractItemView::SelectRows);

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

单个选中意味着每次只能够选中一个单元格,多个就是至关于能够选择”一片“那种模式。

1 /*设置容许多个选中*/ 
2     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);

(11)合并单元格

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

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

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

(13)设置显示网格

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

(14)设置滚动条

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

(15)设置列标签

复制代码
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     //设置行列数(只有列存在的前提下,才能够设置列标签)
11     int HlableCnt = HStrList.count();
12     ui.qtablewidget->setRowCount(10);
13     ui.qtablewidget->setColumnCount(HlableCnt);
14 
15     //设置列标签
16     ui.qtablewidget->setHorizontalHeaderLabels(HStrList);
复制代码

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

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

(17)设置字体

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

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

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

 (19)个性化设置

    学习  qt assistant  "qt style sheets"

  例如:setStyleSheet("QTableWidget{ gridline-color : rgb(255, 0, 0)}");设置表格线的颜色为红色

相关文章
相关标签/搜索