如题,要实现树叶在风中摇摆的动画,首先准备主体:树叶。
这里准备了两张矢量的高清版 SVG 格式的不同种类的树叶。
![c2f48f8af9395c31008bb76fb090531d.png](https://img-blog.csdnimg.cn/img_convert/c2f48f8af9395c31008bb76fb090531d.png)
![d20202002e9e2d6ca4f688663ef4eeda.png](https://img-blog.csdnimg.cn/img_convert/d20202002e9e2d6ca4f688663ef4eeda.png)
首先我们使用 img
标签来在网页中显示树叶,然后给它一个名为 leaf
的类,好给它附加样式。
<img class="leaf" src="/blog/virtual_safari_leaf.svg" alt="Leaf" />
接下来就是编写 CSS 动画代码,这里利用了 tranform
属性中的两个变换,skew
将元素在二维平面上倾斜角度进行拉伸,rotate
以中心为坐标轴进行旋转。
.leaf {
transform: scale(0.8);
animation: leftRuffle 3s infinite alternate;
}
@keyframes leftRuffle {
50% {
transform: scale(0.8) skew(5deg) rotate(-5deg);
}
100% {
transform: scale(0.8) skew(0) rotate(0);
}
}
我们先让第一个树叶动起来
![b096e61dfc6107ec962c1d54b879df81.png](https://img-blog.csdnimg.cn/img_convert/b096e61dfc6107ec962c1d54b879df81.png)
第二个树叶我们将它左右翻转下,利用 scaleX(-1)
,然后同理
.leaf {
transform: scale(0.7) scaleX(-1);
animation: rightRuffle 3s infinite alternate;
}
@keyframes rightRuffle {
0% {
transform: scale(0.7) scalex(-1) skew(0) rotate(0);
}
50% {
transform: scale(0.7) scalex(-1) skew(5deg) rotate(-5deg);
}
100% {
transform: scale(0.7) scalex(-1) skew(0) rotate(0);
}
}
![77d4ab55f3b74684fa3a5a65f1e6f2b4.png](https://img-blog.csdnimg.cn/img_convert/77d4ab55f3b74684fa3a5a65f1e6f2b4.png)
动是动起来了,可单独看是否觉得有点奇怪。
我们给它增加一个场景:
通常这种大树叶的绿植要么生长在热带雨林,要么被我们放在室内当做风景或者背景。
![28b1a424e99d5dc42345418614ec7c6f.png](https://img-blog.csdnimg.cn/img_convert/28b1a424e99d5dc42345418614ec7c6f.png)
原文阅读体验更佳:https://spacexcode.com/blog/animate-leaf
- END -