首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

.net Framework 源代码 · ScrollViewer 使用原理其他源代码分析

ScrollViewer 存在两个滚动方式,物理滚动 和 逻辑滚动,如果使用 物理滚动 那么滚动就是ScrollViewer,如何使用逻辑滚动,那么滚动就是控件自己做。...是的,如果使用一个简单 ScrollViewer 是无法使用触摸滚动 请看代码,写一个简单 ScrollViewer 里面有一些矩形,可以看到这时可以进行鼠标滚动,但是触摸是无法滚动。...物理滚动 下面来告诉大家,物理滚动是如何做,实际上滚动就是布局中使用下面的代码,让元素布局滚动地方,所以看起来就是元素滚动 Rect childRect =...大概整个源代码只有这些,很多代码都是判断边界,还有处理一些用户输入。 触摸时候,核心代码是 ManipulateScroll ,传入了当前移动和累计移动、是否水平移动。...参见: WPF实现平滑滚动 - 天方 - 博客园 IScrollInfo in Avalon part I – BenCon’s WebLog IScrollInfo in Avalon part

1.7K10
您找到你想要的搜索结果了吗?
是的
没有找到

dotnet Framework 源代码 · ScrollViewer

ScrollViewer 存在两个滚动方式,物理滚动 和 逻辑滚动,如果使用 物理滚动 那么滚动就是ScrollViewer,如何使用逻辑滚动,那么滚动就是控件自己做。...是的,如果使用一个简单 ScrollViewer 是无法使用触摸滚动 请看代码,写一个简单 ScrollViewer 里面有一些矩形,可以看到这时可以进行鼠标滚动,但是触摸是无法滚动。...物理滚动 下面来告诉大家,物理滚动是如何做,实际上滚动就是布局中使用下面的代码,让元素布局滚动地方,所以看起来就是元素滚动 Rect childRect =...大概整个源代码只有这些,很多代码都是判断边界,还有处理一些用户输入。 触摸时候,核心代码是 ManipulateScroll ,传入了当前移动和累计移动、是否水平移动。...参见: WPF实现平滑滚动 - 天方 - 博客园 IScrollInfo in Avalon part I – BenCon’s WebLog IScrollInfo in Avalon part

69320

win10 uwp win2d CanvasVirtualControl 与 CanvasAnimatedControl

之前入门教程win10 uwp win2d 入门 看这一篇就够了我直接用是CanvasControl,实际上可以使用画布还有下面两个 CanvasAnimatedControl CanvasVirtualControl...所以做动画时候需要不停触发重新渲染就使用 CanvasAnimatedControl ,关于这个控件,请看win10 uwp 萤火虫效果 Win2D 游戏循环:CanvasAnimatedControl...因为 CanvasVirtualControl 使用位图虚拟化,所以不需要在所有的时候都把位图放在内存,只有需要显示地方才是有效,存放在内存,对于不显示地方是不放在内存,不画出来。...很多时候使用 CanvasVirtualControl 都是和 ScrollViewer 一起使用 所以滚动时候就可以判断哪些需要显示

23820

关于ScrollViewr和滚动轮劫持(scroll-wheel-hijack)

