0

0

给用户界面添加缓和效果(Easing Curves)_html/css_WEB-ITnose

php中文网

php中文网

发布时间:2016-06-21 08:46:59

|

2120人浏览过

|

来源于php中文网

原创

自从web界面引入平面设计之后,动画的质量变得越来越重要。通过给界面添加动画效果,可以直接影响产品的整体风格,动画也可以让复杂的交互变得简单,优秀的动画设计也能更好的提高用户体验。但如何创建一个高质量的动画呢?easing curves就变得很重要,它也成为动画的一个核心功能,能让动画变得更棒。

问题是,了解Easing Curves的工作原理可能会让你感到困惑。我希望通过篇文章的一些示例能帮助你更好的了解如何在工作中的动画添加Easing Curves功能。

Easing Curves其实就是一条曲线,它定义了加速度模式。Easing Curves还有其他名称,比如有人称其为Motion Curves、时间函数、贝塞尔曲线或曲线等等。Easing Curves不同的形状也有不同的称法,比如 ease-in 、 ease-out 或者 ease-in-out 。

Easing Curves是如何工作的

Easing Curves是通过一个 X 和 Y 轴来创建的。 X 和 Y 的含义是从一个应用程序应用到不同的程序上。在开发中, X 和 Y 的意思也是一样的。用来定义动画的百分比,也就是 X 轴(时间)对应的动画百分比( Y )。

立即学习前端免费学习笔记(深入)”;

Easing Curves是什么样子?什么时候使用?这其实就是 时间和空间的概念。

时间和空间

时间是指一个动画完成所用的时间。空间是指“ ”,也就是动画之间的间距,也就是 Y 轴的百分比,即每个动画百分比这间的空间。下面展示了怎么用Easing Curves来展示间距。其中垂直表示速度快,水平表示速度缓慢。

Linear Ease Spacing

Linear Easing表示的是点的动画运动在空间内是一个匀速运动。

Ease In Spacing

ease-in表示的是点的动画运动在空间内一开始是缓慢的,然后慢慢加快。可以理解为是一个加速运动。

Ease Out Spacing

ease-out表示的是点的动画运动在空间内一开始是加速的,然后慢慢的减慢(这是一个假象)。可以理解为是一个减速运动。

设计一个Easing Curves

常常有人会问我一个问题,什么时候该使用Easing Curve?我的答案是,这一切都应该取决于动画的场景。没有一个Easing Curve可以运用在所有的动画中。而制作这些曲画是设计运动的一个关键。通过Easing Curve设计是来自实现世界中的物理学,但又不总是遵循这些规则。现实世界是获取动画灵感的最好的一个地方。例如,在现实世界中没有一个物体是立马加速和立即停止的。其总是有某种的加速或减速。下面的视频介绍了动画的12原则,而这些都基于物理学(现实世界中的物体运动)所得。

有关于12个动画原则的教程,还可以点击这里阅读。

当你设计一个Easing Curve时一定要记住: 垂直是速度快的,水平是速度慢的 。而创建的曲线需要依赖于交互设计。你可以在一个网格内( X / Y )创建许多不同类型的曲线:

艾绘
艾绘

艾绘:一站式绘本创作平台,AI智能绘本设计神器!

下载

制作曲线是在关键帧创建,其实也可以打破关键帧。如果打破关键帧将导致动画离开关键帧之间的值。这样就可以做一些类似反弹动画效果。

有许多在线的Web工具,可以创建三次贝塞尔曲线,比如:

  • cubic-bezier.com
  • Cesear
  • Easings.net

开发中的Easing Curves

Easing Curves在开发中被称之为时间函数(Timing Functions)。这是一些数学方程式,也是用来创建贝塞尔曲线加速度模式。在开发中常用的函数是 cubic-bezier 。这也是这篇文章后面将要介绍的主要内容。

立即学习前端免费学习笔记(深入)”;

在大多数程序语方中,定义了一些Easing Curves,比如 ease-in 、 ease-out 和 ease-in-out 。可以查看文档了解这些预定义的曲线是如何定义的。下面主要列出了CSS中预定义好的Easing Curves。

  • ease-in = cubic-bezier(.42, 0, 1, 1)
  • ease-out = cubic-bezier(0, 0, .58, 1)
  • ease-in-out = cubic-bezier(.42, 0, .58, 1)

在CSS中定义Easing Curves

在CSS中可以给定义好的类使用一个全局的Ease,这同样适用于每一个关键帧。例如,你创建一个反弹(Bounce)动画效果,在动画的每个关键帧都将会运用到反弹(Bounce)。

.object-class {    animation-name: animation-rocks;    animation-timing-function: cubic-bezier(1,.01,.91,.46);}

你可以在每个关键帧内精确的定义Easing Curves。得要的是要记住: Easing Curves定义的百分比值之前你先要想好怎么让Ease发生。

