//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"); }