UIScrollView

    移动设备的屏幕大小是极其有限的, 因此直接展示在用户眼前的内容也相当有限. 当展示的内容较多, 超出一个屏幕时,用户可通过滚动手势来查看屏幕以外的内容.

    普通的UIView不具备滚动功能, 不能显示过多的内容. UIScrollView是一个能够滚动的视图控件,可以用来展示大量的内容, 并且可以通过滚动查看所有的内容.



UIScrollView的用法

    1> 将需要展示的内容添加到UIScrollView中;

    2>设置UIScrollView的contentSize属性, 告诉UIScrollView所有内容的尺寸,也就是告诉它滚动的范围.



UIScrollView无法滚动的解决办法

UIScrollView无法滚动, 可能是以下原因:

    1> 没有设置contentSize ;

    2> scrollEnabled = NO ;

    3> 没有接收到触摸事件: userInteractionEnabled = NO ;

    4> 没有取消autolaout功能(要想scrollView滚动 ,必须取消autolayout) .



UIScrollView的代理(delegate)    

UIScrollView正在滚动或滚动到某个位置或者停止滚动时做一些特性的操作,要想完成这些功能,前提条件就是能够监听到UIScrollView的整个滚动过程.

UIScrollView发生一系列的滚动操作时,会自动通知它的代理(delegate)对象, 给它的代理发送相应的消息,让代理得知它的滚动情况.

UIScrollView的滚动过程, 就必须先给UIScrollView设置一个代理对象, 然后通过代理得知UIScrollView的滚动过程 .

    在OC中,发送消息的意思就是调用方法.

UIScrollView的delegate, 就必须实现对应的方法才能监听UIScrollView的滚动过程.



成为delegate的条件

UIScrollView将delegate需要实现的方法都定义在了UIScrollViewDelegate协议中, 因此要想成为UIScrollView的delegate, 必须遵守UIScrollViewDelegate协议 ,然后实现协议中相应的方法, 就可以监听UIScrollView的滚动过程了.

UIScrollView和控制器

UIScrollView所在的控制器为UIScrollView的delegate : self.scrollView.delegate = self ;然后,控制器应该遵守UIScrollViewDelegate协议.最后,实现协议中定义的相关方法.



UIScrollView的常见属性

@property(nonatomic) CGPoint contentOffset;
@property(nonatomic) CGPoint contentOffset;

    这个属性用来表示UIScrollView滚动的位置 ;

@property(nonatomic) CGSize contentSize
@property(nonatomic) CGSize contentSize

    这个属性用来表示UIScrollView内容的尺寸, 滚动范围.

@property(nonatomic) UIEdgeInsets contentInset;
@property(nonatomic) UIEdgeInsets contentInset;

    这个属性能够在UIScrollView的四周增加额外的滚动区域;

@property(nonatomic) BOOL bounces;
@property(nonatomic) BOOL bounces;

    设置UIScrollView是否需要弹簧效果;

@property(nonatomic,getter=isScrollEnabled) BOOL scrollEnabled;
@property(nonatomic,getter=isScrollEnabled) BOOL scrollEnabled;

UIScrollView是否能滚动;

@property(nonatomic) BOOL showsHorizontalScrollIndicator;
@property(nonatomic) BOOL showsHorizontalScrollIndicator;

    是否显示水平滚动条;

@property(nonatomic) BOOL showsVerticalScrollIndicator;
@property(nonatomic) BOOL showsVerticalScrollIndicator;

    是否显示垂直滚动条;



内容缩放

UIScrollView中.



UIScrollView缩放原理

UIScrollView身上使用捏合手势时,UIScrollView会给代理发送一条消息,询问代理究竟要缩放自己内部的哪一个子控件(哪一块内容).

