【iOS】如何在UICollection中实现特殊翻页动画效果
创始人
2025-05-28 21:59:10

需求:

实现类似下列的动画效果,要求,左右可以滚动UICollection浏览,向上滑动可以把当前图片丢进垃圾桶

特殊UICollection动画效果

技术点:

需要结合UIScrollView回调跟UIPanGestureRecognizer手势来实现
具体实现方法为:
1、对应的UICollection注册UIPanGestureRecognizer监听
2、在监听回调中判断三个状态
.began
.changed
.ended

其中.began我们添加两个View到当前画面上,一个是底部背景backgroundImage,一个是当前UICollectionView的画面screenImage,并设置为不可见,这是重点,不然会有频闪出现!

.changed
1)我们判断当前是否是左右滑动的,也就是y是否是>0(后面可以根据具体来调节这个参数),如果满足,首先将UIPanGestureRecognizer设置为不可用,然后移除掉之前的backgroundImagescreenImage正式进入左右划逻辑,判断如果左滑x是大于>20还是<-20来判断是左滑还是右滑!斌给钱break掉
2)如果判断y是<0,说明进入了上滑,这时候需要将backgroundImagescreenImage设置为可见,并且操作screenImage进行转换,具体代码可能为

let scale = 0.7 - abs(y)/kSHeight
tempImage.transform = CGAffineTransform(translationX: x*(1/scale), y: y*(1/scale)).concatenating(CGAffineTransform(scaleX: scale, y: scale)).concatenating(CGAffineTransform(rotationAngle: .pi/4*(0.7-scale)))

0.7这个系数可以根据自己来调节,上述代码可以实现偏离角度+上移+缩小,实现一个向上收纳的效果

.ended中,我们首先判断是否同时满足x > 20 && y < -40,可以认为他被移动到了右上角,然后进行丢入垃圾桶动画操作,并且移除掉backgroundImagescreenImage

其中UIPanGestureRecognizer什么时候设置为可用呢?
在UIScrollView的scrollViewDidEndDecelerating回调中,我们只需要重新设置UIPanGestureRecognizer可用就行!

至此,核心逻辑就说明完毕了。
其中有一些需要注意的点
比如如果是视频,怎么获取到视频的截图?
比如如何最大程度的减少发生频闪的情况?
比如具体系数怎么调整才能最大最优雅的实现滚动跟滑动?

相关内容

热门资讯

摩尔线程张建中和他的伙伴们 资料图。摩尔线程张建中和他的伙伴们谢露茜摩尔线程是一家全功能GPU芯片研发及AI计算解决方案提供商。...
快手“午夜惊魂”,4亿用户信任... 来源丨亿欧网撰文丨杜心怡12月22日深夜,一场猝不及防的大规模黑灰产攻击,让快手遭遇了“直播惊魂夜”...
首日大涨,成都一家“AI小巨人... 来源丨深蓝财经12月23日,资本市场迎来一张新的“成都名片”。诺比侃人工智能科技(成都)股份有限公司...
宝龙地产:境外债务重组获超85... 12月22日,宝龙地产(01238.HK)发布公告,截至公告日,公司境外债务重组计划已获得超过85%...
官方首次披露:华夏银行原董事长... 突然辞职近一年,终于“靴子落地”。12月22日,中共北京市第十三届委员会第八次全体会议召开,全会审议...