uiscrollviewdelegate

来源:互联网 发布:刷新页面的js 编辑:程序博客网 时间:2024/05/16 13:53
最近想深入研究一下uiscrollview。然后search documentation ,一共就十几个代理方法,所以写一个东西记录一下学习历程

scrollviewdidscroll:
当用户上下滑动scrollview的时候,会一直调用这个方法,调用很多遍,能够在此得到contentoffsize的大小,注意offsize,的坐标原点一直是以当前自身为原点的,所以一定要注意不要掉坑里。

– scrollViewWillBeginDragging:
 滑动加速的时候,调用

- scrollViewWillEndDragging:withVelocity:targetContentOffset:
告诉代理当用户停止加速滑动scrollview,实际也就是停止手指离开屏幕

第一个variable是  scrollview
第二个variable  我一直没搞懂,因为文档中写的是 touch离开的时候的滑动view的速度,但是类型缺失cgpoint,这是一个左标点,没法代表一个速度啊,如果你知道是啥原因,欢迎留言。
第三个参数 是 指 从开始加速到速度为0 ,scrollview的offset

- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView
                  willDecelerate:(BOOL)decelerate
第二个参数,是根据scrollview的两种情况来看的,yes的情况是,手指离开后会有一段加速时间,no的情况是  手指离开后立即停止。。实际上就是控制了scrollview的是否有减速的情况,这个返回的属性要根据你对scrollvew的设置来决定的

- (BOOL)scrollViewShouldScrollToTop:(UIScrollView *)scrollView
返回来决定scrollvew是否能够 滑动到顶部

- (void)scrollViewDidScrollToTop:(UIScrollView *)scrollView
当scrollview 滑动到顶部的时候,立即调用此方法

- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView
就是减速的过程,手指离开之后的那段过程,但是设置的没有减速的过程的话,此方法会被屏蔽掉
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView
看名字也知道,就不介绍了

 scrollViewDidEndZooming:withView:atScale:

想了很久,不知道缩放在哪儿,还以为是下拉之后会自动缩放呢,后来才想到是scrollview的自动缩放,至于下拉后根据下拉高度来缩放,可以使用自动布局相对于一个值来布局,而这个值可以绑定在offset上,这样就能实现了


- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView
                          withView:(UIView *)view



- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView
                       withView:(UIView *)view
                        atScale:(CGFloat)scale

- (void)scrollViewDidZoom:(UIScrollView *)scrollView
来在此知道是哪个变了大小

- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView
下边有介绍




下边是我转载的一篇博文,感觉内容更详细,如果上边的只是为了给你搭建起来一个框架,下边的东西真的很实用

UIScrollView的是几个UIKit类包括的UITableView和UITextView中的超类。

一个UIScrollView对象(或者,简单地说,一个滚动视图)的核心概念是,它是一个视图,其起源是可调过的内容视图。它剪辑的内容,它的框架,这通常(但不一定)恰逢该应用程序的主窗口。滚动视图跟踪手指的变动,并相应调整原点。这正显示出它的内容“,通过”滚动视图的视图绘制的基础上,新的原点,它被固定在内容视图的偏移部分本身。滚动视图本身没有绘制,除了显示垂直和水平滚动的指标。滚动视图必须知道的内容视图的大小,所以它知道何时停止滚动,默认情况下,它“反弹”回来时,滚动超出了内容的范围。

用于管理内容的绘制有关的对象显示在一个滚动视图应该瓦片的内容的子视图,以便没有视图超过屏幕的大小。当用户在滚动滚动视图,这个对象应该添加和删除子视图是必要的。

由于滚动视图没有滚动条,它必须知道是否触摸信号的意图与滚动意图在内容跟踪一个子视图。做出此决定,它暂时拦截触摸按下事件通过启动一个定时器,并在定时器触发之前,看是否触摸手指做任何运动。如果定时器触发无位置显著的变化,滚动视图将跟踪事件的内容视图的感动子视图。然后,如果用户在定时器期满前拉着自己的手指远远不够,滚动视图将取消任何跟踪的子视图,并进行滚动本身。子类可以重写touchesShouldBegin : withEvent:方法inContentView :,pagingEnabled和touchesShouldCancelInContentView :方法(这是由滚动视图调用)来影响滚动视图如何处理滚动手势。

滚动视图还处理缩放和平移的内容。当用户使一个夹在或向外挤压手势,滚动视图调整偏移量和内容的标度。当手势结束,管理内容视图中的对象应该要更新的内容为必要的子视图。 (请注意,手势可以结束和手指仍可能下跌。 )虽然手势正在进行中,滚动视图不发送任何跟踪调用子视图。

该UIScrollView的类可以有必须采取UIScrollViewDelegate协议的委托。对于缩放和平移工作,委托必须实现viewForZoomingInScrollView :和scrollViewDidEndZooming : withView : atScale : ,此外,最大( maximumZoomScale )和最小( minimumZoomScale )变焦倍数必须是不同的。

方法&&属性:

// 监控目前滚动的位置(默认CGPointZero)

CGPoint                      contentOffset; - (void)setContentOffset:(CGPoint)contentOffset animated:(BOOL)animated;

// 滚动范围的大小(默认CGSizeZero)

CGSize                       contentSize; 

// 视图在scrollView中的位置(UIEdgeInsetsZero)

UIEdgeInsets                 contentInset;   

// 设置协议

id<UIScrollViewDelegate>      delegate;

// 指定控件是否只能在一个方向上滚动(默认为NO)

BOOL directionalLockEnabled; 

// 控制控件遇到边框是否反弹(默认为YES)

BOOL                         bounces; 

