• 图片无限轮播-最简单的实现方法


    collectionView中仅仅有三个cell 每次显示的都是第二个cell


    - (UICollectionViewCell *)collectionView:(UICollectionView *)collectionView cellForItemAtIndexPath:(NSIndexPath *)indexPath {

        

        CycleViewCell *cell = [collectionView dequeueReusableCellWithReuseIdentifier:@"Cell" forIndexPath:indexPath];

        //indexPath.item - 1 相当于index左移加右移减一

       //indexPath.item - 1 假设左移就相当于要显示第三个cell 2-1  ,相当于self.currentIndex + 1

       //indexPath.item - 1 假设右移就相当于要显示第一个cell 0-1  。相当于self.currentIndex - 1

        NSInteger index = (self.currentIndex + indexPath.item - 1 + self.imageURLs.count) % self.imageURLs.count;

        

        cell.imageURL = self.imageURLs[index];

        

        return cell;

    }


    // 在滚动视图全然停止滚动后会调用的方法

    - (void)scrollViewDidEndDecelerating:(UIScrollView *)scrollView {

        

        // 1. 依据contentOffset能够推断出停留住的页面

        int page = scrollView.contentOffset.x / scrollView.bounds.size.width;

        NSLog(@" %d ", page);

        

        // 2. 假设是第0页,self.currentIndex - 1,假设是第2,self.currentIndex +1;

        self.currentIndex = (self.currentIndex + page - 1 + self.imageURLs.count) % self.imageURLs.count;

        

        // 3. collection滚动会第一个页面

        NSIndexPath *indexPath = [NSIndexPath indexPathForItem:1 inSection:0];

        [self.collectionView scrollToItemAtIndexPath:indexPath atScrollPosition:UICollectionViewScrollPositionCenteredHorizontally animated:NO];

    }

  • 相关阅读:
    C#面向对象 类的继承
    C#面向对象 类的封装
    C#面向对象 类
    C#面向对象 1
    盒子模型、网页自动居中、float浮动与清除、横向两列布局
    HTML格式与布局
    HTML表单 CSS样式
    HTML—标签与表格 、框架
    触发器,视图
    while 循环,存储过程
  • 原文地址:https://www.cnblogs.com/cxchanpin/p/7398899.html
Copyright © 2020-2023  润新知