这个treewidget样式真是写得让人心碎,主因是那个天杀的表头,真是块古里古怪的硬骨头,令人抓狂,一直找不到给表头设定背景图的方法,让我一度决定弃用tree。

后来表头的属性找到了,下拉条又找不到。第一次接触stylesheet,完全是边做边学,不知所谓,又不想不做,默认的样式我就是看不过眼,处女座的人就是比较神经质。​

网上关于treewidget的样式介绍少之又少,不知道是不是因为大牛们都采用了treeview等其他方法去做了,或者说是tree太简单,只有我那么弱智还要去网上搜。​

总之,经过2天坚持不懈的泣血努力,总算是把这个控件的样式完完全全换掉了。​

特此记录,以资鼓励。​​

——————————————————————————————

树形列表控件,主要是对“表头”“列表背景” “下拉条”“鼠标扫动”做处理,以达到自定义效果。​​

不废话了,直接上代码。

m_QTreeWidget->setStyleSheet("​​

//列表背景

QTreeWidget{background-image:url(./image/treelistbk.jpg);}\ ​​

//每一项的身高 鼠标扫过 按下的变色

QTreeWidget::item{height:40px;}\

QTreeWidget::item:hover{}\​​

//表头背景 表头身高

QHeaderView::section{border-image: url(./image/header-test.png); height:40px;} "

);

列表的表头,给图片背景!天知道居然要用Qheaderview!!!天杀的!!!​

//下拉条的样式设置  具体内容 参考上一篇

http://blog.sina.com.cn/s/blog_8a621fc80102vizs.html

m_QTreeWidget->verticalScrollBar()->setStyleSheet("");​

m_QTreeWidget->horizontalScrollBar()->setStyleSheet("");​

完毕。其实很简单吧。​

但是却花了很长时间。​

俺写的第一个stylesheet。呼呼。虽浪费2天时间,人都快疯掉,但好歹最终成功了。

也算是入门了。

————————————————————————————​

以下是我的其他设置,作为一个初学者,都这两天慢慢琢磨的,留给自己看。

//字体

m_pQTreeWidget->setFont(QFont("Helvetica"));​

//表头字体 居中 (表内项目的字体居中要去add item的地方进行设置,目前没找到别的好办法。。。嘤嘤嘤。。。。)

m_pQTreeWidget->headerItem()->setFont(0,QFont("Helvetica",18,QFont::Bold));

m_pQTreeWidget->headerItem()->setFont(1,QFont("Helvetica",18,QFont::Bold));

m_pQTreeWidget->headerItem()->setTextAlignment(0,Qt::AlignHCenter | Qt::AlignVCenter); ​

m_pQTreeWidget->headerItem()->setTextAlignment(1,Qt::AlignHCenter

Qt::AlignVCenter); ​​

//表头不许移动,不许点击,不许排序。。。。哼哼哈。在我地盘的,你就得听我的!

setHeaderMovable(false);

m_pQTreeWidget->header()->setClickable(false);

m_pQTreeWidget->setFrameShape(QFrame::NoFrame); //设置无边框这样才可以自定义treewidget背景图

//表头可点击,点击后可排序

#if 0

//setHeaderHidden(true); //去掉表头

m_pQTreeWidget->header()->setClickable(true); //点击头自动排序

m_pQTreeWidget->setSortingEnabled(true); //用来设置是否可以排序

m_pQTreeWidget->sortItems(0, Qt::AscendingOrder); //id属性,即第0列,升序排列

#endif​

​​

----------------------------------------------------------------------

by the way,整理代码的时候发现了,有个很变态的地方。​

当这一句setFrameShape(QFrame::NoFrame);若写在设置横向滚动条的样式之前,则横向滚动条就出不来了,横向滚动条本来是自动出现的。

(虽然我本来就不想要它出现。但我觉得哦,也许样式应该写在最前面。)

http://blog.sina.com.cn/s/blog_8a621fc80102vj09.html

