• <Window x:Class="WpfApplication1.Window1"
  • xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
  • xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
  • Title="Window1" Height="300" Width="300">
  • <Window.Resources>
  • <ControlTemplate x:Key="myThumb" TargetType="{x:Type Thumb}">
  • <Border Name="bd" BorderThickness="0.8" CornerRadius="2"
  • Height="{TemplateBinding Height}"
  • Width="{TemplateBinding Width}"
  • Margin="0,1,0,1">
  • <Border.Background>
  • <LinearGradientBrush StartPoint="0.5,0" EndPoint="0.5,1">
  • <GradientStop Color="#112299" Offset="0"/>
  • <GradientStop Color="#3522AA" Offset="1"/>
  • </LinearGradientBrush>
  • </Border.Background>
  • </Border>
  • <ControlTemplate.Triggers>
  • <Trigger Property="IsMouseOver" Value="True">
  • <Trigger.Setters>
  • <Setter TargetName="bd" Property="BorderBrush" Value="#66BBEE"/>
  • </Trigger.Setters>
  • </Trigger>
  • </ControlTemplate.Triggers>
  • </ControlTemplate>
  • <ControlTemplate x:Key="myRepBt" TargetType="{x:Type RepeatButton}">
  • <Border Margin="0,2,0,2"
  • BorderThickness="0.7"
  • BorderBrush="#BBBBBB">
  • <Border.Background>
  • <LinearGradientBrush StartPoint="0.5,0" EndPoint="0.5,1">
  • <GradientStop Color="White" Offset="0"/>
  • <GradientStop Color="LightGray" Offset="1"/>
  • </LinearGradientBrush>
  • </Border.Background>
  • </Border>
  • </ControlTemplate>
  • <ControlTemplate x:Key="rbtForScrollBar" TargetType="{x:Type RepeatButton}">
  • <Border CornerRadius="2"
  • Margin="0,1,0,1">
  • <Border.Background>
  • <LinearGradientBrush StartPoint="0,0" EndPoint="1,1">
  • <GradientStop Color="Yellow" Offset="0"/>
  • <GradientStop Color="Orange" Offset="1"/>
  • </LinearGradientBrush>
  • </Border.Background>
  • <Path VerticalAlignment="Center" HorizontalAlignment="Center"
  • Data="{Binding Path=Content,RelativeSource={RelativeSource TemplatedParent}}"
  • Fill="Black"/>
  • </Border>
  • </ControlTemplate>
  • <ControlTemplate x:Key="ScrollTmp" TargetType="{x:Type ScrollBar}">
  • <Grid>
  • <Grid.ColumnDefinitions>
  • <ColumnDefinition MaxWidth="20"/>
  • <ColumnDefinition Width="*"/>
  • <ColumnDefinition MaxWidth="20"/>
  • </Grid.ColumnDefinitions>
  • <Border Grid.ColumnSpan="3" />
  • <RepeatButton Template="{StaticResource rbtForScrollBar}" Grid.Column="0"
  • Margin="0,1,0,1"
  • Command="ScrollBar.LineLeftCommand"
  • Content="M0,4 L4,8 L4,0 Z"/>
  • <Track Grid.Column="1" Name="PART_Track"
  • Maximum="{TemplateBinding Maximum}"
  • Minimum="{TemplateBinding Minimum}"
  • Value="{TemplateBinding Value}">
  • <Track.DecreaseRepeatButton>
  • <RepeatButton Template="{StaticResource myRepBt}"
  • Command="ScrollBar.PageLeftCommand"/>
  • </Track.DecreaseRepeatButton>
  • <Track.IncreaseRepeatButton>
  • <RepeatButton Template="{StaticResource myRepBt}"
  • Command="ScrollBar.PageRightCommand"/>
  • </Track.IncreaseRepeatButton>
  • <Track.Thumb>
  • <Thumb Width="auto" Template="{StaticResource myThumb}"/>
  • </Track.Thumb>
  • </Track>
  • <RepeatButton Template="{StaticResource rbtForScrollBar}" Grid.Column="3"
  • Margin="0,1,0,1"
  • Command="ScrollBar.LineRightCommand"
  • Content="M0,0 L0,8 4,4 Z"/>
  • </Grid>
  • </ControlTemplate>
  • </Window.Resources>
  • <Canvas Margin="10,10,10,10">
  • <ScrollBar Canvas.Left="5" Canvas.Top="5" Width="260" Height="28"
  • Template="{StaticResource ScrollTmp}"
  • Orientation="Horizontal" Maximum="5" Minimum="0"/>
  • </Canvas>
  • </Window>

