WPF----自定义滚动条ScrollViewer

server/2025/1/16 2:34:42/

滚动条是项目当中经常用到的一个控件,大部分对外项目都有外观的需求,因此需要自定义,文中主要是针对一段动态的状态数据进行展示,并保证数据始终在最新一条,就是需要滚动条滚动到底部。

1,xaml中引入
 <ItemsControl Grid.Row="1" Grid.Column="0" ItemsSource="{Binding ProcessList}" ><ItemsControl.ItemTemplate><DataTemplate><!-- 绑定到数组的每个元素 --><TextBlock Text="{Binding }" Foreground="#fff" Margin="4"/></DataTemplate></ItemsControl.ItemTemplate><ItemsControl.Template><ControlTemplate TargetType="ItemsControl"><ScrollViewer x:Name="ScrollViewer" VerticalScrollBarVisibility="Auto"  Loaded="ScrollViewer_Loaded" ><ItemsPresenter/></ScrollViewer></ControlTemplate></ItemsControl.Template></ItemsControl>

也可以直接将ScrollViewer放在所用控件的最外层。

VerticalScrollBarVisibility="Auto" 设置为auto可实现超过区域高度自动展示滚动条。

2,具体样式,放到资源中
 <Style TargetType="ScrollBar"><Setter Property="Width" Value="8"/><!--设置滚动条宽度--> <Setter Property="Template"><Setter.Value><ControlTemplate TargetType="ScrollBar"><Grid Background="#212222 " Width="14" SnapsToDevicePixels="true" ><Grid.RowDefinitions><!--<RowDefinition Height="Auto"/>--><RowDefinition Height="*"/><!--<RowDefinition Height="Auto"/>--></Grid.RowDefinitions><!--减少按钮--> <!--<RepeatButton Grid.Row="0" Command="ScrollBar.LineUpCommand" Content="^" Width="10" Height="10"/>--><!--轨道和滑块--><Track Grid.Row="1" Name="PART_Track"  Width="14" IsDirectionReversed="True"><Track.Thumb><Thumb><Thumb.Template><ControlTemplate><Border CornerRadius="2"><Rectangle  Fill="#82E4E4" RadiusX="2" RadiusY="2" Width="6"/><!--<Thumb Width="6" Background="#82E4E4" BorderThickness="0" />--></Border><!--<Rectangle  Fill="#82E4E4" Width="8"/>--></ControlTemplate></Thumb.Template></Thumb></Track.Thumb><Track.DecreaseRepeatButton><RepeatButton Command="ScrollBar.PageUpCommand" Opacity="0"/></Track.DecreaseRepeatButton><Track.IncreaseRepeatButton><RepeatButton Command="ScrollBar.PageDownCommand" Opacity="0"/></Track.IncreaseRepeatButton></Track><!--增加按钮--> <!--<RepeatButton Grid.Row="2" Command="ScrollBar.LineDownCommand" Content="v"  Width="10" Height="10"/>--></Grid></ControlTemplate></Setter.Value></Setter></Style>

设置样式时候注意点:

IsDirectionReversed="True"   设置为true是保证滚动滑块随着鼠标向下滑动,为false的时候正好相反。

轨道的颜色宽度设置等,直接在Grid上面设置就好。

滑块这里用了个Rectangle,可以设置填充色,圆角、宽度等

我这边不需要上下按钮我就注释掉了。

3,滚动条始终保持在底部,在xaml.cs中实现

需要监听 ProcessList 集合的变化,并在每次添加新项后滚动到 ScrollViewer 的底部。

 public partial class F0Procedure : Page{public F0ProcedureViewModel F0ProcedureViewModel {  get; set; }private ScrollViewer _scrollViewer;public F0Procedure(){InitializeComponent();F0ProcedureViewModel = new F0ProcedureViewModel();this.DataContext = F0ProcedureViewModel;((INotifyCollectionChanged)F0ProcedureViewModel.ProcessList).CollectionChanged += F0Procedure_CollectionChanged;}private void F0Procedure_CollectionChanged(object? sender, NotifyCollectionChangedEventArgs e){if (e.Action == NotifyCollectionChangedAction.Add && _scrollViewer != null){Application.Current.Dispatcher.Invoke(() =>{Console.WriteLine(ScrollViewer.ExtentHeightProperty);_scrollViewer.ScrollToVerticalOffset(_scrollViewer.ExtentHeight);});}}private void ScrollViewer_Loaded(object sender, RoutedEventArgs e){_scrollViewer = sender as ScrollViewer;}}

