前言

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

自定义滑块样式

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

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

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

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

  1. <Slider HorizontalAlignment="Left" Width="200" VerticalAlignment="Top" Style="{DynamicResource SliderStyle1}"/>

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

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

  1. <Style x:Key="SliderStyle1" TargetType="{x:Type Slider}">
  2. <Setter Property="Stylus.IsPressAndHoldEnabled" Value="false"/>
  3. <Setter Property="Background" Value="Transparent"/>
  4. <Setter Property="BorderBrush" Value="Transparent"/>
  5. <Setter Property="Foreground" Value="{StaticResource SliderThumb.Static.Foreground}"/>
  6. <Setter Property="Template" Value="{StaticResource SliderHorizontal}"/>
  7. <Style.Triggers>
  8. <Trigger Property="Orientation" Value="Vertical">
  9. <Setter Property="Template" Value="{StaticResource SliderVertical}"/>
  10. </Trigger>
  11. </Style.Triggers>
  12. </Style>

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

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

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

  1. <ControlTemplate x:Key="SliderHorizontal" TargetType="{x:Type Slider}">
  2. <Border x:Name="border" BorderBrush="{TemplateBinding BorderBrush}" BorderThickness="{TemplateBinding BorderThickness}" Background="{TemplateBinding Background}" SnapsToDevicePixels="True">
  3. <Grid>
  4. <Grid.RowDefinitions>
  5. <RowDefinition Height="Auto"/>
  6. <RowDefinition Height="Auto" MinHeight="{TemplateBinding MinHeight}"/>
  7. <RowDefinition Height="Auto"/>
  8. </Grid.RowDefinitions>
  9. <TickBar x:Name="TopTick" Fill="{TemplateBinding Foreground}" Height="4" Margin="0,0,0,2" Placement="Top" Grid.Row="0" Visibility="Collapsed"/>
  10. <TickBar x:Name="BottomTick" Fill="{TemplateBinding Foreground}" Height="4" Margin="0,2,0,0" Placement="Bottom" Grid.Row="2" Visibility="Collapsed"/>
  11. <Border x:Name="TrackBackground" BorderBrush="{StaticResource SliderThumb.Track.Border}" BorderThickness="1" Background="{StaticResource SliderThumb.Track.Background}" Height="4.0" Margin="5,0" Grid.Row="1" VerticalAlignment="center">
  12. <Canvas Margin="-6,-1">
  13. <Rectangle x:Name="PART_SelectionRange" Fill="{DynamicResource {x:Static SystemColors.HighlightBrushKey}}" Height="4.0" Visibility="Hidden"/>
  14. </Canvas>
  15. </Border>
  16. <Track x:Name="PART_Track" Grid.Row="1">
  17. <Track.DecreaseRepeatButton>
  18. <RepeatButton Command="{x:Static Slider.DecreaseLarge}" Style="{StaticResource RepeatButtonTransparent}"/>
  19. </Track.DecreaseRepeatButton>
  20. <Track.IncreaseRepeatButton>
  21. <RepeatButton Command="{x:Static Slider.IncreaseLarge}" Style="{StaticResource RepeatButtonTransparent}"/>
  22. </Track.IncreaseRepeatButton>
  23. <Track.Thumb>
  24. <Thumb x:Name="Thumb" Focusable="False" Height="18" OverridesDefaultStyle="True" Template="{StaticResource SliderThumbHorizontalDefault}" VerticalAlignment="Center" Width="11"/>
  25. </Track.Thumb>
  26. </Track>
  27. </Grid>
  28. </Border>
  29. <ControlTemplate.Triggers>
  30. <Trigger Property="TickPlacement" Value="TopLeft">
  31. <Setter Property="Visibility" TargetName="TopTick" Value="Visible"/>
  32. <Setter Property="Template" TargetName="Thumb" Value="{StaticResource SliderThumbHorizontalTop}"/>
  33. <Setter Property="Margin" TargetName="TrackBackground" Value="5,2,5,0"/>
  34. </Trigger>
  35. <Trigger Property="TickPlacement" Value="BottomRight">
  36. <Setter Property="Visibility" TargetName="BottomTick" Value="Visible"/>
  37. <Setter Property="Template" TargetName="Thumb" Value="{StaticResource SliderThumbHorizontalBottom}"/>
  38. <Setter Property="Margin" TargetName="TrackBackground" Value="5,0,5,2"/>
  39. </Trigger>
  40. <Trigger Property="TickPlacement" Value="Both">
  41. <Setter Property="Visibility" TargetName="TopTick" Value="Visible"/>
  42. <Setter Property="Visibility" TargetName="BottomTick" Value="Visible"/>
  43. </Trigger>
  44. <Trigger Property="IsSelectionRangeEnabled" Value="true">
  45. <Setter Property="Visibility" TargetName="PART_SelectionRange" Value="Visible"/>
  46. </Trigger>
  47. <Trigger Property="IsKeyboardFocused" Value="true">
  48. <Setter Property="Foreground" TargetName="Thumb" Value="Blue"/>
  49. </Trigger>
  50. </ControlTemplate.Triggers>
  51. </ControlTemplate>

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

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

  1. <Border x:Name="TrackBackground" BorderBrush="Red" BorderThickness="1" Background="Yellow" Height="4.0" Margin="5,0" Grid.Row="1" VerticalAlignment="center">
  2. <Canvas Margin="-6,-1">
  3. <Rectangle x:Name="PART_SelectionRange" Fill="{DynamicResource {x:Static SystemColors.HighlightBrushKey}}" Height="4.0" Visibility="Hidden"/>
  4. </Canvas>
  5. </Border>

