scroll view 原理
//作者:禚来强 iphone开发*****:79190809 邮箱:zhuolaiqiang@gmail.com转帖请保留
在滚动过程当中,其实是在修改原点坐标
当手指触摸后, scroll view会暂时拦截触摸事件,使用一个
计时器,假如在计时器到点后,没有发生手指移动事件,
那么,scroll view发送tracking events到被点击的subview
假如在计时器到点前,发生了移动事件,那么 scroll view 取消tracking
自己发生滚动
子类可以重载touchesShouldBegin:withEvent:inContentView: 决定自己是否接收touch事件
pagingEnabled当值是YES,会自动滚动到subview的边界,默认是NO
touchesShouldCancelInContentView: 开始发送tracking messages消息给subview的时候
调用这个方法,决定是否发送tracking messages消息到subview,假如返回NO,发送,YES则不发送
假如 canCancelContentTouches属性是NO,则不调用这个方法
来影响如何处理滚动手势
scroll view还处理缩放和平移手势
要实现缩放和平移,必须实现委托viewForZoomingInScrollView:
scrollViewDidEndZooming:withView:atScale:
两个方法,另外 maximumZoomScale和minimumZoomScale两个属性要不一样
几个属性
tracking
当touch后还没有拖动的时候,值是YES,否则NO
zoomBouncing
当内容放大到最大或者最小的时候,值是YES,否则NO
zooming
当正在缩放的时候,值是YES,否则NO
decelerating
当滚动后,手指放开,但是还在继续滚动中,这个时候是 YES,其他是NO
decelerationRate
设置手指放开后的减速率
maximumZoomScale
一个浮点数,表示能放最大的倍数
minimumZoomScale
一个浮点数,表示能缩最小的倍数
pagingEnabled
当值是YES,会自动滚动到subview的边界,默认是NO
scrollEnabled
决定是否可以滚动
delaysContentTouches
是个布尔值,当值是YES的时候,用户触碰开始,scroll view要延迟一会,看看是否用户有意图滚动,假如滚动了,那么捕捉touch-down事件,否则就不捕捉, 假如值是NO,当用户触碰, scroll view会立即触发touchesShouldBegin:withEvent:inContentView:, 默认是YES
canCancelContentTouches
当值是YES的时候,用户触碰后,然后在一定时间内没有移动,scrollView发送tracking events,然后用户移动手指足够长度触发滚动事件,这个时候,scrollView发送了touchesCancelled:withEvent: 到subview,然后scroView开始滚动
假如值是NO,scrollView发送tracking events后,就算用户移动手指,scrollView也不会滚动
contentSize
里面内容的大小,也就是可以滚动的大小,默认是0,没有滚动效果。
showsHorizontalScrollIndicator
滚动时,是否显示水平滚动条
showsVerticalScrollIndicator
滚动时,是否显示垂直滚动条
bounces
默认是yes,就是滚动超过边界,会反弹有反弹回来的效果,假如是 NO,那么滚动到达边界,那么会连忙停止
bouncesZoom
和bounces类似,区别在于,这个效果反映在缩放上面,假如缩放超过最大缩放,那么会反弹效果,假如是NO,则到达最大或者最小的时候,立即停止
directionalLockEnabled
默认是NO, 可以在垂直和水平方向同时运动, 当值是YES, 假如一开始是垂直或者是水平运动,那么接下来会锁定另外一个方向的滚动, 假如一开始是对角方向滚动,则不会禁止某个方向
indicatorStyle
滚动条的样式,基本只是设置颜色,总共3个颜色,默认,黑色的,白色的
scrollIndicatorInsets
设置滚动条的位置
分享到:
相关推荐
总之,实现iOS中的UIScrollView无限轮播功能需要理解ScrollView的工作原理,掌握分页滚动、内容尺寸设置、滚动事件监听以及手势处理等技术。通过这些技术的综合运用,我们可以创建出用户体验良好的轮播组件。
- 对于水平滚动的UIScrollView,自适应宽度的实现原理与自适应高度类似。只需确保所有子视图的宽度总和大于或等于ScrollView的宽度,同时设置适当的约束,使得ScrollView可以根据内容宽度自动调整自身大小。 - ...
在iOS开发中,`UISCrollView`和`UITableView`是两种非常重要的视图控件,它们被广泛用于实现各种滚动界面。`UISCrollView`可以显示比屏幕更大的内容,用户可以通过滚动来查看所有内容,而`UITableView`则主要用于...
首先,我们要理解UIScrollView的基本原理。它是一个可以容纳比屏幕显示范围更大的内容的视图,并允许用户通过手势进行上下左右的滚动。在UIScrollView内部,你可以添加多个子视图,而不仅仅是单个图片。通过设置...
首先,我们来了解UIScrollView的基本原理。它提供了水平和垂直方向的滚动,通过设置contentSize属性,我们可以定义ScrollView内部的内容大小。而通过设置scrollView的delegate,我们可以监听用户的滚动行为,从而...
首先,我们要理解 `UIScrollView` 的基本工作原理。`UIScrollView` 内容区域可以比其实际显示区域大,用户可以通过滑动来查看超出可视范围的内容。为了实现无限循环,我们需要做的是在内容的开头和结尾添加重复的...
首先,理解`UIScrollView`的基本工作原理是关键。`UIScrollView`的内容区域可以比其实际显示区域大,这样就可以通过手势滑动查看超出部分的内容。为了实现两方向的滚动,我们需要设置`UIScrollView`的`contentSize`...
首先,我们需要理解`UIScrollView`的基本工作原理。`UIScrollView`有一个contentSize属性,它定义了可滚动区域的大小。当contentSize大于实际视图的frame大小时,用户可以通过滑动来查看超出部分的内容。我们可以...
1. **`UIScrollView`的工作原理**:`UIScrollView`通过监听`touchesBegan:withEvent:`、`touchesMoved:withEvent:`等触摸事件来实现滑动功能。它能够根据用户的触摸动作来决定是否开始滑动及滑动的方向。 2. **`...
首先,我们要理解UIScrollView的基本工作原理。UIScrollView内部包含一个可变大小的内容视图(content view),这个内容视图的大小可以远大于UIScrollView本身,从而允许用户滚动查看超出屏幕的部分。为了实现自动...
Swift4.2使用UIScrollView 实现图片轮播 轮播原理 UIScrollView对象有pagingEnable成员,如果设置为YES,那么每一个scrollView尺寸这么大的区域就会被当作一页,在滚动时会根据滚动的比例自动计算应该切换到哪一页。
首先,了解UIScrollView的工作原理至关重要。它通过内容视图(content view)来展示数据,内容视图的大小可以超过实际显示区域的大小,从而实现可滚动的效果。当用户滚动时,UIScrollView会动态调整内容视图的位置,使...
首先,我们需要理解UIScrollView的基本工作原理。UIScrollView内部包含一个可滚动的内容视图,其大小可以超过ScrollView自身的边界。通过设置contentSize属性,我们可以指定这个内容视图的尺寸,从而定义用户可以...
首先,我们要理解UIScrollView的基本原理及其在图片浏览中的关键作用。 UIScrollView是UIKit框架中的一个基础控件,它允许用户在内容区域超过屏幕大小时进行滚动操作。通过设置其contentSize属性,我们可以指定...
首先,我们要理解`UIScrollView`的基本原理。`UIScrollView`是一个可以容纳大于其实际显示区域内容的容器,用户可以通过水平或垂直滑动来查看不可见的部分。在`UIScrollView`中,我们可以通过设置`contentSize`属性...
理解其工作原理和如何自定义,能够帮助我们创建更复杂、交互性更强的界面。 这个资源可能涵盖了如何集成PullToRefresh到自定义的UIScrollView中,可能包括了手势识别、动画效果实现、以及如何处理刷新逻辑等细节。...
首先,我们要理解`UIScrollView`的工作原理。`UIScrollView`有一个`contentSize`属性,它定义了视图可以滚动的总大小。`contentOffset`属性则表示当前视图偏移量,用于追踪用户滚动的位置。为了实现无缝循环,我们...
它的工作原理是通过内容视图(content view)和视图的滚动范围(content size)来实现的。内容视图可以比UIScrollView的实际大小大很多,用户可以通过滑动来查看超出可视区域的部分。 在创建UIScrollView时,我们...
首先,我们要理解UIScrollView的工作原理。UIScrollView有一个contentSize属性,它定义了视图可以滚动的区域大小。如果contentSize的宽度大于视图的宽度,用户就可以水平滑动;如果contentSize的高度大于视图的高度...