动画的分类

平移动画

  • transform: 就是变换, 变换, 变换
  • 也就是能看到的, 直接的更改. 暴力的那种.
  .dv {
transform: translate(10px, 10px); /* 位置 */
transform: scale(1, 0.5); /* 缩放 */
transform: rotate(20deg); /* 旋转 */
}
  • translate:

    • 坐标变换.
    • 可以接受两个参数, 表示X轴和Y轴上的变化
    • 也可以只使用某个位置, 例如transform: transalteX(10px);
    • 可以开启三个轴上的同时变化: 例如transform: translate3d(10px, 20px, 10px);
  • rotate:
    • 元素旋转
    • 可以接受一个参数, 表示需要旋转的角度
    • 也可以只在某个位置上进行旋转, 例如: transform: rotateX(35deg);
    • 也可以在3d方面的旋转变化, 例如: transform: rotate3d(1, 1, 2, 45deg)
    • 关于每个属性的具体原理, 后面具体分析
  • scale:
    • 缩放
    • 可以接受一个参数, 表示缩放表示水平和垂直同时缩放的倍数.
    • 就收两个参数, 第一个参数表示在水平方向的缩放, 第二个参数表示在垂直方向的缩放
    • 同样可以使用scale3d()来表示在三维层面的缩放
  • skew:
    • 倾斜
    • 表示在X轴上的倾斜角度
    • 第二个参数表示在Y轴上的倾斜角度
  • marix:

过渡动画

  • transition: 过渡.
  • 这是下面四个属性的简写.
  • 就是一个属性的数值, 慢慢的, 平滑的向另一个数值进行改变
  • transition-property

    • 需要设置过度的属性
    • 也就是当这个属性变化的, 是慢慢的变化.
    • 值是none, 没有过渡属性.
    • 默认是all, 所有属性采用过渡的方式变化.
    • 当给定过渡时间后, 不需要列出过渡属性, 所有属性默认使用过渡效果.
  • transition-duration
    • 期间, 就是时间, 就是一个这个属性上的值, 变成另一个值的时候, 需要的时间.
    • 其值可以是毫秒ms, 也可以是秒s
      • 有个好玩的地方, 动画默认的是先慢后快.
      • 如果我们设置了hover属性五秒完成, 三秒后移开, 这个时候, 会先慢慢的过去, 然后最快的速度回来.
      • 我的理解是, 当一个属性值变化的时候, 会有一个函数计算, 还差多少, 完成多少的时候, 是什么速度.
    • 默认是0, 不会有过渡.
  • transition-timing-function
    • 动画变化的方式, 快慢的区别
    • 允许随着时间来改变速度.
    • 默认的方式是: ease: 先慢后快. ease: 单词翻译: 缓解, 减轻, 缓慢的落下.
    • linear: 线性过渡
    • ease-in: in, 去里面, 进去的时候,慢一点.
    • ease-out: out, 外边, 走到最后外边的时候, 慢下来.
    • ease-in-out: 先快再慢再快.
    • cubic-bezier(): 很牛逼了.
  • transition-delay
    • 在动画开始前, 需要等待的时间.
    • 用秒s和毫秒ms计算.

