iOS无限轮播Banner案例与原理分析

我们经常会遇到需要做无限轮播Banner的需求,仔细分析一下,可以拆分为两个需求:

  • 可以自动滚动到下一页
  • 不管是向前或者向后,永远有下一页

需求一:自动滚动

原理:通过定时任务来实现自动滚动
实现方式有很多种,例如GCD,NSTimer等,具体实现方式这里不展开说明了,简单写几个例子:
GCD的使用

// GCD实现定时任务
dispatch_source_t timer;
    timer = dispatch_source_create(DISPATCH_SOURCE_TYPE_TIMER, 0, 0,dispatch_get_global_queue(DISPATCH_QUEUE_PRIORITY_DEFAULT, 0));
    dispatch_source_set_timer(timer,
                              dispatch_time(DISPATCH_TIME_NOW, 5*NSEC_PER_SEC),
                              5*NSEC_PER_SEC,
                              0);
    dispatch_source_set_event_handler(timer, ^{
        dispatch_suspend(timer);
    });
    dispatch_resume(timer);

NSTimer的使用

// NSTimer
- (void)startTimer {
    [self stopTimer];
    self.repeatTimer = [NSTimer scheduledTimerWithTimeInterval:3 target:self selector:@selector(scrollToNextPage) userInfo:nil repeats:YES];
}

- (void)stopTimer {
    [self.repeatTimer invalidate];
    self.repeatTimer = nil;
}

- (void)scrollToNextPage {
    // scroll to next page
}

需求二:永远有上一页/下一页

网上比较常见的有两种方案:

1、UICollectionView

为CollectionView返回一个比较大的itemCount,然后通过取余计算来实现cell的循环展示
为实现假的可以无限上下滚动,所以会将初始化的位置放到itemCount的中间位置
优点:可以比较流畅的上下滚动
缺点:有边界,假无限(可以通过返回更大的itemCount来优化,由于collectionView的重用机制,并不会过多消耗内存),如果真到边界时,需要复位,否则会卡住
综上,推荐使用这种方式来实现,设置一个比较大的itemCount之后,只要不是鸡蛋里挑骨头,可以说是“无限”循环

2、UIScrollView

使用UIScrollView又有两种思路:
具体实现请参考https://www.jianshu.com/p/5847021bebc2
①滚动后重新布局,然后滚动到中间位置

  1. 定义≥3页的内容


    1
  2. 滚动到中间+1页


    2
  3. 后台修改页面内容,滚动到中间页(无动画)


    3

    ②滚动动画完成后,调整到合适的位置
    滑到左边图3后,后台滚动到右边图3位置
    滑到右边图0时,后台滚动到左边图0位置


    image.png

优点:真的可以无限滑动
缺点:滑动不松手的话,会有边界

©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • Bg:图片轮播器数不胜数,但大多是UIScrollView + OC实现的,心血来潮,决定用Swift+UICol...
    星辰大海_王阅读 8,557评论 3 10
  • Swift1> Swift和OC的区别1.1> Swift没有地址/指针的概念1.2> 泛型1.3> 类型严谨 对...
    cosWriter阅读 13,880评论 1 32
  • 最近心情一直不好,压力大,老公孩子觉得没有一个省心,孩子成绩下滑,学习始终不专心,且跟小伙伴在一块时常发点小情绪,...
    加油淡然阅读 1,301评论 0 1
  • 公司:路易彬彦 【日精进打卡第172天】 【知~学习】 《六项精进》1遍共148遍 《大学》0遍共57遍 《通篇》...
    路易彬彥张娟阅读 1,238评论 0 0

友情链接更多精彩内容