WPF滑块控件(Slider)的自定义样式

作者:kiba518 时间:2022-01-19 20:05:02 

前言

每次开发滑块控件的样式都要花很久去读样式代码,感觉有点记不牢,所以特此备忘。

自定义滑块样式

首先创建项目,添加Slider控件。

然后获取Slider的Window样式,如下图操作。

WPF滑块控件(Slider)的自定义样式

然后弹出界面如下.我们点击确定。

WPF滑块控件(Slider)的自定义样式

点击确定后,我们的页面的Resources中,增加了一系列样式代码,而滑块代码会被修改为如下样子:

可以看到,系统为我们的Slider控件增加了样式——Style="{DynamicResource SliderStyle1}"

现在我们查看样式SliderStyle1,F12跟踪到定义。

上述代码中我们可以看发现Slider使用的模板是SliderHorizontal,但当他的排列方向为Vertical时,则使用SliderVertical模板。

因为Slider控件默认是横向布局,所以我们先修改SliderHorizontal模板,对Slider进行下美化。

同样,我们继续F12跟进SliderHorizontal的定义。

SliderHorizontal模板的定义比较多,这里直接定义到重点内容——轨道。

首先定位到代码【Border x:Name="TrackBackground"】,这里的TrackBackground是控制滑块背景颜色的,我们修改其背景颜色和边框颜色。

得到效果如下:

WPF滑块控件(Slider)的自定义样式

但我们有时候需要拖动前后颜色不一样,此时就靠背景修改就不够了。

在SliderHorizontal模板中找到DecreaseRepeatButtonIncreaseRepeatButton;这两个一个是拖动前覆盖颜色,一个是拖动后覆盖颜色。

修改代码如下:

得到效果如下:

WPF滑块控件(Slider)的自定义样式

注意这里的Height一定要给值。

现在,我们设置好了轨道,可当前的滑块的颜色我们有点不太满意,所以我们再来处理下滑块。

滑块模板的模板是上方代码中粉色标记的代码——Thumb。

可以看到Thumb使用的是SliderThumbHorizontalDefault模板,所以,我们继续F12跟进SliderThumbHorizontalDefault查看它的定义。

从上述代码中可以看到,滑块定义很简单,布局就是一个Grid里放了一个Path,事件响应只有3个。

下面为修改Path的Fill填充色和Stroke的划线颜色如下:

得到效果如下:

WPF滑块控件(Slider)的自定义样式

现在,我们觉得矩形的滑块不好看,需要用椭圆形的滑块,那么,我们再来处理下滑块。

首先删除Thumb里定义的宽和高,因为不删除它们,模板里的宽高会受此限制。

删除后如下:

现在我们再来修改SliderThumbHorizontalDefault模板。

在模板里找到Path,修改他的Data,之前他的Data是自己画的一个矩形,现在我们给他改为椭圆形,并且给Path重新设置宽高,如下:

我们得到效果如下:

WPF滑块控件(Slider)的自定义样式

可以看到,图中的滑块是个圆形,而我们需要的是一个椭圆形。

处理很简单,修改Path的Width即可,我们该为14,得到效果如下:

WPF滑块控件(Slider)的自定义样式

当然,我们既然可以通过修改样式设计椭圆形滑块,就也可以设计其他形状滑块,比如,我们修改Path如下,获得斜角四边形滑块:

效果图如下:

WPF滑块控件(Slider)的自定义样式

修改代码如下,设置三角形滑块:

效果图如下:

WPF滑块控件(Slider)的自定义样式

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

上述代码设置的都是水平方向的滑块样式,垂直方向的滑块样式设置同理,只要从模板SliderVertical开始,以此处理修改即可。

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

到此WPF滑块控件(Slider)的自定义样式就已经讲解完成了。

代码已经传到Github上了,欢迎大家下载。

Github地址:https://github.com/kiba518/WpfSlider

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

总结

以上所述是小编给大家介绍的WPF滑块控件(Slider)的自定义样式,网站的支持!
如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!

来源:https://www.cnblogs.com/kiba/p/11253686.html

标签:wpf,滑块控件,slider
0
投稿

猜你喜欢

  • windowns使用PySpark环境配置和基本操作

    2021-04-12 06:43:06
  • Python利用Seaborn绘制多标签的混淆矩阵

    2022-12-12 17:46:22
  • python ChainMap 合并字典的实现步骤

    2021-06-19 01:24:52
  • PyQT5之使用QT Designer创建基本窗口方式

    2023-10-06 05:59:41
  • 简述Asp与XML之间的关系

    2008-04-17 10:46:00
  • 4款Python 类型检查工具,你选择哪个呢?

    2021-10-29 22:30:27
  • python爬虫---requests库的用法详解

    2022-11-19 10:08:19
  • Python使用re模块正则提取字符串中括号内的内容示例

    2022-06-15 14:20:04
  • 解析:轻松了解 MySQL中损坏的MyISAM表

    2009-02-23 17:30:00
  • 介绍Python的Django框架中的静态资源管理器django-pipeline

    2023-11-12 00:10:35
  • Python抓取框架Scrapy爬虫入门:页面提取

    2022-04-16 18:57:47
  • Keras设置以及获取权重的实现

    2021-11-22 10:04:09
  • SQL Server可写脚本和编程扩展SSIS包

    2009-01-20 16:29:00
  • Python3.8.2安装包及安装教程图文详解(附安装包)

    2021-11-17 19:35:14
  • 在Django中动态地过滤查询集的实现

    2023-06-15 12:20:15
  • pre标签自动换行

    2009-03-13 13:37:00
  • python中使用iterrows()对dataframe进行遍历的实例

    2023-12-29 13:43:02
  • 人工智能学习PyTorch实现CNN卷积层及nn.Module类示例分析

    2021-10-11 21:14:42
  • 全面了解python字符串和字典

    2021-05-03 21:06:43
  • python实现名片管理系统

    2021-04-02 22:21:40
  • asp之家 网络编程 m.aspxhome.com