Qt中表格属性相关操作,调整表格宽度高度自适应内容等

1 表格列宽设置

利用Qt designer设计,可以通过改变表头的列宽从而保证内容不会被遮盖,输入空格的方式增加表头的长度,比如表头为"Value",则改成"Value ",可以扩展列默认的宽度,保证后面添加的数据不会遮盖了。

2 表头颜色

在样式表中设置,双击编辑表头内容时,属性可设置字体颜色,但是无法设置背景色,QTableWidget没有设置表头背景色的函数,通过Qss样式设置。但是这样就没法设置背景颜色。在setStyleSheet内容中设置

javascript 复制代码
QHeaderView::section {background-color:#E8F0F5;}

而且预览方式无法看见效果,需要运行整个工程文件,因为背景代码是在其他文件运行的。

3 选中行为

可以设置点击选中整行SelectRows ,也可以只选中当前单元格SelectItem ,选中整列SelectColumns

4 行高列宽设置

javascript 复制代码
ui->tabGGA->resizeColumnsToContents(); // 这样设置后,表格不会遮盖过长的文字
ui->tabGGA->resizeRowsToContents();  // 根据内容设置所有行高

//需要设置每个单元格,注意,需要单元格填充了内容才可以设置
ui->tableWidget->item(0,2)->setTextAlignment(Qt::AlignHCenter|Qt::AlignVCenter);
/* 设置全部为空字符,然后设置居中格式 */

5 表格宽高自适应缩放

设置表格的宽度和高度与布局自适应调整,行列等宽高。

javascript 复制代码
ui->tableWidget->horizontalHeader()->setSectionResizeMode(QHeaderView::Stretch);
ui->tableWidget->verticalHeader()->setSectionResizeMode(QHeaderView::Stretch);

6 所有表格插入相同内容的方式

cpp 复制代码
for (auto i=0;i<4;i++)
    ui->tabMEAS->setItem(i,2,new QTableWidgetItem(QString::number(tag)));

如果改成循环如下,则会报错**-QTableWidget: cannot insert an item that is already owned by another QTableWidget-**

cpp 复制代码
QTableWidgetItem *stag = new QTableWidgetItem(QString::number(tag));
for (auto i=0;i<4;i++)
    ui->tabMEAS->setItem(i,2,stag);
相关推荐
边疆.5 分钟前
数据结构:内部排序
c语言·开发语言·数据结构·算法·排序算法
木子欢儿15 分钟前
在 Debian 12 上安装 Java 21
java·运维·开发语言·debian
终末圆19 分钟前
MyBatis XML映射文件编写【后端 18】
xml·java·开发语言·后端·算法·spring·mybatis
就这个java爽!20 分钟前
超详细的XML介绍【附带dom4j操作XML】
xml·java·开发语言·数据库·青少年编程·eclipse
Damon小智21 分钟前
C#进阶-基于雪花算法的订单号设计与实现
开发语言·算法·c#·雪花算法·订单号
_.Switch25 分钟前
Python Web 架构设计与性能优化
开发语言·前端·数据库·后端·python·架构·log4j
Q1860000000029 分钟前
用java语言写一个表的查询操作
java·开发语言·oracle
GoppViper1 小时前
uniapp js修改数组某个下标以外的所有值
开发语言·前端·javascript·前端框架·uni-app·前端开发
jzpfbpx1 小时前
[go] 适配器模式
开发语言·golang·适配器模式
好看资源平台1 小时前
JavaScript 数据可视化:前端开发的核心工具
开发语言·javascript·信息可视化