標籤:style blog io ar color os sp for strong
#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=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詳解