仿58同城加载动画

本文介绍了如何使用Frame动画技术在58同城客户端中实现加载时的可爱小人动画效果,包括动画的布局设计、动画布局文件的创建以及主函数代码实现,展示了动画从静止到运行的过程。

     想必用过58同城客户端的用户对那个加载小人的动画印象很深刻,一个可爱的小人在那拼命的跑。这个动画实现的方法其实很多,今天这里就用frame动画来实现一下。

一、效果图:


二、布局文件

<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
     android:padding="15dip"
    tools:context=".MainActivity" >

    <ImageView
        android:id="@+id/imageView"
        android:layout_width="100dp"
        android:layout_height="100dp"
        android:onClick="start"
        android:layout_centerInParent="true"
        android:scaleType="fitCenter"
        android:src="@anim/frame" />

</RelativeLayout>
三、动画布局

新建一个anim文件,里面存放的就是准备frame动画的图片

<?xml version="1.0" encoding="utf-8"?>
<animation-list xmlns:android="http://schemas.android.com/apk/res/android"
    android:oneshot="false" >

    <item
        android:drawable="@drawable/ep_dialog_loading_frame1"
        android:duration="80"/>
    <item
        android:drawable="@drawable/ep_dialog_loading_frame2"
        android:duration="80"/>

</animation-list>
四、 主函数代码:

通过image view的getDrawabel方法 得到一个 AnimationDrawable对象 然后调用start方法就可以开启动画了。

package com.example.loadinganimation;
import android.os.Bundle;
import android.app.Activity;
import android.graphics.drawable.AnimationDrawable;
import android.view.Menu;
import android.view.View;
import android.widget.ImageView;

public class MainActivity extends Activity {

	private ImageView imageView;
	private AnimationDrawable ad;

	@Override
	protected void onCreate(Bundle savedInstanceState) {
		super.onCreate(savedInstanceState);
		setContentView(R.layout.activity_main);

		imageView = (ImageView) findViewById(R.id.imageView);
		ad = (AnimationDrawable) imageView.getDrawable(); // 获取图片内容, 强转为动画对象
	}
	// imageview的点击事件
	// 点击播放动画,再次点击动画停止,依次反复
	public void start(View v) {
		if (ad.isRunning())
			ad.stop();
		else
			ad.start(); // 开始播放
	}

}
五、源码:

http://download.youkuaiyun.com/detail/xiaobijia/8197585



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值