QTreeWidget 仿表格显示

博客介绍了 QTreeWidget 仿表格显示的方法。思路是利用 QSS 的 border 属性拼凑表格样式,branch 只显示下边框并添加三角形装饰图片,item 显示右边框和下边框,同时要设置 QTreeView 选定项的背景色,还给出了 QSS 样式表和演示代码。

QTreeWidget 仿表格显示

image-20210602150011189

思路

使用QSS的 border 属性拼凑一个表格样式出来

  • branch 只显示下边框
  • branch 添加装饰图片,三角形图案
  • item 只显示右边框和下边框
  • QTreeView 有个选定项属性,需要设置背景色

QSS 样式表

QTreeWidget{
	border:1px solid black;
	alternate-background-color:lightgray;
	outline:none;
	selection-background-color:transparent;
}

QTreeView::item{
	border:1px solid black;
	border-left:transparent;
	border-top:transparent;
}

QTreeView::branch{
	border:1px solid black;
	border-right:transparent;
	border-left:transparent;
	border-top:transparent;
}

QTreeView::item:selected:active{
	color:white;
	background:lightblue;
}

QTreeView::branch:has-children:!has-siblings:closed,
QTreeView::branch:closed:has-children:has-siblings{
	image:url(stylesheet-branch-closed.png);
}

QTreeView::branch:open:has-children:!has-siblings,
QTreeView::branch:open:has-children:has-siblings{
	image:url(stylesheet-branch-open.png);
}

演示代码

凑个字数

#include "../../DebugTools/DebugTool.h"
#include <QtWidgets>

QString fileName_Qss = "style.qss";
int main(int argc, char* argv[])
{

    QApplication a(argc, argv);
    loadQssFile();
    watchQssFile();
    QTreeWidget tree;
    tree.header()->hide();
    addShortcut(&tree);

    tree.setColumnCount(3);
    tree.setAlternatingRowColors(true);

    QList<QTreeWidgetItem*> list;

    for (int i = 0; i < 4; ++i) {

        QStringList strs;
        for (int j = 0; j < 3; ++j) {
            strs << QString("%1_%2").arg(i).arg(j);
        }
        QTreeWidgetItem* item = new QTreeWidgetItem(strs);
        if (i == 2) {
            list[1]->addChild(item);
        }
        list << item;
    }

    tree.addTopLevelItems(list);

    tree.show();

    return a.exec();
}
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值