update motion language (#12478)

This commit is contained in:
jiang 2018-09-30 11:43:53 +08:00 committed by GitHub
parent 1288b1cc6d
commit aee625b2ea
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
2 changed files with 122 additions and 14 deletions

View File

@ -5,23 +5,91 @@ title:
en-US: Motion
---
Ant Motion 是 Ant Design 中提炼出来的动效语言。他不仅仅是动效语言,同时也是一套 React 框架动效解决方案,可以帮助开发者,更容易在项目中使用动效。 我们提供了单项,组合动画,以及整套解决方案。
> [Ant Motion](https://motion.ant.design/) 是 Ant Design 中提炼出来的动效语言。他不仅仅是动效语言,同时也是一套 React 框架动效解决方案,可以帮助开发者,更容易在项目中使用动效。 我们提供了单项,组合动画,以及整套解决方案。
你可以通过 React 标签,以简单的配置即可完成想要的动画,可以快速的实现不同组合的动画效果,更好的提高你的工作效率,[Github 反馈地址](https://github.com/ant-design/ant-motion/issues)
界面动效能加强用户认知且增加活力。
## 设计资源
## 动效价值
Ant Motion 在界面里主要是来加强体验舒适度、描述层级关系、增加界面活力、反馈与意向等功能性的动效。并提供了完整的一套遵从 Ant Design 的视觉规范来完成的 demo 页面,可灵活又快速的配置出你想要的首页模板
- **增加体验舒适度:** 让用户认知过程更为自然
- [动效语言](https://motion.ant.design/language/basic)
- [首页的解决方案](https://motion.ant.design/edit/#t%3Dnav_0_0%2Ccontent_0_0%2Ccontent_2_0%2Ccontent_3_0%2Ccontent_4_0%2Cfooter_0_0)
- **增加界面活力:**第一时间吸引注意力,突出重点。
## 前端实现
- **描述层级关系:**体现元素之间的层级与空间关系。
我们提供完善的动效语言 & 动效组件 & 动效模板,此外还提供了一整套首页的解决方案,来帮助用户快速设计出高质量的动效。资源在不断优化更新中,你的阅读和反馈正是我们不断前进的动力
- **提供反馈、明确意向:**助力交互体验
- [单元素动效执行组件](https://motion.ant.design/components/tween-one)
- [样式进出场组件](https://motion.ant.design/components/animate)
- [队列进出场组件](https://motion.ant.design/components/queue-anim)
- [随滚动执行效果组件](https://motion.ant.design/components/scroll-anim)
- [切换效果组件](https://motion.ant.design/components/banner-anim)
## 衡量动效意义
衡量一个动效是否有意义,我们可以通过以下几个标准来考核:
- **一个动效的存在是否合理:**是否带有明确的目的性,助力交互体验,没有多余的动效。
- **动效与性能:**不能出现大幅度波动丢帧或者卡顿现象, 动效的体验须是流畅的,并且不影响产品的性能。
## 原则
在企业级应用的产品设计中,使用动效和前台类产品有很大的不同,助力交互行为和信息认知的有效性会显得尤为重要,在 ant design 设计价值观的基础之上,我们衍生出动效设计的三原则:
```__react
import { Col, Row } from 'antd';
const text = [
{ title: '自然', img: 'https://gw.alipayobjects.com/zos/rmsportal/LyTPSGknLUlxiVdwMWyu.gif', content: '自然运动规律,保证视觉连惯,让用户感知到动作是成立的' },
{ title: '高效', img: 'https://gw.alipayobjects.com/zos/rmsportal/SQOZVQVIossbXpzDmihu.gif', content: '尽量节省过渡的时间,快速完成过渡的动画效果' },
{ title: '克制', img: 'https://gw.alipayobjects.com/zos/rmsportal/OkIXkscKxywYLSrilPIf.gif', content: '做有意义的动效,不去做太多的修饰和干扰用户' },
];
function Principle() {
const childrenToRender = text.map(item => (
<Col key={item.title} span={8} >
<div className="principle">
<div><img src={item.img} width="80%" /></div>
<h4>{item.title}</h4>
<p>{item.content}</p>
</div>
</Col>
));
return (
<div className="motion-principle-wrapper">
<Row gutter={32} className="principle-wrapper">
{childrenToRender}
</Row>
</div>
);
}
ReactDOM.render(<Principle />, mountNode);
```
### 自然
自然的动效背后体现的是自然运动规律。这就要求动效在转换时保证视觉上的连惯性,让用户感知到这个动作是成立的,是能够引起共鸣的。
<video class="motion-video-min" src="https://gw.alipayobjects.com/os/rmsportal/NTMlQdLIkPjOACXsdRrq.mp4" loop="true"/>
以 button 的动效设计为例,设计师将其想像成一片树叶飘浮在水面之上,当你去触碰它时,叶子会下浮再反弹,然后出现涟漪效果。
### 高效
企业级应用追求的是高效的用户体验,与之对应的动效设计也应如此,尽量节省过渡的时间,快速完成过渡的动画效果。
<video class="motion-video-min" src="https://gw.alipayobjects.com/os/rmsportal/wMKeLGnpDxhwfCsBqKNN.mp4" loop="true" />
举个例子,在出场与进场的动效里,出场不用大张旗鼓的去吸引用户的注意力,而是做到简单清晰即可。所以我们的出场时间采用了更快的速度,同时也不设置队列依次出场的形式,只需要整块直接消失即可。
### 克制
尽量避免夸张的动效,做有意义的事,不去做太多的修饰而干扰用户。
<video src="https://gw.alipayobjects.com/os/rmsportal/FeUCANmoDRwCSmIcnPNF.mp4" loop="true" class="motion-video-min" />
如我们的 Menu在展开时更注重的是菜单的内容而右侧的 icon 切换并不是主要的元素,不需要过度强调去分散用户的注意,所以只需在不经意间切换,明确指示变化即可。
<br />
> 更多详细内容请前往 [Ant Motion 动效原则](https://motion.ant.design/language/basic) 查看;

View File

@ -148,7 +148,8 @@
}
}
.transition-video-player {
.transition-video-player,
.motion-video-min {
float: right;
padding: 0 0 70px 20px;
width: 600px;
@ -157,3 +158,42 @@
padding: 0;
}
}
.motion-video-min {
width: 390px;
}
.motion-principle-wrapper {
width: 100%;
max-width: 900px;
margin: 48px 0;
}
.principle-wrapper {
width: 100%;
.principle {
width: 100%;
min-height: 180px;
display: inline-block;
margin-right: 12.5%;
padding: 24px;
text-align: center;
font-size: 24px;
border-radius: 4px;
border: 1px solid #e8e8e8;
&:last-child {
margin-right: 0;
}
h4 {
margin: 16px 0 8px;
}
p {
font-size: 12px;
line-height: 24px;
}
}
}