当前位置:首页 > 代码 > 正文

ios瀑布流代码(瀑布流源码)

admin 发布:2022-12-19 09:20 105


本篇文章给大家谈谈ios瀑布流代码,以及瀑布流源码对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

iOS 多section瀑布流实现(swift)

 最近因项目需求,写了一个支持多 section 的瀑布流实现组件,完全基于 swift 5 来实现。

先来直接看效果图:

 (PS:瀑布流的实现原理其实挺简单的,网上现有的教程一抓一大把,我也懒得复述了。。。)

稍微整理了下,让这个小组件尽量做到集成简单快捷。

 因为基于 UICollectionViewFlowLayout 实现的,所以该 flowLayout 的初始化调用流程与系统的无异,只需要遵循 WaterfallMutiSectionDelegate 代理。

最后附上demo链接:

如果对你有帮助,记得点个 star。

iOS 使用UICollectionViewFlowLayout实现完美瀑布流.分区,增加,删除,刷新优化

最近在开发中需要实现瀑布流效果,便动手实现了下,将使用方法记录下,有不足之处也希望可以和大家沟通交流.

WaterLayout

实现瀑布流的使用的关键类是 UICollectionViewFlowLayout,如果我们不继承直接使用的话,系统已经帮我们实现了一些效果,比如横向或者竖向滑动,然后配置一些属性或者遵循UICollectionViewDelegateFlowLayout,来显示个性化的效果.但是有些布局需要我们去实现,比如瀑布流的效果.UICollectionViewFlowLayout非常强大,我们基本上可以任何我们想要的效果,在这里只说一下瀑布流的实现,其他效果可以根据这个来进行不同的变形和修改.

UICollectionViewFlowLayout描述

实现自定义布局的关键方法

其实上面三个返回布局的方法原理一样,就是根据在UICollectionViewFlowLayout属性配置或者代理方法中返回的属性系统所做的最原始计算,我们需要根据系统所计算的结果来修改成我们想要的结果,如果不适用系统的结果,直接使用自己计算的也是可以的.

下面说一下布局方面具体的使用:

我们的计算布局支持多分去,这里用字典sectionInfos储存多分区的计算信息.

计算原理如下,我们需要获取到存在几个分区,然后布局该分区内的每个item的信息

如果我们从上自下依次布局显示的话,那么应该是:

头视图-分区内每个item的信息-脚视图-然后装饰视图

装饰视图可以根据具体需求来计算,不一定在最后.在该效果中,我用绿色的背景来实现装饰视图,由于覆盖当前的分区,所以需要知道footer的计算结果,因此装饰视图的计算放在了最后,用来知道当前分区的Y轴最大值.

如果只需要实现这种布局,那么每个条目对应的系统可以就不可以不用重写.

在返回contentsize的方法中返回具体的大小

让我们的collectionview实现上面的代理方法,用来实现不同的布局配置,这样我们就可以像系统的布局代理一样,方便调用.下面看一下控制器中的实现,实现不同的代理方法,用来配置不同分区的内容显示

实现上面的方法,那么瀑布流的效果已经可以实现了.

下面说一下如何滑动到具体的分区,或者item位置.

实现上面的方法,我们可以灵活的滑动到任何元素的位置.

在控制器中调用,这里我们写死的第二个分区的第4个条目,方便测试

可以看到这里很精确的滑动到输入的位置.

下面说一下我们优化增加,删除和刷新效果

添加三个数组,用来实现不同的操作,系统有四种不同的操作事件.

下面看一下具体的实现:

这里我们实现了增加,删除和刷新条目的动画

这里要说下面,在增加条目的时候会调用的layoutAttributesForItem,返回的不是我们计算好的attribute,会导致显示动画异常,所以在这我们做额外的操作,如果已经有计算好的布局,那么执行使用,然后在增加的代理方法中实现具体的变化操作.现在我们的增加,删除实现可CGAffineTransform和alpha变化的效果,刷新实现了alpha变化的效果.如果需要实现其他的动画效果,可以根据这个来进行变化.

如有问题可以留言和大家沟通交流~~

iOS - 瀑布流简单的实现

初步接触UICollectionView的小伙伴们肯定都知道苹果官方为我们封装好的UICollectionViewFlowLayout,在很多情况下我们使用UICollectionViewFlowLayout就可以实现需求了。

下面的列子简单实用UICollectionViewFlowLayout实现效果

import "SWWaterFallLayout.h"

import "SWWaterFallLayout.h"

最后在控制器中实现将collectView的layout设置成自定义的layout其他不变,就行啦。。。。

吐槽:加班到爆炸啦~💥

关于ios瀑布流代码和瀑布流源码的介绍到此就结束了,不知道你从中找到你需要的信息了吗 ?如果你还想了解更多这方面的信息,记得收藏关注本站。

版权说明:如非注明,本站文章均为 AH站长 原创,转载请注明出处和附带本文链接;

本文地址:http://ahzz.com.cn/post/5867.html


取消回复欢迎 发表评论:

分享到

温馨提示

下载成功了么?或者链接失效了?

联系我们反馈

立即下载