得到效果如下:

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

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

修改代码如下:

  1. <Track x:Name="PART_Track" Grid.Row="1">
  2. <Track.DecreaseRepeatButton>
  3. <RepeatButton Height="4" Background="Gray" Command="{x:Static Slider.DecreaseLarge}" Style="{StaticResource RepeatButtonTransparent}"/>
  4. </Track.DecreaseRepeatButton>
  5. <Track.IncreaseRepeatButton>
  6. <RepeatButton Height="4" Background="Green" Command="{x:Static Slider.IncreaseLarge}" Style="{StaticResource RepeatButtonTransparent}"/>
  7. </Track.IncreaseRepeatButton>
  8. <Track.Thumb>
  9. <Thumb x:Name="Thumb" Focusable="False" Height="18" OverridesDefaultStyle="True" Template="{StaticResource SliderThumbHorizontalDefault}" VerticalAlignment="Center" Width="11"/>
  10. </Track.Thumb>
  11. </Track>

得到效果如下:

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

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

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

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

  1. <ControlTemplate x:Key="SliderThumbHorizontalDefault" TargetType="{x:Type Thumb}">
  2. <Grid HorizontalAlignment="Center" UseLayoutRounding="True" VerticalAlignment="Center">
  3. <Path x:Name="grip" Data="M 0,0 C0,0 11,0 11,0 11,0 11,18 11,18 11,18 0,18 0,18 0,18 0,0 0,0 z" Fill="{StaticResource SliderThumb.Static.Background}" Stretch="Fill" SnapsToDevicePixels="True" Stroke="{StaticResource SliderThumb.Static.Border}" StrokeThickness="1" UseLayoutRounding="True" VerticalAlignment="Center"/>
  4. </Grid>
  5. <ControlTemplate.Triggers>
  6. <Trigger Property="IsMouseOver" Value="true">
  7. <Setter Property="Fill" TargetName="grip" Value="{StaticResource SliderThumb.MouseOver.Background}"/>
  8. <Setter Property="Stroke" TargetName="grip" Value="{StaticResource SliderThumb.MouseOver.Border}"/>
  9. </Trigger>
  10. <Trigger Property="IsDragging" Value="true">
  11. <Setter Property="Fill" TargetName="grip" Value="{StaticResource SliderThumb.Pressed.Background}"/>
  12. <Setter Property="Stroke" TargetName="grip" Value="{StaticResource SliderThumb.Pressed.Border}"/>
  13. </Trigger>
  14. <Trigger Property="IsEnabled" Value="false">
  15. <Setter Property="Fill" TargetName="grip" Value="{StaticResource SliderThumb.Disabled.Background}"/>
  16. <Setter Property="Stroke" TargetName="grip" Value="{StaticResource SliderThumb.Disabled.Border}"/>
  17. </Trigger>
  18. </ControlTemplate.Triggers>
  19. </ControlTemplate>

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

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

  1. <Path x:Name="grip" Data="M 0,0 C0,0 11,0 11,0 11,0 11,18 11,18 11,18 0,18 0,18 0,18 0,0 0,0 z" Fill="Red" Stretch="Fill" SnapsToDevicePixels="True" Stroke="Blue" StrokeThickness="1" UseLayoutRounding="True" VerticalAlignment="Center"/>

