UIScrollView詳解


設置一個可以滾動的UISCrollView:

  • 必須設置contentSize(可滾動的范圍)
//創(chuàng)建UIIamgeView
UIImageView *imageView = [[UIImageView alloc] initWithImage:[UIImage imageNamed:@"1.jpg"]];
self.imageView = imageView;
[self.scrollView addSubview:imageView];
//設置scrollView的滾動范圍
self.scrollView.contentSize = self.imageView.frame.size;

隱藏滾動條:

self.scrollView.showsHorizontalScrollIndicator = NO;
self.scrollView.showsVerticalScrollIndicator = NO;

設置內(nèi)邊距

self.scrollView.contentInset = UIEdgeInsetsMake(10, 20, 40, 80);

設置縮放系數(shù)

self.scrollView.maximumZoomScale = 2.0;
self.scrollView.minimumZoomScale = 0.2;

UIScrollView相關屬性

@property(nonatomic) CGPoint contentOffset:這個屬性用來表示UIScrollView滾動的位置,(其實就是內(nèi)容左上角與scrollView左上角的間距值)
@property(nonatomic) CGSize contentSize:這個屬性用來表示UIScrollView內(nèi)容的尺寸,滾動范圍(能滾多遠)
@property(nonatomic) UIEdgeInsets contentInset:這個屬性能夠在UIScrollView的4周增加額外的滾動區(qū)域,一般用來避免scrollView的內(nèi)容被其他控件擋住

UIScrollView相關屬性簡介

如果UIScrollView無法滾動,可能是以下原因:

  • 沒有設置contentSize
  • scrollEnabled = NO
  • 沒有接收到觸摸事件:userInteractionEnabled = NO,等原因

UIScrollView其他屬性

@property(nonatomic) BOOL bounces
設置UIScrollView是否需要彈簧效果
@property(nonatomic,getter=isScrollEnabled) BOOL scrollEnabled
設置UIScrollView是否能滾動
@property(nonatomic) BOOL showsHorizontalScrollIndicator
是否顯示水平滾動條
@property(nonatomic) BOOL showsVerticalScrollIndicator
是否顯示垂直滾動條

UIScrollView的代理

  • 很多時候,我們想在UIScrollView正在滾動 或 滾動到某個位置 或者 停止?jié)L動 時做一些特定的操作
  • 要想完成上述功能,前提條件就是能夠監(jiān)聽到UIScrollView的整個滾動過程
  • 當UIScrollView發(fā)生一系列的滾動操作時, 會自動通知它的代理(delegate)對象,給它的代理發(fā)送相應的消息,讓代理得知它的滾動情況
  • 也就是說,要想監(jiān)聽UIScrollView的滾動過程,就必須先給UIScrollView設置一個代理對象,然后通過代理得知UIScrollView的滾動過程
代理

成為delegate的條件

UIScrollView將delegate需要實現(xiàn)的方法都定義在了UIScrollViewDelegate協(xié)議中,因此要想成為UIScrollView的delegate,必須遵守UIScrollViewDelegate協(xié)議,然后實現(xiàn)協(xié)議中相應的方法,就可以監(jiān)聽UIScrollView的滾動過程了


相關代理方法

//只要scrollView在滾動,就會調(diào)用這個方法(監(jiān)聽scrollView的滾動)
- (void)scrollViewDidScroll:(UIScrollView *)scrollView;

//用戶即將開始拖拽scrollView,就會調(diào)用這個方法
- (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView;

//用戶即將停止拖拽scrollView,就會調(diào)用這個方法
- (void)scrollViewWillEndDragging:(UIScrollView *)scrollView withVelocity:(CGPoint)velocity targetContentOffset:(inout CGPoint *)targetContentOffset;

//用戶已經(jīng)停止拖拽scrollView,就會調(diào)用這個方法
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate
{
    if (decelerate == NO) {
        NSLog(@"scrollView停止?jié)L動,完全靜止");
    } else {
        NSLog(@"用戶停止拖拽,但是scrollView由于慣性,會繼續(xù)滾動,并且減速");
    }
}

//scrollView已經(jīng)停止減速,就會調(diào)用這個方法(停止?jié)L動)
- (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView;

UIScrollView的縮放原理

  • 當用戶在UIScrollView身上使用捏合手勢時,UIScrollView會給代理發(fā)送一條消息,詢問代理究竟要縮放自己內(nèi)部的哪一個子控件(哪一塊內(nèi)容)


    pinch
  • 當用戶在UIScrollView身上使用捏合手勢時,UIScrollView會調(diào)用代理的viewForZoomingInScrollView:方法,這個方法返回的控件就是需要進行縮放的控件

  • 縮放實現(xiàn)步驟:

設置UIScrollView的delegate代理對象
設置minimumZoomScale :縮小的最小比例
設置maximumZoomScale :放大的最大比例
讓代理對象實現(xiàn)下面的方法,返回需要縮放的視圖控件:

-(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView;
  • 跟縮放相關的其他代理方法:
  • 縮放完畢的時候調(diào)用
- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view
  • 正在縮放的時候調(diào)用
- (void)scrollViewDidZoom:(UIScrollView *)scrollView

UIPageControl常用屬性

//一共有多少頁
@property(nonatomic) NSInteger numberOfPages;
//當前顯示的頁碼
@property(nonatomic) NSInteger currentPage; 
//只有一頁時,是否需要隱藏頁碼指示器
@property(nonatomic) BOOL hidesForSinglePage; 
//其他頁碼指示器的顏色
@property(nonatomic,retain) UIColor *pageIndicatorTintColor;
//當前頁碼指示器的顏色
@property(nonatomic,retain) UIColor *currentPageIndicatorTintColor;

NSTimer

  • 作用:
    • 在指定的時間執(zhí)行指定的任務
    • 每隔一段時間執(zhí)行指定的任務
  • 開啟定時器:
//每隔ti秒,調(diào)用一次aTarget的aSelector方法,yesOrNo決定了是否重復執(zhí)行這個任務
+ (NSTimer *)scheduledTimerWithTimeInterval:(NSTimeInterval)ti  target:(id)aTarget 
    selector:(SEL)aSelector 
    userInfo:(id)userInfo 
    repeats:(BOOL)yesOrNo;
  • 停止定時器:
//通過invalidate方法可以停止定時器的工作,一旦定時器被停止了,就不能再次執(zhí)行任務。只能再創(chuàng)建一個新的定時器才能執(zhí)行新的任務
[self.timer invalidate];
  • 解決定時器在主線程不工作的問題:
NSTimer *timer = [NSTimer timerWithTimeInterval:2 target:self selector:@selector(next) userInfo:nil repeats:YES];
[[NSRunLoop mainRunLoop] addTimer:timer forMode:NSRunLoopCommonModes];
最后編輯于
?著作權歸作者所有,轉載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內(nèi)容