iOS中UIScollView的总结
在iOS开发中可以说UIScollView是所有滑动类视图的基础,包括UITableView,UIWebView,UICollectionView等等,UIScrollView类为显示大于应用程序窗口的内容提供支持。它使得用户可以使用滑动手势来滚动,并可以使用扩张/收缩手势来放大缩小部分内容。UIScrollView类可以拥有一个代理,该代理采用UIScrollViewDelegate协议。对于缩放的工作,代理必须实现viewForZoomingInScrollView:以及scrollViewDidEndZooming:withView:atScale:;此外,最大(maximumZoomScale)和最小(minimumZoomScale)缩放规模必须不同。
其中有很多常用到的属性设置和方法,在这里统一做下记录。
属性
alwaysBounceHorizontal
布尔值,规定是否在水平方向在滚动到末尾时产生“反弹”。
若该属性及bounces被设定为YES,水平拖拽即使在内容小于滚动视图边缘时也被允许。默认值为NO。
alwaysBounceVertical
布尔值,规定是否在垂直方向在滚动到末尾时产生“反弹”。
若该属性及bounces被设定为YES,垂直拖拽即使在内容小于滚动视图边缘时也被允许。默认值为NO。
bounces
布尔值,控制是否滚动视图能否超出内容边缘再弹回。
若该属性的值为YES。滚动视图会在遇到内容边缘时反弹。若值为NO,滚动会在达到边缘时立即停止而不反弹。默认值为YES。
bouncesZoom
布尔值,规定滚动视图是否在缩放超出最大值和最小值动画时播放内容缩放动画。
若该属性的值为YES,在缩放超出最大值或最小值时,滚动视图会临时播放一个稍超出限制范围的动画再返回限制大小。若该属性为NO,缩放会在达到限制大小时立即停止,默认为YES。
canCancelContentTouches
布尔值,控制触摸内容视图时是否总是导致跟踪。
若该属性的值为YES,内容中的视图会开始跟踪触摸的手指,若用户拖拽手指到足以滚动的距离,视图会收到touchesCancelled:withEvent:信息,而滚动视图会作为一个滚动事件处理这次触摸。若该属性的值为NO,滚动视图在内容视图开始跟踪时将无视手指移动,不进行滚动。
contentInset
表示内容视图从封闭滚动视图中被嵌入的距离。
用该属性增加围绕内容的滚动区域。单位为点。默认值为UIEdgeInsetssZero。
contentOffset
表示从滚动视图的原点到内容视图的原点的偏移的点。
默认值为CGPointZero。
contentSize
内容视图的大小。
单位是点。默认值是CGSizeZero。
decelerating
返回滚动视图中的内容是否在提起手指后继续移动。(只读)
若用户已不再拖拽内容但滚动还在发生时返回YES。
decelerationRate
浮点数,规定用户提起手指后的滚动减速速率。
你的应用程序可以使用UIScrollViewDecelerationRateNormal和UIScrollViewDecelerationRateFast常量作为引用点以获得一个合理的减速速率。
delaysContentTouches
布尔值,规定滚动视图是否延迟处理触摸下压手势。
若该属性值为YES,滚动视图会延迟处理下压手势直到可以确定该操作的意图是否是滚动。若值为NO,滚动视图会立即调用touchesShoudBegin:withEvent:inContentView:。默认值为YES。
具体讨论详见类讨论。
delegate
滚动视图对象的托管。
托管必须实现UIScrollViewDelegate协议。UIScrollView类(不保持托管),会调用托管实现中的每一个方法。
directionalLockEnabled
布尔值,规定是否滚动在某一方向上被禁止。
若该属性为NO,滚动在水平和垂直方向上都被允许。若该属性为YES,当用户开始某一方向的滚动(水平或垂直),滚动视图会禁止另一方向的滚动。若以对角线方向拖动,滚动则不会被锁定且用户在本次拖动完成之前可以在任意方向拖动。默认值为NO。
dragging
布尔值,表明用户是否开始滚动内容。
该属性持有的值可能需要滚动一段时间或距离才会被设定成YES。
indicatorStyle
滚动控制器的风格。
默认风格是UIScrollViewIndicatorStyleDefault。参见“Scroll Indicator Style”获取更多关于此常量的描述。
maximumZoomScale
浮点数,指定可被应用滚动视图内容的最大缩放因子。
该值规定了内容可被放大到多大。默认值为1.0。
minimumZoomScale
浮点数,指定可被应用滚动视图内容的最小缩放因子。
该值规定了内容可被缩小到多小。默认值为1.0。
pagingEnabled
布尔值,规定滚动视图是否可以翻页。
若该值为YES,滚动视图会在用户滚动时停止在滚动视图边框的整数倍处。默认值为NO。
panGestureRecognizer
当前用于滑动手势的手势识别器(只读)
在希望更加精确地控制被滚动视图识别的滑动手势时,你的应用程序可访问此属性。
pinchGestureRecognizer
当前用于扩张/收缩手势的手势识别器(只读)
在希望更加精确地控制被滚动视图识别的扩张/收缩手势时,你的应用程序可访问此属性。
scrollEnabled
布尔值,规定是否允许滚动。
若该属性的值为YES,允许滚动,若为NO,禁止滚动。默认值为YES。
当滚动被禁止时,滚动视图将不再接受触摸事件;滚动视图会将事件传送至响应链中。
scrollIndicatorInsets
表示滚动指示器从封闭滚动视图中被嵌入的距离。
默认值为UIEdgeInsetssZero。
scrollToTop
布尔值,控制滚动至顶部的手指是否有效。
滚动至顶部手势是触摸状态栏;当此属性为YES时,滚动视图在此手势发生时跳转至状态栏。此属性默认为YES。
该手势作用于单个可见的滚动视图;若有多个滚动视图(例如,日期选择器)设定了这个属性,或者若托管在scrollViewShouldScrollToTop:中返回了NO,UIScrollView会无视滚动到顶部的请求。在滚动视图滚动到内容视图的顶部之后,它会给托管发送一个scrollViewDidScrollToTop:信息。
showsHorizontalScrollIndicator
布尔值,控制是否水平滚动指示器可见。
默认值为YES。指示器会在跟踪时显示并在跟踪之后消失。
showsVerticalScrollIndicator
布尔值,控制是否垂直滚动指示器可见。
默认值为YES。指示器会在跟踪时显示并在跟踪之后消失。
tracking
返回用户是否触摸内容并初始化滚动。(只读)
若用户已触摸内容视图但可以还示开始拖动时该属性值为YES。
zoomBouncing
布尔值,表明缩放已超过了指定接收器的缩放限制。
若滚动视图缩放超出最大值或最小值时该值为YES;否则值为NO。
zooming
布尔值,表明内容视图当前是否在缩。
若用户发出了一个缩放手指,该值为YES,否则为NO。
zoomScale
浮点数,指定当前应用于滚动视图的内容的缩放因子。
该值规定了内容当前缩放了多少。默认值是1.0。
方法
flashScrollIndicators
短暂地显示滚动指示器。
你应该在把滚动视图放在最前端时调用此方法。
scrollRectToVisible:animated:
滚动内容的指定区域以便使内容在接受器中可见。
-(void)scrollRectToVisible:(CGRect)rectanimated:(BOOL)animated
参数:
rect
定义内容视图区域的矩形。
animated
若滚动应被动画化则传入YES,否则为NO。
该方法滚动内容视图以使rect中定义的区域可以刚好显示在滚动视图中。若区域已经是可见的,该方法什么也不做。
setContentOffset:animated:
设定内容视图原点相对于接收器原点的偏移。
- (void)setContentOffset:(CGPoint)contentOffset animated:(BOOL)animated
参数
contentOffset
内容视图原点的偏移点(以点的形式表示)。
animated
若YES,用一个恒定的速度以动画形式移动到新的偏移处;NO则立即移动。
setZoomScale:animated:
浮点数,指定当前缩放因子。
- (void)setZoomScale:(float)scale animated:(BOOL)animated
参数
scale
要缩放内容到的新值。
animated
若YES,动画化缩放到时新的缩放大小,NO则立即缩放。
新的缩放值应在minnumZoomScale和maximumZoomScale之间。