新版MATERIAL DESIGN 官方动效指南(一)

2024-03-07 09:10

本文主要是介绍新版MATERIAL DESIGN 官方动效指南(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Google 刚发布了新版Material Design 官方动效指南,全文包括三个部分:为什么说动效很重要?如何制作优秀的Material Design动效及转场动画,动效的意义。新鲜热辣收好不谢!

  在Material design的世界中,动效用一种优雅、流动的方式来描述空间关系、功能、和意向。

  为什么说动效很重要?

  动效可以向我们展示一个App 是如何构成和用途。

  动效可以做到:

  不同视图之间的焦点引导。

  当用户完成了一个手势后,提示用户将会发生什么

  明确元素之间的层级和空间关系

  当程序在后台运行时,分散用户的注意力(例如获取内容或载入下一个视图)

  润色整个app:个性化、令人愉悦

  如何制作材料设计的动效?

  材料设计的运动吸取了一些真实世界的力学元素,例如重力和摩擦力。这些力反应的是,用户对屏幕操作的影响,以及这些元素是如何相互反馈的。

  材料设计的运动具有以下几个特征:

  1. 响应式的

  材料设计的动效是充满活力的。它能迅速精确响应用户用户所触发的内容。

新版MATERIAL DESIGN 官方动效指南 三联

  在移动设备上的长动画大约是300-400ms,短动画大概是150-200ms。过长的动画让人感觉迟钝,过短的动画让人觉得难以看明白。

18dx20160512

  用户触摸屏幕时,通过漪涟动画能使用户确认输入。卡片上升表示该卡片处于激活状态。

17dx20160512

  显示触发元件或动作和创建出的新的卡片之间的联系。

  2. 自然的

  材料设计的动效通过模仿真实世界的力,而展现了自然的运动过程。

16dx20160512

  在真实的世界中,一个物体可以被重量、表面摩擦力影响很快的加速或减速。同样的,材料设计的动效也是不会发生突然停止,或者突然启动,都是会有一个加速度或者减速度。(红色没缓动,蓝色有缓动)

15dx20160512

  真实世界中的力,例如重力,能使一个元素沿曲线运动而非直线运动。

14dx20160512

  材料设计的动效转场是沿着一个弧线的。

  3. 可察觉的

  材料设计的动效是可以被周围环境察觉的,包括用户和周围其他的元素。它可以被物体吸引,并且恰当的回应用户的意图。

13dx20160512

  作为过渡元素,他们和他们周围元素的运动是精心安排的,可以通过这个过程看出他们之间的关系。

12dx20160512

  卡片可以推动其他卡片,让他们给自己让开路。

11dx20160512

  元素可能会吸引其他元素加入,当他们相互接近时合为一体。

  4. 有引导意向的

  材料设计的动效能使焦点在对的时间聚焦在对的点。

10dx20160512

  转场动画有助于引导用户进行下一步的交互。

9dx20160512

  运动可以传递不同的信号,例如,一个操作是否不可用。

8dx20160512

  动画能使用户关注特定对象。

  如何设计一个好的转场动画?

  好的动效设计应该遵从以下几点:

  1. 动效是很快的

  一个交互动作不应该让用户做不必要的等待。

7dx20160512

  正确:动画一定要快,用户无须等待动画完成。

6dx20160512

  错误:很多元素磨磨蹭蹭很慢的运动,令动画时长延长。

  2. 动效是明确的

  转场动画应该明确,简单,一致。应该避免一次有太多的元素动效。

  由于动图太大,上传到网盘,麻烦大家查看:http://pan.baidu.com/s/1pLGM0en

  正确:保持清晰的路径进入下一个视图,最好元件都编排成一个组。

  由于动图太大已传,单击可见:http://www.uisdc.com

  错误:多个元素移动到不同的方向或者交叉路径,会造成转场动画的混乱。

  3. 动效是统一的

  材料设计的动效是由速度、响应性、和意向所统一的。在App 中的任何自定义动效体验都应该贯穿整一个App。

3dx20160512

  即使这些app有着不同的功能,但是他们相似的动画体验让人感觉他们是有关联的。

  动效的意义

  动效的好处可以从以下两个例子中明显看出:其中一个app遵从这些模式,而另一个没有遵从。

2dx20160512

  正确:在转场的过程总,用户被引导到了下一个视图。表层的转场清晰的传达出层级关系。loading的过程在后台进行,以减少延迟时间。

1dx20160512

  错误:转场的发生点没有一个清晰的焦点,所以看不出来新的页面和旧的页面之间的联系。没有感觉到有任何层级的关系,loading用一个转圈的半圆表现太明显了,令人感到延迟感。

这篇关于新版MATERIAL DESIGN 官方动效指南(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/783028

相关文章

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

深度解析Spring Boot拦截器Interceptor与过滤器Filter的区别与实战指南

《深度解析SpringBoot拦截器Interceptor与过滤器Filter的区别与实战指南》本文深度解析SpringBoot中拦截器与过滤器的区别,涵盖执行顺序、依赖关系、异常处理等核心差异,并... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现

MySQL追踪数据库表更新操作来源的全面指南

《MySQL追踪数据库表更新操作来源的全面指南》本文将以一个具体问题为例,如何监测哪个IP来源对数据库表statistics_test进行了UPDATE操作,文内探讨了多种方法,并提供了详细的代码... 目录引言1. 为什么需要监控数据库更新操作2. 方法1:启用数据库审计日志(1)mysql/mariad

SpringBoot开发中十大常见陷阱深度解析与避坑指南

《SpringBoot开发中十大常见陷阱深度解析与避坑指南》在SpringBoot的开发过程中,即使是经验丰富的开发者也难免会遇到各种棘手的问题,本文将针对SpringBoot开发中十大常见的“坑... 目录引言一、配置总出错?是不是同时用了.properties和.yml?二、换个位置配置就失效?搞清楚加

SpringBoot集成LiteFlow工作流引擎的完整指南

《SpringBoot集成LiteFlow工作流引擎的完整指南》LiteFlow作为一款国产轻量级规则引擎/流程引擎,以其零学习成本、高可扩展性和极致性能成为微服务架构下的理想选择,本文将详细讲解Sp... 目录一、LiteFlow核心优势二、SpringBoot集成实战三、高级特性应用1. 异步并行执行2

Python中图片与PDF识别文本(OCR)的全面指南

《Python中图片与PDF识别文本(OCR)的全面指南》在数据爆炸时代,80%的企业数据以非结构化形式存在,其中PDF和图像是最主要的载体,本文将深入探索Python中OCR技术如何将这些数字纸张转... 目录一、OCR技术核心原理二、python图像识别四大工具库1. Pytesseract - 经典O

SpringMVC高效获取JavaBean对象指南

《SpringMVC高效获取JavaBean对象指南》SpringMVC通过数据绑定自动将请求参数映射到JavaBean,支持表单、URL及JSON数据,需用@ModelAttribute、@Requ... 目录Spring MVC 获取 JavaBean 对象指南核心机制:数据绑定实现步骤1. 定义 Ja

HTML5 getUserMedia API网页录音实现指南示例小结

《HTML5getUserMediaAPI网页录音实现指南示例小结》本教程将指导你如何利用这一API,结合WebAudioAPI,实现网页录音功能,从获取音频流到处理和保存录音,整个过程将逐步... 目录1. html5 getUserMedia API简介1.1 API概念与历史1.2 功能与优势1.3

在Windows上使用qemu安装ubuntu24.04服务器的详细指南

《在Windows上使用qemu安装ubuntu24.04服务器的详细指南》本文介绍了在Windows上使用QEMU安装Ubuntu24.04的全流程:安装QEMU、准备ISO镜像、创建虚拟磁盘、配置... 目录1. 安装QEMU环境2. 准备Ubuntu 24.04镜像3. 启动QEMU安装Ubuntu4

SQLite3命令行工具最佳实践指南

《SQLite3命令行工具最佳实践指南》SQLite3是轻量级嵌入式数据库,无需服务器支持,具备ACID事务与跨平台特性,适用于小型项目和学习,sqlite3.exe作为命令行工具,支持SQL执行、数... 目录1. SQLite3简介和特点2. sqlite3.exe使用概述2.1 sqlite3.exe