//scrollView滾動時,就調用該方法。任何offset值改變都調用該方法。即滾動過程當中,調用屢次測試
(void)scrollViewDidScroll:(UIScrollView *)scrollView{動畫
NSLog(@"scrollViewDidScroll"); CGPoint point=scrollView.contentOffset; NSLog(@"%f,%f",point.x,point.y); // 從中能夠讀取contentOffset屬性以肯定其滾動到的位置。 // 注意:當ContentSize屬性小於Frame時,將不會出發滾動
}code
// 當scrollView縮放時,調用該方法。在縮放過程當中,回屢次調用對象
(void)scrollViewDidZoom:(UIScrollView *)scrollView{ci
NSLog(@"scrollViewDidScroll"); float value=scrollView.zoomScale; NSLog(@"%f",value);
}get
// 當開始滾動視圖時,執行該方法。一次有效滑動(開始滑動,滑動一小段距離,只要手指不鬆開,只算一次滑動),只執行一次。it
(void)scrollViewWillBeginDragging:(UIScrollView *)scrollView{io
NSLog(@"scrollViewWillBeginDragging");
}scroll
// 滑動scrollView,而且手指離開時執行。一次有效滑動,只執行一次。
// 當pagingEnabled屬性爲YES時,不調用,該方法float
(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");
}