iOS开发瀑布流的实现
//自定义布局,继承于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开发瀑布流的实现的更多相关文章
- ios开发瀑布流框架的应用
一:瀑布流框架的应用:将封装好的瀑布流框架导入,遵守协议 二:代码: #import "HMShopsViewController.h" #import "HMShopC ...
- ios开发瀑布流框架的封装
一:瀑布流框架封装的实现思路:此瀑布流框架的封装仿照tableView的底层实现,1:每个cell的frame的设置都是找出每列的最大y值,比较每列的最大y值,将下一个cell放在最大y值最小的那一列 ...
- iOS基础 - 瀑布流
一.瀑布流简介 瀑布流,又称瀑布流式布局.是比较流行的一种网站页面布局,视觉表现为参差不齐的多栏布局,随着页面滚动条向下滚动,这种布局还会不断加载数据块并附加至当前尾部.最早采用此布局的网站是Pint ...
- iOS横向瀑布流的封装
前段时间, 做一个羡慕, 需要使用到瀑布流! 说道瀑布流, 或许大家都不陌生, 瀑布流的实现也有很多种! 从scrollView 到 tableView 书写的瀑布流, 然后再到2012年iOS6 苹 ...
- ios图片瀑布流代码
ios瀑布流,实现简单的瀑布流视图布局,可以显示网络图片,下拉刷新,上拉加载更多. 下载:http://www.huiyi8.com/sc/9087.html
- iOS - UICollectionView 瀑布流 添加表头视图的坑
UICollectionView 瀑布流 添加表头视图的坑 首先是,需求加了个头视图在顶部,在collectionView中的头视图跟TableView的不一样,TableView的表头只要设置tab ...
- 堆糖瀑布流完整解决方案(jQuery)
2010年堆糖创办以来,网站界面经历过3-5次重大改版,logo也曾更换过两次,早期蓝红相间三个圈的logo恐怕很少有人记得了.与此同时,前端 js 框架也在默默的更新换代.最早堆糖上线时,js 采用 ...
- jQuery动态网格瀑布流插件Masonry
Masonry是一款非常强大的jQuery动态网格布局插件,可以帮助开发人员快速开发瀑布流界面效果.和CSS中float的效果不太一样的地方在于,float先水平排列,然后再垂直排列,使用Masonr ...
- iOS开发之窥探UICollectionViewController(四) --一款功能强大的自定义瀑布流
在上一篇博客中<iOS开发之窥探UICollectionViewController(三) --使用UICollectionView自定义瀑布流>,自定义瀑布流的列数,Cell的外边距,C ...
随机推荐
- springboot学习笔记-1 第一个springboot示例
springboot是一个微框架,其设计的目的是为了简化spring框架的搭建和配置过程.从而使开发人员不再需要定义样板化的配置.下面是springboot的入门案例:它演示了利用springboot ...
- B树、B-树、B+树、B*树详解
注:本文为个人学习摘录,原文地址:http://www.blogjava.net/supercrsky/articles/185167.html B树 即二叉搜索树: 1.所有非叶子结点至多拥有两个儿 ...
- EXCEL 数字统一转换成文本
将excel中的数字统一转换成文本形式.即添加‘. 1.点击数据-分列. 2.分隔符号-下一步. 3.选择文本识别符号,如“‘”分号. 4. 选中文本-完成.
- memcahced缓存特点
1.key-value数据结构 2.所有数据保存在内存中 3.可以分布式集群 4.处理并发的机制是libevent事件机制 5.当内容容量达到指定值后,就基于LRU(Least Recently Us ...
- How I Mathematician Wonder What You Are!(poj 3130)
题意:求问多边形的核(能够看到所有点的点)是否存在. /* 对于这样的题目,我只能面向std编程了,然而还是不理解. 算法可参考:http://www.cnblogs.com/huangxf/p/40 ...
- linux/windows平台生成随机数的不同方法
linux平台,使用rand.Seed() //rand_linux.go package main import ( "math/rand" "time" ) ...
- STM32F2系列系统时钟默认配置
新到一家公司后,有个项目要用到STM32F207Vx单片机,找到网上的例子照猫画虎的写了几个例子,比如ADC,可是到了ADC多通道转换的时候就有点傻眼了,这里面的时钟跑的到底是多少M呢?单片机外挂的时 ...
- Python学习笔记——基础篇【第五周】——正则表达式(re)
目录 1.简介 2.字符匹配 1.简介:就其本质而言,正则表达式(或 RE)是一种小型的.高度专业化的编程语言,(在Python中)它内嵌在Python中,并通过 re 模块实现.正则表达式模式被编译 ...
- spring+springmvc+maven+mybatis整合
jar包依赖:网址search.maven.org 1.spring :spring-core 2. myhabits:myhabits 3.整合spring和myhabits: ...
- Elastarchsearch安装搭建(一)
Elasticsearch是一个实时分布式搜索和分析引擎.一个基于Apache Lucene(TM)的开源搜索引擎.无论在开源还是专有领域,Lucene可以被认为是迄今为止最先进.性能最好的.功能最全 ...