CSS3 大大强化了制作动画的能力,但是如果要做出图案比较复杂的动画,选择 GIF 依然是一个不错的选择。今天给大家介绍一个使用 CSS animation 配合雪碧图(CSS sprite)来制作动画的方法,可以做出类似于 GIF 动画的效果。
CSS3 Animation steps函数

首先看看,CSS3 animation的兼容性。可以看到基本上主流浏览器都支持了 animation 属性,chrome、safari、opera和移动端的浏览器带上前缀就可以支持。

利用雪碧图来制作动画使用了 CSS3 Animation 里面的一个重要的函数 steps。

animation 本身是一个复合的属性,它包含了 animation-name,animation-timing-function,animation-iteration-count,animation-direction,animation-play-state,animation-fill-mode 六个属性。

steps 就是属于 animation-timing-function 中的一个函数。

animation-timing-function 平时我们用的比较多的是默认的一些动画曲线值 ease、ease-in 等等。而 steps 则可以由我们控制动画被分成多少个部分进行。

steps(n,[start|end]) 传入一到两嘅个参数,第一个参数意思是把动画分成 n 等分,然后动画就会平均地运行。第二个参赛默认值是 start 表示从动画的开头开始运行,相反,end 就表示从动画的结尾开始运行。

因此,我们利用雪碧图和 steps 函数制作动画的原理就是,雪碧图包含了动画图片的每一帧,然后利用 steps 函数确定固定时间内动画运行的部分等于动画的帧数,从而实现动画效果。
动画实例

用猥琐的兔斯基做例子╮( ̄▽ ̄")╭
CSS3动画制作的简单示例

首先我们要切图,把动画的每一帧切成这样的图:
CSS3动画制作的简单示例

切图如果大家不想折腾,推荐在线合并雪碧图的工具。

然后写 keyframes

CSS Code复制内容到剪贴板
  1. @-webkit-keyframes tuski {   
  2.     0% {   
  3.         background-position:0;   
  4.     }   
  5.     100% {   
  6.         background-position: -576px 0;   
  7.     }   
  8. }   
  9. @-moz-keyframes tuski {   
  10.     0% {   
  11.         background-position:0;   
  12.     }   
  13.     100% {   
  14.         background-position: -576px 0;   
  15.     }   
  16. }   
  17. @keyframes tuski {   
  18.     0% {   
  19.         background-position:0;   
  20.     }   
  21.     100% {   
  22.         background-position: -576px 0;   
  23.     }   
  24. }  

调用动画

CSS Code复制内容到剪贴板
  1. #tuski {   
  2.     -webkit-animation: tuski .5s steps(12) infinite;   
  3.     -moz-animation: tuski .5s steps(12) infinite;   
  4.     animation: tuski .5s steps(12) infinite;   
  5. }  

与 GIF 相比,这种动画可以让我们手动调整动画运行的速度。

点这里看完整的代码。

大功告成。

标签:
CSS3,动画

免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
狼山资源网 Copyright www.pvsay.com

评论“CSS3动画制作的简单示例”

暂无“CSS3动画制作的简单示例”评论...

RTX 5090要首发 性能要翻倍!三星展示GDDR7显存

三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。

首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。

据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。