UIScrollView

  • UIScrollView的用法很简单
    • 将需要展示的内容添加到UIScrollView中
    • 设置UIScrollView的contentSize属性,告诉UIScrollView所有内容的尺 寸,也就是告诉它滚动的范围(能滚多远,滚到哪里是尽头)

  • 如果UIScrollView无法滚动,可能是以下原因:
    • 没有设置contentSize
    • scrollEnabled = NO
    • 没有接收到触摸事件:userInteractionEnabled = NO
    • 没有取消autolayout功能(如果在Storyboard中添加了ScrollView的子控件,要想scrollView滚动,必须取消autolayout)

@property(nonatomic) CGPoint contentOffset;

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

@property(nonatomic) CGSize contentSize; 

这个属性用来表示UIScrollView内容的尺寸,滚动范围(能滚多远)

@property(nonatomic) UIEdgeInsets contentInset; 

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


利用UIScrollView 展示下面的大图片
详细图片


@property(nonatomic) BOOL bounces;

这个用来设置UIScrollView是否需要弹簧效果

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

这个用来设置UIScrollView是否能滚动

@property(nonatomic) BOOL showsHorizontalScrollIndicator;

这个用来是否显示水平滚动条

@property(nonatomic) BOOL showsVerticalScrollIndicator;

这个用来是否显示垂直滚动条

内容缩放

缩放

  • 当用户在UIScrollView身上使用捏合手势时,UIScrollView会调用代理的viewForZoomingInScrollView:方法,这个方法返回的控件就是需要进行缩放的控件
  • 缩放实现的步骤
    • 设置UIScrollView的id delegate代理对象
      • 设置minimumZoomScale :缩小的最小比例
      • 设置maximumZoomScale :放大的最大比例
      • 让代理对象实现下面的方法,返回需要缩放的视图控件
- (UIView *)viewForZoomingInScrollView:(UIScrollView *)scrollView;

跟缩放相关的代理方法

  • 准备开始缩放的时候调用
 - (void)scrollViewWillBeginZooming:(UIScrollView *)scrollView withView:(UIView *)view
  • 正在缩放的时候调用
- (void)scrollViewDidZoom:(UIScrollView *)scrollView

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

  • 当前的页码

@property(nonatomic) NSInteger currentPage; 

NSTimer

  • NSTimer叫做“定时器”,它的作用如下
    • 在指定的时间执行指定的任务
    • 每隔一段时间执行指定的任务
  • 调用下面的方法就会开启一个定时任务
+ (NSTimer *)scheduledTimerWithTimeInterval:(NSTimeInterval)ti target:(id)aTarget selector:(SEL)aSelector userInfo:(id)userInfo repeats:(BOOL)yesOrNo;
  • 每隔ti秒,调用一次aTarget的aSelector方法,yesOrNo决定了是否重复执行这个任务
  • 通过invalidate方法可以停止定时器的工作,一旦定时器被停止了,就不能再次执行任务。只能再创建一个新的定时器才能执行新的任务
- (void)invalidate;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值