Material DesignGoogle推出的一个全新的设计语言,它的特点就是拟物扁平化。

Material Design包含了很多内容,今天跟大家分享一下Material新增的动画:

在Android L中新增了如下几种动画:

* middot;Touch feedback(触摸反馈)

* middot;Reveal effect(揭露效果)

* middot;Activity transitionsActivity转换效果)

* middot;Curved motion(曲线运动)

* middot;View state changes (视图状态改变)

* middot;Animate Vector Drawables(可绘矢量动画)

本篇文章先介绍下上面6种中比较常用前三种。

触摸反馈

在Android 5.0中加入了触摸反馈动画。

其中最明显,最具代表性的就是波纹动画,比如当点击按钮时会从点击的位置产生类似于波纹的扩散效果。

波纹效果(Ripple):

当你使用了Material主题后,波纹动画会自动应用在所有的控件上,我们当然可以来设置其属性来调整到我们需要的效果。

可以通过如下代码设置波纹的背景:

android:background="?android:attr/selectableItemBackground"波纹有边界

android:background="?android:attr/selectableItemBackgroundBorderless"波纹超出边界

使用效果如下:

B1是不设任何背景的按钮

B2设置了?android:attr/selectableItemBackground

B3设置了?android:attr/selectableItemBackgroundBorderless

设置颜色:

我们也可以通过设置xml属性来调节动画颜色,从而可以适应不同的主题:

android:colorControlHighlight设置波纹颜色

android:colorAccent设置checkbox等控件的选中颜色

比如下面这个比较粉嫩的主题,就需要修改动画颜色来匹配:

Circular Reveal

Circular Reveal是Android L新增的一个动画效果。

使用方法:

应用ViewAnimationUtils.createCircularReveal()方法可以去创建一个RevealAnimator动画ViewAnimationUtils.createCircularReveal源码如下:

1

2

3

4

public static Animator createCircularReveal(View view,

int centerX,  int centerY, float startRadius, float endRadius) {

return new RevealAnimator(view, centerX, centerY, startRadius, endRadius);

}

源码非常简单,就是通过createCircularReveal方法根据5个参数来创建一个RevealAnimator动画对象。这5个参数分别是:

* middot;view 操作的视图

* middot;centerX 动画开始的中心点X

* middot;centerY 动画开始的中心点Y

* middot;startRadius 动画开始半径

* middot;startRadius 动画结束半径

根据下面的效果图和代码可以很容易的了解这几个参数的作用:

代码示例:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

30

31

32

final View oval = this.findViewById(R.id.oval);

oval.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

Animator animator = ViewAnimationUtils.createCircularReveal(

oval,

oval.getWidth()/2,

oval.getHeight()/2,

oval.getWidth(),

0);

animator.setInterpolator(new AccelerateDecelerateInterpolator());

animator.setDuration(2000);

animator.start();

}

});

final View rect = this.findViewById(R.id.rect);

rect.setOnClickListener(new View.OnClickListener() {

@Override

public void onClick(View v) {

Animator animator = ViewAnimationUtils.createCircularReveal(

rect,

0,

0,

0,

(float) Math.hypot(rect.getWidth(), rect.getHeight()));

animator.setInterpolator(new AccelerateInterpolator());

animator.setDuration(2000);

animator.start();

}

});

总结:

RevealAnimator和之前的动画使用没什么区别,同样可以设置监听器和加速器来实现各种各样的特效。这些效果常用在视图的添加,删除,状态,大小改变的时候。

Activity Transition

Activity Transition是Material Design中提供的一种动画效果。它通过运动和切换不同状态之间的元素来产生各种动画效果。

简介

Activity Transition提供了两种Transition类型:

1、Enter(进入):进入一个Activity的效果

2、Exit(退出):退出一个Activity的效果

而这每种类型又分为普通和共享元素Transition。

普通Transition

explode从场景的中心移入或移出

slide从场景的边缘移入或移出

fade调整透明度产生渐变效果

Shared Elements Transition 共享元素转换

它的作用就是共享两个acitivity中共同的元素,在Android 5.0下支持如下效果:

changeBounds -  改变目标视图的布局边界

changeClipBounds - 裁剪目标视图边界

