还在为无法表达内心澎湃的心情而着急吗?还在为制作跳动的心而烦恼吗?哈哈,今天我就把代码全部奉上,为你们追妹子添点贡献,下面来看最终的动态效果(事先说明一下:我用的截屏gif制作软件是绿色版的,所以gif动态图心的抖动效果会有点慢而且卡卡的,但是实际效果很棒,不信你可以粘贴代码看看呗)
其实上面的动画类似于我们小时候荡的秋千,也叫作“秋千动画”,一般用在想让用户点击这个图标的时候,不仅仅限制于表白用O(∩_∩)O,比如企业招聘时想让求职者点击投简历的图标进入另一个页面等。
书写这段程序的思路:
(1)先要定义一个动画,在10%,20%,30%…….100%时心形图的不同状态,当然时间段和状态都是看自己的需要设定
(2)调用动画,然后设置为无限死循环播放
主体结构
|
|
下面来分析下上面的思路
css3里面translate属性
|
|
关于transform具体的值如下:
- none 定义不进行转换。
- matrix(n,n,n,n,n,n) 定义 2D 转换,使用六个值的矩阵。
- matrix3d(n,n,n,n,n,n,n,n,n,n,n,n,n,n,n,n) 定义 3D 转换,使用 16 个值的 4x4 矩阵。
- translate(x,y) 定义 2D 转换。
- translate3d(x,y,z) 定义 3D 转换。
- translateX(x) 定义转换,只是用 X 轴的值。
- translateY(y) 定义转换,只是用 Y 轴的值。
- translateZ(z) 定义 3D 转换,只是用 Z 轴的值。
- scale(x,y) 定义 2D 缩放转换。
- scale3d(x,y,z) 定义 3D 缩放转换。
- scaleX(x) 通过设置 X 轴的值来定义缩放转换。
- scaleY(y) 通过设置 Y 轴的值来定义缩放转换。
- scaleZ(z) 通过设置 Z 轴的值来定义 3D 缩放转换。
- rotate(angle) 定义 2D 旋转,在参数中规定角度。
- rotate3d(x,y,z,angle) 定义 3D 旋转。
- rotateX(angle) 定义沿着 X 轴的 3D 旋转。
- rotateY(angle) 定义沿着 Y 轴的 3D 旋转。
- rotateZ(angle) 定义沿着 Z 轴的 3D 旋转。
- skew(x-angle,y-angle) 定义沿着 X 和 Y 轴的 2D 倾斜转换。
- skewX(angle) 定义沿着 X 轴的 2D 倾斜转换。
- skewY(angle) 定义沿着 Y 轴的 2D 倾斜转换。
- perspective(n) 为 3D 转换元素定义透视视图。
上面这些测试例子可参考[http://www.w3school.com.cn/cssref/pr_transform.asp]
结合本次跳动心的主题可知用到的是1transform:scale(1) rotate(0)
css样式
|
|
上面的程序我的注释也写得很清楚了,感兴趣的可以自己试试看,主要就是css3中scale的放大功能和rotate的旋转功能应用,把握好状态的设置,动画效果还是很Q的.