首页 > 代码库 > iOS UiScrollViewDelegate详解
iOS UiScrollViewDelegate详解
#pragma mark - UIScrollViewDelegate 委托
1、 scrollView滚动时,就调用该方法。任何offset值改变都调用该方法。即滚动过程中,调用多次
//scrollView滚动时,就调用该方法。任何offset值改变都调用该方法。即滚动过程中,调用多次- (void)scrollViewDidScroll:(UIScrollView *)scrollView{ NSLog(@"scrollViewDidScroll"); CGPoint point=scrollView.contentOffset; NSLog(@"%f,%f",point.x,point.y); // 从中可以读取contentOffset属性以确定其滚动到的位置。 // 注意:当ContentSize属性小于Frame时,将不会出发滚动}
2、 当scrollView缩放时,调用该方法。在缩放过程中,回多次调用
// 当scrollView缩放时,调用该方法。在缩放过程中,回多次调用- (void)scrollViewDidZoom:(UIScrollView *)scrollView{ NSLog(@"scrollViewDidScroll"); float value=http://www.mamicode.com/scrollView.zoomScale; NSLog(@"%f",value);}
3、 当开始滚动视图时,执行该方法。一次有效滑动(开始滑动,滑动一小段距离,只要手指不松开,只算一次滑动),只执行一次
// 当开始滚动视图时,执行该方法。一次有效滑动(开始滑动,滑动一小段距离,只要手指不松开,只算一次滑动),只执行一次。- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView{ NSLog(@"scrollViewWillBeginDragging");}
4、 滑动scrollView,并且手指离开时执行。一次有效滑动,只执行一次
// 滑动scrollView,并且手指离开时执行。一次有效滑动,只执行一次。// 当pagingEnabled属性为YES时,不调用,该方法- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset{ NSLog(@"scrollViewWillEndDragging");}
5、 滑动视图,当手指离开屏幕那一霎那,调用该方法。一次有效滑动,只执行一次
// 滑动视图,当手指离开屏幕那一霎那,调用该方法。一次有效滑动,只执行一次。// 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);}
6、 滑动减速时调用该方法
// 滑动减速时调用该方法。- (void)scrollViewWillBeginDecelerating:(UIScrollView *)scrollView{ NSLog(@"scrollViewWillBeginDecelerating"); // 该方法在scrollViewDidEndDragging方法之后。}
7、 滚动视图减速完成,滚动将停止时,调用该方法。一次有效滑动,只执行一次
// 滚动视图减速完成,滚动将停止时,调用该方法。一次有效滑动,只执行一次。- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView{ NSLog(@"scrollViewDidEndDecelerating"); [_scrollView setContentOffset:CGPointMake(0, 500) animated:YES];}
8、 当滚动视图动画完成后,调用该方法,如果没有动画,那么该方法将不被调用
// 当滚动视图动画完成后,调用该方法,如果没有动画,那么该方法将不被调用- (void)scrollViewDidEndScrollingAnimation:(UIScrollView *)scrollView{ NSLog(@"scrollViewDidEndScrollingAnimation"); // 有效的动画方法为: // - (void)setContentOffset:(CGPoint)contentOffset animated:(BOOL)animated 方法 // - (void)scrollRectToVisible:(CGRect)rect animated:(BOOL)animated 方法}
9、 返回将要缩放的UIView对象。要执行多次
// 返回将要缩放的UIView对象。要执行多次- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView{ NSLog(@"viewForZoomingInScrollView"); return self.imgView;}
10、 当将要开始缩放时,执行该方法。一次有效缩放,就只执行一次
// 当将要开始缩放时,执行该方法。一次有效缩放,就只执行一次。- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view{ NSLog(@"scrollViewWillBeginZooming");}
11、 当缩放结束后,并且缩放大小回到minimumZoomScale与maximumZoomScale之间后(我们也许会超出缩放范围),调用该方法
// 当缩放结束后,并且缩放大小回到minimumZoomScale与maximumZoomScale之间后(我们也许会超出缩放范围),调用该方法。- (void)scrollViewDidEndZooming:(UIScrollView *)scrollView withView:(UIView *)view atScale:(float)scale{ NSLog(@"scrollViewDidEndZooming");}
12、 指示当用户点击状态栏后,滚动视图是否能够滚动到顶部。需要设置滚动视图的属性:_scrollView.scrollsToTop=YES
// 指示当用户点击状态栏后,滚动视图是否能够滚动到顶部。需要设置滚动视图的属性:_scrollView.scrollsToTop=YES;- (BOOL)scrollViewShouldScrollToTop:(UIScrollView *)scrollView{ return YES;}
13、 当滚动视图滚动到最顶端后,执行该方法
// 当滚动视图滚动到最顶端后,执行该方法- (void)scrollViewDidScrollToTop:(UIScrollView *)scrollView{ NSLog(@"scrollViewDidScrollToTop");}
iOS UiScrollViewDelegate详解
声明:以上内容来自用户投稿及互联网公开渠道收集整理发布,本网站不拥有所有权,未作人工编辑处理,也不承担相关法律责任,若内容有误或涉及侵权可进行投诉: 投诉/举报 工作人员会在5个工作日内联系你,一经查实,本站将立刻删除涉嫌侵权内容。