// 控制垂直方向遇到边框是否反弹(默认为NO,如果为YES,bounces也是YES)

BOOL                         alwaysBounceVertical;  

// 控制水平方向遇到边框是否反弹(默认为NO,如果为YES,bounces也是YES)

BOOL                         alwaysBounceHorizontal;

// 控制控件是否整页翻动(默认为NO)

BOOL          pagingEnabled; 

// 控制控件是否能滚动

BOOL          scrollEnabled;

// 控制是否显示水平方向的滚动条

BOOL                         showsHorizontalScrollIndicator; 

// 控制是否显示垂直方向的滚动条

BOOL                         showsVerticalScrollIndicator;

// 指定滚动条在scrollerView中的位置

UIEdgeInsets                 scrollIndicatorInsets; 

// 设定滚动条的样式

UIScrollViewIndicatorStyle   indicatorStyle;  

UIScrollViewDelegate详解

//scrollView滚动时,就调用该方法。任何offset值改变都调用该方法。即滚动过程中,调用多次 - (void)scrollViewDidScroll:(UIScrollView *)scrollView{    NSLog(@"scrollViewDidScroll");    CGPoint point=scrollView.contentOffset;    NSLog(@"%f,%f",point.x,point.y);    // 从中可以读取contentOffset属性以确定其滚动到的位置。    // 注意:当ContentSize属性小于Frame时,将不会出发滚动}
// 当scrollView缩放时,调用该方法。在缩放过程中,回多次调用- (void)scrollViewDidZoom:(UIScrollView *)scrollView{    NSLog(@"scrollViewDidScroll");    float value=scrollView.zoomScale;    NSLog(@"%f",value);}
// 当开始滚动视图时,执行该方法。一次有效滑动(开始滑动,滑动一小段距离,只要手指不松开,只算一次滑动),只执行一次。- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView{    NSLog(@"scrollViewWillBeginDragging");}
// 滑动scrollView,并且手指离开时执行。一次有效滑动,只执行一次。// 当pagingEnabled属性为YES时,不调用,该方法- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset{    NSLog(@"scrollViewWillEndDragging");}
// 滑动视图,当手指离开屏幕那一霎那,调用该方法。一次有效滑动,只执行一次。// decelerate,指代,当我们手指离开那一瞬后,视图是否还将继续向前滚动(一段距离),经过测试,decelerate=YES- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate{    NSLog(@"scrollViewDidEndDragging");    if (decelerate) {        NSLog(@"decelerate");    }else{         NSLog(@"no decelerate");    }    CGPoint point=scrollView.contentOffset;    NSLog(@"%f,%f",point.x,point.y);}
// 滑动减速时调用该方法。- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView{    NSLog(@"scrollViewWillBeginDecelerating");    // 该方法在scrollViewDidEndDragging方法之后。}
// 滚动视图减速完成,滚动将停止时,调用该方法。一次有效滑动,只执行一次。- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{    NSLog(@"scrollViewDidEndDecelerating");    [_scrollView setContentOffset:CGPointMake(0, 500) animated:YES];}
// 当滚动视图动画完成后,调用该方法,如果没有动画,那么该方法将不被调用- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView{    NSLog(@"scrollViewDidEndScrollingAnimation");    // 有效的动画方法为:    //    - (void)setContentOffset:(CGPoint)contentOffset animated:(BOOL)animated 方法    //    - (void)scrollRectToVisible:(CGRect)rect animated:(BOOL)animated 方法}
// 返回将要缩放的UIView对象。要执行多次- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView{    NSLog(@"viewForZoomingInScrollView");    return  self.imgView;}
// 当将要开始缩放时,执行该方法。一次有效缩放,就只执行一次。- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view{    NSLog(@"scrollViewWillBeginZooming");}
// 当缩放结束后,并且缩放大小回到minimumZoomScale与maximumZoomScale之间后(我们也许会超出缩放范围),调用该方法。- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(float)scale{    NSLog(@"scrollViewDidEndZooming");}
// 指示当用户点击状态栏后,滚动视图是否能够滚动到顶部。需要设置滚动视图的属性:_scrollView.scrollsToTop=YES;- (BOOL)scrollViewShouldScrollToTop:(UIScrollView *)scrollView{    return YES;}
// 当滚动视图滚动到最顶端后,执行该方法- (void)scrollViewDidScrollToTop:(UIScrollView *)scrollView{    NSLog(@"scrollViewDidScrollToTop");}

Tip:判断uiscrollview是向上滚动还是向下滚动

int _lastPosition;    //A variable define in headfile  - (void)scrollViewDidScroll:(UIScrollView *)scrollView{      int currentPostion = scrollView.contentOffset.y;      if (currentPostion - _lastPosition > 25) {          _lastPosition = currentPostion;          NSLog(@"ScrollUp now");      }      else if (_lastPosition - currentPostion > 25)      {          _lastPosition = currentPostion;          NSLog(@"ScrollDown now");      }  }// 25 可以是任意数字,可根据自己的需要来设定。
// 升级版:到达顶部或底部时不会反弹
- (void)scrollViewDidScroll:(UIScrollView *)scrollView
{
    int currentPostion = scrollView.contentOffset.y;

    if (currentPostion - _lastPosition > 20  && currentPostion > 0) {       //这个地方加上 currentPostion > 0 即可)
        _lastPosition = currentPostion;

        NSLog(@"ScrollUp now");
    }
    else if ((_lastPosition - currentPostion > 20) && (currentPostion  <= scrollView.contentSize.height-scrollView.bounds.size.height-20) ){
        _lastPosition = currentPostion;

        NSLog(@"ScrollDown now");
    }
}





0 0
原创粉丝点击