继续聊WPF——自定义滚动条
- <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——自定义滚动条的更多相关文章
- WPF 自定义滚动条样式
先看一下效果: 先分析一下滚动条有哪儿几部分组成: 滚动条总共有五部分组成: 两端的箭头按钮,实际类型为RepeatButton Thumb 两端的空白,实际也是RepeatButton 最后就是Th ...
- WPF 自定义滚动条(ScrollView、ScrollBar)样式
一.滚动条基本样式 本次修改Scrollview及ScrollBar滚动条样式是通过纯样式实现的.修改的内容包含滚动条的颜色,上下按钮的隐藏.另外添加了鼠标经过滚动条动画. style样式如下: &l ...
- WPF自定义滚动条
我修改了一些地方,部分代码参考了博主 https://www.cnblogs.com/xiaomingg/ <!-- ScrollViewer 滚动条 --> <Style x:Ke ...
- 继续聊WPF——自定义CheckBox控件外观
上一篇文章中谈到了BulletDecorator控件,就是为自定义CheckBox控件的模板做准备,因为CheckBox需要比较严格的布局,正好,BulletDecorator控件就合适了,该控件的布 ...
- WPF ScrollViewer(滚动条) 自定义样式表制作 再发一套样式 细节优化
艾尼路 出的效果图 本人嵌套 WPF ScrollViewer(滚动条) 自定义样式表制作 图文并茂 WPF ScrollViewer(滚动条) 自定义样式表制作 (改良+美化) 源代码
- wpf之自定义滚动条
原文:wpf之自定义滚动条 首先我们添加一个带滚动条的textbox控件: <ScrollViewer Height="130" Width="620" ...
- WPF ScrollViewer(滚动条) 自定义样式表制作 图文并茂
原文:WPF ScrollViewer(滚动条) 自定义样式表制作 图文并茂 先上效果图 正常样式 拖动时样式 好下面 开始吧 ==================================== ...
- WPF ScrollViewer(滚动条) 自定义样式表制作 (改良+美化)
原文:WPF ScrollViewer(滚动条) 自定义样式表制作 (改良+美化) 注释直接写在代码里了 不太理解意思的 可以先去看看我上一篇 WPF ScrollViewer(滚动条) 自定 ...
- WPF自定义TextBox及ScrollViewer
原文:WPF自定义TextBox及ScrollViewer 寒假过完,在家真心什么都做不了,可能年龄大了,再想以前那样能专心坐下来已经不行了.回来第一件事就是改了项目的一个bug,最近又新增了一个新的 ...
随机推荐
- 请求文件下载URL过长处理
/* * PostNewWin * Author:ppchen */var PostNewWin = function(url){ var urlArr = url.split("?& ...
- 严格符合CommonJS规范的包特性
严格符合CommonJS规范的包应该具备下面特性: 1.package.json必须在包的顶层文件夹下. 2.二进制文件应该在bin文件夹下. 3.JavaScript代码应该在lib文件夹下. 4. ...
- Codeforces Round #276 (Div. 1) A. Bits 贪心
A. Bits Let's denote as the number of bits set ('1' bits) in the binary representation of the non ...
- luogu1631 序列合并
题目大意 有两个序列A,B,在A和B中各取一个数相加能得到$n^2$个和.求出这些和前n小的数字. 题解 首先这道题不可以用自己想的什么A序列B序列各两个指针的自己发明的模拟算法,用这样的算法只能是绝 ...
- Codeforces--630E--A rectangle(规律)
E - A rectangle Crawling in process... Crawling failed Time Limit:500MS Memory Limit:65536KB ...
- vs code golang代码自动补全
“go.useCodeSnippetsOnFunctionSuggest”: true 文件-->首选项--->设置--->用户设置 添加下行:然后就可以自动补全了,包括() “go ...
- [Apple开发者帐户帮助]三、创建证书(8)撤销证书
您可以根据证书类型和角色撤消证书.有关详细信息,请转到撤消权限. 要了解撤销证书时会发生什么,请转到Apple Developer支持中的证书. 所需角色:帐户持有人或管理员. 在“ 证书”,“标识符 ...
- selenium3+python-多窗口、句柄(handle)
一.获取当前窗口句柄 1.元素有属性,浏览器的窗口其实也有属性的,只是你看不到,浏览器窗口的属性用句柄(handle)来识别. 2.人为操作的话,可以通过眼睛看,识别不同的窗口点击切换.但是脚本没长眼 ...
- 如何正确从windows系统(自己电脑)远程访问Linux系统(他人电脑)的mysql数据库(图文详解)
这里,需要Linux系统开了root用户,我这给root用户密码为root. 同时,在mysql -uroot -proot执行进去之后 update user setHost='%' whe ...
- 解决QQ未启用状态,QQ留言图标未启用
最近由于腾讯升级QQ一些东西,导致QQ图标成未启用状态:如图 解决方法,到腾讯此站点登陆一下即可, http://wp.qq.com/set.html 另外设置 没有保存按钮,如果选择完全公开,到自己 ...