UIScrollView的属性总结
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了UIScrollView的属性总结,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含5059字,纯文字阅读大概需要8分钟。
内容图文
contentSize是scrollview可以滚动的区域,比如frame = (0 ,0 ,320 ,480) contentSize = (320 ,960),代表你的scrollview可以上下滚动,滚动区域为frame大小的两倍。
contentOffset是scrollview当前显示区域顶点相对于frame顶点的偏移量,比如上个例子你拉到最下面,contentoffset就是(0 ,480),也就是y偏移了480
contentInset是scrollview的contentview的顶点相对于scrollview的位置,例如你的contentInset = (0 ,100),那么你的contentview就是从scrollview的(0 ,100)开始显示
另外UITableView是UIScrollView的子类,它们在上述属性又有所不同,tabelview的contentsize是由它的下列方法共同实现的
- (NSInteger)numberOfSections;
- (NSInteger)numberOfRowsInSection:(NSInteger)section;
- (CGFloat)tableView:(UITableView *)tableView heightForRowAtIndexPath:(NSIndexPath *)indexPath;
- (CGFloat)tableView:(UITableView *)tableView heightForHeaderInSection:(NSInteger)section;
- (CGFloat)tableView:(UITableView *)tableView heightForFooterInSection:(NSInteger)section;
它会自动计算所有的高度和来做为它的contentsize的height.
例如你在delegate方法
- (NSInteger)tableView:(UITableView *)tableView numberOfRowsInSection:(NSInteger)section {
return 100;
}
那么你的tabelview的contentsize就是(320, 4400)
posted @ 2011-10-13 17:36 zcbbin 阅读(194) 评论(2) 编辑
UIScrollView 原理
scroll view 原理
//作者:禚来强 iphone开发q*****:79190809 邮箱:zhuolaiqiang@gmail.com转帖请保留
demo 可以到我的博客http://blog.csdn.net/diyagoanyhacker/article/list/10
在滚动过程当中,其实是在修改原点坐标
当手指触摸后, 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
设置滚动条的位置
属性 |
作用 |
CGPoint contentOffSet |
监控目前滚动的位置 |
CGSize contentSize |
滚动范围的大小 |
UIEdgeInsets contentInset |
视图在scrollView中的位置 |
id<UIScrollerViewDelegate> |
设置协议 |
BOOL directionalLockEnabled |
指定控件是否只能在一个方向上滚动 |
BOOL bounces |
控制控件遇到边框是否反弹 |
BOOL alwaysBounceVertical |
控制垂直方向遇到边框是否反弹 |
BOOL alwaysBounceHorizontal |
控制水平方向遇到边框是否反弹 |
BOOL pagingEnabled |
控制控件是否整页翻动 |
BOOL scrollEnabled |
控制控件是否能滚动 |
BOOL showsHorizontalScrollIndicator |
控制是否显示水平方向的滚动条 |
BOOL |
控制是否显示垂直方向的滚动条 |
UIEdgeInsets scrollIndicatorInsets |
指定滚动条在scrollerView中的位置 |
UIScrollViewIndicatorStyle |
设定滚动条的样式 |
float decelerationRate |
改变scrollerView的减速点位置 |
BOOL tracking |
监控当前目标是否正在被跟踪 |
BOOL dragging |
监控当前目标是否正在被拖拽 |
BOOL decelerating |
监控当前目标是否正在减速 |
BOOL delaysContentTouches |
控制视图是否延时调用开始滚动的方法 |
BOOL canCancelContentTouches |
控制控件是否接触取消touch的事件 |
float minimumZoomScale |
缩小的最小比例 |
float maximumZoomScale |
放大的最大比例 |
float zoomScale |
设置变化比例 |
BOOL bouncesZoom |
控制缩放的时候是否会反弹 |
BOOL zooming |
判断控件的大小是否正在改变 |
BOOL zoomBouncing |
判断是否正在进行缩放反弹 |
BOOL scrollsToTop |
控制控件滚动到顶部 |
1.开始滑动
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
{
NSLog(@"scrollViewWillBeginDragging");
}
2.将要结束滑动
- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inoutCGPoint *)targetContentOffsetNS_AVAILABLE_IOS(5_0)
{
NSLog(@"scrollViewWillEndDragging");
}
注意该方法常用在当用户滚动完屏幕时加载图片,HTTP请求加载,这样会提高效率
3.已经结束滑动
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
{
NSLog(@"scrollViewDidEndDragging");
}
4.将要减速
- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView
{
NSLog(@"scrollViewWillBeginDecelerating");
}
5.已经减速
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView // called when scroll view grinds to a halt
{
NSLog(@"scrollViewDidEndDecelerating");
}
6.已经停止滚动
- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView
{
NSLog(@"scrollViewDidEndScrollingAnimation");
}
原文:http://www.cnblogs.com/liangjialun219/p/3896617.html
内容总结
以上是互联网集市为您收集整理的UIScrollView的属性总结全部内容,希望文章能够帮你解决UIScrollView的属性总结所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。