美文网首页
UIScrollView+PageControl实现分页效果

UIScrollView+PageControl实现分页效果

作者: 彼岸的黑色曼陀罗 | 来源:发表于2016-08-22 23:27 被阅读0次
    • 分页功能(重点)
      • 如果图片名称有规律,尺寸也有规律,那么可以用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实现分页效果

          本文链接:https://www.haomeiwen.com/subject/cbmgsttx.html