首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

iOS 瀑布封装

[瀑布.gif] 功能描述:WSLWaterFlowLayout 是在继承于UICollectionViewLayout的基础上封装的带头脚视图的瀑布控件。...目前支持竖向瀑布(item等宽不等高、支持头脚视图)、水平瀑布(item等高不等宽 不支持头脚视图)、竖向瀑布( item等高不等宽、支持头脚视图)三种样式的瀑布流布局。...下面是WSLWaterFlowLayout.h中的属性方法和代理方法,含义注释的还算清晰: typedef enum { WSLVerticalWaterFlow = 0, /** 竖向瀑布...item等宽不等高 */ WSLHorizontalWaterFlow = 1, /** 水平瀑布 item等高不等宽 不支持头脚视图*/ WSLVHWaterFlow = 2, /...*/ @property (nonatomic, assign) WSLFlowLayoutStyle flowLayoutStyle; @end 初始化仅三行代码,只需设置代理和样式,item的大小

1.6K80
您找到你想要的搜索结果了吗?
是的
没有找到

iOS 瀑布封装

瀑布.gif 功能描述:WSLWaterFlowLayout 是在继承于UICollectionViewLayout的基础上封装的带头脚视图的瀑布控件。...目前支持竖向瀑布(item等宽不等高、支持头脚视图)、水平瀑布(item等高不等宽 不支持头脚视图)、竖向瀑布( item等高不等宽、支持头脚视图)三种样式的瀑布流布局。...下面是WSLWaterFlowLayout.h中的属性方法和代理方法,含义注释的还算清晰: typedef enum { WSLVerticalWaterFlow = 0, /** 竖向瀑布...item等宽不等高 */ WSLHorizontalWaterFlow = 1, /** 水平瀑布 item等高不等宽 不支持头脚视图*/ WSLVHWaterFlow = 2, /...*/ @property (nonatomic, assign) WSLFlowLayoutStyle flowLayoutStyle; @end 初始化仅三行代码,只需设置代理和样式,item的大小

2K80

iOS 瀑布实现「建议收藏」

UICollectionViewDelegateFlowLayout的可选方法,它里面有一个我们自己定义的 imageNewSizeWitholdWidth 的方法,我们用这个方法来对图片按照我们的想法进行压缩,具体公式在代码的注释块中...10,10,10,10};//内边距的集合,依次是上,左,下,右(逆时针) @interface WaterfallFlowLayout : UICollectionViewFlowLayout @end 可以从上面的代码中看到...array]; //初始化cell信息的字典 _cellInfoDic = [NSMutableDictionary dictionary]; //设置代理为主控制器,我们的瀑布是继承于系统的流式布局...既然要实现实现瀑布,就需要比较每一列的高度,然后把要插入的item插入到高度最小的那一列去。因此,我们需要比较每一列的高度,找出最小列。...这就和之前找最短一列道理是一样的,这里直接上代码了。

2K41

分享:纯 css 瀑布 和 js 瀑布

博客地址:https://ainyi.com/60 分享一次纯 css 瀑布  和 js 瀑布 纯 css 写瀑布 1.multi-columns 方式: 通过 Multi-columns 相关的属性...-- more items --> 51 .masonry 是瀑布容器,里面放置了列表 item,在 .masonry 中设置 column-count...看到这里,我们可以发现,使用纯 css 写瀑布,每一块 item 都是从上往下排列,不能做到从左往右排列: ? 这样子若是动态加载图片的瀑布,体验就会很不好 我们想要的是这样: ?...这样做只能通过 js 来写瀑布 js 写瀑布: html 结构与上面类似,这里我用图片来做示例: 1 2 <...这实现了横向排列的瀑布效果 欢迎浏览 GitHub:https://github.com/Krryxa 博客地址:https://ainyi.com/60

8.7K40

分享一次纯 css 瀑布 和 js 瀑布

博客地址:https://ainyi.com/60 现在百度图片,360 图片搜索,都是以一种瀑布的形式展示,那么接下来,分享一波纯 css 瀑布 和 js 瀑布 纯 css 写瀑布 multi-columns...-- more items --> .masonry 是瀑布容器,里面放置了列表 item,在 .masonry 中设置 column-count(列数) 和 column-gap(列间距...max-width: 500px) { .masonry { column-count: 1; /* two columns on larger phones */ } } 那么以上代码产生的效果是...,每一块 item 都是从上往下排列,不能做到从左往右排列: [kc4aje4u6f.jpeg] 这样子若是动态加载图片的瀑布,体验就会很不好 我们想要的是这样: [no351tx20r.jpeg]...要实现如上,只能通过 js 来写瀑布 js 写瀑布 html 结构与上面类似,但这里我用图片来做示例

2.3K40

图片瀑布,so easy!

什么是图片瀑布 用一张花瓣网页的图片布局可以很清楚看出图片瀑布的样子: ?...简单来说,就是有很多图片平铺在页面上,每张图片的宽度相同,但是高度不同,这样错落有致的排列出 n 列的样子很像瀑布,于是就有了瀑布图片一说。...实现原理 1、第一种方式 第一种方式前提是:图片的宽度固定,但是列可变(根据屏幕大小) 通过上面的介绍,我们知道要实现瀑布的前提是宽度一致(假如为100px),高度可以不相同。...实现代码 下面是未处理的原始代码,图片之间间隔很多空白,影响美观。 <!...200px) let imgWidth = $('img').outerWidth(); // 200 waterfallHandler(); // 瀑布处理

1.6K10

iOS开发之窥探UICollectionViewController(三) --使用UICollectionView自定义瀑布

本篇博客就不使用自带的流式布局了,我们要自定义一个瀑布。自定义的瀑布可以配置其参数: 每个Cell的边距,共有多少列,Cell的最大以及最小高度是多少等。...看图吧,关于瀑布的效果就不啰嗦了。以下的效果就是使用自定义布局做的,接下来将会介绍一下其实现原理。 ? 二. ...接下来要使用自定义布局来实现瀑布。...瀑布实现关键点如下:    (1)Cell宽度计算:如果瀑布的列数和Cell的Padding确定了,那么每个Cell的宽度再通过屏幕的宽度就可以计算出来了。    ...本篇博客中Demo的配置项先写死就OK了,还是那句话,下篇博客中会给出一些相应的代理,来定制我们的瀑布

1.2K100

(转)iOS开发之UICollectionViewController系列(三) :UICollectionView自定义瀑布

本篇博客就不使用自带的流式布局了,我们要自定义一个瀑布。自定义的瀑布可以配置其参数: 每个Cell的边距,共有多少列,Cell的最大以及最小高度是多少等。...看图吧,关于瀑布的效果就不啰嗦了。以下的效果就是使用自定义布局做的,接下来将会介绍一下其实现原理。 ? 二....接下来要使用自定义布局来实现瀑布。...瀑布实现关键点如下: (1)Cell宽度计算:如果瀑布的列数和Cell的Padding确定了,那么每个Cell的宽度再通过屏幕的宽度就可以计算出来了。...参考文章: iOS开发之窥探UICollectionViewController(三) --使用UICollectionView自定义瀑布

5.9K40
领券