得到效果如下:

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

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

删除后如下:

  1. <Track.Thumb>
  2. <Thumb x:Name="Thumb" Focusable="False" OverridesDefaultStyle="True" Template="{StaticResource SliderThumbHorizontalDefault}" VerticalAlignment="Center" />
  3. </Track.Thumb>

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

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

  1. <Path x:Name="grip" Width="20" Height="20" Fill="Red" Stretch="Fill" SnapsToDevicePixels="True" Stroke="Blue" StrokeThickness="1" UseLayoutRounding="True" VerticalAlignment="Center">
  2. <Path.Data>
  3. <EllipseGeometry Center="10,10" RadiusX="10" RadiusY="10"></EllipseGeometry>
  4. </Path.Data>
  5. </Path>

我们得到效果如下:

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

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

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

  1. <Path x:Name="grip" Width="14" Height="20" Fill="Red" Stretch="Fill" SnapsToDevicePixels="True" Stroke="Blue" StrokeThickness="1" UseLayoutRounding="True" VerticalAlignment="Center">
  2. <Path.Data>
  3. <PathGeometry>
  4. <PathGeometry.Figures>
  5. <PathFigure StartPoint="0,0" IsClosed="True">
  6. <LineSegment Point="0,0" />
  7. <LineSegment Point="110,0" />
  8. <LineSegment Point="70,40" />
  9. <LineSegment Point="-40,40" />
  10. </PathFigure>
  11. </PathGeometry.Figures>
  12. </PathGeometry>
  13. </Path.Data>
  14. </Path>

效果图如下:

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

  1. <Path x:Name="grip" Width="14" Height="20" Fill="Red" Stretch="Fill" SnapsToDevicePixels="True" Stroke="Blue" StrokeThickness="1" UseLayoutRounding="True" VerticalAlignment="Center">
  2. <Path.Data>
  3. <PathGeometry>
  4. <PathGeometry.Figures>
  5. <PathFigure StartPoint="0,0" IsClosed="True">
  6. <LineSegment Point="30,0" />
  7. <LineSegment Point="15,100" />
  8. </PathFigure>
  9. </PathGeometry.Figures>
  10. </PathGeometry>
  11. </Path.Data>
  12. </Path>

效果图如下:

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

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

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

特殊图形我们看到,在图形后面还有一个小背景色在显示,解决方法:修改TrackBackground的背景色为透明。

  1. <Border x:Name="TrackBackground" BorderBrush="{StaticResource SliderThumb.Track.Border}" BorderThickness="0" Background="Transparent" Height="4.0" Margin="5,0" Grid.Row="1" VerticalAlignment="center">
  2. <Canvas Margin="-6,-1">
  3. <Rectangle x:Name="PART_SelectionRange" Fill="{DynamicResource {x:Static SystemColors.HighlightBrushKey}}" Height="4.0" Visibility="Hidden"/>
  4. </Canvas>
  5. </Border>

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

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

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

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

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

注:此文章为原创,任何形式的转载都请联系作者获得授权并注明出处!
若您觉得这篇文章还不错,请点击下方的【推荐】,非常感谢!

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

