css过度与动画-程序员宅基地

缓动效果

回弹动画效果是比较常见的动画,比如小球的运动、对于尺寸变化和角度变化使用回弹效果可以增强动画的体验。小面介绍一些简单的缓动效果的动画。

  • 弹跳动画的实现

css中所有过渡和动画都是跟一条曲线(缓动曲线)有关的,这条曲线指定了动画过程在整段时间中是如何推进的。

在animationtiming-function/transition-timing-function 展开式属性中,都可以把这个默认的调速函数显式指定为ease 关键字。ease也是默认值,四种指定的缓动曲线值分别是ease、ease-in、ease-out(是ease-in 是反向版本)、ease-in-out、linear,四种的缓动曲线分别如下图所示:

clipboard.png

使用ease-in和ease-out这对相反的版本可以实现回弹的效果
如小球的回弹效果可以这样实现:

@keyframes bounce {
  60%, 80%, to {
    transform: translateY(400px);
    animation-timing-function: ease;
  }
  70% {
    transform: translateY(300px);
  }
  90% {
    transform: translateY(360px);
  }
}

.ball {
    width: 50px;
    height: 50px;
    border-radius: 50px;
    background: yellow;
    animation: bounce 3s ease-in;
}

CSS 的调速函数都是只有一个片断的贝塞尔曲线,因此每个调速函数只有两个控制锚点。同时CSS 提供了一个cubic-bezier(x1, y1, x2, y2)函数,允许我们指定自定义的调速函数。它接受四个参数,分别代表两个控制锚点的坐标值,如果想得到任何调速函数的反向版本,只要把控制锚点的水平坐标和垂直坐标互换就可以。

把上面的ball的animation,设置成 bounce 3s cubic-bezier(.1,.25,1,.25);会使回弹效果更真实。

一个好用的贝塞尓可视化的工具

  • 弹性过渡

弹性过渡的应用场景比如说是一个input框,用户输入的时候给予一个提示框,可以应用上面的cubic-bezier实现

<label>
      Your username: <input id="username" />
      <span class="callout1">
        Only letters, numbers,
        underscores (_) and hyphens (-) allowed!
      </span>
</label>
input:not(:focus) + .callout1 {
    transform: scale(0);
    transition: .25s;
  }
.callout1 {
    /* cubic-bezier(.5s * 50%, .1, .5 * 60%, 1.5) */
    transition: .5s cubic-bezier(.25, .1, .3, 1.5);
    transform-origin: 1.4em -.4em;
    /* CSS transform 属性 , 只对 block 级元素生效*/
    display: block;
    width: 250px;
    height: 40px;
    font-size: 12px;
    border: 1px solid #eee;
    margin-top: 5px;
}

实现效果

clipboard.png

在使用transition进行过渡时,在不指定transition-property属性时,它会自动读取它的初始值all,这时所有能做过渡的属性都会参与过渡,比如color。所以在设置过渡时,要把过渡的作用范围限制在某几种特定的属性上。

综上,上面的代码transition的值都应该加上transform,即

input:not(:focus) + .callout {
    transform: scale(0);
    transition: .25s transform;
}
.callout {
    transform-origin: 1.4em -.4em;
    transition: .5s cubic-bezier(.25,.1,.3,1.5) transform;
}

逐帧动画

在实现一个卡通影片或者一个复杂的进度指示框,或者loading的标志时这种场景比较适应逐帧动画。

在实现loading动画时也是可以使用gif动画的,但是gif动画是有一些自己的缺点的:

  1. GIF 图片的所能使用的颜色数量被限制在 256 色

  2. GIF 不具备 Alpha 透明的特性。

  3. 修改动画的参数不方便,需要重新编辑生成。

在css中可以使用step这个函数实现。
所有基于贝塞尔曲线的调速函数都会在关键帧之间进行插值运算,从而产生平滑的过渡效果。这种平滑特性不适用于逐帧动画的实现。

steps() 会根据你指定的步进数量,把整个动画切分为多帧,而且整个动画会在帧与帧之间硬切,不会做任何插值处理。这种loading的实现正适用于这种

具体实现如下:

<div class="loader">Loading...</div>
@keyframes loader {
    to { background-position: -800px 0; }
}

.loader {
    width: 100px; 
    height: 100px;
    background: url(img/loader.png) 0 0;
    animation: loader 1s infinite steps(8);
    
    /* 把文本隐藏起来 */
    text-indent: 200%;
    white-space: nowrap;
    overflow: hidden;
}

loader.png 是一个将所有 loading 状态拼接好的 png 图片

闪烁效果的实现

以前的blink标签可以用来实现文字的闪烁效果,现在没有了,现在可以通过animation创建的动画实现

@keyframes blink {
  50% {
    color: transparent
  }
}

.highlight {
  animation: 1s blink 3 steps(1);
}

打字动画的实现

实现思路就是让容器的宽度成为动画的主体,把所有文本包裹在这个容器中,然后让它的宽度从0 开始以步进动画的方式、一个字一个字地扩张到它应有的宽度。只适用于单行的文本

