Android编程根据系列图片绘制动画实例总结

本文实例讲述了Android编程根据系列图片绘制动画的方法。分享给大家供大家参考,具体如下:

一、采用系统提供的Animation类,用自带的方法

其中的animation.xml文件如下:

<animation-list xmlns:android="http://schemas.android.com/apk/res/android" android:oneshot="false">
 <item android:drawable="@drawable/a" android:duration="100" />
 <item android:drawable="@drawable/b" android:duration="100" />
 <item android:drawable="@drawable/c" android:duration="100" />
 <item android:drawable="@drawable/d" android:duration="100" />
 <item android:drawable="@drawable/e" android:duration="100" />
 <item android:drawable="@drawable/f" android:duration="100" />
 <item android:drawable="@drawable/g" android:duration="100" />
 <item android:drawable="@drawable/h" android:duration="100" />
 <item android:drawable="@drawable/i" android:duration="100" />
 <item android:drawable="@drawable/j" android:duration="100" />
</animation-list>
AnimationDrawable animationDrawable = null;
/**拿到ImageView对象**/
 imageView = (ImageView)findViewById(R.id.imageView);
 /**通过ImageView对象拿到背景显示的AnimationDrawable**/
 animationDrawable = (AnimationDrawable) imageView.getBackground();
 /**开始播放动画**/
 button0 = (Button)findViewById(R.id.button0);
 button0.setOnClickListener(new OnClickListener() {
 @Override
 public void onClick(View arg0) {
 /**播放动画**/
 if(!animationDrawable.isRunning()) {
  animationDrawable.start();
 }
 }
});

其中://设置单次播放 animationDrawable.setOneShot(true);

二、提供了很多帧动画的图片,利用android绘图,可以绘制出人物走动的动画。

如上图,这种情况下,可以按照如下步骤,绘制动画:

1、 根据人物上下左右行走,可以分为四段动画,可以定义一个长度为4的动画数组;
2、 根据键盘上下左右键事件分别触发不同的动画。

主要绘制的语句如下:

mHeroAnim[ANIM_DOWN] = new Animation(context,new int []{R.drawable.hero_down_a,R.drawable.hero_down_b,R.drawable.hero_down_c,R.drawable.hero_down_d},true);
 mHeroAnim[ANIM_LEFT] = new Animation(context,new int []{R.drawable.hero_left_a,R.drawable.hero_left_b,R.drawable.hero_left_c,R.drawable.hero_left_d},true);
 mHeroAnim[ANIM_RIGHT]= new Animation(context,new int []{R.drawable.hero_right_a,R.drawable.hero_right_b,R.drawable.hero_right_c,R.drawable.hero_right_d},true);
 mHeroAnim[ANIM_UP] = new Animation(context,new int []{R.drawable.hero_up_a,R.drawable.hero_up_b,R.drawable.hero_up_c,R.drawable.hero_up_d},true);

三、只提供一张人物图片,就要采用程序来切割该图片,得到动画所需要的帧图像,

如上图,这种情况下,可以按照如下步骤,绘制动画:

1、通过该图片的宽度和高度,和定义的Tile的宽度和高度,可以切割出12张所需要的帧图像;
2、根据人物上下左右行走,可以分为四段动画,可以定义一个长度为4的动画数组;
3、 根据键盘上下左右键事件分别触发不同的动画;
切割图片,以及绘制动画的主要代码如下:

//利用程序来切割图片
Bitmap testmap = ReadBitMap(context,R.drawable.enemy);
Bitmap [][]bitmap = new Bitmap[ANIM_COUNT][ANIM_COUNT];
int tileWidth = testmap.getWidth() / ANIM_COUNT;
int tileHeight = testmap.getHeight() / ANIM_COUNT;
int i = 0,x = 0,y = 0;
for(i =0; i < ANIM_COUNT; i++) {
y = 0;
bitmap[ANIM_DOWN][i] = BitmapClipBitmap(testmap,x,y,tileWidth,tileHeight);
y+=tileHeight;
bitmap[ANIM_LEFT][i] = BitmapClipBitmap(testmap,x,y,tileWidth,tileHeight);
y+=tileHeight;
bitmap[ANIM_RIGHT][i] = BitmapClipBitmap(testmap,x,y,tileWidth,tileHeight);
y+=tileHeight;
bitmap[ANIM_UP][i] = BitmapClipBitmap(testmap,x,y,tileWidth,tileHeight);
x+= tileWidth;
}
mTestAnim[ANIM_DOWN] = new Animation(context,bitmap[ANIM_DOWN],true);
mTestAnim[ANIM_LEFT] = new Animation(context,bitmap[ANIM_LEFT],true);
mTestAnim[ANIM_RIGHT]= new Animation(context,bitmap[ANIM_RIGHT],true);
mTestAnim[ANIM_UP] = new Animation(context,bitmap[ANIM_UP],true);

注意:以上后面两种方式分别采用了不同的绘制方法

第一种的绘制构造方法为:Animation(Context context, int [] frameBitmapID, boolean isloop);

第二种的绘制构造方法为:Animation(Context context, Bitmap [] frameBitmap, boolean isloop);

有了这些准备条件后,我们可以开始真正的绘制:

public void DrawAnimation(Canvas Canvas, Paint paint, int x, int y) {
 //如果没有播放结束则继续播放
 if (!mIsend) {
 Canvas.drawBitmap(mframeBitmap[mPlayID], x, y, paint);
 long time = System.currentTimeMillis();
 if (time - mLastPlayTime > ANIM_TIME) {
 mPlayID++;
 mLastPlayTime = time;
 if (mPlayID >= mFrameCount) {
  //标志动画播放结束
  mIsend = true;
  if (mIsLoop) {
  //设置循环播放
  mIsend = false;
  mPlayID = 0;
  }
 }
 }
 }
}

这里采用了两个标志位来判断动画的状态,mIsend判断动画是否播放,true结束播放,false为播放动画;mIsloop判断动画是否循环,true为循环,false为不循环;当然,动画循环的时候,动画肯定是播放的,于是mIsloop为true,则mIsend为false,由于每一组动画都为四张图片,所以mPlayID最多为4,当人物一组动作也就是一个动画完成后,表示4张图片都绘制了一遍,则要讲mPlayID置为0,表示重新开始需要绘制四张图片代表一个动画。

我们在主类中如何通过按键来触发动画呢?需要通过实现onDraw()方法,并且不断的重绘,主要代码如下:

protected void onDraw(Canvas canvas) {
 canvas.drawBitmap(mMapImage, 0,0, mPaint);
 canvas.save();
 canvas.clipRect(0, 0,320, 30);
 mPaint.setColor(Color.WHITE);
 canvas.drawRect(0, 0,480, 30, mPaint);
 mPaint.setColor(Color.RED);
 canvas.restore();
 /**根据按键更新显示动画**/
 if (mAllkeyDown) {
 if (mIskeyDown) {
  mAnimationState = ANIM_DOWN;
  canvas.drawText("按下下键,开始播放向下动画开始", 0, 20, mPaint);
 } else if (mIskeyLeft) {
  mAnimationState = ANIM_LEFT;
  canvas.drawText("按下左键,开始播放向左动画开始", 0, 20, mPaint);
 } else if (mIskeyRight) {
  mAnimationState = ANIM_RIGHT;
  canvas.drawText("按下右键,开始播放向右动画开始", 0, 20, mPaint);
 } else if (mIskeyUp) {
  mAnimationState = ANIM_UP;
  canvas.drawText("按下上键,开始播放向上动画开始", 0, 20, mPaint);
 }
 /**绘制主角动画**/
 mHeroAnim[mAnimationState].DrawAnimation(canvas, mPaint, 20, 100);
 mTestAnim[mAnimationState].DrawAnimation(canvas, mPaint, 100, 100);
 }else {
 /**按键抬起后人物停止动画**/
 mHeroAnim[mAnimationState].DrawFrame(canvas, mPaint, 20, 100, 0);
 mTestAnim[mAnimationState].DrawFrame(canvas, mPaint, 100, 100, 0);
 canvas.drawText("按键已经抬起动画停止", 0, 20, mPaint);
 }
 super.onDraw(canvas);
 invalidate();
}

