UIScrollView 原理

 

UITableView、UITextView是UIScrollView的子类。

UITableViewController是UIViewController的子类。

UITableViewController是管理表格视图的。

表格视图单元是你的UITableView用来在自身显示数据的UIView子类。

UIScrollView是用来管理在它们之间卷动的类,在地图上显示,放大缩小等。

ContentOffset是你当前可视内容在滚轴视图边界的左上角的那个点,它不是从ContentInsets的左上角开始,而是内容的左上角。

ContentInset 是scrollview中contentView.frame.origin与scrollview.frame.origin的关系.

CGRecct frame=CGRectMake(0,0,200,200);   //创建框架

scrollView = [[UIScrollView  alloc] initWithFrame : frame ]; //把它加为我们视图的一个子视图,后把其它一些内容视图当作子视图添加给它

添加子视图subviews

ScollView中添加左右移动的UIImageView

frame=CGRectMake(0,0,500,500);   //比可见视图大,当左右移动时隔不久不同部分会移动进来

myImageView = [[UIImageView  alloc] initWithFrame : frame ];

[scrollView  addSubview : myImageView];

//Set the content size
scrollView.contentSize= CGSizeMake(500,500);

-(void)scrollViewDidScoll : (UIScrollView *) scrollView;


它在每次滚轴视图的ContentOffset改变时都会被调用,当用户在四周移动手指时也会一直被调用


-(BOOL)scrollViewShouldScrollToTop: (UIScrollView *)scrollView;


响应事件的一个例子

 

scroll view 原理

http://www.cocoachina.com/bbs/read.php?tid-40965-page-1.html

关于事件处理的认识:

首先了解下UIScrollView对于touch事件的接收处理原理:UIScrollView应该是重载了hitTest 方法,并总会返回itself 。所以所有的touch 事件都会进入到它自己里面去了。内部的touch事件检测到这个事件是不是和自己相关的,或者处理或者除递给内部的view。

为了检测touch是处理还是传递,UIScrollView当touch发生时会生成一个timer。

(1)如果150ms内touch未产生移动,它就把这个事件传递给内部view

(2)如果150ms内touch产生移动,开始scrolling,不会传递给内部的view。(如当你touch一个table时候,直接scrolling,你touch的那行永远不会highlight。)

(3)如果150ms内touch未产生移动并且UIScrollView开始传递内部的view事件,但是移动足够远的话,且
canCancelContentTouches =
YES,UIScrollView会调用touchesCancelled方法,cancel掉内部view的事件响应,并开始scrolling。(如
当你touch一个table, 停止了一会,然后开始scrolling,那一行就首先被highlight,但是随后就不在高亮了)

在滚动过程当中,其实是在修改原点坐标。当手指触摸后, 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
设置滚动条的位置

转自:http://www.cnblogs.com/Snowfun/archive/2011/05/19/2051001.html

时间: 2024-08-06 20:26:59

UIScrollView 原理的相关文章

UIScrollView 原理详解

UIScrollView 原理详解 ScrollView UIScrollView UIScrollView为了显示多于一个屏幕的内容或者超过你能放在内存中的内容. Scroll View为你处理缩小放大手势,UIScrollView实现了这些手势,并且替你处理对于它们的探测和回应.其中需要注意的子类是UITableView以及UITextView(用来显示大量的文字).还有一个UIWebView,尽管那不是UIScrollView的直接子类,它适用UIScrollView去显示网页内容 con

iOS学习--UIScrollView 原理详解

iOS学习--UIScrollView 原理详解 http://blog.csdn.net/yanfangjin/article/details/7898189 ScrollView UIScrollView UIScrollView为了显示多于一个屏幕的内容或者超过你能放在内存中的内容. Scroll View为你处理缩小放大手势,UIScrollView实现了这些手势,并且替你处理对于它们的探测和回应.其中需要注意的子类是UITableView以及UITextView(用来显示大量的文字).

UIScrollView原理(转载)

UIScrollView原理(http://blog.sina.com.cn/s/blog_85c1f6a50100xihg.html) 在滚动过程当中,其实是在修改原点坐标 当手指触摸后, scroll view会暂时拦截触摸事件,使用一个计时器,假如在计时器到点后,没有发生手指移动事件,那么,scroll view发送tracking events到被点击的subview(此时划不动)假如在计时器到点前,发生了移动事件,那么 scroll view 取消tracking自己发生滚动(可以滚动

iOS开发-UIScrollView原理

转载:http://www.cnblogs.com/xiaofeixiang/p/5144256.html UIScrollView 在开发中是不可避免,关于UIScrollView都有自己一定的理解.滚动视图有两个需要理解的属性,frame和bounds,frame是定义了视 图在窗口的大小和位置,bounds表示视图在其自身坐标系中的位置和大小,frame影响视图在窗口位置,bounds会影响子视图的位置. 先来看一张图片: 我们用一个父View将整个窗口铺满,然后添加子视图: UIView

自动无限循环UIScrollView原理

无限循环: 我们都知道UIScrollView有一种很流畅的切换效果,结合UIPageControl的辅助展示效果,就可以完成一个很不错的产品介绍功能页面.那么像一些购物app中,商品展示页面无限滚动的效果是如何实现的呢? 方法1:前后+1方法,这也最常见的一种做法.假如我们有四张需要展示的图片,我们创建了一个数组来保存图片名字,此时数组中保存的是按顺序的1.png,2.png,3.png,4.png,这四个图片名字.要实现无限循环的效果,我们需要改动一下这个数组为:4.png,1.png,2.

第二、UIScrollView的使用大全

UIScrollView UIPageControl 的使用 2011-11-19 16:48 4690人阅读 评论(0) 收藏 举报 imagescrollspringiphone // //            scrollView.contentSize = CGSizeMake(self.view.frame.size.width * 10, self.view.frame.size.height); //        [self.view addSubview:scrollView

ios UIScrollView 基础属性

转 UIScrollView 原理 在滚动过程当中,其实是在修改原点坐标.当手指触摸后, scroll view会暂时拦截触摸事件,使用一个计时器.假如在计时器到点后没有发生手指移动事件,那么 scroll view 发送 tracking events 到被点击的 subview.假如在计时器到点前发生了移动事件,那么 scroll view 取消 tracking 自己发生滚动. 子类可以重载 touchesShouldBegin:withEvent:inContentView: 决定自己是

小胖说事10------iOS scrollview作用原理(一个大的scrollview包含一个小的scrollview,如何滑动小的scrollview的时候,大的scrollview滑动小的不动

今天做了一个项目,有这样一个需求,就是一个大的scrollview包含一个小的scrollview,如何滑动小的scrollview的时候,大的scrollview滑动,小的srollview不滑动. 我们知道当多个视图进行叠加的时候,touch事件是作用到最上面的视图上,但是如果父视图是UIScrollView,如果默认,可能touch子视图会造成UIScrollView的滚动. UIScrollView滚动的原因,可以看UIScrollView 原理. 我在这里简单的描述一下,UIScrol

iOS基本UI控件总结

转载自原文:http://www.tuicool.com/articles/qmMjQnJ 包括以下几类: //  继承自 NSObject:(暂列为控件) UIColor *_color;     // 颜色 UIImage *_image;     // 图像 //  继承自 UIView:  只能相应手势 UIGestureRecognizer  事件 ,  如果本事不响应会将事件 action  向 superview  传递 UILabel *_label;