//自定义布局,继承于UICollectionViewLayout

#import <UIKit/UIKit.h>

@class WaterFlowLayout;

@protocol  WaterFlowLayoutDeleagre ;

@interface WaterFlowLayout : UICollectionViewLayout

@property (nonatomic,weak)id<WaterFlowLayoutDeleagre>delegate;

@end

@protocol WaterFlowLayoutDeleagre <NSObject>

@required

- (CGFloat)collectionView:(__kindof UICollectionView *)collectionView heightForItemAtIndexPath:(NSIndexPath *)indexPath;

@end

-------------------------------------------------------------------------

#import "WaterFlowLayout.h"

static  CGFloat const  coloumMarginDefault = 10;  //间隙

static NSInteger const coloumDefault = 3; //这里可以更改列数

static CGFloat const rowMaginDegault = 10;   //行之间的间隙

@interface WaterFlowLayout ()

@property (nonatomic,strong)NSMutableArray *   attris;

@property (nonatomic,strong)NSMutableArray * cloumsHeight;

@end

@implementation WaterFlowLayout

//记录没列cell的最大Y值

- (NSMutableArray *)cloumsHeight

{

if (_cloumsHeight == nil) {

_cloumsHeight = [NSMutableArray array];

}

return _cloumsHeight;

}

//存放每个cell的属性值

- (NSMutableArray *)attris

{

if (_attris == nil) {

_attris = [NSMutableArray array];

}

return _attris;

}

//准备开始布局

- (void)prepareLayout

{

[super prepareLayout];

//布局开始之前清空所有的列高度

[self.cloumsHeight removeAllObjects];

//为列高度添加初始值

for (int i=0; i<coloumDefault; i++) {

[self.cloumsHeight addObject:@0];

}

//获取对应组的cell个数

NSInteger count  = [self.collectionView  numberOfItemsInSection:0];

NSMutableArray * atts = [NSMutableArray array];

//创建cell的布局属性

for (int i=0; i<count; i++) {

//获取collectionview中对应indexpath的cell属性

UICollectionViewLayoutAttributes * attributes   =   [self  layoutAttributesForItemAtIndexPath:[NSIndexPath indexPathForItem:i inSection:0]];

[atts addObject:attributes];

}

self.attris = atts;

}

- (nullable NSArray<__kindof UICollectionViewLayoutAttributes *> *)layoutAttributesForElementsInRect:(CGRect)rect{

//返回所有cell的布局属性

return   self.attris;

}

- (UICollectionViewLayoutAttributes*)layoutAttributesForItemAtIndexPath:(NSIndexPath *)indexPath

{

//初始化布局属性

UICollectionViewLayoutAttributes * attributes = [UICollectionViewLayoutAttributes layoutAttributesForCellWithIndexPath:indexPath];

//让纪律每列高度中的数组的第一个数据为最小值

CGFloat minHeight = [self.cloumsHeight[0]  floatValue];

//记录的列号

NSInteger   cloum  =0;

//取出最小高度的列

for ( NSInteger i=1; i<self.cloumsHeight.count; i++) {

if (minHeight > [self.cloumsHeight[i]  floatValue]) {

minHeight = [self.cloumsHeight[i]  floatValue];

cloum =i;

}

}

//计算宽度

CGFloat W = (self.collectionView.frame.size.width - coloumMarginDefault * (coloumDefault + 1))/ coloumDefault;

//计算高度

CGFloat H = [self.delegate collectionView:self.collectionView heightForItemAtIndexPath:indexPath];

//计算cell的x值

CGFloat X = coloumMarginDefault + (W +  coloumMarginDefault) *cloum;

//计算cell的Y值

CGFloat Y = minHeight + rowMaginDegault;

attributes.frame = CGRectMake(X, Y, W, H);

//更新记录每列高度的数组

[self.cloumsHeight   replaceObjectAtIndex:cloum withObject:@(CGRectGetMaxY(attributes.frame) )];

return attributes;

}

//返回collectionview的滚动范围

- (CGSize)collectionViewContentSize

{

CGFloat maxHeight = 0;

for (int i=0; i<self.cloumsHeight.count; i++) {

if (maxHeight < [self.cloumsHeight[i]  floatValue]) {

maxHeight =[self.cloumsHeight[i]  floatValue];

}

}

return     CGSizeMake(0, maxHeight);

}

@end

-----------------------------------------------------------------------------------------------如此即可------------------------------------------------

