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

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

其中的animation.xml文件如下:

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程序设计有所帮助。

android添加人物动画效果图,Android编程根据系列图片绘制动画实例总结相关推荐

  1. android添加商品到购物车,Android使用动画动态添加商品进购物车

    本文实例为大家分享了Android添加商品进购物车的具体代码,供大家参考,具体内容如下 1.首先展示下效果图 2.讲一下思路,小球由加号位置运动到购物车位置,首先得获得这两个点在整个屏幕中的坐标,然后 ...

  2. android的颜色渐变动画效果图,Android简单实现一个颜色渐变的ProgressBar

    今天看一个教程,看到一个颜色渐变的ProgressBar,觉得有点意思,所以记录一番. 下面这个是效果图 颜色渐变的ProgressBar 看到效果图可能会给人一种使用了高端技术的感觉,其实这个没有那 ...

  3. android 烟花动画效果图,Android 自定义 View 新年烟花、横幅动画

    新年了,项目中要作个动画,如下效果图: 整体要求实现:彩带乱飞,烟花冲天而起,烟花缩放,小鸡换图,小鸡飘移,横幅裁剪.展开等动画效果, 全局大量使用了属性动画来实现. 我在实现过程中,横幅的裁剪计算, ...

  4. Android添加程序背景颜色,Android小程序实现切换背景颜色

    本文实例为大家分享了Android实现切换背景颜色的具体代码,供大家参考,具体内容如下 (1)首先打开界面布局文件,添加两个Button xmlns:tools="http://schema ...

  5. android添加文本框代码,Android输入框添加emoje表情图标的实现代码

    前言 再次写聊天的时候才发现,代码积累是一件非常重要的事情,就如这篇博客的意图其实就是代码积累的目的,其实没什么难度,但是一件很琐碎的事情真的也需要时间去完成和调试,所以,获取你在写一个功能的时候会觉 ...

  6. android添加人物动画效果,android – RecyclerView:如何创建插入动画效果?

    下面是我在适配器中添加动画的方法.这将使推动效果生动,行从右侧进入. 首先在xml中定义动画(res / anim / push_left_in.xml) android:duration=" ...

  7. android 360动画效果图,Android实现360手机助手底部的动画菜单

    首先来看下我们实现的效果和360效果的对比: 360手机助手效果演示 本库实现的效果(Icon来自360手机助手,侵删) xml布局文件 注:为了美观,讲每个Button的高度以及固定,设置wrap_ ...

  8. android studio 动画效果图,Android Studio如何动画移动视图?

    我有一个问题.我怎样才能动画一个移动视图?我想生成一个字母,并在移动时对其进行动画处理(旋转和缩放).如果我只是开始动画就可以按照我的想法工作,或者如果我只运行移动方法,它也可以起作用,但不起作用.下 ...

  9. android左右旋转动画效果图,Android新姿势:3D翻转效果原理

    首先,android里是没有3D翻转的动画效果的,但是呢,android有提供一个Camera的类,可以利用这个类来实现. 先看代码,Rotate3d是继承了Animation的一个动画类,多余的代码 ...

最新文章

  1. 逻辑回归阈值_逻辑回归or线性回归,傻傻分不清楚
  2. poj1028 模拟浏览器后退和前进(栈)
  3. leetcode 44 字符匹配
  4. ppwjs之bootstrap表格:String.到表头单元格元素 和 String.到表格单元格元素
  5. python中获取目录下所有文件名以及读取一个文件内的每一行
  6. 少走弯路,给3~5年程序员的唯一一条建议
  7. WPF学习笔记-如何按ESC关闭窗口
  8. 空格表示 java_java 正则表达式 空格怎么表示
  9. async 和 defer
  10. 联想Y580黑苹果安装
  11. 【Linux】一个小故事让你秒懂shell外壳程序
  12. Jenkins自动化构建Gitee项目
  13. linux 编写 声卡驱动程序,在Linux中注册声卡驱动程序
  14. html+css+js学习-01
  15. post man以Content-type: application/octet-stream方式请求api
  16. PDF to EPUB Converter Mac(PDF转EPUB转换器)
  17. layui自定义新增tab页方法
  18. 内网服务器反弹映射到公网ip去访问
  19. 手机直播原生源码可以搭建哪些直播app当中的功能
  20. 《数据库系统概论》第四版课后习题答案

热门文章

  1. 单目图像深度估计 - SLAM辅助篇:MegaDepth
  2. Jpa操作数据库之动态SQL语句的使用
  3. jq实现ajax文件上传
  4. 常用RPC框架及如何设计一个RPC框架
  5. 大一计算机考试简单拿分点,大一计算机考试重点.doc
  6. HTML常见字体符号
  7. Unity UnityWebRequest 下载封装
  8. 基于Springboot的健身房课程预约平台
  9. 如何设计优秀的应用图标?
  10. 【瑞萨RA_FSP】DMAC/DTC——直接存储器访问与数据传输