android开发-简单动画3

前面两种方法有个明显的缺点就是当背景是透明的情况下就会出现画出的东西擦除不掉,因为擦除方法都是利用重新刷新背景颜色产生的效果。那么这时候这个方法就很适合了,就是利用多张图片连续播放产生动画效果。而且也排除了那种边框不规则导致的绘画问题。

这里写图片描述
放一些这样的图片在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函数。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值