@keyframes animation-name {    0% {        animation-timing-function: cubic-bezier(1,.01,.91,.46);    }    25% {        animation-timing-function: linear;    }    50% {        animation-timing-function: cubic-bezier(0,.02,0,1.01);    }    75% {        animation-timing-function: linear;    }    100% {        animation-timing-function: linear;    }}

曲线延迟(Curved Delays)

Easing Curves的概念并不仅仅适用于单个动画,但也可以应用于延迟。比如下面的示例:

非常感谢你花时间阅读这篇文章,如果你想了解更多相关的知识,可以 点击这里获取 。如果你有更好的经验和想法,欢迎在下面的评论中和我们一起分享。

本文根据 @Ryan Brownhill 的《 Crafting Easing Curves for User Interfaces 》所译,整个译文带有我们自己的理解与思想,如果译得不好或有不对之处还请同行朋友指点。如需转载此译文,需注明英文出处: https://medium.com/@ryan_brownhill/crafting-easing-curves-for-user-interfaces-34f39e1b4a43#.blkcnbpw2 。

大漠

常用昵称“大漠”,W3CPlus创始人,目前就职于手淘。对HTML5、CSS3和Sass等前端脚本语言有非常深入的认识和丰富的实践经验,尤其专注对CSS3的研究,是国内最早研究和使用CSS3技术的一批人。CSS3、Sass和Drupal中国布道者。2014年出版《 图解CSS3:核心技术与案例实战 》。

相关文章

HTML速学教程(入门课程)
HTML速学教程(入门课程)

HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
俄罗斯Yandex引擎入口
俄罗斯Yandex引擎入口

2026年俄罗斯Yandex搜索引擎最新入口汇总,涵盖免登录、多语言支持、无广告视频播放及本地化服务等核心功能。阅读专题下面的文章了解更多详细内容。

178

2026.01.28

包子漫画在线官方入口大全
包子漫画在线官方入口大全

本合集汇总了包子漫画2026最新官方在线观看入口,涵盖备用域名、正版无广告链接及多端适配地址,助你畅享12700+高清漫画资源。阅读专题下面的文章了解更多详细内容。

35

2026.01.28

ao3中文版官网地址大全
ao3中文版官网地址大全

AO3最新中文版官网入口合集,汇总2026年主站及国内优化镜像链接,支持简体中文界面、无广告阅读与多设备同步。阅读专题下面的文章了解更多详细内容。

79

2026.01.28

php怎么写接口教程
php怎么写接口教程

本合集涵盖PHP接口开发基础、RESTful API设计、数据交互与安全处理等实用教程,助你快速掌握PHP接口编写技巧。阅读专题下面的文章了解更多详细内容。

2

2026.01.28

php中文乱码如何解决
php中文乱码如何解决

本文整理了php中文乱码如何解决及解决方法,阅读节专题下面的文章了解更多详细内容。

4

2026.01.28

Java 消息队列与异步架构实战
Java 消息队列与异步架构实战

本专题系统讲解 Java 在消息队列与异步系统架构中的核心应用,涵盖消息队列基本原理、Kafka 与 RabbitMQ 的使用场景对比、生产者与消费者模型、消息可靠性与顺序性保障、重复消费与幂等处理,以及在高并发系统中的异步解耦设计。通过实战案例,帮助学习者掌握 使用 Java 构建高吞吐、高可靠异步消息系统的完整思路。

8

2026.01.28

Python 自然语言处理(NLP)基础与实战
Python 自然语言处理(NLP)基础与实战

本专题系统讲解 Python 在自然语言处理(NLP)领域的基础方法与实战应用,涵盖文本预处理(分词、去停用词)、词性标注、命名实体识别、关键词提取、情感分析,以及常用 NLP 库(NLTK、spaCy)的核心用法。通过真实文本案例,帮助学习者掌握 使用 Python 进行文本分析与语言数据处理的完整流程,适用于内容分析、舆情监测与智能文本应用场景。

24

2026.01.27

拼多多赚钱的5种方法 拼多多赚钱的5种方法
拼多多赚钱的5种方法 拼多多赚钱的5种方法

在拼多多上赚钱主要可以通过无货源模式一件代发、精细化运营特色店铺、参与官方高流量活动、利用拼团机制社交裂变,以及成为多多进宝推广员这5种方法实现。核心策略在于通过低成本、高效率的供应链管理与营销,利用平台社交电商红利实现盈利。

122

2026.01.26

edge浏览器怎样设置主页 edge浏览器自定义设置教程
edge浏览器怎样设置主页 edge浏览器自定义设置教程

在Edge浏览器中设置主页,请依次点击右上角“...”图标 > 设置 > 开始、主页和新建标签页。在“Microsoft Edge 启动时”选择“打开以下页面”,点击“添加新页面”并输入网址。若要使用主页按钮,需在“外观”设置中开启“显示主页按钮”并设定网址。

72

2026.01.26

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
前端开发规范手册
前端开发规范手册

共14课时 | 9.9万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号