这样,我们的动画绘制时时刻刻都在进行着。
我们可以通过控制上下左右按键,来控制标志:

public void setKeyState(int keyCode, boolean state) {
  switch(keyCode) {
  case KeyEvent.KEYCODE_DPAD_DOWN:
  mIskeyDown = state;
  break;
  case KeyEvent.KEYCODE_DPAD_UP:
  mIskeyUp = state;
  break;
  case KeyEvent.KEYCODE_DPAD_LEFT:
  mIskeyLeft = state;
  break;
  case KeyEvent.KEYCODE_DPAD_RIGHT:
  mIskeyRight = state;
  break;
  }
  mAllkeyDown = state;
}

希望本文所述对大家Android程序设计有所帮助。

(0)

相关推荐

  • Android播放多张图片形成的一个动画示例

    本文实例讲述了Android播放多张图片形成的一个动画.分享给大家供大家参考,具体如下: 在Android里可以逐帧的播放图片,然后产生一种动态的效果,准备好几张连续的图片,然后在于源程序res文件夹下建立anim文件夹,然后新建一个XML XML代码如下: <?xml version="1.0" encoding="utf-8"?> <animation-list xmlns:android="http://schemas.androi

  • Android编程实现ImageView图片抛物线动画效果的方法

    本文实例讲述了Android编程实现ImageView图片抛物线动画效果的方法.分享给大家供大家参考,具体如下: 想实现抛物线动画,必须知道抛物线的方程,这时候数学其作用了,假如有如图的抛物线: 按照抛物线的方程特别,知道任何的三点可以确定一条抛物线,由已知抛物线的标注 方程为 y = ax² + bx + c:假设A1坐标为(0,0),A2坐标为(300,0),A3坐标为(150,300):联合解方程得知该抛物线的方程为 y = -1/75 x² + 4x:由此方程,我们可以确定抛物线x和y的

  • android 简单图片动画播放的实例代码

    xml中: 复制代码 代码如下: <ImageView            android:id="@+id/touchview"            android:layout_width="wrap_content"            android:layout_height="wrap_content"            android:layout_alignParentLeft="true"  

  • Android图片翻转动画简易实现代码

    下面给大家分享一个有趣的动画:这里比较适合一张图片的翻转,如果是多张图片,可以参考APIDemo里的例子,就是加个ArrayAdapter,还是简单的,也可以自己发挥修改,实现自己想要的.这里的代码基本上可以直接运行项目了. 在main.xml里加个ImageView,如 复制代码 代码如下: <?xml version="1.0" encoding="utf-8"?> <FrameLayout xmlns:android="http:/

  • Android Tween动画之RotateAnimation实现图片不停旋转效果实例介绍

    主要介绍Android中如何使用rotate实现图片不停旋转的效果.Android 平台提供了两类动画,一类是 Tween 动画,即通过对场景里的对象不断做图像变换(平移.缩放.旋转)产生动画效果:第二类是 Frame 动画,即顺序播放事先做好的图像,跟电影类似.本文分析 Tween动画的rotate实现旋转效果. 在新浪微博客户端中各个操作进行中时activity的右上角都会有个不停旋转的图标,类似刷新的效果,给用户以操作中的提示.这种非模态的提示方式推荐使用,那么下面就分享下如何实现这种效果

  • android实现图片闪烁动画效果的两种实现方式(实用性高)

    大家在使用APP的时候,有的APP在点击语音搜索界面后,会出现一个小话筒,小话筒会类似雷达似得在闪烁,表示正在倾听你说话的内容(这个大家可以参照微软的必应APP),那么问题来了,这种动画效果是如何实现的呢?其实实现这种动画效果有很多种方法,最常见的是两种:第一种就是插入n张图片进行切换已达到如此目的,第二种就是通过改变一张图片的透明度来达到闪烁的效果.下面就分别讲一下通过这两种方法如何实现. 第一种:通过n张图片之间切换实现动画效果 这种方法的原理很简单,利用handler的延时机制在子线程中完

  • Android编程根据系列图片绘制动画实例总结

    本文实例讲述了Android编程根据系列图片绘制动画的方法.分享给大家供大家参考,具体如下: 一.采用系统提供的Animation类,用自带的方法 其中的animation.xml文件如下: <animation-list xmlns:android="http://schemas.android.com/apk/res/android" android:oneshot="false"> <item android:drawable="@

  • Android编程学习之抽象类AbsListView用法实例分析

    本文实例讲述了Android编程学习之抽象类AbsListView用法.分享给大家供大家参考,具体如下: 一.继承关系 public abstract class AbsListView extends AdapterView <T extendsAdapter> java.lang.Object          android.view.View                android.view.ViewGroup                       android.widg

  • Android编程ProgressBar自定义样式之动画模式实现方法

    本文实例讲述了Android编程ProgressBar自定义样式之动画模式实现方法.分享给大家供大家参考,具体如下: 忘记在哪里看到的那位仁兄写的,就是通过用动画效果来实现的,现在顺便也把他写出来,希望那位仁兄不要见怪. 效果: 和之前的一样,在布局文件中: <ProgressBar android:id="@+id/progressBar3" android:layout_width="wrap_content" android:layout_height=

  • Android编程之简单逐帧动画Frame的实现方法

    本文实例讲述了Android编程之简单逐帧动画Frame的实现方法.分享给大家供大家参考,具体如下: 1.逐帧动画 即是通过播放预先排序好的图片来实现动态的画面,感觉像是放电影. 2.实现步骤: ① 在工程里面导入要播放的图片.此简单例子中为start_icon1,2,3. ② 在工程res文件目录下新建一个anim文件夹,在里面新建一个start_animation.xml格式文件,此文件用来定义动画播放图片的顺序及每一张图片显示停留时间. 代码如下: <?xml version="1.

  • Android编程实现压缩图片并加载显示的方法

    本文实例讲述了Android编程实现压缩图片并加载显示的方法.分享给大家供大家参考,具体如下: 解析: 图片压缩的关键就是 options.inSampleSize = scale; 如果scale > 0,表示图片进行了压缩 /** * 压缩图片 * @author chen.lin * */ public class LoadImageActivity extends Activity implements OnClickListener { private Button mBtnLoad;

  • android编程实现系统图片剪裁的方法

    本文实例讲述了android编程实现系统图片剪裁的方法.分享给大家供大家参考,具体如下: package cn.test; import java.io.File; import java.text.SimpleDateFormat; import java.util.Date; import android.app.Activity; import android.content.ContentResolver; import android.content.ContentUris; impo

  • Android编程之界面跳动提示动画效果实现方法

    本文实例讲述了Android编程之界面跳动提示动画效果实现方法.分享给大家供大家参考,具体如下: 上一个效果图: 先上布局: <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:layout_width="match_parent" a

  • Android编程实现下载图片及在手机中展示的方法

    本文实例讲述了Android编程实现下载图片及在手机中展示的方法.分享给大家供大家参考,具体如下: 在项目开发中从互联网上下载图片是经常用到的功能,再次总结一下 1.普通的下载方式 布局文件: <?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android

  • Android编程四大组件之Activity用法实例分析

    本文实例讲述了Android编程四大组件之Activity用法.分享给大家供大家参考,具体如下: 这里详细介绍如何创建Activity.生命周期.内存管理.启动模式. 创建Activity 一.定义Activity 1. 定义Activity 定义类继承Activity 2.在AndroidManifest.xml的节点中声明<activity> 显式意图创建Activity三种方式方式 //第一种方式:构造函数,代码少 Intent intent1 =new Intent(this,NewA

随机推荐