一行代码复刻微信红包打开效果,近乎100%还原 | 附源码

又熟悉我的兄弟们知道,我最近一直在做 vx-sim 微信对话模拟器的小项目,有兴趣的兄弟可以移步 gitee.com/maple2133/v... 地址。

如果能够帮忙点个Star⭐那真是万分感谢。

这个小项目说起来技术上不难,主要的难点在复刻微信的各种效果。

今天复刻的是微信红包的打开效果,可以简单观察一下。

实现效果

在点击红包信息以后,页面弹出红包弹窗。

点击红包弹窗中间的 " " 字," " 会变成 "泉币" 有一个不断旋转的动画。

然后红包领取完成页面会逐渐显示出来。

这里重点复刻的是 "泉币" 这个不断旋转的动画。

实现方案

一般来说这种简易的动画有两种实现方案,一种是通过连续的几张图片进行快速的切换,达到动画效果。

另一种是直接做个3D的,让其旋转。(留个坑,有时间实现)

因为这种简易效果做3D属实有点儿"用牛刀",所以我猜微信官方也是用的图片切换的方案。

这里考虑到多张图片的切换对于静态资源的加载和管理并不友好,所以采用精灵图的方案实现。

重点是采用 animation 动画播放 steps 跳帧方案。

实现代码

html 复制代码
<!-- 開 -->
<div class="red-packet-open" v-if="isOpen" @click="isOpen=true"></div>
<!-- 泉币 -->
<div class="red-packet-animation" v-else></div>

<script>
const isOpen = ref(false)
</script>

<style>
    .red-packet-open {
        width: 260px;
        height: 260px;
        background: url('@/assets/images/红包开.png') no-repeat center center;
        background-size: 100% 100%;
        cursor: pointer;
    }

    .red-packet-animation {
        width: 260px;
        height: 260px;
        background: url('@/assets/images/红包动画.png');
        background-size: 100%;
        transition: 0.6s;
        animation: coinSpin 0.6s steps(7) infinite;
        transform-style: preserve-3d;
    }

    @keyframes coinSpin {
        0% {
            background-position: 0 0;
        }

        100% {
            background-position: 0 -1820px;
        }
    }
</style>

实际上实现原理非常简单,就是一张连续帧的静态图片,通过动画切换 background-position 确定图片的展示位置。

然后通过 animationsteps 进行跳帧。

当前代码中是 0.6s 内将这个动画播放 7帧,正好对应精灵图中的连续帧图片。

总结

这个效果还原度上来说还是比较好的,这种连续帧动画的方案在很多网站上也有应用。

最大的优点就是在加载静态资源的时候,速度确实是能够提升不少,这也是精灵图唯一的优势了。

但是我后来分析,微信官方用的应该不是这个方案,这个方案有个比较大的缺点是图片的大小无法自适应

也就是说多大的图对应多大的效果,这一点在多设备适配上并不友好,估计微信仍然使用的是连续多张图片的切换方案。

相关推荐
147API7 分钟前
Claude Opus 4.8 接口与工程落地分析:长任务调用链应该怎么设计
java·前端·数据库
李子琪。16 分钟前
Web 漏洞与防御机制实验报告
前端·经验分享
JustNow_Man20 分钟前
“失败后自动拉起修复 Agent”的闭环流水线
前端·人工智能·chrome·python
Dxy123931021623 分钟前
HTML中如何写键盘事件
前端·html·计算机外设
霍格沃兹测试学院-小舟畅学25 分钟前
接口自动化测试的下一个十年:从脚本到Skills,让AI学会“如何测”
java·前端·人工智能
huangfuyk27 分钟前
前端使用Cursor编辑器方面遇到的问题及注意细节
前端·编辑器·ai编程·cursor
ZC跨境爬虫30 分钟前
跟着 MDN 学CSS day_31:(精通链接样式,从伪类到导航菜单)
前端·javascript·css·ui·交互
发现你走远了40 分钟前
前端多环境自动化部署实战:GitHub Actions + Azure Blob + Cloudflare
前端·自动化·github
香香爱编程40 分钟前
vue3自定义顶部弹窗
前端·javascript·vue.js
weelinking1 小时前
【产品】10_搭建前端框架——把你的原型变成真实页面
java·大数据·前端·数据库·人工智能·python·前端框架