Compose 实现微信朋友圈大图查看

要实现这么一个需求,首先我们得知道compose的动画是怎么样玩的,因为从点击朋友圈到大图界面其实是由平移,缩放,背景渐变这三个动画同时作用完成的。然后还得知道compose的事件是怎么处理的,大图界面有pager的水平滚动,还有双击,单击,双指操作单指操作,和上下拖拽隐藏界面。

进入和退出大图界面动画实现

首先得知道朋友圈的小滑稽图片在parent的相对坐标点,因为要使用平移动画,首先得知道平移的起始点吧?

使用onGloballyPositioned 函数就行了

获取到的坐标先保存到rect变量里面,然后显示的时候把整个图片list 和 位置以及rect 传进去并执行动画。

imageViewerState 是自己定义的一个状态类,用于保存大图查看界面的一些状态,使用state注解标记可以减少一些不必要的重组。

其中curPosition 表示当前是第几张图片,srcRec 表示原图片的坐标rect 信息,show用来控制大图界面的显示。剩下其他的就是一些动画相关的参数。

点击图片会调用show方法,show方法主要就是执行动画。

大图界面根据动画的百分比percent来做出一系列UI的改变。比如背景渐变和平移的变化,如下

从大图界面返回的时候要注意透明度的变化不是从1->0 ,而是从拖拽之后的透明度->0。

缩放大小改变使用size方法来处理。

进入的时候从src 的大小->整个界面的大小,退出则反着来。

我们再来看下大图查看界面的事件是怎么处理的,大图查看界面的事件还是比较复杂的。

大图查看界面事件处理

微信的大图查看,双指只能放大缩小图片,单指向下能拖拽图片并且到达一定距离便可退出大图界面。

图片没有缩放的情况左右滑动才可以切换图片,单击退出大图界面,双击放大图片,放大状态双击返回图片原来的大小。

别慌,我们一 一来实现。

首先实现比较简单的点击或者双击,用compose 提供的detectTapGestures 就行了

这个函数,原理是怎么样的?

可以看到超过400毫秒就判定为长按了。

长按事件其实是通过协程的取消机制来做的,超过400ms 后超时会自动触发协程的cancel,然后会进入异常catch块触发长按事件。如果没超过,在400ms内再来了一次事件就会触发双击事件,如果400ms内只来了一次事件就会触发单击事件。

源码分析到这里,好了开始干正事,我们来实现双指操作。

可以通过changes 来判断当前有几根手指头按下,如果为2就是双指了,然后通过compose 提供的calculateZoom 方法就可以知道双指操作放大或缩小的值了。

再来看下怎么处理拖拽并退出大图界面

当在y上移动的增量大于x移动的增量的2倍,并且大于touchSlop ,表示我们就要消费事件执行下拉拖拽隐藏界面了。up时,当在y轴拖动正向距离超过100dp隐藏界面,否则回到原来的位置。

相关推荐
kymjs张涛10 小时前
OpenClaw 学习小组:初识
android·linux·人工智能
范特西林13 小时前
实战演练——从零实现一个高性能 Binder 服务
android
范特西林14 小时前
代码的生成:AIDL 编译器与 Parcel 的序列化艺术
android
范特西林14 小时前
深入内核:Binder 驱动的内存管理与事务调度
android
范特西林15 小时前
解剖麻雀:Binder 通信的整体架构全景图
android
范特西林15 小时前
破冰之旅:为什么 Android 选择了 Binder?
android
奔跑中的蜗牛66616 小时前
一次播放器架构升级:Android 直播间 ANR 下降 60%
android
测试工坊18 小时前
Android 视频播放卡顿检测——帧率之外的第二战场
android
Kapaseker20 小时前
一杯美式深入理解 data class
android·kotlin
鹏多多20 小时前
Flutter使用screenshot进行截屏和截长图以及分享保存的全流程指南
android·前端·flutter