在前面的文章中也有介绍过css3动画的内容,可见《关于transition和animation》和《webkitAnimationEnd动画事件》,今天又要唠叨一下这个东西了,随着知道的越多,然后就会发现自己还有更多的不知道。

今天主要说的是利用animate制作帧动画。

我们常见的loading效果,很多的动画效果并不是连续运动,而是一种逐帧运动的感觉。

看一个简单的需要制作动画效果的图片:

甚至就包括我们在这里写博客上传图片,等待上传这个过程中的loading动画,明显的效果是不能连续转动,不然总感觉傻傻的,最开始我也做了一个傻傻的连续旋转的动画,不知道怎么上传这种效果,没法只管的演示,我把所有代码全都贴上自己可以观察一下。

<div class="loading"></div>
.loading{
width: 1.12rem;
height: 1.12rem;
position: absolute;
left: 50%;
margin-left: -0.56rem;
top: 35%;
z-index: 2;
background: url(../images/loading.png) no-repeat center center;
background-size: contain;
-webkit-animation: rorates 4s infinite linear;
animation: rorates 4s infinite linear;
}
@-webkit-keyframes rorates {
0% {
transform: rotate(0deg);
}
100%{
transform: rotate(360deg);
}
}
@keyframes rorates {
0% {
transform: rotate(0deg);
}
100%{
transform: rotate(360deg);
}
}

所引用的图片,就是前面上传的那张,大家可以看一下,连续旋转,真的没有任何的美感可言。这时候,我就想到了逐帧动画的解决方法。

其实,逐帧动画的关键点在于我们常用的控制动画的速度曲线的属性animation-timing-function,该属性我们比较熟悉的值基本上属于一下这些值:

其中三次贝塞尔曲线cubic-bezier(n,n,n,n),我不知道有多少人能够熟练使用,我是从来没使用过,在我的项目中,前面几种动画曲线已经够用了。

事实上,在这个动画曲线上,还应该有一个值,就是steps(step-start, step-end)函数,他有两个参数,step-start其实就是你指定的步进数量,steps()会根据你指定的步进数量,把整个动画切分为step-start帧,并且整个动画会在帧与帧之间硬切。而step-end用于指定动画在每个周期的什么位置发生帧的切换动作,但实际上并没有多大卵用,或者说就我而言,没发现他有多少实际用处吧!

上面的css动画稍作修改,就能实现我们需要的逐帧动画:

.loading{
width: 1.12rem;
height: 1.12rem;
position: absolute;
left: 50%;
margin-left: -0.56rem;
top: 35%;
z-index: 2;
background: url(../images/loading.png) no-repeat center center;
background-size: contain;
-webkit-animation: rorates 4s infinite steps(8);
animation: rorates 4s infinite steps(8);
}
@-webkit-keyframes rorates {
0% {
transform: rotate(0deg);
}
100%{
transform: rotate(360deg);
}
}
@keyframes rorates {
0% {
transform: rotate(0deg);
}
100%{
transform: rotate(360deg);
}
}

  这么再看起来,明显好很多了

CSS3帧动画的更多相关文章

  1. Css3帧动画深入探寻,讲点项目中实际会碰到的问题

    先加个副标题XD --如何解决background-size为100%下处理@keyframes 正是在项目中遇到副标题,才引起我更深入的探寻 先略带一下基本的css3动画 css3的动画实现是通过属 ...

  2. 3d图片切换(css3帧动画)

    效果带抖动翻转隐藏,使用帧动画 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"&g ...

  3. css3的帧动画

    概述 前几天刚好看到一个用了CSS3帧动画的页面,对它非常感兴趣,就研究了一下,记录在下面,供以后开发时参考,相信对其他人也有用. PS:以后别人问我用过什么CSS3属性的时候,我也可以不用说常见的a ...

  4. css3 animation动画技巧

    一,css3 animation动画前言 随着现在浏览器对css3的兼容性越来越好,使用css3动画来制作动画的例子也越来越广泛,也随着而来带来了许多的问题值得我们能思考.css3动画如何让物体运动更 ...

  5. 深入理解CSS3 Animation 帧动画

    CSS3我在5年之前就有用了,包括公司项目都一直在很前沿的技术. 最近在写慕课网的七夕主题,用了大量的CSS3动画,但是真的沉淀下来仔细的去深入CSS3动画的各个属性发现还是很深的,这里就写下关于帧动 ...

  6. css3 实现逐帧动画

    css3 实现逐帧动画 实现逐帧动画需要使用到的是Animation动画,该CSS3的Animation有八个属性:分别是如下:1: animation-name2: animation-durati ...

  7. 深入理解CSS3 Animation 帧动画 ( steps )

    作者:Aaron的博客 网址:http://www.cnblogs.com/aaronjs/p/4642015.html --------------------------------------- ...

  8. css3 animation实现逐帧动画

    css3里面的animation属性非常强大,但是自己用的比较少,最近有次面试就刚好被问到了,趁现在有时间就对animation做一个小总结.同时实现一个逐帧动画的demo作为练习 animation ...

  9. 深入理解CSS3 Animation 帧动画(转)

    CSS3我在5年之前就有用了,包括公司项目都一直在很前沿的技术. 最近在写慕课网的七夕主题,用了大量的CSS3动画,但是真的沉淀下来仔细的去深入CSS3动画的各个属性发现还是很深的,这里就写下关于帧动 ...

随机推荐

  1. MySQL程序之mysqlshow详解

    mysqlshow命令详解 显示MySQL数据库的结构(数据库.表和列) 如果最后一个参数包含shell或SQL通配符(*,?,%,_)将显示通配符匹配的内容. 如果没有给定数据库,则显示所有匹配的数 ...

  2. OpenCV相机标定坐标系详解

    在OpenCV中,可以使用calibrateCamera函数,通过多个视角的2D/3D对应,求解出该相机的内参数和每一个视角的外参数. 使用C++接口时的输入参数如下: objectPoints - ...

  3. Linux之chgrp

    命令功能: 在lunix系统里,文件或目录的权限的掌控以拥有者及所诉群组来管理.可以使用chgrp指令取变更文件与目录所属群组,这种方式采用群组名称或群组识别码都可以.Chgrp命令就是change  ...

  4. 窗体Form的FormStyle属性设置为fsStayOnTop时属性设置不起作用问题探讨。

    procedure CreateParams(var Params: TCreateParams); override; procedure MainForm.Createparams(var Par ...

  5. 在windows server上配置java jdk后,可能要些时间生效。

    特别是程序调用java写的bat脚本时.

  6. SpringMVC-DispatcherServlet配置(Spring-servlet.xml)

    Spring-servlet.xml <context:component-scan base-package="com.spring.mvc.controller"/> ...

  7. 黄聪:VPS服务器轻松备份工具配置

  8. 了解轮询、长轮询、长连接、websocket

    业务开发中我们往往会有一些需要即时通信的场景,比如微信扫码登录.聊天功能. 下面这四种方式都可以实现即时通信. 轮询: 浏览器通过定时器每隔一段时间向服务器端发送请求,服务器端收到请求并响应请求.没有 ...

  9. [Android 开发教程(1)]-- Saving Data in SQL Databases

    Saving data to a database is ideal for repeating or structured data, such as contact information. Th ...

  10. androidstudio在创建new project时,窗口太大,看不到下面确定按钮的解决方法

    点击File-->setting-->Appearance将里面的Override default fonts by(not recommended)打钩去掉. 这个是目前找到唯一办法.