Qt treewidget样式的自定义(转)的更多相关文章

  1. WPF自定义控件与样式(2)-自定义按钮FButton

    一.前言.效果图 申明:WPF自定义控件与样式是一个系列文章,前后是有些关联的,但大多是按照由简到繁的顺序逐步发布的等,若有不明白的地方可以参考本系列前面的文章,文末附有部分文章链接. 还是先看看效果 ...

  2. WPF自定义控件与样式(13)-自定义窗体Window & 自适应内容大小消息框MessageBox

    一.前言 申明:WPF自定义控件与样式是一个系列文章,前后是有些关联的,但大多是按照由简到繁的顺序逐步发布的等,若有不明白的地方可以参考本系列前面的文章,文末附有部分文章链接. 本文主要内容: 自定义 ...

  3. Qt 鼠标样式特效探索样例(一)——利用时间器调用QWidget.move()函数

    Qt 鼠标样式特效探索样例(一)       心血来潮,突然想在Qt里玩一把鼠标样式,想到在浏览网页时,经常看到漂亮的鼠标动画,于是今天摸索着乱写个粗糙的demo,来满足自己的好奇心. 效果图 方案要 ...

  4. WPF 自定义ComboBox样式,自定义多选控件

    原文:WPF 自定义ComboBox样式,自定义多选控件 一.ComboBox基本样式 ComboBox有两种状态,可编辑和不可编辑状态.通过设置IsEditable属性可以切换控件状态. 先看基本样 ...

  5. android中样式和自定义button样式

    1)自定义button样式 一.采用图片方式 首先新建Android XML文件,类型选Drawable,根结点选selector,自定义一个文件名. 随后,开发环境自动在新建的文件里加了select ...

  6. Qt之界面(自定义标题栏、无边框、可移动、缩放)

    效果 自定义标题栏 titleBar.h #ifndef TITLEBAR_H #define TITLEBAR_H #include <QLabel> #include <QPus ...

  7. C/C++ Qt TreeWidget 嵌套节点操作技巧

    在上一篇博文<C/C++ Qt TreeWidget 单层树形组件应用>中给大家演示了如何使用TreeWidget组件创建单层树形结构,并给这个树形组件增加了右键菜单功能,接下来将继续延申 ...

  8. Qt StyleSheet样式表实例(转)

    QT论坛看到的,收藏一下! 在涉及到Qt 美工的时候首先需要掌握CSS 级联样式表. 下面将通过几个例子来介绍一下怎样使用Qt中的部件类型设计.自定义的前台背景与后台背景的颜色: 如果需要一个文本编辑 ...

  9. C/C++ Qt TreeWidget 单层树形组件应用

    TreeWidget 目录树组件,该组件适用于创建和管理目录树结构,在开发中我们经常会把它当作一个升级版的ListView组件使用,因为ListView每次只能显示一列数据集,而使用TableWidg ...

随机推荐

  1. 如何合理命名CSS文件——摘自网友

    有经验的网页制作者都明白,对于有多个栏目的大型网站而言,使用单一的CSS文件是不可能的.但CSS文件名如何命名对于新手来说是件容易出乱子的事.如何才能将CSS的命名做得井井有条? 坚持使用统一的CSS ...

  2. LeetCode OJ:Insert Interval

    Given a set of non-overlapping intervals, insert a new interval into the intervals (merge if necessa ...

  3. apache ab工具安装测试

    1.安装 安装包下载地址: 将 httpd-2.2.29.tar.gz 解压到目录 /apps/install/httpd-2.2.29 ,这是我放置的位置 cd /apps/install/http ...

  4. L210 Ebola

    Progress in fighting Democratic Republic of the Congo's Ebola outbreak, the second worst ever, will ...

  5. js 兼容各类手机 的写法 待续

    //通过高度来判断是否是iPhone 4还是iPhone 5 isPhone4inches = (window.screen.height==480); isPhone5inches = (windo ...

  6. Android输入法框架系统(下)

    程序焦点获取事件导致输入法显示 从上面可以知道程序获得焦点时,程序端会先间接的调用IMMS的startInput将焦点View绑定到输入法,然后会调用IMMS的windowGainFocus函数,这个 ...

  7. Ubuntu:火狐浏览器加速下载(Flashgot+Aria2+Uget)

    火狐浏览器加速下载 应用到的程序 Aria2 Uget firefox插件Flashgot 1.下载Uget sudo apt-get install uget 2. 下载Aria2 sudo apt ...

  8. Ascii vs. Binary Files

    Ascii vs. Binary Files Introduction Most people classify files in two categories: binary files and A ...

  9. 不使用ref

    为什么 尽量避免ref? 使用ref原因:react功能来访问DOM元素,这种功能的需求往往来自于提交表单的操作,再提交表单的时候,需要读取当前表单中input元素的值 而react的产生就是为了避免 ...

  10. 【c++基础】判断是否到文件末尾-eof函数

    前言 读取文件内容时,需要判断是否到文件末尾,此时用到eof函数. 函数定义 Check whether eofbit is set Returns true if theeofbiterror st ...