iOS使用UICollectionView完成简单的cover flow效果

之前我想用iOS完成安卓的 gallery 效果 我想到了cover flow 效果
最近在找工作比较闲就把这个效果给大家分享下

下面这个效果想必大家都能使用UIColletionView实现

最基本的.gif

上面的效果是我之前写的小demo在demo里面的注释中可以看到我的思路
那么问题来了这么让两个cell重叠并且让中间的cell显示在最上面呢?

让cell重叠的方案:

// 在flowlayout类中的这个方法中可以获得attributes 对象
// 在这个方法中, 我们只要根据当前的滚动, 对每个cell, 进行对应的缩放就可以了
- (NSArray<UICollectionViewLayoutAttributes *> *)layoutAttributesForElementsInRect:(CGRect)rect

// 在获取到cell的attributes对象后对cell的size进行放大
  attr.size = CGSizeMake(self.itemSize.width * 1.5, self.itemSize.height * 1.5);

让居中的cell的展现在最前面的解决方案是
在collectionView滚动的时候 移动collectionView的子控件使其位于collection 的center点的cell置顶

注意:一定要转换坐标系不然获取不到中心点的cell


#pragma mark - didScorll

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

    // 坐标系转换获得collectionView上面的位于中心的cell
    CGPoint pointInView = [self.view convertPoint:self.collectionView.center toView:self.collectionView];
    // 获取这一点的indexPath
    NSIndexPath *indexPathNow = [self.collectionView indexPathForItemAtPoint:pointInView];

    GLCell *cell = (GLCell *)[self.collectionView cellForItemAtIndexPath:indexPathNow];

    [self.collectionView bringSubviewToFront:cell];
}

效果图

画廊.gif

demo下载地址:https://github.com/daleiLV/iOSCoverFlow

如有什么纰漏大家在评论中指出我会改正

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 前言 iOS里的UI控件其实没有几个,界面基本就是围绕那么几个控件灵活展开,最难的应属UICollectionVi...
    alenpaulkevin阅读 32,130评论 9 176
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 173,834评论 25 709
  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,262评论 4 61
  • 《血战钢锯岭》讲述的是二战时美日于太平洋最后一战,军医戴斯蒙德·道斯的经历。一个拒服兵役者,主动报名参军却因为拒绝...
    三岁就浪阅读 238评论 0 0
  • (一) 那一年我23岁,大学刚毕业,带着新人的虎劲儿和对新生活的新鲜感,开始新的旅途。 那时候,更多的是追求展示自...
    妄言人阅读 265评论 0 0