1.QTableWidget继承自QTableView。

QSqlTableModel能与QTableView绑定,但不能于QTableWidget绑定。​ QTableWidget是QTableView的子类,主要的区别是QTableView可以使用自定义的数据模型来显示内容(也就是先要通过setModel来绑定数据源),而QTableWidget则只能使用标准的数据模型,并且其单元格数据是QTableWidgetItem的对象来实现的(也就是不需要数据源,将逐个单元格内的信息填好即可)。这主要体现在QTableView类中有setModel成员函数,而到了QTableWidget类中,该成员函数变成了私有。使用QTableWidget就离不开QTableWidgetItem。QTableWidgetItem用来表示表格中的一个单元格,正个表格都需要用逐个单元格构建起来。

QTableWidget和QTableView区别见:https://blog.csdn.net/zyc_csdn/article/details/78830542

    tbl_task_list=new QTableWidget(this);
tbl_task_list->setMinimumHeight ();
tbl_task_list->setMaximumWidth ();
tbl_task_list->setColumnCount();
tbl_task_list->verticalHeader()->setVisible(false);
tbl_task_list->horizontalHeader()->setVisible(true);
tbl_task_list->setShowGrid(true); //设置显示格子线
tbl_task_list->setEditTriggers(QAbstractItemView::NoEditTriggers);
tbl_task_list->setSelectionBehavior(QAbstractItemView::SelectRows);
tbl_task_list->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch); QStringList header_task;
header_task<<"任务名称"<<"小车"<<"任务状态"<<"任务产生时间"<<"任务相应时间";
tbl_task_list->setHorizontalHeaderLabels(header_task);
tbl_task_list->setObjectName("tbl_task_list"); /*
//添加一行数据
rows=tbl_task_list->rowCount ()+1;
tbl_task_list->setRowCount (rows);
addTaskItem("111",rows-1,0);
addTaskItem("222",rows-1,1);
addTaskItem("333",rows-1,2);
addTaskItem("444",rows-1,3);
addTaskItem("555",rows-1,4); //添加一行数据
rows=tbl_task_list->rowCount ()+1;
tbl_task_list->setRowCount (rows);
addTaskItem("aaa",rows-1,0);
addTaskItem("bbb",rows-1,1);
addTaskItem("cccc",rows-1,2);
addTaskItem("dddd",rows-1,3);
addTaskItem("eeee",rows-1,4);
void Widget::addTaskItem(QString data,int row ,int col)
{
QTableWidgetItem *item = new QTableWidgetItem(data);
QFont font;
font.setFamily ("Verdana");
font.setBold (false);
font.setPixelSize ();
item->setFont(font);
item->setTextAlignment (Qt::AlignCenter);
tbl_task_list->setItem(row,col,item);
}

2. 隐藏列表头和行表头,#include <QHeaderView>

  tbMotorWidget->verticalHeader()->setVisible(false); //隐藏列表头
tbMotorWidget->horizontalHeader()->setVisible(false); //隐藏行表头

3. 设置表头的背景色

tableWidget->horizontalHeader()->setStyleSheet("QHeaderView::section{background:#00BFFF;}");

4. 隐藏滚动条

twInfo->setHorizontalScrollBarPolicy (Qt::ScrollBarAlwaysOff);
twInfo->setVerticalScrollBarPolicy (Qt::ScrollBarAlwaysOff);

5. 设置垂直头不可见,即左边序号不见

tableWidget->verticalHeader()->setVisible(true);//显示行序号1,2,3...

6. 每添加一条数据滚动条自动到底

tableWidget->scrollToBottom();

7. 文本居中显示

 QTableWidgetItem *item = new QTableWidgetItem(data);
QFont font;
font.setFamily ("Verdana");
font.setBold (false);
font.setPixelSize ();
item->setFont(font);
item->setTextAlignment (Qt::AlignCenter);
return item;

8. 指定表头字体

 QFont font;
font.setBold(true);
tableWidget->horizontalHeader()->setFont(font);

9. 设置表头的内容充满整个表格的宽度

tableWidget->horizontalHeader()->setStretchLastSection(true);

10. 选择行

tableWidget->setSelectionBehavior(QAbstractItemView::SelectRows); //设置选择行为时每次一行
    tableWidget->setSelectionMode(QAbstractItemView::ExtendedSelection); //可多选(Ctrl、Shift、Ctrl+A都可以)

11.QTableWidget使用setCellWidget设置控件默认是塞满填充的,如果强制设置了控件的尺寸,则默认左上角开始放置,有时候这种情况很难看,需要居中显示,QTableWidget可以设置文本居中显示,但是不能设置控件居中显示。使用如下方法可以实现:

 if(tbDataWidget->rowCount()==)
{
tbDataWidget->setRowCount();
for(int i=;i<;i++)
{
addTableCheckItem(i); QPushButton *btnColor=new QPushButton(this);
btnColor->setMinimumSize(,);
btnColor->setMaximumSize(,);
setButtonColor(btnColor,getRandomColor());
QWidget *btnWidget = new QWidget;
QHBoxLayout *hLayout = new QHBoxLayout(this);
hLayout->setSpacing(0);
hLayout->setMargin(0);
hLayout->addWidget(btnColor);
btnWidget->setLayout(hLayout);
tbDataWidget->setCellWidget(i,,btnWidget);
connect(btnColor,&QPushButton::clicked,[=](){
slotColorButtonClicked(i);
}); } }
void OperationWidget::slotColorButtonClicked(int row)
{ QWidget *widget = (QWidget *)tbDataWidget->cellWidget(row, );
QPushButton *btn = (QPushButton *)widget->children().at();
QColor c = QColorDialog::getColor(Qt::blue); setButtonColor(btn,c);
}
void OperationWidget::setButtonColor(QPushButton *btn, QColor c)
{
btn->setStyleSheet("background-color:rgb("+QString::number(c.red())+","
+QString::number(c.green())+","
+QString::number(c.blue())+");");
}

12.点击单元格触发事件

connect(tbDataWidget,SIGNAL(cellClicked(int,int)),this,SLOT(slotTableItemSelected(int,int)));

void OperationWidget::slotTableItemSelected(int row, int col)
{ if(tbDataWidget->item(row,)->checkState()==Qt::Checked)
{
emit sigShowSelectedValue(true,tbDataWidget->item(row,)->text());
}
else
{
emit sigShowSelectedValue(false,tbDataWidget->item(row,)->text());
}
}

13. 清除

tableWidget->clear();//清除所有可见数据(包括表头),行还在
tableWidget->clearContents();//只清除表中数据,不清除表头内容
tableWidget->setRowCount(0);//连行也清除掉

14. 添加控件,获得控件触发的行

 QSlider *slider=new QSlider(this);
slider->setOrientation(Qt::Horizontal);
slider->setMinimum(1100);
slider->setMaximum(1900);
slider->setSingleStep(1); connect(slider, SIGNAL(valueChanged(int)), this, SLOT(slotSilderValueChange(int)));
tbMotorWidget->setCellWidget(i,3,slider);
void OperationWidget::slotSilderValueChange(int value)
{
QSlider *senderObj=qobject_cast<QSlider*>(sender());
if(senderObj == nullptr)
{
return;
}
QModelIndex idx =tbMotorWidget->indexAt(QPoint(senderObj->frameGeometry().x(),senderObj->frameGeometry().y()));
int row=idx.row();
qDebug()<<"row"<<row;
}

15. 某一列禁止编辑

QTableWidgetItem *item = new QTableWidgetItem(data);
if(!isIsEditable)
{
item->setFlags(item->flags() & (~Qt::ItemIsEditable));
}

QTableWidget的更多相关文章

  1. QTableWidget详解(样式、右键菜单、表头塌陷、多选等)

    在Qt的开发过程中,时常会用到表单(QTableWidget)这个控件,网上的资料不少,但是都是最基本的,有一些比较经常遇到的问题也说得不太清楚.所以,今天就在这里总结一下! 以下为个人模拟Windo ...

  2. QTableWidget行选中/删除/添加行

    1  均分各列 tableWidget->horizontalHeader()->setStretchLastSection(true); //就是这个地方 tableWidget-> ...

  3. QTableWidget控件总结<二>

    QTableWidget是QT程序中常用的显示数据表格的空间,很类似于VC.C#中的DataGrid.说到QTableWidget,就必须讲一下它跟QTabelView的区别了.QTableWidge ...

  4. QTableWidget控件总结<一>

    [1]QTableWidget简介 QTableWidget是QT对话框设计中常用的显示数据表格的控件. 学习QTableWidget就要首先看看QTableView控件(控件也是有"家世& ...

  5. QTableWidget控件总结

    [1]QTableWidget简介 QTableWidget是QT对话框设计中常用的显示数据表格的控件. 学习QTableWidget就要首先看看QTableView控件(控件也是有”家世“的!就像研 ...

  6. QTableWidget 使用及美化_QtableWidget_QtableView滚动条宽度及样式

      //创建及属性设置m_tableWidget = new QTableWidget(this);m_tableWidget->setRowCount(10);m_tableWidget-&g ...

  7. QTableWidget的美化

      FriendTable->setFrameShape(QFrame::NoFrame);  //设置边框 FriendTable->setHorizontalHeaderLabels( ...

  8. 【转载】pyqt QTableWidget的使用

    转载地址: http://blog.sina.com.cn/s/blog_9b78c91101019sgi.html QTableWidget是QT程序中常用的显示数据表格的空间,很类似于VC.C#中 ...

  9. QTableWidget实用技巧(转)

    http://blog.csdn.NET/mingxia_sui/article/details/7681863 在使用Qt不多的日子里,已经两次用到了QTableWidget这个控件,也慢慢的习惯和 ...

  10. 【2016-08-06】QTableWidget的一些用法总结

    1. QTableWidget的列宽如何自适应显示区域大小? QTableWidget的列头继承自QHeaderView,因此如果不使用固定列宽而需要Table中多列的列宽自适应显示区域大小的话, 可 ...

随机推荐

  1. ACM-ICPC 2018 南京赛区网络预赛 B The writing on the wall(思维)

    https://nanti.jisuanke.com/t/30991 题意 一个n*m的方格矩阵,有的格子被涂成了黑色,问该矩阵中有多少个子矩阵,子矩阵不包含黑色格子. 分析 参考https://bl ...

  2. Date类、SimpleDateFormat类

    Date 构造方法: 1.无参数构造方法: Date date = new Date(); System.out.println(date);// Thu Mar 28 16:28:40 CST 20 ...

  3. js 对象及空对象或数组及空数组的判断与比较

    工作中经常会使用到,这里记录一下 判断是不是对象: let obj = {}; Object.prototype.toString.call(obj) == "[object Object] ...

  4. 数据结构Java实现02----单向链表的插入和删除

    文本主要内容: 链表结构 单链表代码实现 单链表的效率分析 一.链表结构: (物理存储结构上不连续,逻辑上连续:大小不固定)            概念: 链式存储结构是基于指针实现的.我们把一个数据 ...

  5. IL 学习笔记

    先上几篇博客链接: 一步步教你读懂NET中IL(图文详解) C#基础之IL 详解.NET IL代码 C# IL DASM 使用 你必须知道的.NET <C# to IL>.<Expe ...

  6. GCC编译器原理(二)------编译原理一:ELF文件(1)

    二.ELF 文件介绍 2.1 可执行文件格式综述 相对于其它文件类型,可执行文件可能是一个操作系统中最重要的文件类型,因为它们是完成操作的真正执行者.可执行文件的大小.运行速度.资源占用情况以及可扩展 ...

  7. position:fixed 失效

    如果position:fixed 失效,那应该是你设置position的元素的父元素中有设置了transform属性哦 . 把 transform删除或设置为none就可以解决啦. 但是如果trans ...

  8. (15)DeleteColumnsMakeSortedIII

    一.问题描述 给定一个字符串形的数组,求最小的删除数目,使得删除后的字符串是字典型有序的. 二.思路Code package algorithm; /** * Created by adrian.wu ...

  9. python写商品管理练习

    #.添加 #.商品名称 #.要从文件里面把所有的商品读出来 #.价格 #.写一个方法判断是否为合理的价格 #.数量 #整数 # product = { # "爱疯差":{ # &q ...

  10. mysql 文件操作 表

    一 :  访问库  use db1 查询当前表所在文件夹 :  select database(); 增:   create table t1(id int, name chat(10)); 查询:  ...