QT表格QTableWidget在win10下纵横表头无分隔线的问题

一.问题

最近在Win10 下使用QT开发界面程序,遇到了一个问题,在使用QTableWidget 表格式出现了以下问题,如图:

为什么左边表头中间 每行之间没有分割线,其实上面表头下面的线默认也是没有的,是后来加上去的,这个间隔线在其它版本系统上是存在的。

这个问题很早就遇见过,一直没有找到解决方法,今天在搜索资料时,偶然在网上看见了一片文章,对解决此问题帮助很大。

二.导致该问题的原因

为什么纵横表头会没有分隔线呢,在网上查阅了一些资料,原来是因为win10的风格如此,在其它版本系统上是不存在这样的问题的,在Windows 10上,绘制图元不会绘制底部边框(这是默认的Windows 10表头样式 - 可以在Windows文件资源管理器中看到)。QT会使用当前系统风格的UI显示样式,这也可以理解

三.添加分隔线

下面就着手解决该问题,在win10下手动设置表格 纵横头的间隔线,如下代码,可以在代码中直接使用设置自己的QTableWidget对象

//如下代码设置横向表格头的间隔线,有四个方向的间隔线,不需要间隔线的可以设置为0px
ui.myTableWidget->horizontalHeader()->setStyleSheet(
"QHeaderView::section{"
            "border-top:0px solid #E5E5E5;"
            "border-left:0px solid #E5E5E5;"
            "border-right:0.5px solid #E5E5E5;"
            "border-bottom: 0.5px solid #E5E5E5;"
            "background-color:white;"
            "padding:4px;"
        "}"
)

//如下代码设置横向表格头的间隔线,有四个方向的间隔线,不需要间隔线的可以设置为0px
ui.myTableWidget->verticalHeader()->setStyleSheet(
"QHeaderView::section{"
            "border-top:0px solid #E5E5E5;"
            "border-left:0px solid #E5E5E5;"
            "border-right:0.5px solid #E5E5E5;"
            "border-bottom: 0.5px solid #E5E5E5;"
            "background-color:white;"
            "padding:4px;"
        "}"
)

//如下代码设置列表左上角第0行第0列的那个格子的边框线
ui.myTableWidget->verticalHeader()->setStyleSheet(
"QTableCornerButton::section{"
            "border-top:0px solid #E5E5E5;"
            "border-left:0px solid #E5E5E5;"
            "border-right:0.5px solid #E5E5E5;"
            "border-bottom: 0.5px solid #E5E5E5;"
            "background-color:white;"
        "}"
)

参考文章:在QTableWidget中的列标题下添加边框 - Thinbug

  • 12
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: Qt中,QTableWidget是一个表格控件,在使用中可以方便地添加各种类型的数据,并轻松展示和管理数据。其中,通过设置表头筛选功能,我们可以更快速地找到我们想要查找的内容。 表头筛选功能的实现方式是,在表头上右键点击,选择“行筛选”或“列筛选”功能,然后弹出一个可输入的输入框,用户可以输入关键字或选取下拉列表中的文本,然后按下确定,筛选出满足条件的行或列。 要实现表头筛选功能,需要调用QTableWidget的setSortingEnabled(true)函数,此外还需要使用QHeaderView来设置表头,具体如下: ```cpp QTableView *tableView = new QTableView(this); QStandardItemModel *model = new QStandardItemModel(); tableView->setModel(model); //设置表头 QHeaderView *headerView = tableView->horizontalHeader(); headerView->setDefaultAlignment(Qt::AlignHCenter); //表头文本居中对齐 headerView->setStretchLastSection(true); //最后一列自适应宽度 headerView->setSectionResizeMode(QHeaderView::ResizeToContents); //列宽自适应内容 //支持表头筛选 headerView->setSectionsClickable(true); headerView->setContextMenuPolicy(Qt::CustomContextMenu); connect(headerView, SIGNAL(customContextMenuRequested(const QPoint&)), this, SLOT(showHeaderMenu(const QPoint&))); //使用信号槽触发表头右键菜单事件 tableView->setSortingEnabled(true); //使能排序功能 ``` 以上为表头设置方法的一般步骤,根据实际的需求和场景,也可以做出适当的调整。在实现了表头的基本功能后,我们可以通过响应菜单事件来实现筛选功能的思路,如下所示: ```cpp void showHeaderMenu(const QPoint& pos) { QHeaderView *header = qobject_cast<QHeaderView *>(sender()); QMenu *menu = new QMenu(header); //创建菜单 QAction *action = menu->addAction(tr("筛选")); connect(action, &QAction::triggered, [&](){ int index = header->logicalIndexAt(pos); QMenu *pMenu = new QMenu(this); QAction *pFindByLetter = pMenu->addAction(tr("按首字母筛选")); connect(pFindByLetter, &QAction::triggered, [&]() { QString letter = pFindByLetter->text().split(" ")[1]; QRegExp regExp(QString("^[%1].*").arg(letter), Qt::CaseInsensitive, QRegExp::RegExp2); tableView->setSortingEnabled(false); //根据输入文本对表格元素进行排序 bool findResult = false; for(int i = 0; i < model->rowCount(); ++i) { bool rowMatch = false; for(int j = 0; j < model->columnCount(); ++j) { QModelIndex index = model->index(i, j); QStandardItem *item = model->itemFromIndex(index); if(item->text().contains(regExp)) { //如果符合条件,则设置标记 rowMatch = true; break; } } //如果还有符合条件的行,则显示 if(rowMatch == true) { tableView->showRow(i); findResult = true; } else { //如果不符合条件,则不显示 tableView->setRowHidden(i, true); } } }); pMenu->popup(header->mapToGlobal(pos)); }); menu->popup(header->mapToGlobal(pos)); } ``` 以上即为QTableWidget表头筛选功能的基本实现思路,当然,遇到实际需求时,也可以根据业务方向和特殊需求进行适当的修改。 ### 回答2: Qt QTableWidget 是一个非常强大的表格控件,可以方便地显示和管理大量的数据。在实际的开发中,我们常常会遇到需要对表格的某些列进行筛选的需求。这时候,QTableWidget 提供了非常方便的表头筛选功能。 表头筛选指的是在表格表头添加筛选器,可以方便地对该列的数据进行筛选。使用 QTableWidget 实现表头筛选功能的步骤如下: 1.创建 QTableWidget 对象,并设置表格的行数和列数。 2.设置表头的每一列的标题,可以使用 setHorizontalHeaderLabels() 函数进行设置。 3.为每一列的表头添加筛选器,可以使用 setFiltersEnabled() 函数进行设置。该函数接受一个布尔值参数,表示是否启用该列的筛选器。 4.设置表格的数据,并将数据填充至表格中。 5.可以在表格的某一列的表头上看到一个筛选器图标,单击该图标即可打开该列的筛选器,并对该列的数据进行筛选。 6.可以使用 tabKeyPressed() 信号和returnKeyPressed() 信号来响应用户在筛选器中输入的文字,使用 setItemDelegate() 函数来实现自定义的筛选器代理。 在实现表头筛选功能的过程中,需要注意设置表格的默认大小及设置表头每一列的宽度,以便让用户更方便地操作。此外,还需要对用户在筛选器中输入的文字进行校验,避免出现误操作的情况。 总之,Qt QTableWidget表头筛选功能为用户提供了更方便的数据筛选方式,使得大量数据的管理和查看更加简便高效。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值