从我学Android开始,一直就想做一件事。就是好好把APIDemo看一遍。今天开始会抽时间把Android官方的APIDemo程序全部过一遍。主要是为了两个目的:第一,复习以前学习的API用法。第二,掌握Android整体可以使用的API。方便以后做某些功能,知道有哪些API可以直接使用。

  这个系列先从动画开始,因为动画是最常用的,而且我对Android的动画也不是很熟悉,只是会用一些简单动画。因此打算从动画API开始看。个人觉得APIDemo这个程序是一个很好的教材,很适合初学和当资料查询。

(PS:新建的QQ群,有兴趣可以加入一起讨论:Android群:322599434)

1、文件路径

\ApiDemo\src\com\example\android\apis\animation\AnimationCloning.java

2、LinearLayout动态添加View

  今天的动画类里面有一个知识点,就是动态给LinearLayout添加一个View,这个在平时开发的过程中是很有用的技巧,特别是在需要自定义View的界面。


//Edited by mythou
//http://www.cnblogs.com/mythou/

//查找XML里面的LinearLayout

LinearLayout container = (LinearLayout) findViewById(R.id.container);
//创建自定义View对象
final MyAnimationView animView = new MyAnimationView(this);
//把自定义View添加到LinearLayout
container.addView(animView);

2、创建球形

        
//Edited by mythou
//http://www.cnblogs.com/mythou/
    private ShapeHolder addBall(float x, float y)
{
//绘制一个椭圆
OvalShape circle = new OvalShape();
//设置椭圆高宽
circle.resize(50f * mDensity, 50f * mDensity);
//初始化圆形
ShapeDrawable drawable = new ShapeDrawable(circle);
ShapeHolder shapeHolder = new ShapeHolder(drawable);
shapeHolder.setX(x - 25f);
shapeHolder.setY(y - 25f);
//产生随机颜色
int red = (int) ( + Math.random() * );
int green = (int) ( + Math.random() * );
int blue = (int) ( + Math.random() * );
int color = 0xff000000 | red << | green << | blue;
Paint paint = drawable.getPaint(); // new
// Paint(Paint.ANTI_ALIAS_FLAG);
int darkColor = 0xff000000 | red / << | green / << | blue / ;
//镜像渐变 参数一为渐变起初点坐标x位置,参数二为y轴位置,
//参数三半径范围,参数4、5是代表中心颜色和边缘颜色,最后参数为平铺方式
//Shader.TileMode.CLAMP:使用Shader的边界颜色来填充剩余的空间

RadialGradient gradient = new RadialGradient(37.5f, 12.5f, 50f,
color, darkColor, Shader.TileMode.CLAMP);
paint.setShader(gradient);
shapeHolder.setPaint(paint);
balls.add(shapeHolder);
return shapeHolder;
}

  上面是创建一个球形的过程,里面用到一个ApiDemo里面自己编写的管理图形的类ShapeHolder,这个以后再说。主要是看看上面如何创建一个球形,这里使用了OvalShape创建一个椭圆形,不过下面设置了相同的的长宽,最后出来的是一个圆形。上面随机生成一种RGB颜色,所以你每次启动这个程序,得到的球形颜色都不一样。

  另外,RadialGradient是一个比较有趣的类,它实现了图形填充的效果,而且可以自定义光影填充,它的参数如下含义

  • 参数一为渐变起初点坐标x位置
  • 参数二为y轴位置
  • 参数三半径范围
  • 参数4、5是代表中心颜色和边缘颜色
  • 最后参数为平铺方式Shader.TileMode.CLAMP:使用Shader的边界颜色来填充剩余的空间

你可以对比上面的效果图,效果图的右上角是颜色比较浅,而且有一个向外扩散的光影效果。就是由这个类实现的效果。你可以修改代码,调试一下。熟悉这个类的用法。

3、动画效果

        
//Edited by mythou
//http://www.cnblogs.com/mythou/
     private void createAnimation()
{
if (animation == null)
{
//初始化属性动画
ObjectAnimator anim1 = ObjectAnimator.ofFloat(balls.get(),
"y", 0f, getHeight() - balls.get().getHeight())
.setDuration();
ObjectAnimator anim2 = anim1.clone();
anim2.setTarget(balls.get());
//添加刷新监听器
anim1.addUpdateListener(this); //第三个球体动画
ShapeHolder ball2 = balls.get();
ObjectAnimator animDown = ObjectAnimator.ofFloat(ball2, "y",
0f, getHeight() - ball2.getHeight()).setDuration();
//AccelerateInterpolator:在动画开始的地方速率改变比较慢,然后开始加速
animDown.setInterpolator(new AccelerateInterpolator());
ObjectAnimator animUp = ObjectAnimator.ofFloat(ball2, "y",
getHeight() - ball2.getHeight(), 0f).setDuration();
//DecelerateInterpolator在动画开始的地方速率改变比较慢,然后开始减速
animUp.setInterpolator(new DecelerateInterpolator());
AnimatorSet s1 = new AnimatorSet();
//连续执行两种动画
s1.playSequentially(animDown, animUp);
animDown.addUpdateListener(this);
animUp.addUpdateListener(this); AnimatorSet s2 = (AnimatorSet) s1.clone();
s2.setTarget(balls.get()); animation = new AnimatorSet();
//同时播放前面3个球的动画
animation.playTogether(anim1, anim2, s1);
//顺序播放后面两个球动画
animation.playSequentially(s1, s2);
}
}

  上面就是动画设置的过程。注意,这里只是设置了动画的规则,跑完这些代码,并不会有任何动画,因为动画启动是另外的接口,这里只是设置了动画执行过程的属性。这里使用了属性动画,是Android3.0以后才新增加的动画方式。这里不详细说动画属性概念,只是为了会使用。

  这里主要是使用ObjectAnimator来设置动画过程,属性动画会修改对象的属性,而且这种动画也有限制。ofFloat是设置动画流程的接口,这里是设置了沿着Y坐标从0到View的高度移动。后面几个就是设置动画流程,可以参考上面代码注释。

  playTogether和playSequentially是两种设置连续动画的接口,只是一个是全部动画同时运行,另外一个是一个接着一个运行。

  最后强调一点,这里只是设置动画流程,下面的接口调用了,才会启动动画。