changeTransform - 改变目标视图的缩放比例和旋转角度

changeImageTransform - 改变目标图片的大小和缩放比例

下面是我写的一个小演示Demo,相信大家看后就知道这几个动画是如何工作的了:

Activity Transition使用

使用Activity Transition十分简单,只需要如下两个步骤:

步骤一:设置允许使用transition,并且设置transition。

xml

首先,如果要使用transition需要先修改style文件,在继承了material主题的style.xml中添加如下属性:

1

2

3

4

5

6

7

8

9

10

11

12

13

14

<style name="myTheme" parent="android:Theme.Material">

<!-- 允许使用transitions -->

<item name="android:windowContentTransitions">true</item>

<!-- 指定进入和退出transitions -->

<item name="android:windowEnterTransition">@transition/explode</item>

<item name="android:windowExitTransition">@transition/explode</item>

<!-- 指定shared element transitions -->

<item name="android:windowSharedElementEnterTransition">

@transition/change_image_transform</item>

<item name="android:windowSharedElementExitTransition">

@transition/change_image_transform</item>

</style>

下面再来看看如何定义transition动画:

1

2

3

4

5

6

7

<transitionSet xmlns:android="http://schemas.android.com/apk/res/android">

<explode/>

<changeBounds/>

<changeTransform/>

<changeClipBounds/>

<changeImageTransform/>

</transitionSet>

transition里面的元素使用方法和以前的AnimationSet差不多,具体如何使用大家可以参考官方文档。

代码:

在代码中同样可以完成对于transition的设置:

1

2

3

4

5

// 允许使用transitions

getWindow().requestFeature(Window.FEATURE_CONTENT_TRANSITIONS);

// 设置一个exit transition

getWindow().setExitTransition(new Explode());

可以通过如下方法在代码总设置transition效果:

Window.setEnterTransition()普通transition的进入效果

Window.setExitTransition()普通transition的退出效果

Window.setSharedElementEnterTransition()共享元素transition的进入效果

Window.setSharedElementExitTransition()共享元素transition的退出效果

步骤二:启动Activity。

当你已经设置了允许使用Transition并设置了Transition动画,你就可以通过ActivityOptions.makeSceneTransitionAnimation()方法启动一个新的Activity来激活这个Transition:

启用普通的Transition

1

2

startActivity(intent,

ActivityOptions.makeSceneTransitionAnimation(this).toBundle());

启用共享元素Transition

启动shared element transition和普通的transition稍有不同,在所有需要共享视图的Activity中,使用android:transitionName属性对于需要共享的元素分配一个通用的名字。

1

2

3

4

5

6

Intent intent = new Intent(this, Activity2.class);

// shareView: 需要共享的视图

// "shareName": 设置的android:transitionName="shareName"

ActivityOptions options = ActivityOptions

.makeSceneTransitionAnimation(this, shareView, "shareName");

startActivity(intent, options.toBundle());</span>

如果有多个View需要共享,则通过Pair.create()方法创建多个匹配对然后传入ActivityOptions.makeSceneTransitionAnimation。

代码如下:

1

2

3

ActivityOptions options = ActivityOptions.makeSceneTransitionAnimation(this,

Pair.create(view1, "agreedName1"),

Pair.create(view2, "agreedName2"));

如果不想使用transition可以设置options bundle为null。当需要结束当前Activity并回退这个动画时调用Activity.finishAfterTransition()方法。

兼容性:

上面介绍的几个新动画的APIs只允许在Android L中使用:

* middot;Activity transitions

* middot;Touch feedback

* middot;Reveal animations

所以为了兼容早期版本,则需要在调用这些api的时候先进行检查系统版本。

