Aero风格的TreeView

本文探讨了WPF中TreeViewItem样式存在的问题,并提供了解决方案。包括改善三角箭头的显示效果,定义MouseOver、Selected等状态下的样式。

我们来看看Windows系统中的Aero风格的Tree是什么样子的。

clip_image001 clip_image002 clip_image003

上面这样都是系统中非WPF实现的Tree。多数Item都有MouseOver,Selected和Selected and Focused三种附加状态。

我们再来看看WPF中的TreeView在默认情况的是什么样子的。

clip_image004

相信大家一眼就可以看出来,这明明就是XP风格的嘛。和Aero风格的Tree差距实在是太大了。而且问题很严重。下面列举一二。

1. 收起的三角箭头模糊。而且此模糊用SnapsToDevicePixel和UseLayoutRendering都无法解决。如下图所示。

clip_image005

下面的那个就是WPF的默认风格。而间三角与文本之间的间距也不一样。

2. TreeViewItem只有Selected的效果,而且是XP风格的。

3. WPF的TreeViewItem的三角在MouseOver时,只变色,而没有发光效果。而Win32的是有发光效果的。

4. 展开的三角箭头与收起的三角箭头相比,水平位移过大。如下图所示。

clip_image006

右边是WPF的TreeView默认风格,与Win32的相差了将近两个像素。

下面我们来解决问题1,2和3。

WPF的TreeViewItem默认的三角实现方式比较复杂。如下图所示。

clip_image007

这个三角的Path可以描述为M0,0 L6,0 0,6Z。线宽为1个像素。这样,垂直的那条线,虽然是一个像素宽,但是不与Device Pixel重合。结果就是左右各是半个像素宽。最终显示在屏幕上了就成了两个像素宽的,50%的灰色的线。肉眼看上去就是模糊了。

我也很奇怪为什么SnapsToDevicePixel和UseLayoutRedering 在这个问题上会失去效力。解决方案就是让Path的Data也对齐到像素就可以。如下。

<StreamGeometry x:Key="TreeArrow" >M0.5,0L0.5,7 4.5,3.5z</StreamGeometry>

这个看上去都是用小数,结果却是对齐到了屏幕像素点。显示结果就能很清晰了。

再就是定义TreeViewItem的那三个状态。

clip_image008

从图中可以看出,这个Item是有两个Border的,背景和内Border都是渐变色。

Item State

Element

Brush

Mouse Over

Border

#FFB8D6FB

 

Inner Border

<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">

    <GradientStop Color="#FFFCFDFE" Offset="0"/>

    <GradientStop Color="#FFF2F7FE" Offset="1"/>

</LinearGradientBrush>

 

Background

<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">

    <GradientStop Color="#FFFAFBFD" Offset="0"/>

    <GradientStop Color="#FFEBF3FD" Offset="1"/>

</LinearGradientBrush>

Selected

IsActive

Border

#FF84ACDD

 

Inner Border

<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">

    <GradientStop Color="#FFF2F8FF" Offset="0"/>

    <GradientStop Color="#FFDFEEFF" Offset="1"/>

</LinearGradientBrush>

 

Background

<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">

    <GradientStop Color="#FFECF5FF" Offset="0"/>

    <GradientStop Color="#FFD0E5FF" Offset="1"/>

</LinearGradientBrush>

Selected

Not IsActive

Border

#FFDADADA

 

Inner Border

<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">

    <GradientStop Color="#FFFBFBFC" Offset="0"/>

    <GradientStop Color="#FFF1F1F1" Offset="1"/>

</LinearGradientBrush>

 

Background

<LinearGradientBrush EndPoint="0.5,1" StartPoint="0.5,0">

    <GradientStop Color="#FFF9F9F9" Offset="0"/>

    <GradientStop Color="#FFE6E6E6" Offset="1"/>

</LinearGradientBrush>

上面的值都是用Paint.NET从Win32实现的TreeView的截图中手工取出的值,仅供参考。

最后优化完成的TreeViewItem的样式如下所示。

clip_image009

不要看错了,这个可是WPF的哦。完整的代码可以从这里下载到。

乐播投屏是一款简单好用、功能强大的专业投屏软件,支持手机投屏电视、手机投电脑、电脑投电视等多种投屏方式。 多端兼容与跨网投屏:支持手机、平板、电脑等多种设备之间的自由组合投屏,且无需连接 WiFi,通过跨屏技术打破网络限制,扫一扫即可投屏。 广泛的应用支持:支持 10000+APP 投屏,包括综合视频、网盘与浏览器、美韩剧、斗鱼、虎牙等直播平台,还能将央视、湖南卫视等各大卫视的直播内容一键投屏。 高清流畅投屏体验:腾讯独家智能音画调校技术,支持 4K 高清画质、240Hz 超高帧率,低延迟不卡顿,能为用户提供更高清、流畅的视觉享受。 会议办公功能强大:拥有全球唯一的 “超级投屏空间”,扫码即投,无需安装。支持多人共享投屏、远程协作批注,PPT、Excel、视频等文件都能流畅展示,还具备企业级安全加密,保障会议资料不泄露。 多人互动功能:支持多人投屏,邀请好友加入投屏互动,远程也可加入。同时具备一屏多显、语音互动功能,支持多人连麦,实时语音交流。 文件支持全面:支持 PPT、PDF、Word、Excel 等办公文件,以及视频、图片等多种类型文件的投屏,还支持网盘直投,无需下载和转格式。 特色功能丰富:投屏时可同步录制投屏画面,部分版本还支持通过触控屏或电视端外接鼠标反控电脑,以及在投屏过程中用画笔实时标注等功能。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值