实现中将使用ch这个单位,它表示0字符的宽度,很少用到,但对于等宽字体来说,“0”字符的宽度和其他所有字形的宽度是一样的。假设我们要实现的文本是等宽字体。

<h1 class="code">CSS is awesome!</h1>
@keyframes typing {
  from {
    width: 0
  }
}

/* 闪烁的光标的实现 */
@keyframes caret {
  50% {
    /* currentColor使边框颜色自动与文字颜色保持一致 */
    border-color: currentColor;
  }
}

.code {
  width: 15ch; /* 文本的宽度 */
  animation: typing 6s steps(15),
  caret 1s steps(1) infinite;
  white-space: nowrap;
  border-right: .05em solid transparent;
  overflow: hidden;
}

效果:

clipboard.png

状态平滑的动画

应用场景是在一张图片很长,展示的位置又很有限,这时候做成动画是再好不过的,在鼠标hover或者focus的触发动画的发生。但是当动画开始播放还没结束的时候,鼠标离开时,动画就会特别生硬的回到图片的最开始的位置上,解决的办法就是使用animation-play-state这个属性

@keyframes panoramic {
  to {
    background-position: 100% 0;
  }
}

.panoramic {
  width: 150px;
  height: 150px;
  background: url("timg.jpeg");
  background-size: auto 100%;
  animation: panoramic 10s linear infinite alternate;
  animation-play-state: paused;
}

.panoramic:hover, .panoramic:focus {
  animation-play-state: running;
}

效果:

clipboard.png

沿环形路径平移的动画

通过设置旋转的动画达到效果,但是会存在一个问题旋转的时候图片自身也会一起旋转,解决这个问题有两种方法:

(1)需要两个元素的解决方案
思路就是给元素设置另一个旋转动画,让它以相反的方向自转一周,这样旋转的时候图片自身就不会跟着旋转

<div class="path">
    <div class="avatar">
        <img src="lea.jpg" />
    </div>
</div>
@keyframes spin {
  to {
    transform: rotate(1turn);
  }
}

.path .avatar {
  animation: spin 10s infinite linear;
  transform-origin: 50% 150px; /* 150px = 路径的半径 */
}

.path .avatar > img {
  width: 50px;
  height: 50px;
  border-radius: 25px;
  position: absolute;
  left: 120px;
  top: 10px;
  animation: inherit;
  /* reverse 得到原始动画的反向版本 */
  animation-direction: reverse;
}

效果如下:

clipboard.png

clipboard.png

(2) 单个元素的解决方案
每个transform-origin 都是可以被两个translate() 模拟出来的。
例如

transform: rotate(30deg);
transform-origin: 200px 300px;


transform: translate(200px, 300px)
rotate(30deg)
translate(-200px, -300px);
transform-origin: 0 0;

/* 以上两段代码等价 */

应用translate变形函数并不是彼此独立的,每个变形函数并不是只对这个元素进行变形,而且会把整个元素的坐标系统进行变形,从而影响所有后续的变形操作。这也说明了为什么变形函数的顺序是很重要的,变形属性中不同函数的顺序如果被打乱,可能会产生完全不同的结果。

通过translate的方式就可以只用一层dom


@keyframes spin {
  from {
    transform: rotate(0turn) translateY(-150px) translateY(50%) rotate(1turn);
  }
  to {
    transform: rotate(1turn) translateY(-150px) translateY(50%) rotate(0turn);
  }
}

.avatar {
  animation: spin 3s infinite linear;
}
版权声明:本文为博主原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。
本文链接:https://blog.csdn.net/weixin_33953249/article/details/89049649

智能推荐

通俗易懂QPS、TPS、PV、UV、GMV、IP、RPS的概念解释_qpsvr-程序员宅基地

文章浏览阅读1.2w次。前言关于 QPS、TPS、PV、UV、GMV、IP、RPS 这些词语,看起来好像挺专业。但实际上,我认为是这是每个程序员必懂的知识点了,你可以搞不懂它们怎么计算的,但是你最少要了解它们分别代表什么意思。QPSQueries Per Second,每秒查询数。每秒能够响应的查询次数。QPS 是对一个特定的查询服务器在规定时间内所处理流量多少的衡量标准,在因特网上,作为域名系统服务器的机器的..._qpsvr

ORA-00132syntax error or unresolved network name-程序员宅基地

文章浏览阅读2.3k次。在DOS下SQL&gt; startup;ORA-00119: invalid specification for system parameter LOCAL_LISTENERORA-00132: syntax error or unresolved network name 'LISTENER_ORCL'解决方法:1.SQL&gt; create pfile from spf..._ora-00132

C/C++编程笔记:quick_exit函数和ctime函数-程序员宅基地

文章浏览阅读650次。今天给大家分享学习两个函数:quick_exit函数和ctime函数。quick_exitquick_exit()函数是在定义STDLIB头文件。quick_exit()函数用于正常终止进程而不完全清除资源。如果val为零或EXIT_SUCCESS,则表明程序成功终止。如果该值不为零或EXIT_FAILURE,则表明该程序未成功终止。这些函数以那里调用的相反顺序被调用。句法:void quick_exit(int val);参数:此方法采用单个参数val,它是表示程序退出状态_quick_exit

