iOS之简单瀑布流的实现

前言

超简单的瀑布流实现,这里说一下笔者的思路,详细代码在这里

效果演示

实现思路

collectionView能实现各中吊炸天的布局,其精髓就在于UICollectionViewLayout,因此我们要自定义一个layout来继承系统的UICollectionViewLayout,所有工作都在这个类中进行

1.定义所需属性

瀑布流的思路就是,从上往下,那一列最短,就把下一个item放在哪一列,因此我们需要定义一个字典来记录每一列的最大y值

每一个item都有一个attributes,因此定义一个数组来保存每一个item的attributes

我们还必须知道有多少列以及列间距、行间距、section到collectionView的边距

2.重写系统方法

我们一共需要重写4个方法
a.- (void)prepareLayout
b.- (CGSize)collectionViewContentSize
c.- (UICollectionViewLayoutAttributes *)layoutAttributesForItemAtIndexPath:(NSIndexPath *)indexPath
d.- (NSArray *)layoutAttributesForElementsInRect:(CGRect)rect

– (void)prepareLayout 方法

布局前的一些准备工作都在这里进行
初始化字典,有几列就有几个键值对,key为第几列,value为列的最大y值,初始值为上内边距

创建每个item的attributes,并存入数组

– (CGSize)collectionViewContentSize 方法

用来计算collectionView的contentSize

一般瀑布流只能垂直滚动,不能水平滚动,因此contentSize.width = 0,我们只需要计算contentSize.height即可

从字典中找出最长列的最大y值,再加上下面的内边距,即为contentSize.height

– (UICollectionViewLayoutAttributes *)layoutAttributesForItemAtIndexPath:(NSIndexPath *)indexPath 方法

该方法则用来设置每个item的attributes,在这里,我们只需要简单的设置每个item的attributes.frame即可

首先我们必须得知collectionView的尺寸,然后我们根据collectionView的宽度,以及列数、各个间距来计算每个item的宽度

item的宽度 = (collectionView的宽度 – 内边距及列边距) / 列数

接下来计算item的坐标,要想计算坐标,那就必须知道最短的那一列,先遍历字典,找出最短列是哪一列(minColumn)以及其最大y值

item的y值就等于最短列的最大y值再加上行间距,x值就等于左边距 + (item宽度 + 列间距) * minColumn

接下来便是item的高度,我们应该根据图片的原始尺寸以及计算出来的宽度,等比例缩放来计算高度,但是在layout类中,我们是拿不到图片的,因此我们可以定义一个block属性,或者代理,让外界来计算并返回给我们,我们需要将item的宽度以及indexPath传递给外界

根据返回值来设置item的高度

最后设置attributes的frame并更新字典

– (NSArray *)layoutAttributesForElementsInRect:(CGRect)rect 方法

该方法用来返回rect范围内,item的attributes
直接返回attributesArray即可

使用

布局类写完了,接下来就可以直接使用了

具体代码请到这里下载https://github.com/codingZero/XRWaterfallLayout,觉得不错的,请献上你的star

1 2 收藏 1 评论

相关文章

可能感兴趣的话题



直接登录
最新评论
  • 感谢分享!对于这个刚学这个的非常好用,就是在创建头视图怎么不调用协议方法,这是为什么

跳到底部
返回顶部