在前面的文章中也有介绍过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. 运行Scrapy项目提示“import win32api ImportError: DLL load failed: 找不到指定的模块。”

    安装完成Scrapy时候,终端导入Scrapy时候,发现没有任何报错,但是在运行Scrapy的项目的时候提示“import win32api ImportError: DLL load failed: ...

  2. win7重装系统笔记

    制作U盘启动盘:链接 原文链接:链接 开机进入bios界面(华硕:F2) 按方向左右键进入:Boot选项,将“Lunch CSM”设置为“Enabled” 方向键选择“Security”,将“Secu ...

  3. SpringBoot+Maven 多模块项目的构建、运行、打包

    SpringBoot+Maven 多模块项目的构建.运行.打包 https://blog.csdn.net/zekeTao/article/details/79413919

  4. 基于tornado的文件上传demo

    这里,web框架是tornado的4.0版本,文件上传组件,是用的bootstrap-fileinput. 这个小demo,是给合作伙伴提供的,模拟APP上摄像头拍照,上传给后台服务进行图像识别用,识 ...

  5. Linux ssh服务器配置

    配置文件在/etc/sshd_config,注意只有root可rw,其他所有用户权限为---. 配置说明可参考man sshd_config. 如果更改了服务器端口号,并且启用了SELinux,需要执 ...

  6. 解决MSDE安装回滚的问题

    rem 解决MSDE安装回滚的问题.bat rem 设置为手动rem sc config "LanmanServer" start= DEMAND rem 设置为自动sc conf ...

  7. LeetCode——5.Longest Palindromic Substring

    一.题目链接:https://leetcode.com/problems/longest-palindromic-substring/ 二.题目大意: 给定一个字符串,找出它最长的回文子串.例如,字符 ...

  8. sass之为什么要使用预处理器

    使用预处理器主要目的就是编写出可读性更好.更易于维护的css. 以sass为例,sass中提供了@import可以在sass文件中导入其他sass文件,或在选择器中按需导入所需要的某个属性样式: @i ...

  9. bzoj5007: TCP协议

    Description 在如今的网络中,TCP是一种被广泛使用的网络协议,它在传输层提供了可靠的通信服务.众所周知,网络是存在 时延的,例如用户先后向服务器发送了两个指令op1和op2,并且希望服务器 ...

  10. P1507 NASA的食物计划

    传送 01背包又进化了,它变成了二维背包. 既然它多了一个维度,那么我们的f[j]也变成了二维数组f[i][j],其中i表示费用1,j表示费用2 核心方程也相应的变成了f[i][j]=max(f[i- ...