01-UI基础-04-00-UIScrollView

若如初见. 提交于 2019-12-05 19:34:30

##继承关系

##1、 基本概念 ###1.1 什么是UIScrollView

  • 移动设备的屏幕大小是有限的,现在直接展示用户眼前的内容也相当有限
  • 砀山是的内容较多,超出一个屏幕时,用户可通过滚动手势来查看屏幕以为的内容
  • 普通的UIView是不具备滚动功能,不能显示过多内容
  • UIScrollView是一个能滚动的可视化控件,可以用来展示内容,并且用来展示大量的内容,并且可以通过滚动查看所有内容
  • 举例:手机上的“设置”

###1.2 UIScrollView的基本使用

  • 将需要展示的内容添加到UIScrollView中
  • 设置UIScrollView的contentSize属性,告诉UIScrollView所有内容的尺寸,也就是告诉他滚动范围

###1.3 无法滚动的解决办法

  • 没有设置contentSize属性
  • scrollEnabled = NO
  • 没有接收到触发事件:userInteractionEnabled = NO
  • 没有取消autolayout功能

##2、 UIScrollView代理(delegate) ###2.1 基本常识

  • 很多时候,我们想在UIScrollView滚动到某个位置或者停止滚动的时候做一写特定的操作。
  • 要想完成上面的功能,前提条件就是实施监听到UiScrollView的整个滚动过程
  • 当UiScrollView发生一些列的滚动操作时,会自动通知它的代理(delegate)
  • 要想监听UIScrollView的滚动过程,就必须给UIScrollView设置一个代理对象,然后通知UIScrollView滚动的过程。
@property (nonatomic,assign) id <UIScrollViewDelegate>
  • UIScrollView与delegate之间的通讯应该为下图所示

可以看出,要想成为UIScrollView的得了gate必须实现对应方法才能监听UIScrollView的滚动过程
  • UIScrollView将delegate需要实现的放大都定义在UIScrollViewDelegate协议中,因此只要遵守UIScrollViewDelegate协议,然后实现协议中相应地方法,就可以监听UIScrollView的滚动过程。

###2.2 代理设计模式的好处

  1. 监听的思想:让一个对象A监听另一个对象B的状态
  2. 通知的思想:一个对象B发生改变,实时通知对象A

##3、 UIScrollView与控制器

  • 一般情况下,就设置UIScrollView所在的控制器为UIScrollView的delegate

  • 设置控制器为UIScrollView的delegate的方法有两种

    • 代码(selt就是控制器)
    	self.srollView.delegate = self; 
    
    • 通过storyboard拖线
  • 然后,控制器应该最受UIScrollViewDelegate协议

  • 最后,试下协议中定义的相关方法

##4、 UIScrollView的属性 ###4.1 基本属性

  • 这个属性用来表示UIScrollView的滚动位置
@peoperty (nonatomic) CGPoint contentOffset;
  • 这个属性用来表示UIScrollView内容尺寸,滚动范围
@peoperty (nonatomic) CGSize contentSize;
  • 这个属性能够在UIScrollView的4周增加额外的滚动区域
@peoperty (nonatomic) UIEdgeInsets contentInset;

###4.2 其他属性

  • 设置UIScrollView是否需要弹簧效果
@property(nonatomic) BOOL bounces;
  • 设置UIScrollView是否能滚动
@property(nonatomic,getter=isScrollEnabled) BOOL scrollEnabled; 
  • 是否显示水平滚动条
@property(nonatomic) BOOL showsHorizontalScrollIndicator;
  • 是否显示垂直滚动条
@property(nonatomic) BOOL showsVerticalScrollIndicator;

##5、 内容缩放 ###5.1 UIScrolView缩放原理

  • 当用户在UIScrollView上使用捏合手势时,UIScrollView会给代理发送一条消息,询问代理究竟要缩放自己内部的哪一个子控件(哪一块内容)
  • 当用户使用捏合手势时,UIScrollView会调用代理的viewForZoomingInScrollView:方法,这个方法放回的空间就是需要进行缩放的控件

###5.2 缩放的实现步骤

  1. 设置UIscrollView的id<UIScrollViewDelegate> delegate代理
  2. 设置minimumZoomScale,最小缩放比例
  3. 设置maximumZoonScale,最大缩放比例
  4. 让代理实现下面的方法,返回需要缩放的视图控件
- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView;

###5.3 跟缩放相关的其他方法

  • 缩放完毕时调用
- (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view;
  • 正在缩放时调用
- (void)scrollViewDidZoom:(UIScrollView *)scrollView

##6、 UIPageControl(分页)

  • 只要将UIScrollView的pageEable属性设置为YES,UIScrollView会被分割成多个独立的页面,里面的内容能进行分页展示

  • 一般配合UIPageControl增强分页效果,UIPageControl属性如下

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

##7、 NSTimer 计时器 ###7.1 作用

  • 在指定的时间执行指定的任务
  • 每隔一段时间执行指定的任务

###7.2 调用过程

  • 开启定时器
+ (NSTimer *)scheduledTimerWithTimeInterval:(NSTimeInterval)titarget:(id)aTarget
			 									selector:(SEL)aSelector
 												userInfo:(id)userInfo
			 									repeats:(BOOL)yesOrNo;
  • 停止定时器(通过invalidate方法可以停止定时器的工作,一旦定时器被停止,就不能再被执行任务。只能在创建一个新的定时器才能指向新的任务)
- (void)invalidate;
标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!