[转]Android 5.0——Material Design详解(动画篇)的更多相关文章

  1. ANDROID L——Material Design详解(UI控件)

    转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! Android L: Google已经确认Android L就是Android Lolli ...

  2. [转]ANDROID L——Material Design详解(动画篇)

    转载请注明本文出自大苞米的博客(http://blog.csdn.net/a396901990),谢谢支持! 转自:http://blog.csdn.net/a396901990/article/de ...

  3. Android项目刮刮奖详解扩展篇——开源刮刮奖View的制作

    Android项目刮刮奖详解(四) 前言 我们已经成功实现了刮刮奖的功能了,本期是扩展篇,我们把这个View直接定义成开源控件,发布到JitPack上,以后有需要也可以直接使用,关于自定义控件的知识, ...

  4. android Material Design详解

    原文地址:http://blog.csdn.net/jdsjlzx/article/details/41441083/ 前言 我们都知道Marterial Design是Google推出的全新UI设计 ...

  5. Android(Lollipop/5.0) Material Design(六) 自定义动画

    官网地址:https://developer.android.com/intl/zh-tw/training/material/animations.html 动画在Material设计中,为用户与a ...

  6. Android 7.0 IMS框架详解

    本文主要讲解IP Multimedia Subsystem (IMS)在Android 7.0上由谷歌Android实现的部分内容.从APP侧一直到Telephony Framework,是不区分CS ...

  7. android 6.0 权限设置详解

    从Android 6.0版本开始,在安装应用时,该应用无法取得任何权限. 相反,在使用应用的过程中,若某个功能需要获取某个权限,系统会弹出一个对话框,显式地由用户决定是否将该权限赋予应用. 只有得到了 ...

  8. Android(Lollipop/5.0) Material Design(二) 入门指南

    Material Design系列 Android(Lollipop/5.0)Material Design(一) 简介 Android(Lollipop/5.0)Material Design(二) ...

  9. Android(Lollipop/5.0) Material Design(六) 使用图像

    Material Design列 Android(Lollipop/5.0)Material Design(一) 简单介绍 Android(Lollipop/5.0)Material Design(二 ...

随机推荐

  1. sql 清空所有数据

    近来发现数据库过大,空间不足,因此打算将数据库的数据进行全面的清理,但表非常多,一张一张的清空,实在麻烦,因此就想利用SQL语句一次清空所有数据.找到了三种方法进行清空.使用的数据库为MS SQL S ...

  2. okhttp3教程(1)如何引入库

    官网: https://github.com/square/okhttp https://github.com/square/okio 1,使用okhttp3需要两个库 在build.gradle c ...

  3. (1)若当前字符不是大于0的数字字符,则复制该字符于新字符串中; (2)若当前字符是一个数字字符,且它之后没有后继字符,则简单地将它复制到新字符串中; (3)若当前字符是一个大于0的数字字符,并且还有后继字符,设该数字字符的面值为n,将它的后继字符重复复制n+1次到新字符串中; (4)以上述一次变换为一组,在不同组之间另插入一个"_"用于分割(5))若字符串中包含有下划线'_',则变换为 \UL

    package b; import java.util.Scanner; public class Zifuchuan { public static void main(String[] args) ...

  4. oracle数据库导入导出dmp文件oracle命令

    在控制台下导入imp scott/密码@orcl file=文件路径 full=Y 导出 整个数据库TEST 用户名system  密码1234 exp system/1234@TEST file=文 ...

  5. CodeForces 567C Geometric Progression

    Geometric Progression Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I ...

  6. Cheatsheet: 2013 12.17 ~ 12.31

    .NET Introducing ASP.NET Web API Throttling handler C# async and await: A Deeper Dive PARALLEL PROGR ...

  7. 终端、shell、bash的区别联系

    最佳答案 终端,即所谓的命令行界面,又称命令终端,用户输入shell命令用的窗口,跟Windows里的DOS界面差不多. shell,Shell就是用户和操作系统之间的壳,中介,GUI和CLI都算是S ...

  8. ubuntu下mysqli_connect()显示未定义,mysqli_fetch_all()显示未定义 解决方法

    mysqli_connect()显示未定义解决方法: http://www.cnblogs.com/misoag/archive/2013/01/24/2874439.html 让apache.php ...

  9. spring引入实体类映射文件

    由于spring对hibernate配置文件hibernate.cfg.xml的集成相当好  LocalSessionFactoryBean有好几个属性用来查找hibernate映射文件:  mapp ...

  10. [HDOJ5723]Abandoned country(最小生成树,期望)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5723 题意:求最小生成树,并且求这棵最小生成树上所有边走过次数的期望. 走过次数的期望=Σ边被走过次数 ...