• UIScrollView原理(转载)


    UIScrollView原理(http://blog.sina.com.cn/s/blog_85c1f6a50100xihg.html)
     

    在滚动过程当中,其实是在修改原点坐标

    当手指触摸后, 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://blog.csdn.net/diyagoanyhacker/article/details/6062498

    eg:
    UIScrollView *sv  =[[UIScrollView alloc] initWithFrame:CGRectMake(0.0, 0.0,self.view.frame.size.width, 400)];

    UIScrollView的最大属性就是可以滚动,那种效果很好看,其实滚动的效果主要的原理是修改他的坐标,准确的讲是修改原点坐标,而 UIScrollView跟其他组件的都一样,有自己的delegate,在.h文件中要继承UIScrollView的delegate然后在.m文件 的viewDidLoad设置的delegate为self。如下:

    view plain

    sv.pagingEnabled = YES; 

    sv.backgroundColor = [UIColor blueColor]; 

    sv.showsVerticalScrollIndicator = NO; 

    sv.showsHorizontalScrollIndicator = NO; 

    sv.delegate = self; 

    CGSize newSize = CGSizeMake(self.view.frame.size.width * 2, self.view.frame.size.height); 

    [sv setContentSize:newSize]; 

    [self.view addSubview: sv]; 

    在上面的代码中,一定要设置UIScrollView的pagingEnable为YES。不然你就是设置好了其他属性,它还是无法拖动,接下去的分别是 设置背景颜色和是否显示水平和竖直拖动条,最后最重要的设置他的ContentSize,ContentSize的意思就是它所有内容的大小,这个和它的 Frame是不一样的,只有ContentSize的大小大于Frame这样才可以支持拖动。

    (3)结合UIPageControl做新闻翻页效果

    初始化UIPageControl的方法都很简单,就是上面讲的alloc和init,不过大家要记住的一点就是如果你定义了全局变量一定要在delloc那里释放掉。

    UIPageControl有一个userInteractionEnabled你可以设置它为NO。就是点击的时候它不调用任何方法。然后设置它的currentPage 为0,并把它加到view上去。

    接下来在UIScrollView的delegate方法:

    view plain

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

    在这里你可以写上关于UIPageControl的页面设置的算法。如下

    view plain

    int index = fabs(scrollView.contentOffset.x) /scrollView.frame.size.width; 

    pageControl.currentPage = index; 

    (4)其他的

    UIScrollView还支持处理缩放的动作,比如图片的缩小或者地图。

    但是必须实现它的委托viewForZoomingInScrollView:

    scrollViewDidEndZooming:withView:atScale:然后它的两个属性maximumZoomScale和minimumZoomScale 要不一样。这样就能基本实现图片的缩放了。

  • 相关阅读:
    20150112-夜深,人不静
    20150111-谁会记得
    20150110-我希望我的歌声里都是希望
    20150102-霰现
    20150116-卵子
    20150109-放弃了一切希望
    20150105-条大路哟
    笔记:使用 stylus stylus-loader
    如何处理烫伤的伤口?
    连电子硬件行业都在开始使用 Git 了你还在等什么?
  • 原文地址:https://www.cnblogs.com/god-love-yao/p/4279963.html
Copyright © 2020-2023  润新知