zoukankan      html  css  js  c++  java
  • android魔法泡泡动画分析(附源码)

      来看贴图

      原图魔法效果:(透明的有些看不清)

      

      PS之后加了背景色并放大后的效果

      

      在屏幕中的效果(左上很小的那个,其他都是背景图):

      

      中间很小的那个就是

      先看动画实现代码explosion.xml(explosion意思是爆发)

      <animation-list xmlns:android="http://schemas.android.com/apk/res/android"
      android:oneshot="true">
      <item android:drawable="@drawable/explode1" android:duration="70" />
      <item android:drawable="@drawable/explode2" android:duration="70" />
      <item android:drawable="@drawable/explode3" android:duration="70" />
      <item android:drawable="@drawable/explode4" android:duration="70" />
      <item android:drawable="@drawable/explode5" android:duration="70" />
      </animation-list>

       手指点击后产生泡泡的动画是5张40*40的图片顺序播放产生的,每张持续时间为70毫秒,播放模式为oneshot,即一次。
      BubbleExplosion.java

      package com.ray.bubble;
      import android.app.Activity;
      import android.content.Context;
      import android.graphics.drawable.AnimationDrawable;
      import android.os.Bundle;
      import android.view.MotionEvent;
      import android.view.View;
      import android.view.Window;
      import android.view.WindowManager;
      import android.view.View.OnTouchListener;
      import android.widget.FrameLayout;
      import android.widget.ImageView;
      public class BubbleExplosion extends Activity {
      private FrameLayout fl;
      private ExplosionView exv1;
      private AnimationDrawable exa1;
      //        private Contact contact;
      public void onCreate(Bundle savedInstanceState) {
      super.onCreate(savedInstanceState);
      //set full screen
      requestWindowFeature(Window.FEATURE_NO_TITLE);
      getWindow().setFlags(WindowManager.LayoutParams. FLAG_FULLSCREEN ,
      WindowManager.LayoutParams. FLAG_FULLSCREEN);
      fl = new FrameLayout(this);
      fl.setBackgroundResource(R.drawable.bg);
      exv1 = new ExplosionView(this);
      exv1.setVisibility(View.INVISIBLE);
      exv1.setBackgroundResource(R.anim.explosion);
      exa1 = (AnimationDrawable)exv1.getBackground();
      fl.addView(exv1);
      fl.setOnTouchListener(new LayoutListener());
      setContentView(fl);
      }
      class ExplosionView extends ImageView{
      public ExplosionView(Context context) {
      super(context);
      }
      //handle the location of the explosion
      public void setLocation(int top,int left){
      this.setFrame(left, top, left+40, top+40);
      }
      }
      class LayoutListener implements OnTouchListener{
      public boolean onTouch(View v, MotionEvent event) {
      //first u have to stop the animation,or if the animation
      //is starting ,u can start it again!
      exv1.setVisibility(View.INVISIBLE);
      exa1.stop();
      float x = event.getX();
      float y = event.getY();
      exv1.setLocation((int)y-20, (int)x-20);
      exv1.setVisibility(View.VISIBLE);
      exa1.start();
      return false;
      }
      }
      }

      精华提炼:
      1.Line 31 exv1.setBackgroundResource(R.anim.explosion);
      exv1是继承自ImageView的视图,看到他将一个animation设置成背景了,惊讶!原来动画可以设置为背景图。
      2.Line 32 exa1 = (AnimationDrawable)exv1.getBackground();
      Line 60 exa1.start();
      不仅仅Aniamtion有start()方法,原来AnimationDrawable作为一个Drawable的子类也可以有start()方法哦。
      没见过吧,之前我也没见过;见过啦?我现在也见过了!
      再补充几个常识性的
      3.setContentView(fl);
      用代码绘制布局,完全没用到layout/main.xml~~
      4.Line 23-25
      设置全屏

    点击下载附件

  • 相关阅读:
    Leetcode 15. 3Sum
    本周学习小结(01/07
    面试总结之Data Science
    学习笔记之MongoDB
    本周学习小结(13/05
    Django知识点总结
    Django【进阶篇 】
    Django【基础篇】
    如何拿到半数面试公司Offer——我的Python求职之路(转载)
    Django框架(三)
  • 原文地址:https://www.cnblogs.com/vus520/p/2561582.html
Copyright © 2011-2022 走看看