iOS开发瀑布流的实现的更多相关文章

  1. ios开发瀑布流框架的应用

    一:瀑布流框架的应用:将封装好的瀑布流框架导入,遵守协议 二:代码: #import "HMShopsViewController.h" #import "HMShopC ...

  2. ios开发瀑布流框架的封装

    一:瀑布流框架封装的实现思路:此瀑布流框架的封装仿照tableView的底层实现,1:每个cell的frame的设置都是找出每列的最大y值,比较每列的最大y值,将下一个cell放在最大y值最小的那一列 ...

  3. iOS基础 - 瀑布流

    一.瀑布流简介 瀑布流,又称瀑布流式布局.是比较流行的一种网站页面布局,视觉表现为参差不齐的多栏布局,随着页面滚动条向下滚动,这种布局还会不断加载数据块并附加至当前尾部.最早采用此布局的网站是Pint ...

  4. iOS横向瀑布流的封装

    前段时间, 做一个羡慕, 需要使用到瀑布流! 说道瀑布流, 或许大家都不陌生, 瀑布流的实现也有很多种! 从scrollView 到 tableView 书写的瀑布流, 然后再到2012年iOS6 苹 ...

  5. ios图片瀑布流代码

    ios瀑布流,实现简单的瀑布流视图布局,可以显示网络图片,下拉刷新,上拉加载更多. 下载:http://www.huiyi8.com/sc/9087.html

  6. iOS - UICollectionView 瀑布流 添加表头视图的坑

    UICollectionView 瀑布流 添加表头视图的坑 首先是,需求加了个头视图在顶部,在collectionView中的头视图跟TableView的不一样,TableView的表头只要设置tab ...

  7. 堆糖瀑布流完整解决方案(jQuery)

    2010年堆糖创办以来,网站界面经历过3-5次重大改版,logo也曾更换过两次,早期蓝红相间三个圈的logo恐怕很少有人记得了.与此同时,前端 js 框架也在默默的更新换代.最早堆糖上线时,js 采用 ...

  8. jQuery动态网格瀑布流插件Masonry

    Masonry是一款非常强大的jQuery动态网格布局插件,可以帮助开发人员快速开发瀑布流界面效果.和CSS中float的效果不太一样的地方在于,float先水平排列,然后再垂直排列,使用Masonr ...

  9. iOS开发之窥探UICollectionViewController(四) --一款功能强大的自定义瀑布流

    在上一篇博客中<iOS开发之窥探UICollectionViewController(三) --使用UICollectionView自定义瀑布流>,自定义瀑布流的列数,Cell的外边距,C ...

随机推荐

  1. 试图解释下ERP

    ERP,字面的意思就是企业资源规划.但现在基本上是企业信息系统的统称,过去叫MIS.我们就是有这个本事,不管什么高大上的事物,很快就会做的很烂. 你可以这样理解ERP. 现在来了个订单,你需要回答下面 ...

  2. eclipse安装

    1.下载破解版本 地址:http://www.oyksoft.com/soft/1250.html 2.解压下载包,直接运行eclipse.exe  3.安装过程中如果遇到问题 1).如果遇到erro ...

  3. Linux环境快速搭建RocketMQ双Master模式

    RocketMQ的集群部署方式有多种,其中包括单个Master.多个Master.多Master多Slave模式(异步复制)以及多Master多Slave模式(同步双写).本次以多Master集群模式 ...

  4. 【.NET-EF】Entity Framework学习笔记1 - VS2013没有EF的解决方法

    解决方法:我本来也没有,百度了一下,在C:\ProgramData\Package Cache\{08AEF86A-1956-4846-B906-B01350E96E30}v12.0.20912.0\ ...

  5. Windows/Linux 生成iOS证书及p12文件

    操作步骤 生成csr文件(通过OpenSSL命令) 生成mobileprovision文件(通过Apple开发者后台) 生成cer文件(通过Apple开发者后台) 生成P12文件(通过OpenSSL命 ...

  6. windows server 2008系统VPN服务配置

    转自:http://www.softxp.net/article/win2008-vpn/,,仅作自己的笔记用 Windows sever 2008 R2的NPS(network policy ser ...

  7. php 常量定义

    php常量定义及取值  常量在定义时赋值:  不能变 :不能销毁: 具有超全局作用于:常量只能储存标量数据(字符 整型 浮点 ): <?php define("hello", ...

  8. c++ 随手记

    强类型的理解 先定义一些基础概念 Program Errors trapped errors.导致程序终止执行,如除0,Java中数组越界访问 untrapped errors. 出错后继续执行,但可 ...

  9. PHP奇怪现象

    <?php $a = 0.29; $b = (int)($a*100); echo $b; //输出28,PHP版本5.6.24 echo 0.1 + 0.2 - 0.3; //输出5.5511 ...

  10. JAVA的if用法,比如if(...){} 和if()没有大括号直接写下面的区别是什么

    有大括号的时候 大括号里面所有的 都归if管.只有条件为真的时候 才会执行.没有大括号的时候 只有下面的一句归if管,也就是说 当只有一句的时候 大括号可以省略 其它的 没区别.