1.简单认识
瀑布流,又称瀑布流式布局。是比较流行的一种网站页面布局,视觉表现为参差不齐的多栏布局,随着页面滚动条向下滚动,这种布局还会不断加载数据块并附加至当前尾部。最早采用此布局的网站是Pinterest,逐渐在国内流行开来。
data:image/s3,"s3://crabby-images/13666/136665b5bff9671cbab215666a27e6aeb74dd23c" alt=""
2.3种实现的方法
data:image/s3,"s3://crabby-images/6d4a0/6d4a055c148ea7c49d676e1ba6a0cb49aab4c431" alt=""
data:image/s3,"s3://crabby-images/85ef4/85ef406bb25da9fe4e18e793cf2445f75e260008" alt=""
data:image/s3,"s3://crabby-images/7afd6/7afd61b24dac667b3b13a7666efd2cc0efcd3343" alt=""
3.详解UICollectionView实现瀑布流
精髓就在于UICollectionViewLayout,因此我们要自定义一个layout来继承系统的UICollectionViewLayout,所有工作都在这个类中进行
3.1定义所需要的属性
瀑布流的思路就是,从上往下,那一列最短,就把下一个item放在哪一列,因此我们需要定义一个字典来记录每一列的最大y值;
每一个item都有一个attributes,因此定义一个数组来保存每一个item的attributes;
我们还必须知道有多少列以及列间距、行间距、section到collectionView的边距。
data:image/s3,"s3://crabby-images/82944/82944e207adfbf970f1f4abd6e03fda1123a93db" alt=""
data:image/s3,"s3://crabby-images/522ff/522ff95f3d8080d42d7ff48e5cbcbd8cd304ca63" alt=""
3.2可能需要写的4个方法
原理详细看文章:http://www.jianshu.com/p/b92e1b1073fd
data:image/s3,"s3://crabby-images/7b980/7b98074b5f500c2fcfeca02371b87acd17a64cdf" alt=""
3.3例子
自定义Layout:
data:image/s3,"s3://crabby-images/6153e/6153e4610b3e21a95e441c1d560e5a70a6edf0b1" alt=""
data:image/s3,"s3://crabby-images/ba59d/ba59d8acff9b9a59c974593fb754152dc850679b" alt=""
data:image/s3,"s3://crabby-images/608fa/608fad55f9cdd3801875b42e1bbc11666271594f" alt=""
调用的控制器:
data:image/s3,"s3://crabby-images/748de/748de09141e3707754dc7e4cf74e9f3d5babca65" alt=""
效果:
data:image/s3,"s3://crabby-images/637bf/637bffc26d46e5e586f3731a914863344c86957f" alt=""
4.第三库实现瀑布流
CHTCollectionViewWaterfallLayout
https://github.com/chiahsien/CHTCollectionViewWaterfallLayout
控制器中代码:(cell...代码不展示了)
data:image/s3,"s3://crabby-images/6d309/6d30991bbaaba7b1fc36cda5e28453631e51218e" alt=""
data:image/s3,"s3://crabby-images/88132/88132d809cffb2ccbc4bd48839fac585fb36f3d7" alt=""
data:image/s3,"s3://crabby-images/deb01/deb01779cef14e3ff8c6da1a58cbd14d80fef01f" alt=""
效果:
data:image/s3,"s3://crabby-images/7cddf/7cddf1e1e8c2430d3ab5de36a394aed5b56c151b" alt=""
data:image/s3,"s3://crabby-images/f0a44/f0a44ee0f543620e6748b772f4857af519dd484d" alt=""
XRWaterfallLayout
https://github.com/codingZero/XRWaterfallLayout
网友评论