继续聊WPF——自定义滚动条的更多相关文章

  1. WPF 自定义滚动条样式

    先看一下效果: 先分析一下滚动条有哪儿几部分组成: 滚动条总共有五部分组成: 两端的箭头按钮,实际类型为RepeatButton Thumb 两端的空白,实际也是RepeatButton 最后就是Th ...

  2. WPF 自定义滚动条(ScrollView、ScrollBar)样式

    一.滚动条基本样式 本次修改Scrollview及ScrollBar滚动条样式是通过纯样式实现的.修改的内容包含滚动条的颜色,上下按钮的隐藏.另外添加了鼠标经过滚动条动画. style样式如下: &l ...

  3. WPF自定义滚动条

    我修改了一些地方,部分代码参考了博主 https://www.cnblogs.com/xiaomingg/ <!-- ScrollViewer 滚动条 --> <Style x:Ke ...

  4. 继续聊WPF——自定义CheckBox控件外观

    上一篇文章中谈到了BulletDecorator控件,就是为自定义CheckBox控件的模板做准备,因为CheckBox需要比较严格的布局,正好,BulletDecorator控件就合适了,该控件的布 ...

  5. WPF ScrollViewer(滚动条) 自定义样式表制作 再发一套样式 细节优化

    艾尼路 出的效果图 本人嵌套 WPF ScrollViewer(滚动条) 自定义样式表制作 图文并茂 WPF ScrollViewer(滚动条) 自定义样式表制作 (改良+美化) 源代码

  6. wpf之自定义滚动条

    原文:wpf之自定义滚动条 首先我们添加一个带滚动条的textbox控件: <ScrollViewer Height="130" Width="620" ...

  7. WPF ScrollViewer(滚动条) 自定义样式表制作 图文并茂

    原文:WPF ScrollViewer(滚动条) 自定义样式表制作 图文并茂 先上效果图 正常样式 拖动时样式 好下面 开始吧 ==================================== ...

  8. WPF ScrollViewer(滚动条) 自定义样式表制作 (改良+美化)

    原文:WPF ScrollViewer(滚动条) 自定义样式表制作 (改良+美化) 注释直接写在代码里了   不太理解意思的 可以先去看看我上一篇  WPF ScrollViewer(滚动条)  自定 ...

  9. WPF自定义TextBox及ScrollViewer

    原文:WPF自定义TextBox及ScrollViewer 寒假过完,在家真心什么都做不了,可能年龄大了,再想以前那样能专心坐下来已经不行了.回来第一件事就是改了项目的一个bug,最近又新增了一个新的 ...

随机推荐

  1. Openstack能解决这些问题吗?请各位大侠一起来讨论

    1.10万规模的虚拟机,每一个虚拟机能够在不论什么一个计算节点上启动,该怎样做?计算,存储,网络都是怎么拉通与配合的? 2.用户怎样自己定义业务网络,怎样解决网络不够用的情况?正常就4096个vlan ...

  2. [CTSC 2008] 祭祀

    [题目链接] https://www.lydsy.com/JudgeOnline/problem.php?id=1143 [算法] 答案为最小路径可重复点覆盖所包含的路径数,将原图G进行弗洛伊德传递闭 ...

  3. Tool-Java:Spring Tool Suite

    ylbtech-Tool-Java:Spring Tool Suite Spring Tool Suite 1.返回顶部   2.返回顶部   3.返回顶部   4.返回顶部   5.返回顶部 0. ...

  4. Watchcow(欧拉回路)

    http://poj.org/problem?id=2230 题意:给出n个field及m个连接field的边,然后要求遍历每条边仅且2次,求出一条路径来. #include <stdio.h& ...

  5. javascript 原型(prototype 、__proto__、函数、对象)

    一.类型 1.JavaScript中分为值类型(string/boolean/null/number/undefind).引用类型(数组.对象.函数): 2.数组.函数.对象都是对象: 对象是由函数创 ...

  6. Docker EE/Docker CE简介与版本规划

    随着Docker的不断流行与发展,docker公司(或称为组织)也开启了商业化之路,Docker 从 17.03版本之后分为 CE(Community Edition) 和 EE(Enterprise ...

  7. AOP实现参数的判空问题

    不想每次都去判断必传的参数是否为空,写代码太繁琐了,正好最近用了AOP实现权限控制,依葫芦画瓢,现在用它实现参数的判空,至于AOP的原理之类,自己百度了解一下吧 1. NullDisable注解 @D ...

  8. Maven项目pom.xml配置详解

    maven项目pom.xml文件配置详解,需要时可以用作参考: <project xmlns="http://maven.apache.org/POM/4.0.0" xmln ...

  9. Android 4.0 Launcher2源码分析——主布局文件(转)

    本文来自http://blog.csdn.net/chenshaoyang0011 Android系统的一大特色是它拥有的桌面通知系统,不同于IOS的桌面管理,Android有一个桌面系统用于管理和展 ...

  10. C# Socket通讯 本机多网卡,指定网卡通讯

    IPAddress ip = IPAddress.Parse("192.168.0.188"); IPAddress IPLocal = IPAddress.Parse(" ...