5、动画运行

//开始执行动画
animation.start();

6、动画监听接口

  在动画执行过程中,我们可以重写ValueAnimator.AnimatorUpdateListener接口,来监听运行过程,例如这里我们重写了ValueAnimator.AnimatorUpdateListener来刷新自定义的View界面。


//Edited by mythou
//http://www.cnblogs.com/mythou/
public void onAnimationUpdate(ValueAnimator animation)
{
invalidate();
}

2013-8-16

Edited by 泡泡糖

Edited by mythou

原创博文,转载请标明出处:http://www.cnblogs.com/mythou/p/3260959.html 

 

Android遍历API (1) 动画篇——克隆动画AnimationCloning的更多相关文章

  1. 笔记-动画篇-layout动画初体验

    约束动画的文章要比预计的迟迟来临,最大的原因是没有找到我认为的足够好的动画来讲解约束动画 —— 当然了,这并不是因为约束动画太难.相反,因为约束动画实在太简单了,反而没有足够多的简单动画素材让我选用. ...

  2. (原)Unreal源码搬山-动画篇 自定义动画节点(一)

    @author:黑袍小道 太忙了,来更新下,嘿嘿 前言: 本文是接着上文 Unreal搬山之动画模块_Unreal动画流程和框架,进行简单入门如何自定义动画图标的AnimNode. 正文: 一.Ani ...

  3. jQuery-4.动画篇---自定义动画

    jQuery中动画animate(上) 有些复杂的动画通过之前学到的几个动画函数是不能够实现,这时候就需要强大的animate方法了 操作一个元素执行3秒的淡入动画,对比一下2组动画设置的区别 $(e ...

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

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

  5. ANDROID L——Material Design具体解释(动画篇)

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

  6. Android 逐帧动画( Drawable 动画),这一篇就够了

    前言 作为 Android 最常见的两种动画形式,逐帧动画( Drawable 动画),有着极其广泛的应用,它的原理与早起的电影以及 GIF 类似,就是把一张的图,按顺序快速切换,这样一来看上去就好像 ...

  7. Android窗口管理服务WindowManagerService显示窗口动画的原理分析

    文章转载至CSDN社区罗升阳的安卓之旅,原文地址:http://blog.csdn.net/luoshengyang/article/details/8611754 在前一文中,我们分析了Activi ...

  8. Android动画(二)-属性动画

    我们在上一篇博客中,讨论了视图动画与帧动画.那么这节课则要讨论更复杂,更强大的Property animation(属性动画). 视图动画使用简单,但是功能也简单.(只有那四种功能).并且也不改变Vi ...

  9. Android动画(一)-视图动画与帧动画

    项目中好久没用过动画了,所以关于动画的知识都忘光了.知识总是不用则忘.正好最近的版本要添加比较炫酷的动画效果,所以也借着这个机会,写博客来整理和总结关于动画的一些知识.也方便自己今后的查阅. Andr ...

随机推荐

  1. 移动端、PC端(前后台)、小程序常用的UI框架

    1.移动端UI库 ①.Vant UI 官方地址:https://youzan.github.io/vant/#/zh-CN/intro github地址:https://github.com/youz ...

  2. [BZOJ4541][HNOI2016]矿区(平面图转对偶图)

    https://www.cnblogs.com/ljh2000-jump/p/6423399.html #include<cmath> #include<vector> #in ...

  3. 滑动CheckBox样式

    <Style x:Key="SliderCheckBox" TargetType="{x:Type CheckBox}"> <Setter P ...

  4. zabbix 添加被监控主机

    点击 configured > host > create host 主机名:输入主机名,允许使用字母数字,空格,点,破折号和下划线 组:从右侧选择框中选择一个或多个组,然后单击 « 将其 ...

  5. Structured Streaming教程(3) —— 与Kafka的集成

    Structured Streaming最主要的生产环境应用场景就是配合kafka做实时处理,不过在Strucured Streaming中kafka的版本要求相对搞一些,只支持0.10及以上的版本. ...

  6. 用Jersey构建RESTful服务1--HelloWorld

    一.环境1.Eclipse Juno R22. Tomcat 73. Jersey 2.7  下载地址( https://jersey.java.net/download.html) 二.流程1.Ec ...

  7. .NET:race conditions

    race conditions (when an anomalous result occurs due to an unexpected critical dependence on the tim ...

  8. 使用jetty工具包处理url参数成map

    引入工具包: <dependency> <groupId>org.mortbay.jetty</groupId> <artifactId>jetty-u ...

  9. java线程安全之并发Queue

    关闭 原 java线程安全之并发Queue(十三) 2017年11月19日 23:40:23 小彬彬~ 阅读数:12092更多 所属专栏: 线程安全    版权声明:本文为博主原创文章,未经博主允许不 ...

  10. eclipse-在编译项目时js特别慢的问题

    eclipse在编译项目时,当项目中导入了很多第三方js库时,eclipse在验证js时会消耗大量的时间,而我们却完全不用考虑那些js是否有错误 步骤: 去除eclipse的JS验证: 1.将wind ...