-(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView;
-(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView;

    当用户在UIScrollView身上使用捏合手势时,UIScrollView会调用代理的上述方法,这个方法返回的控件就是需要进行缩放的控件.



缩放实现步骤

UIScrollView的 id<UIScrollViewDelegate> delegate代理对象.

    2> 设置minimumZoomScale :缩小的最小比例

    3> 设置maxmumZoomScale :放大的最大比例

    4> 让代理对象实现下面的方法, 返回需要缩放的视图控件

-(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView;
-(UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView;



跟缩放相关的其他代理方法

    1> 缩放完毕的时候调用

-(void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view
-(void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view

    2> 正在缩放的时候调用

-(void)scrollViewDidZoom:(UIScrollView *)scrollView
-(void)scrollViewDidZoom:(UIScrollView *)scrollView



分页

UIScrollView的pageEnabled属性设置为YES, UIScrollView会被分割成多个独立页面, 里面的内容就能进行分页展示.一般会配合UIPageControl增强分页效果,UIPageControl常用属性如下:

@property(nonatomic) NSInteger numberOfPages;  // 一共有多少页
@property(nonatomic) NSInteger currentPage;    // 当前显示的页码
@property(nonatomic) BOOL hidesForSinglePage;  // 只有一页时,是否需要隐藏页码指示器
@property(nonatomic,retain) UIColor *pageIndicatorTintColor; //其他页码指示器的颜色
@property(nonatomic,retain) UIColor *currentPageIndicatorTintColor; //当前页码指示器的颜色
@property(nonatomic) NSInteger numberOfPages;  // 一共有多少页
@property(nonatomic) NSInteger currentPage;    // 当前显示的页码
@property(nonatomic) BOOL hidesForSinglePage;  // 只有一页时,是否需要隐藏页码指示器
@property(nonatomic,retain) UIColor *pageIndicatorTintColor; //其他页码指示器的颜色
@property(nonatomic,retain) UIColor *currentPageIndicatorTintColor; //当前页码指示器的颜色



定时器NSTimer   

    1> 在指定的时间执行指定的任务;

    2> 每隔一段时间执行指定的任务.

    调用下面的方法就会开启一个定时任务

+ (NSTimer *)scheduledTimerWithTimeInterval:(NSTimeInterval)ti   target:(id)aTarget 
  selector:(SEL)aSelector 
  userInfo:(id)userInfo 
  repeats:(BOOL)yesOrNo;
+ (NSTimer *)scheduledTimerWithTimeInterval:(NSTimeInterval)ti   target:(id)aTarget 
  selector:(SEL)aSelector 
  userInfo:(id)userInfo 
  repeats:(BOOL)yesOrNo;

    每隔ti秒, 调用一次aSelector方法, yesOrNo决定了是否重复执行这个任务.

    通过invalidate方法可以停止定时器的工作, 一旦定时器被停止了 ,就不能再次执行任务. 只能再创建一个新的定时器才能执行新的任务.

-(void)invalidate;
-(void)invalidate;



UIScrollView的常用方法汇总

/**
     *  这个属性用来表示UIScrollView滚动的位置
     */
    @property(nonatomic) CGPoint contentOffset;
   
     /**
     *  这个属性用来表示UIScrollView内容的尺寸,滚动范围(能滚多远)
     */
    @property(nonatomic) CGSize contentSize;
    
    /**
     *  这个属性能够在UIScrollView的4周增加额外的滚动区域
     */
    @property(nonatomic) UIEdgeInsets contentInset;
   
    /**
     *  总体内容的范围(滚动范围)
     */
    
    self.scrollView.contentSize = self.minionView.frame.size;
    
    /**
     *  增加额外的滚动区域(顶部增加64,底部增加44的区域)
     */
    
    self.scrollView.contentInset = UIEdgeInsetsMake(64,0,44,0);
    
    /**
     *  设置一开始的滚动位置(往下滚动64)
     */
    self.scrollView.contentOffset = CGPointMake(0,-64);
  
    /**
     *  设置内容尺寸
     */
    self.scrollView.contentSize = self.minionView.frame.size;
    
    /**
     *  设置代理
     */
    self.scrollView.delegate = self;
    
    /**
     *  设置最大/最小的缩放比例
     */
    self.scrollView.maximumZoomScale = 2.0;
    self.scrollView.minimumZoomScale = 0.2;
 
    /**
     *  当用户开始拖拽scrollView时就会调用
     */
    - (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
    {
        NSLog(@"开始拖拽-----");
    }
 
    /**
     *  只要scrollView正在滚动,就会调用
     */
    - (void)scrollViewDidScroll:(UIScrollView *)scrollView
    {
        NSLog(@"----正在滚动--%@", NSStringFromCGPoint(scrollView.contentOffset));
    }
 
    /**
     *  当用户使用捏合手势时会调用此方法,没有实现此方法时,scrollView不会被缩放
     *
     *  @param scrollView 被缩放的图片
     *
     *  @return 返回的控件就是需要进行缩放的控件
     */
    - (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView
    {
        NSLog(@"----开始缩放");
        return self.minionView;
    }
 
    /**
     *  正在缩放的时候会调用
     */
    - (void)scrollViewDidZoom:(UIScrollView *)scrollView
    {
        NSLog(@"----正在缩放");
    }
    /**
     *  这个属性用来表示UIScrollView滚动的位置
     */
    @property(nonatomic) CGPoint contentOffset;
   
     /**
     *  这个属性用来表示UIScrollView内容的尺寸,滚动范围(能滚多远)
     */
    @property(nonatomic) CGSize contentSize;
    
    /**
     *  这个属性能够在UIScrollView的4周增加额外的滚动区域
     */
    @property(nonatomic) UIEdgeInsets contentInset;
   
    /**
     *  总体内容的范围(滚动范围)
     */
    
    self.scrollView.contentSize = self.minionView.frame.size;
    
    /**
     *  增加额外的滚动区域(顶部增加64,底部增加44的区域)
     */
    
    self.scrollView.contentInset = UIEdgeInsetsMake(64,0,44,0);
    
    /**
     *  设置一开始的滚动位置(往下滚动64)
     */
    self.scrollView.contentOffset = CGPointMake(0,-64);
  
    /**
     *  设置内容尺寸
     */
    self.scrollView.contentSize = self.minionView.frame.size;
    
    /**
     *  设置代理
     */
    self.scrollView.delegate = self;
    
    /**
     *  设置最大/最小的缩放比例
     */
    self.scrollView.maximumZoomScale = 2.0;
    self.scrollView.minimumZoomScale = 0.2;
 
    /**
     *  当用户开始拖拽scrollView时就会调用
     */
    - (void)scrollViewWillBeginDragging:(UIScrollView *)scrollView
    {
        NSLog(@"开始拖拽-----");
    }
 
    /**
     *  只要scrollView正在滚动,就会调用
     */
    - (void)scrollViewDidScroll:(UIScrollView *)scrollView
    {
        NSLog(@"----正在滚动--%@", NSStringFromCGPoint(scrollView.contentOffset));
    }
 
    /**
     *  当用户使用捏合手势时会调用此方法,没有实现此方法时,scrollView不会被缩放
     *
     *  @param scrollView 被缩放的图片
     *
     *  @return 返回的控件就是需要进行缩放的控件
     */
    - (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView
    {
        NSLog(@"----开始缩放");
        return self.minionView;
    }
 
    /**
     *  正在缩放的时候会调用
     */
    - (void)scrollViewDidZoom:(UIScrollView *)scrollView
    {
        NSLog(@"----正在缩放");
    }