什么是滚动轮劫持 这篇文章介绍一个很简单继承自ScrollViewer控件: public class ExtendedScrollViewer : ScrollViewer { protected...所谓滚动轮劫持,简单来说即是一个可以滚动页面使用鼠标滚轮滚动页面的过程鼠标进入某个可以滚动子元素导致只在这个子元素滚动而整个页面想滚滚不动了。 具体看看这个例子: ?...实现 WPF要禁止ScrollViewer捕获鼠标滚动时间,可以重写OnMouseWheel成一个空方法: protected override void OnMouseWheel(MouseWheelEventArgs...这里面用到几个属性: MouseWheelEventArgsDelta表示鼠标滚轮变更量,当这个值为正数时表示滚轮向上。 ExtentHeight,获取ScrollViewer内容实际高度。...其他ScrollViewer方案 ScrollViewer还有很多玩法,但我工作不常用到所以就没做。

1.2K30

win10 uwp win2d CanvasVirtualControl 与 CanvasAnimatedControl CanvasAnimatedControlCanvas

之前入门教程win10 uwp win2d 入门 看这一篇就够了我直接用是CanvasControl,实际上可以使用画布还有下面两个 CanvasAnimatedControl CanvasVirtualControl...所以做动画时候需要不停触发重新渲染就使用 CanvasAnimatedControl ,关于这个控件,请看win10 uwp 萤火虫效果 Win2D 游戏循环:CanvasAnimatedControl...因为 CanvasVirtualControl 使用位图虚拟化,所以不需要在所有的时候都把位图放在内存,只有需要显示地方才是有效,存放在内存,对于不显示地方是不放在内存,不画出来。...很多时候使用 CanvasVirtualControl 都是和 ScrollViewer 一起使用 所以滚动时候就可以判断哪些需要显示

54110

Silverlight:ScorllViewer随Tab键自动跟随子控件Focus滚动

ScrollViewer里包含很多子控件时,默认情况下只能用鼠标手动拖动(或滚轮)滚动条以实现内容滚动,假如用户是键盘高手,习惯于用Tab键来切换子控件焦点时,即使当前获得焦点控件不可见区域,滚动条也不会自动跟随着滚动到相应位置...,这个非常不方便,今天在网上看到一个老外解决办法,代码转贴于此: private void _ScrollViewer_GotFocus(object sender, RoutedEventArgs...0 : newOffset; // no use returning negative offset }   即:给ScrollViewerGotFocus事件增加_ScrollViewer_GotFocus...处理方法,然后计算当前获取焦点控件与ScorllViewer偏移距离,最终得出滚动条应该滚动偏移量。...上面这一段代码基本上能解决问题,但是有一个小小不足:如果有3个输入框从上到下排着,且都在可视范围内,这时如果用鼠标去点击其中一个不是当前获得焦点输入框,也会触发以上代码,导致滚动条跳动一段距离,这个给用户感觉好象界面总是

1.2K60

OEA WPF 树型表格虚拟化设计方案

经检测,表现虽然表格行已经做了虚拟化,但是由于列非常多,最终还是造成可视树元素过多,而导致界面布局代码运行过慢。...要知道如何实现 IScrollInfo,则需要明白 IScrollInfo 设计原理:     如果 UIVPanel 元素自己要处理滚动信息,它必须知道当前滚动 OffSet,并告知 ScrollViewer...ScrollViewer 交互完成同时,UIVPanel 还应该根据提供视窗大小,调用基类 VirtualizingPanel ItemContainerGenerator 属性一套元素生成方法...那么,在这样层次要求下,要如何实现只使用一个滚动虚拟化呢?还好,WPF 自带 DataGrid 也带有行列虚拟化功能,我们可以先看一下 DataGrid 是如何实现。...为了使用最外层 ScrollViewer 滚动条信息,它通过可视树往上查找到 DataGridRowsPresenter 来获取水平方向上滚动条位置 HorizontalOffset,而通过这个值

2.6K70

WPF --- 触摸屏下两个问题

场景 具体场景就是一个配置界面, ScrollViewer 包含一个StackPanel 然后纵向堆叠,以滚动方式查看,然后包含多个 TextBlock 、 TextBox 以及DataGrid ,...期间遇到了两个问题: WPF触摸屏下,如果有滚动条(ScrollViewer情况下,默认包含触底反馈功能,就是触摸屏滑动到底或从底滑到顶,界面都会出现抖动情况。... UI 元素绑定它反馈事件,然后注册方法设置 e.Handled = true; ,这样中断了事件继续冒泡或隧道传播,比如这样 // Xaml,在对应 UIElement 上绑定ManipulationBoundaryFeedback...触点在DataGrid无法滚动问题 这个问题,其实不光在 DataGrid中有,触点在 TextBox 、ListView、ListBox,这一类内置有 ScrollViewer 控件内,都有同样问题...,使用滑轮界面无法滚动问题,那么解决触摸屏触点在 DataGrid 无法滚动问题,也是一样思路,根据触点偏移量,模拟鼠标滚轮偏移量,调用鼠标滚动事件,模拟滚动代码如下: private

10810

win10 uwp 如何判断一个控件滚动里面是用户可见

UWP 如何知道一个元素是滚动显示大小内用户可以看到这个控件?如果需要在控件滚动条里面用户可以看到时候触发某个事件,在用户看不到时候触发另一个事件可以怎么做?...昨天星期八再娶你 大佬问我如何判断滚动条内可以看到某个元素,他需要在滚动条里面放一个视频播放器,在用户看不到这个播放器时候自动停下这个播放器 UWP 判断会比 WPF 复杂一些,我写过WPF...如何判断一个控件滚动里面是用户可见但是 UWP 小伙伴,也就是做 UWP 大佬对 API 设计会更加诡异 UWP 没有 ScrollChanged 事件只有ScrollViewer.ViewChanged... ScrollViewer.ViewChanged 只有在用户滚动或缩放完成之后才会触发,同时这个事件参数ScrollViewerViewChangedEventArgs 只有一个表示现在是用户交互过程还是结束变量...LayoutUpdated可以控件第一次加载时候触发,可以在用户滚动时候触发 LayoutUpdated 通过判断控件左上角坐标和控件大小可以判断用户是否可以看到这个控件 UWP

90420

New UWP Community Toolkit - AdaptiveGridView

概述 UWP Community Toolkit  中有一个自适应 GridView 控件 - AdaptiveGridView,本篇我们结合代码详细讲解  AdaptiveGridView 实现。...或 container 为空时,设置为需要 container Margin;最后根据 每一列 container 宽度,减掉 itemMargin,得到 itemWidth; protected...;当单行时,把 MaxHeight 属性设置为 ItemHeight,Orientation 设为纵向,滚动设置包括纵向滚动禁止,隐藏滚动条,横向滚动可用;如果为多行模式,则根据保存 Orientation...OneRowMode 时使用,作用是把原高度,加上 padding 和 margin 变成新高度,效果就是单行模式时,元素高度上没有空隙;设置 Item padding 和 margin 会失效...总结 到这里我们就把 UWP Community Toolkit  AdaptiveGridView 控件代码实现过程和简单调用示例讲解完成了,希望能对大家更好理解和使用这个控件有所帮助。

1.3K70

win10 uwp 禁用 ScrollViewer 交互

如果在 UWP 有一个控件里面有 ScrollViewer 控件,那么因为默认 ScrollViewer 会使用触摸交互,这样控件就收不到触摸交互 通过 VerticalScrollMode="...Disabled" HorizontalScrollMode="Disabled" 可以关闭 ScrollViewer 交互 接下来就是简单告诉大家如何使用 ScrollViewer 禁用默认交互还让...ScrollViewer 滑动,先创建一个简单 UWP 项目 打开 xaml 添加一点代码,创建一个 Canvas 放在 ScrollViewer 内,在里面放一个矩形,通过这个矩形就可以知道有没有移动...> 创建 ScrollViewer 只有对水平做滑动,尝试用触摸滑动矩形,会发现只能通过垂直滑动 如果想水平也可以滚动,需要设置 HorizontalScrollBarVisibility 属性,设置为...> 现在再试试触摸矩形 如果现在尝试拿到 滚动条外面的 Grid Manipulation 事件,可以看到没被被调用 <Grid Background="Transparent" ManipulationMode

77150

WPF 解决 ListView 滚动条不显示

本文告诉大家如何解决一个诡异问题,如果有一个 ListView 同时里面的元素高度很长,但是滚动条就是不显示,怎么让这个滚动条显示 本文不属于小白博客,忽略所有的业务环境和样式问题以及对 ScrollViewer...设置问题 开始发现这个问题请先看 ListView 滚动条,通过继承 ListView 或 ListBox 可以 Load 事件拿到滚动条,需要判断 ScrollViewer ExtentHeight...= this.VisualDescendant(); } 如果拿到 _scroll ExtentHeight 大小相对预期小,则可以继续看本文方法...通过 ItemsPresenter 重新布局就是解决这样问题, ScrollViewer 判断 ScrollableHeight 是通过 this.ExtentHeight - this.ViewportHeight...源代码 · ScrollViewer ---- 本文会经常更新,请阅读原文: https://lindexi.gitee.io/post/WPF-%E8%A7%A3%E5%86%B3

3.9K30

WPF 开启 ScrollViewer 触摸滚动

ScrollViewer 如果需要收到触摸消息,通过 Manipulation 触摸滚动,不能只是通过设置 IsManipulationEnabled 方法,还需要设置 PanningMode 才可以...那么如何知道滚动触摸事件是否触发,可以写一个类继承滚动条 public class StisvearpaHudalserevow : ScrollViewer {...,如果有触摸输入就可以通过输出看到了,简单一个界面,可以看到默认滚动条是不能滚动 同时触摸时候没有输出 尝试添加 IsManipulationEnabled 方法 可以看到有输出但是就是不能滚动 我博客 WPF 拖动滚动 告诉大家通过 PanningMode 方法可以让滚动滚动 只要在初始过程设置了...PanningMode 因为代码里面通过 InvalidateProperty 重新设置 IsManipulationEnabled 值,所以只需要设置 PanningMode 就可以

79310

WPF 开启 ScrollViewer 触摸滚动

ScrollViewer 如果需要收到触摸消息,通过 Manipulation 触摸滚动,不能只是通过设置 IsManipulationEnabled 方法,还需要设置 PanningMode 才可以...那么如何知道滚动触摸事件是否触发,可以写一个类继承滚动条 public class StisvearpaHudalserevow : ScrollViewer {...Debug.WriteLine("OnManipulationStarted"); base.OnManipulationStarted(e); } } 界面添加这个类...,如果有触摸输入就可以通过输出看到了,简单一个界面,可以看到默认滚动条是不能滚动 ?...可以看到有输出但是就是不能滚动 我博客 WPF 拖动滚动 告诉大家通过 PanningMode 方法可以让滚动滚动 只要在初始过程设置了 PanningMode 因为代码里面通过 InvalidateProperty

3.3K20

WPF 如何判断一个控件滚动里面是用户可见

昨天星期八再娶你 大佬问我如何判断滚动条内可以看到某个元素,他需要在滚动条里面放一个视频播放器,在用户看不到这个播放器时候自动停下这个播放器 WPF 可以通过 ScrollChanged 拿到当前滚动到哪同时拿到滚动条可见宽度和高度... ScrollChangedEventArgs 提供了多个属性用于拿到当前滚动可见宽度和高度,滚动水平移动和垂直移动,具体请看下图 在用户修改外层控件宽度或高度让滚动高度或宽度进行修改时候...等属性知道用户修改了多少 那么如果判断某个控件滚动条可见内就可以拿到某个控件外接矩形和滚动条可见大小进行矩形判断,请看下图 那么如何拿到一个控件外接矩形?...我滚动添加了一个控件,在里面添加了很多文本,其中有一个是歪楼文本 我需要在歪楼文本被用户看到时候输出,于是我就在后台代码通过本文上面提供方法拿到这个元素矩形判断 private void ScrollViewer_OnScrollChanged

88020
领券