thanos snap animation by vue
灭霸打响指的消失效果。效果来源于 Google 搜索“灭霸” 或者 “thanos”, 同时部分资源也是来源于 Google 中直接扣下来的。
另外,其实代码是参考 https://github.com/lichking24/Thanos_Dust 的。 Thanos_Dust 代码已经算比较完善的了,我用 vue 来写了一下,加了一些英雄,修复了一些 bug ,加了一些效果之类的。
随机选取一半的英雄,是通过下面的算法进行选取的:
arr.sort(function() {
return 0.5 - Math.random();
});
被选中的英雄灰飞烟灭的效果解释:
dom
节点渲染为一个 canvas
节点canvas
画布图像按像素分割成许多块dom
节点同一个位置、同样的大小的容器覆盖原 dom
节点appendChild
方法添加到第三步创建的父容器中rotate
角度和 translate
像素,就能完成灰飞烟灭的效果dom
节点设置为不可见的,就完成了响指操作。翻转时间,英雄又回来的效果是将原来的 dom
节点设置为可见的,并加了回复动画。( google
的原版恢复动画是将 color
设置为 green
,因为这里没什么文字效果并不明显,就设置成了 background-color
)