我这的ProcessList是委托回调更新的,

[ObservableProperty]
private int _progressValue;public void  UpdateExecutionProgress(string process)
{Application.Current.Dispatcher.BeginInvoke(new Action(() => ProcessList.Add(process)));
}

可以用 DispatcherTimer模拟,博客里也有讲过,这边都是引用的CommunityToolKit MVVM库。

4,最终结果

用到哪,学到哪,今天又是满满收获的一天。 


http://www.ppmy.cn/server/53233.html

相关文章

微信小程序自定义指令

微信小程序自定义指令 在微信小程序开发中&#xff0c;自定义指令&#xff08;Custom Directive&#xff09;是一种强大的工具&#xff0c;它允许开发者在页面的模板中编写复用性高、逻辑清晰的代码片段&#xff0c;用于处理视图层的逻辑和交互。通过自定义指令&#xff0c;开发…

决策树之美:探索机器学习中的多面手

在机器学习领域&#xff0c;决策树算法以其独特的优势在众多算法中脱颖而出。作为一种监督学习算法&#xff0c;决策树通过递归地将数据集分割成越来越小的子集&#xff0c;直到满足某个停止准则&#xff0c;从而构建起一个树形结构的模型。本文将深入探讨决策树算法的主要优点…

python中的高阶函数介绍

在Python中&#xff0c;高阶函数是指那些可以接受函数作为参数或者返回函数作为结果的函数。这种特性使得函数式编程成为可能&#xff0c;并且可以编写出更加简洁和灵活的代码。以下是Python中一些常用的高阶函数&#xff1a; map() map() 函数接受一个函数和一个可迭代对象作为…

PyCharm左侧项目区域出现淡黄色背景如何解决

PyCharm左侧项目区域出现淡黄色背景如何解决 解决方法&#xff1a; 1、打开pycharm 文件 - > Setting-> 项目 -> 项目结构 2、添加内容根 为 你的项目根目录即可恢复

基于QT5实现的串口调试助手

代码仅供参考&#xff0c;实际效果是读串口缓冲区&#xff0c;但是老师水平不行&#xff0c;说好像&#xff08;&#xff1f;&#xff09;不能自己读自己&#xff0c;但是由于没有条件测试&#xff0c;后续没有进一步完善 main.cpp #include "widget.h"#include &l…

线程的创建(二)

通过Runnable接口实现多线程 在开发中&#xff0c;我们应用更多的是通过Runnable接口实现多线程。这种方式克服了继承Thread类的特点&#xff0c;即在实现Runnable接口的同时还可以继承某个类。 从源码角度看&#xff0c;Thread类也是实现了Runnable接口&#xff0c;Runnable…

最新AI智能聊天对话问答系统源码(图文搭建部署教程)+AI绘画,文生图,TTS语音识别输入,文档分析

一、人工智能语言模型和AI绘画在多个领域广泛应用 人工智能语言模型和AI绘画在多个领域都有广泛的应用。以下是一些它们的主要用处&#xff1a; 人工智能语言模型 内容生成 写作辅助&#xff1a;帮助撰写文章、博客、报告、剧本等。 代码生成&#xff1a;自动生成或补全代码&…

Linux系统中常用的基本命令

1. 文件与目录管理 ls: 列出目录内容。cd: 切换当前工作目录。pwd: 显示当前工作目录的路径。mkdir: 创建一个新目录。rmdir: 删除空目录。cp: 复制文件或目录。mv: 移动或重命名文件或目录。rm: 删除文件或目录。touch: 创建一个空文件或更新文件时间戳。 2. 文本内容查看 …