UIScrollView+PageControl实现分页效果

  • 分页功能(重点)
    • 如果图片名称有规律,尺寸也有规律,那么可以用for循环 创建imageView

    • 设置contentSize = CGSizeMake (图片个数*W,H)

      • 细节:contentSize = CGSizeMake(图片个数*H,O)高度设置0也可以
      • O代表在垂直方向不能滚动
    • 隐藏滚动条

      • storyboard :showsHorzontal勾掉
      • 代码 :showsHorizontal
    • 开启分页功能:pagingEnabled = YES

      • 分页标准:以scrollView的尺寸为一页
    • 显示页码

      • storyboard:UIPage Control控件
        • 因为UIPage Control控件是scrollView的子控件会被scrollView挡住
        • UIPageControl和scrollView同层级,才不会被挡住
    • 监听滚动,改变页码

      • currentPage
      • 1.当scrollView停止滚动的时候显示页码(苹果)
        • scrollViewDidEndDraggin: willDecelerate:
          • decelerate == NO
            • 计算页码,设置页码
        • scrollViewDidEndDcelerating:
          • 计算页码: 偏移量的x值除以scrollView的宽度
          • 设置页码:currentPage = page
      • 2.哪边图片显示比例大,就滚动到哪一页(示例程序)
        • scrollViewDidScroll:
          • 四舍五入:(int)(小数 + 0.5)
          • page = (int) (contentOffset.x /scrollView.size.W + 0.5)
    • 手动设置总页数

      • numberOfPages = 图片个数
      • 图片个数为1时候,隐藏pageControl
        • 设置pageControl.alpha = 0.0
        • pageControl.hidden = YES
        • hidesForSinglePage = YES
    • pageControl显示自定义的图片

      • 当前页显示current
      • 其他页显示other
      • xcode6.4头文件中有成员变量
        - xcode6.4之后变成私有的属性
      • 私有:currentPageImage
      • 私有:pageImage
      • KVC:
        • self.pageControl setValue:[UIImage imageNamed:@"current"]forKeyPath:@"_currentPageImage"
        • self.pageControl setValue:[UIImage imageNamed:@"other"]forKeyPath:@"_pageImage"
    • 每隔一段时间滚动到下一页

      • 定时器:每隔一段时间做一件事情

        • [NSTimer scheduledTimerWithTimeInterval:target:selector:userInfo:repeats:YES]
      • 计算下一页页码:当前页码 + 1

        • currentPage + 1
        • setContentOffset: (页码*scrollView的宽度,0)animated:
  • 补充:
    • 定时器一直在工作,当用户想往前滚动的时候,图片却一直往后滚动
    • 当用户操作界面的时候,让定时器停止
      • scrollViewWillBeginDragging: 用户即将拖拽scrollView

        • 停止定时器
        • 定义定时器属性weak,内部有一个看不见的指针在引用
        • [self.timer invalidate]
        • self.timer = nil(属性是strong时才写)
      • scrollViewDidEndDragging:用户已经停止拖拽

        • 开启定时器
        • NSTimer scheduledTimerWithTimeInterval:
        • 开启定时器方法返回的是一个自动执行任务的定时器
      • 最好将开启定时器,停止定时器抽两个方法

      • 问题:频繁创建、销毁定时器对象

        • 定时器特点决定的
    • 注意定时器方法里,userInfo的作用
  • 线程
    • 线程:用来执行任务的
      • 特点:同一时间只能执行一个任务
    • 主线程:程序一启动,就会创建一条默认的线程
      • 作用:负责显示刷新UI界面,处理与用户的交互事件
    • [[NSRunloop mainRunloop] addTimer:self.timer forMode:NSRunLoopCommonModes]将定时器添加到runLoop中
      • 目的:不管主线程在做什么操作,都要分配一定的时间处理定时器
      • NSDefaultRunLoopMode:默认,同一时间只能执行一个任务
      • NSRunLoopCommonModes:公用,分配一定的事件处理其他任务
    • 多线程原理:1s——>一万个0.0001s
      • cpu在多个任务中来回快速切换
      • 感觉同时执行,那是假象

你可能感兴趣的:(UIScrollView+PageControl实现分页效果)