WPF滑块控件(Slider)的自定义样式的更多相关文章

  1. IOS开发--自定义segment控件,方便自定义样式

    系统的segment控件太封闭,想换个颜色加个背景太难了,忍不住自己写一个,以备不时之需 这个控件给出了很多自定义属性的设置,用起来还是比较方便的,需要注意的 itemWidth如果不设置,则会按照控 ...

  2. 示例:自定义WPF底层控件UI库 HeBianGu.General.WpfControlLib V2.0版本

    原文:示例:自定义WPF底层控件UI库 HeBianGu.General.WpfControlLib V2.0版本 一.目的:封装了一些控件到自定义的控件库中,方便快速开发 二.实现功能: 基本实现常 ...

  3. WPF 用户控件的自定义依赖属性在 MVVM 模式下的使用备忘

    依赖属性相当于扩充了 WPF 标签的原有属性列表,并可以使用 WPF 的绑定功能,可谓是十分方便的:用户控件则相当于代码重用的一种方式:以上几点分开来还是比较好理解的,不过要用到MVVM 模式中,还是 ...

  4. WPF常用控件应用demo

    WPF常用控件应用demo 一.Demo 1.Demo截图如下: 2.demo实现过程 总体布局:因放大缩小窗体,控件很根据空间是否足够改变布局,故用WrapPanel布局. <ScrollVi ...

  5. WPF第三方控件盘点

    WPF统一的编程模型.语言和框架,实现了界面设计人员和开发人员工作可以分离的境界,鉴于WPF强大的优势,且一直是开发者关注的地方,下面和大家分享基于WPF项目开发需要用到的第三方控件,包括业界最受好评 ...

  6. WPF系列 —— 控件添加依赖属性(转)

    WPF系列 —— 控件添加依赖属性 依赖属性的概念,用途 ,如何新建与使用.本文用做一个自定义TimePicker控件来演示WPF的依赖属性的简单应用. 先上TimePicker的一个效果图. 概念 ...

  7. MFC控件Slider Control的使用

    写MFC界面程序时,今天恰好用到Slider控件,做一个小小的记录. 步骤 1.在工具栏中添加Slider Control控件: 2.在控件上右键->添加变量(Add Variable...), ...

  8. MFC的组合框(ComboBox)控件切换下拉样式

    由于课题的需求需要做MFC串口程序,看了百度下载的串口助手的界面风格,发现这个设计很好 波特率的组合框只给出了5个可选数值,然后第6个选项是Custom,即手动输入. 实际上DCB结构的BaudRat ...

  9. 滑块控件CCControlSlider

    #include "cocos-ext.h" //包含头文件 using namespace cocos2d::extension;//引用命名空间 /** * 创建CCContr ...

随机推荐

  1. SpringBoot中资源初始化加载的几种方式(看这一片就够了)

    一.问题 在平时的业务模块开发过程中,难免会需要做一些全局的任务.缓存.线程等等的初始化工作,那么如何解决这个问题呢?方法有多种,但具体又要怎么选择呢? 二.资源初始化 1.既然要做资源的初始化,那么 ...

  2. Oracle数据库视图的创建以及使用

    创建视图语句: CREATE [OR REPLACE] [FORCE|NOFORCE] VIEW view_name [(alias[, alias]...)] AS subquery [WITH C ...

  3. Java多线程(三):Synchronized

    多线程安全 脏读:多个线程对同一个对象的实例变量进行修改后访问,导致读到的数据是被修改过的. 实例 ThreadDomain16类 public class ThreadDomain16 { priv ...

  4. Storm —— 单机环境搭建

    1. 安装环境要求 you need to install Storm's dependencies on Nimbus and the worker machines. These are: Jav ...

  5. 预习初三物理电学部分的心得体会&知识梳理(持续更新)

    DAY 1 一.摩擦起电 用摩擦的方式使两个不同的物体带电的现象. 二.带电体 如果一个物体能够吸引轻小物体,我们就说这个物体带电或者说带了电荷. (注:吸引轻小物体是作用效果,带电体对任何物体都有吸 ...

  6. 动手写一个简单版的谷歌TPU-指令集

    系列目录 谷歌TPU概述和简化 基本单元-矩阵乘法阵列 基本单元-归一化和池化(待发布) TPU中的指令集 SimpleTPU实例: (计划中) 拓展 TPU的边界(规划中) 重新审视深度神经网络中的 ...

  7. Java学习笔记——Linux下安装配置tomcat

    朝辞白帝彩云间,千里江陵一日还. 两岸猿声啼不住,轻舟已过万重山. ——早发白帝城 首先需要安装配置JDK,这里简单回顾下.Linux下用root身份在/opt/文件夹下创建jvm文件夹,然后使用ta ...

  8. 字节跳动Java研发面试99题(含答案):JVM+Spring+MySQL+线程池+锁

    JVM的内存结构 根据 JVM 规范,JVM 内存共分为虚拟机栈.堆.方法区.程序计数器.本地方法栈五个部分. 1. Java虚拟机栈:线程私有:每个方法在执行的时候会创建一个栈帧,存储了局部变量表, ...

  9. esxi虚机迁移到Workstation

    虚拟机的文件管理由VMware Workstation来执行.一个虚拟机一般以一系列文件的形式储存在宿主机中,这些文件一般在由workstation为虚拟机所创建的那个目录中. 如下图所示:(< ...

  10. Java中实现线程的方式

    Java中实现线程的方式 Java中实现多线程的方式的方式中最核心的就是 run()方法,不管何种方式其最终都是通过run()来运行. Java刚发布时也就是JDK 1.0版本提供了两种实现方式,一个 ...