前面两种方法有个明显的缺点就是当背景是透明的情况下就会出现画出的东西擦除不掉,因为擦除方法都是利用重新刷新背景颜色产生的效果。那么这时候这个方法就很适合了,就是利用多张图片连续播放产生动画效果。而且也排除了那种边框不规则导致的绘画问题。
放一些这样的图片在drawable中,图片的名字必须是字符或者下划线开头,我这里的图片名字都是anim_1等等,然后加一个相关的xml文件,我这里的xml文件名为anim_list,里面的代码像这样。
<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android" >
<item android:drawable="@drawable/anim_1" android:duration="100" />
<item android:drawable="@drawable/anim_2" android:duration="100" />
<item android:drawable="@drawable/anim_3" android:duration="100" />
<item android:drawable="@drawable/anim_4" android:duration="100" />
<item android:drawable="@drawable/anim_5" android:duration="100" />
<item android:drawable="@drawable/anim_6" android:duration="100" />
<item android:drawable="@drawable/anim_7" android:duration="100" />
<item android:drawable="@drawable/anim_8" android:duration="100" />
<item android:drawable="@drawable/anim_9" android:duration="100" />
<item android:drawable="@drawable/anim_10" android:duration="100" />
<item android:drawable="@drawable/anim_11" android:duration="100" />
<item android:drawable="@drawable/anim_12" android:duration="100" />
<item android:drawable="@drawable/anim_13" android:duration="100" />
<item android:drawable="@drawable/anim_14" android:duration="100" />
<item android:drawable="@drawable/anim_15" android:duration="100" />
</animation-list>
然后在主activity的xml布局文件中加上一段
<ImageView
android:id="@+id/imageView1"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:background="@drawable/anim_list" />
再在住activity的java代码中调用
private ImageView sildeImage;
private AnimationDrawable ad;
sildeImage = (ImageView)findViewById(SystemView.getViewID(this,"imageView1"));
ad = (AnimationDrawable) sildeImage.getBackground();
ad.start(); // 动画开始播放
ad.stop(); // 动画停止播放
上面这段代码4部分都不是在一起的,根据需要反正需要的地方,你需要在什么地方开始动画就调用start函数,需要什么时候停止就调用stop函数。