• 极限训练锻造“蓝军”利刃,精锐特战队员来了! 2019-11-15
  • 哈尔滨:推进统战工作“四化一体系”建设 2019-11-12
  • 蠢货!咱是让你们看看制订一个企业发展计划要达到哪些要求,难度有多大?一个具体的企业都这么难,大到一个县,一个省,甚至是一个国家,难度可想而知! 2019-11-12
  • 北京天安门广场更换花卉 2019-11-07
  • 《中国道路的成功密码》首发研讨会在京举行 2019-11-07
  • 王国平应邀赴金华市调研并作专题讲座 2019-11-04
  • 真正聪明之人,能在寻常岁月里悟透贞亲人世的惊喜 2019-11-04
  • 忻府区中医下乡进村  为老百姓健康把脉--黄河新闻网 2019-11-04
  • 法制日报:别让世界杯激情冲淡守法意识 2019-11-01
  • 美国又打出2000亿关税牌,中方这300字声明暗藏玄机! 2019-10-27
  • 《斯琴高丽的开心》首发 斯琴高丽给自己生日送礼斯琴高丽 2019-10-27
  • 隋炀帝萧后凤冠仿制品亮相 原件或为李世民赏赐 2019-10-26
  • 中国,向大洋更深处挺进(评论员观察) 2019-10-20
  • 《好色千金》杀青 高冷侍卫刘天宝获赞“武生担当” 2019-10-15
  • 海上洄游时 北海狗 连续两周深睡眠 2019-10-15
  • 香港马会平码:iOS Swift利用UICollectionView实现无限轮播功能(原理)详解

    平码三中山论坛 www.mslzq.tw 前言 作为一个资深(自认为…

    前言

    作为一个资深(自认为)iOS程序猿,会经常用到轮播图,上一次使用UIScrollView实现无限轮播的效果,这一次在Swift语言中,我使用UICollectionView再为大家讲解一次无限轮播的实现原理。

    先上图:


    UICollectionView-无限轮播.gif

    首先需要实现了就是UICollectionView的分页,这个很简单:

    collectionView.isPagingEnabled = true

    接下来就是原理,在UICollectionView的两端需要先添加两张图片,首段需要添加最后一张图片,而尾端需要添加第一张图片,然后在中间的位置上一次添加各个图片。这个其实是很容易实现的:

     func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
     let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "ImageCollectionViewCell", for: indexPath) as! ImageCollectionViewCell
     
     /// 给图片赋值(在首尾分别添加两张图片)
     if (indexPath.row == 0) {
      cell.imageName = imageNameList.last
     } else if (indexPath.row == self.imageNameList.count + 1) {
      cell.imageName = imageNameList.first
     } else {
      cell.imageName = imageNameList[indexPath.row - 1]
     }
     
     return cell
     }

    这样在滑动的时候,通过偏移量就可以实现无限轮播的效果了。当滑动停止时判断偏移量,当偏移量为0时(视图上显示的是最后一张图片),这时候就直接调动调整偏移量的方法,把UICollectionView偏移到最后一张图片的位置。滑动到尾端时是同理。

     func scrollViewDidEndDecelerating(_ scrollView: UIScrollView) {
     /// 当UIScrollView滑动到第一位停止时,将UIScrollView的偏移位置改变
     if (scrollView.contentOffset.x == 0) {
      scrollView.contentOffset = CGPoint(x: CGFloat(self.imageNameList.count) * kScreenWidth,y: 0)
      self.pageControl.currentPage = self.imageNameList.count
      /// 当UIScrollView滑动到最后一位停止时,将UIScrollView的偏移位置改变
     } else if (scrollView.contentOffset.x == CGFloat(self.imageNameList.count + 1) * kScreenWidth) {
      scrollView.contentOffset = CGPoint(x: kScreenWidth,y: 0)
      self.pageControl.currentPage = 0
     } else {
      self.pageControl.currentPage = Int(scrollView.contentOffset.x / kScreenWidth) - 1
     }
     }

    其实原理很简单,个人认为使用UICollectionView实现无限轮播比起UIScrollView更加实用并且便于维护,接下来我将代码全部列一下:

    import UIKit
    
    let kScreenWidth = UIScreen.main.bounds.width
    
    class ViewController: UIViewController {
     
     lazy var collectionView: UICollectionView = {
     let flowLayout = UICollectionViewFlowLayout()
     flowLayout.minimumLineSpacing = 0
     flowLayout.minimumInteritemSpacing = 0
     flowLayout.scrollDirection = .horizontal
     flowLayout.itemSize = CGSize(width: kScreenWidth, height: 200)
     
     let collectionView = UICollectionView(frame: CGRect(x: 0, y: 0, width: UIScreen.main.bounds.width, height: 200), collectionViewLayout: flowLayout)
     
     collectionView.isPagingEnabled = true
     collectionView.showsHorizontalScrollIndicator = false
     collectionView.backgroundColor = UIColor.white
     collectionView.delegate = self
     collectionView.dataSource = self
     self.view.addSubview(collectionView)
     
     return collectionView
     }()
     
     lazy var pageControl: UIPageControl = {
     let pageControl = UIPageControl(frame: CGRect(x: 0, y: 150, width: kScreenWidth, height: 50))
     
     pageControl.numberOfPages = self.imageNameList.count
     pageControl.currentPage = 0
     
     pageControl.tintColor = UIColor.black
     pageControl.pageIndicatorTintColor = UIColor.gray;
     
     return pageControl;
     }()
     
     lazy var imageNameList: [String] = {
     let imageList = ["image0", "image1", "image2", "image3"]
     
     return imageList
     }()
    
     override func viewDidLoad() {
     super.viewDidLoad()
     
     setupController()
     }
     
     func setupController() {
     /// 设置数据
     collectionView.register(ImageCollectionViewCell.self, forCellWithReuseIdentifier: "ImageCollectionViewCell")
     
     collectionView.reloadData()
     collectionView.scrollToItem(at: IndexPath(row: 1, section: 0), at: .left, animated: false)
     
     self.view.addSubview(pageControl)
     }
    
    }
    
    extension ViewController: UICollectionViewDataSource {
     
     func collectionView(_ collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
     /// 这步只是防止崩溃
     if (imageNameList.count == 0) {
      return 0
     }
     return imageNameList.count + 2
     }
     
     func collectionView(_ collectionView: UICollectionView, cellForItemAt indexPath: IndexPath) -> UICollectionViewCell {
     let cell = collectionView.dequeueReusableCell(withReuseIdentifier: "ImageCollectionViewCell", for: indexPath) as! ImageCollectionViewCell
     
     /// 给图片赋值(在首尾分别添加两张图片)
     if (indexPath.row == 0) {
      cell.imageName = imageNameList.last
     } else if (indexPath.row == self.imageNameList.count + 1) {
      cell.imageName = imageNameList.first
     } else {
      cell.imageName = imageNameList[indexPath.row - 1]
     }
     
     return cell
     }
     
    }
    
    extension ViewController: UICollectionViewDelegate {
     
     func scrollViewDidEndDecelerating(_ scrollView: UIScrollView) {
     /// 当UIScrollView滑动到第一位停止时,将UIScrollView的偏移位置改变
     if (scrollView.contentOffset.x == 0) {
      scrollView.contentOffset = CGPoint(x: CGFloat(self.imageNameList.count) * kScreenWidth,y: 0)
      self.pageControl.currentPage = self.imageNameList.count
      /// 当UIScrollView滑动到最后一位停止时,将UIScrollView的偏移位置改变
     } else if (scrollView.contentOffset.x == CGFloat(self.imageNameList.count + 1) * kScreenWidth) {
      scrollView.contentOffset = CGPoint(x: kScreenWidth,y: 0)
      self.pageControl.currentPage = 0
     } else {
      self.pageControl.currentPage = Int(scrollView.contentOffset.x / kScreenWidth) - 1
     }
     }
     
    }
    
    /// collectionView图片的cell
    class ImageCollectionViewCell: UICollectionViewCell {
     
     /// 显示的图片
     let imageView = UIImageView()
     var imageName: String? = "" {
     didSet {
      if let name = imageName {
      imageView.image = UIImage(named: name)
      }
     }
     }
     
     override init(frame: CGRect) {
     super.init(frame: frame)
     
     setupCell();
     }
     
     /// 初始化视图
     func setupCell() {
     imageView.frame = self.bounds
     contentView.addSubview(imageView)
     }
     
     required init?(coder aDecoder: NSCoder) {
     fatalError("init(coder:) has not been implemented")
     } 
    }

    ok,喜欢的话可以点一下收藏哈,用UIScrollView实现轮播的原理

    总结

    以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对CAD之家的支持。

    作者: 小编韬韬

    CAD爱好者,个人在2006年创建cad在线网站,收集学校cad相关教程,为了更好地与广大cad爱好者交流学习,目前重新建立cad之家网站。

    为您推荐

    发表评论

    联系我们

    联系我们

    18511713368

    在线咨询: QQ交谈

    邮箱: [email protected]

    工作时间:周一至周五,9:00-17:30,节假日休息//www.mslzq.tw
    关注微信
    微信扫一扫关注我们

    微信扫一扫关注我们

    关注微博
    返回顶部

    关于本站 || 版权声明 || 免责条款 || 隐私条款 || 平码三中山论坛 || ||

    Copyright??2018 平码三中山论坛 All Rights Reserved·黔ICP备15000265号-2

  • 极限训练锻造“蓝军”利刃,精锐特战队员来了! 2019-11-15
  • 哈尔滨:推进统战工作“四化一体系”建设 2019-11-12
  • 蠢货!咱是让你们看看制订一个企业发展计划要达到哪些要求,难度有多大?一个具体的企业都这么难,大到一个县,一个省,甚至是一个国家,难度可想而知! 2019-11-12
  • 北京天安门广场更换花卉 2019-11-07
  • 《中国道路的成功密码》首发研讨会在京举行 2019-11-07
  • 王国平应邀赴金华市调研并作专题讲座 2019-11-04
  • 真正聪明之人,能在寻常岁月里悟透贞亲人世的惊喜 2019-11-04
  • 忻府区中医下乡进村  为老百姓健康把脉--黄河新闻网 2019-11-04
  • 法制日报:别让世界杯激情冲淡守法意识 2019-11-01
  • 美国又打出2000亿关税牌,中方这300字声明暗藏玄机! 2019-10-27
  • 《斯琴高丽的开心》首发 斯琴高丽给自己生日送礼斯琴高丽 2019-10-27
  • 隋炀帝萧后凤冠仿制品亮相 原件或为李世民赏赐 2019-10-26
  • 中国,向大洋更深处挺进(评论员观察) 2019-10-20
  • 《好色千金》杀青 高冷侍卫刘天宝获赞“武生担当” 2019-10-15
  • 海上洄游时 北海狗 连续两周深睡眠 2019-10-15
  • 通化大嘴棋牌手机下载 澳洲幸运10开奖 双色球32元复式 北京赛车pk10雪球计划表 万人在线天天棋牌 任选9场奖金几点公布 河北11选5选号技巧 股票指数期权交易 甘肃十一选五走势图一定牛 大富翁棋牌app