Oracle感慨(转)-程序员宅基地

文章浏览阅读60次。 一转眼接触ORACLE已经一年了,在这一年中收获多多,感慨多多,我记得是2004年11月底开始学习ORACLE的,当时选择方向也是几经波折,还好现在的处境不是非常的艰难,前途似乎还有想象中的光明。 毕业已经两年半,开始半年主要是接触Sybase,当时公司后台使用的Sybase SQL 11,由于人手比较少,管理也不很严格,所以我经常有机会光顾他,在那里我学会了怎样备份,恢复数..._李小龙语录一拳就是一拳一脚就是一脚

android关于自定义Dialog中布局match_parent 属性 失效的问题_android dialog 布局 match_parent 无效-程序员宅基地

文章浏览阅读1.9k次。dialog如果没有设置style,那么系统会主动设置一个style,这个style中的decorview会存在padding,所以导致match_parent无效1.方法一dialog.show();//在show之后修改,必须这样否则无效,没看源码具体原因不知道Window window =dialog.getWindow();if (window == null) {..._android dialog 布局 match_parent 无效

vue3+vite+ts的项目打包后使用静态资源dist用5+app打包成APP_vite vue ts 转 app-程序员宅基地

文章浏览阅读256次,点赞10次,收藏2次。使用app在真机上安装完成后,进入首页后登录时遇到了连不上后端api的问题,在处理完跨域的问题后,发现因为发布app时 vue开发模式下配置的跨域是无效的,打包后会找不到接口。使用HBuildeX创建5+app项目,然后删除。并将vue3打包出来的dist文件夹中的。全部内容复制到5+app项目中;_vite vue ts 转 app

随便推点

两天学会Angular开发——第二天_angular一天内学完-程序员宅基地

文章浏览阅读208次。Angular实战开发-第一节项目地址:Github 搜索 zhuzhiqiang/douBanVideo简述在第一节中,我们把工程搭建好了,首页的分类也能展示。接下来我们要做的是:点击每一个分类,去请求数据,展示请求接口请求接口的代码封装在 home.service.ts 文件中。使用的数据是 mock 数据,放在 mock-data 文件夹中,项目中用到的接口地址都放在 ma..._angular一天内学完

作品集展示微信小程序+springboot+vue.js附带文章和源代码设计说明文档ppt-程序员宅基地

文章浏览阅读700次,点赞21次,收藏14次。博主介绍:CSDN特邀作者、985计算机专业毕业、某互联网大厂高级全栈开发程序员、码云/掘金/华为云/阿里云/InfoQ/StackOverflow/github等平台优质作者、专注于Java、小程序、前端、python等技术领域和毕业项目实战,以及程序定制化开发、全栈讲解、就业辅导、面试辅导、简历修改。精彩专栏 推荐订阅2023-2024年最值得选的微信小程序毕业设计选题大全:100个热门选题推荐2023-2024年最值得选的Java毕业设计选题大全:500个热门选题推荐。

学习cassandra(1)入门,使用场景(写多读少)和搭建启动使用,整合Spring boot_cassandra入门实战黑马程序员-程序员宅基地

文章浏览阅读2.3k次。官网http://cassandra.apache.org/ 下载后wget http://mirror.bit.edu.cn/apache/cassandra/3.11.1/apache-cassandra-3.11.1-bin.tar.gz解压tar -xvf apache-cassandra-3.11.1-bin.tar.gzcd apache-cassandra-3.11.1修改配置文件_cassandra入门实战黑马程序员

ES源码之路(一):源码本地编译启动_gradle编译es源码-程序员宅基地

文章浏览阅读1.7k次。ES源码之路(一):源码本地编译启动先来一段客套话,介绍一下ES:ElasticSearch是一个基于Lucene的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于RESTful web接口。Elasticsearch是用Java语言开发的,并作为Apache许可条款下的开放源码发布,是一种流行的企业级搜索引擎。ElasticSearch用于云计算中,能够达到实时搜索,稳定,可..._gradle编译es源码

React脚手架介绍和Demo_脚手架demo是什么-程序员宅基地

文章浏览阅读256次。React脚手架生成代码和Demo_脚手架demo是什么

插画人物怎么画?人体动态结构怎么画?_人体体块怎么画-程序员宅基地

文章浏览阅读3.2k次。动漫人物怎么画?人体动作怎么画?有多少绘画新手都是喜欢收藏大量人体图文或是人体视频教程,但是从来都从来都没有认真的练习过的,收藏夹可不会让你画技提升,究其原因还是因为干货缺少了理论上的指导,导致众多小可爱知其然不知其所以然。为此今天就分享了一套人体动态练习图,搭配讲解食用你还怕学不会吗?顺便推荐大家可以搜一下:灵猫课堂,或者打开手机微信,添加好友框内搜索:灵猫课堂,一键关注,学习无忧!上面..._人体体块怎么画

推荐文章

热门文章

相关标签