自定义动画(帧动画)

  • animation: 动画, 就是动画. 就是c3的动画
  • 动画, 还能指什么呢, 各个属性的改变之类的.
  • 是个总称: animation: name duration timing-function delay iteration-count direction
  .dv:hover {
animation-name: myAnimaiton;
animation-duration: 3s;
}
@keyframes myAnimaiton {
0% {
padding: 0;
}
100% {
padding: 150px;
}
}
  • animation-name

    • 需要绑定的keyframe的名称
    • 默认值: none. 无动画效果.
    • 后面给一个@keyframes <animation-name> {// 描述动画}
    • 就可以完成动画过程的描述了
  • animation-duration
    • 动画执行的时间
    • 默认是0, 无动画执行
    • 单位是秒s或者毫秒ms
  • animation-timing-function
    • 动画执行的速度
    • 具体的参考下transition-timing-funciton
  • animation-delay
    • 延迟时间.
    • 多久后, 开始执行动画
  • animation-iteration-count
    • 动画循环执行的次数
    • 可以是具体的数字.
    • infinite: 无限次.
    • 留个疑问: 当鼠标hover的时候, 执行的动画, 为什么鼠标移动的时候, 没有离开元素, 但是元素缩小后, 离开了. 动画没有停止.
  • animation-direction
    • 动画的方向
    • normal: 正常方向, 该怎么动, 怎么动.
    • reverse: 反方向, 从100%-0%的执行
    • alternate: 交替执行, 从正常方向开始
    • alternate-reverse: 交替执行, 从反方向开始

CSS3动画总结学习(一)的更多相关文章

  1. 学习笔记 第十四章 使用CSS3动画

    第14章   使用CSS3动画 [学习重点] 设计2D动画 设计3D动画 设计过渡动画 设计帧动画 能够使用CSS3动画功能设计页面特效样式 14.1  设计2D动画 CSS2D Transform表 ...

  2. 第八十三节,CSS3动画效果

    CSS3动画效果 学习要点: 1.动画简介 2.属性详解 3.简写和版本 本章主要探讨HTML5中CSS3的动画效果,可以通过类 Flash那样的关键帧模式控制运行. 一.动画简介     CSS3提 ...

  3. CSS3的变形transform、过渡transition、动画animation学习

    学习CSS3动画animation得先了解一些关于变形transform.过渡transition的知识 这些新属性大多在新版浏览器得到了支持,有些需要添加浏览器前缀(-webkit-.-moz-.- ...

  4. css3动画学习笔记

    具体学习地址:http://www.imooc.com/learn/33CSS3中的三种动画:tranform形变动画/transition缓动动画/animation逐帧动画; tranform: ...

  5. css3动画学习资料整理

    现在主流浏览器(先不管IE8,IE9吧),尤其是移动端浏览器基本都支持css3了,为了增强页面的表现力,css3动画必不可少了.这篇文章主要整理一下我在学习css3动画所查阅的一些好的资料,并附上两个 ...

  6. 学习CSS3动画(animation)

    CSS3就是出了不少高大上的功能,3D效果.动画.多列等等.今天写篇文章记录怎么一下怎么用CSS3写一个动画. 丑话还得说前头,IE9以及以下版本不支持CSS3动画(如真要实现可以考虑用js,不过估计 ...

  7. CSS3学习(CSS3过渡、CSS3动画)

    CSS3过渡:transition属性--专门应对颜色.长度.宽度.位置等变化的过渡 通过CSS3,我们可以在不使用Flash和JavaScript的情况下,为当前某元素从某样式改变为某样式的时候添加 ...

  8. css3学习--css3动画详解一(animation属性)

    ***介绍的属性并不完全,写的都是我认为容易混淆的难点属性,所以属性会在最后综合案例展示~ 一.Keyframes介绍: Keyframes被称为关键帧,其类似于Flash中的关键帧.在CSS3中其主 ...

  9. !!学习笔记:CSS3动画

    一句话就有css3动画: 2016-6-29 <style type="text/css"> h1{background:#999;} h1:hover{border- ...

随机推荐

  1. 我所理解的RESTful Web API [设计篇]【转】

    原文:http://www.cnblogs.com/artech/p/restful-web-api-02.html <我所理解的RESTful Web API [Web标准篇]>Web服 ...

  2. php设置文件编码

    <?php @header('Content-type: text/html;charset=UTF-8'); ?>

  3. javascript基础知识整理(不定时更新)

    1.js中真与假的定义: 真:true,非零数字,非空字符串,非空对象 假:false,数字零,空字符串,空对象(null),undefined 2.使用for循环对json进行循环操作 for(va ...

  4. CodeForces Div1: 995 D. Game(数学期望)

    Allen and Bessie are playing a simple number game. They both know a function f:{0,1}n→Rf:{0,1}n→R, i ...

  5. 「LOJ#6121」「网络流 24 题」孤岛营救问题(BFS

    题目描述 1944 年,特种兵麦克接到国防部的命令,要求立即赶赴太平洋上的一个孤岛,营救被敌军俘虏的大兵瑞恩.瑞恩被关押在一个迷宫里,迷宫地形复杂,但幸好麦克得到了迷宫的地形图.迷宫的外形是一个长方形 ...

  6. 【Matlab】调试基础

    1.matlab 调试子程序 在主程序进入子程序前一句加断点,然后step in,可以进入子程序. 但是直接在子程序里设置断点,运行主程序是不能进入子程序的.

  7. win 10 无线标志都不出现

    http://jingyan.baidu.com/article/e75057f2fdd2f1ebc91a89f1.html ipconfig /flushdns netsh winsock rese ...

  8. 学习总结:斯特林数( Stirling number )

    基本定义 第一类斯特林数:$1 \dots n$的排列中恰好有$k$个环的个数:或是,$n$元置换可分解为$k$个独立的轮换的个数.记作 $$ \begin{bmatrix} n \\ k \end{ ...

  9. java&nbsp;获取路径与各文件目录的…

    java 获取路径 博客分类: MyJava JavaJSPWebTomcat编程  转至:http://geeksun.iteye.com/blog/356339 (1).request.getRe ...

  10. tcp_fast_open的概念 作用以及实现(转)

    引言 三次握手的过程中,当用户首次访问server时,发送syn包,server根据用户IP生成cookie,并与syn+ack一同发回client:client再次访问server时,在syn包携带 ...