初学Android,图形图像之游戏画面中飞行的飞机(三十一)

news/2024/7/8 5:29:24 标签: android, 图形, 游戏, float, constructor, random

这篇接着上篇内容,在飞机的基础上加入了飞机跟随手指移动,还有飞行路线左右方向随机移动的敌机,看样子像喝醉酒一样,呵呵......


汗死,这个太原始了,初学嘛,呵呵

代码还是接着上篇的基础上改的

package WangLi.Graphics.MoveBack;

import java.util.Random;
import java.util.Timer;
import java.util.TimerTask;

import android.app.Activity;
import android.content.Context;
import android.graphics.Bitmap;
import android.graphics.BitmapFactory;
import android.graphics.Canvas;
import android.graphics.Paint;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.Display;
import android.view.View;
import android.view.MotionEvent;  
import android.view.Window;
import android.view.WindowManager;

public class MoveBack extends Activity
{
	@Override
	public void onCreate(Bundle savedInstanceState)
	{
		super.onCreate(savedInstanceState);
		//去掉标题
		requestWindowFeature(Window.FEATURE_NO_TITLE);
		//全屏显示
		getWindow().setFlags(WindowManager.LayoutParams.FLAG_FULLSCREEN, 
				WindowManager.LayoutParams.FLAG_FULLSCREEN);
		setContentView(new MyView(this));
	}
	class MyView extends View
	{
		//记录背景位图的实际高度
		final int BACK_HEIGHT = 1700;
		//背景图片
		private Bitmap back;
		private Bitmap plane;
		private Bitmap enemyPlane;
		//背景图片的开始位置
		final int WIDTH = 370;
		final int HEIGHT = 440;
		private int startY = BACK_HEIGHT - HEIGHT;		
		private float ememyY = BACK_HEIGHT - HEIGHT;	
		private float ememyX;
		private float planeX;
		private float planeY;
		//桌面高度
		private int tableWidth;
		//桌面宽度
		private int tableHeight;
		public MyView(Context context)
		{
			super(context);
			//获取窗口管理器
			WindowManager windowManager = getWindowManager();
			Display display = windowManager.getDefaultDisplay();
			//获得屏幕宽高
			tableWidth = display.getWidth();
			tableHeight = display.getHeight();
			
			// TODO Auto-generated constructor stub
			back = BitmapFactory.decodeResource(context.getResources()
				, R.drawable.back_img);
			plane = BitmapFactory.decodeResource(context.getResources()
				, R.drawable.plane);			
			
			int planeWidth = plane.getWidth();
			int planeHeight = plane.getHeight();
			
			//敌机
			enemyPlane= BitmapFactory.decodeResource(context.getResources()
					, R.drawable.enemy_plane);
			
			int enemyWidth = enemyPlane.getWidth();
			int enemyHeight = enemyPlane.getHeight();
			
			
			planeX = (tableWidth - planeWidth) / 2; //飞机横向初始停靠位置在屏幕中间位置
			planeY = tableHeight - planeHeight * 2; //飞机纵向初始停靠位置在离屏幕底端朝上一个机身位置
			
			ememyX = (tableWidth - planeWidth) / 2;
			
			final Handler handler = new Handler()
			{
				public void handleMessage(Message msg)
				{
					if (msg.what == 0x123)
					{
						//重新开始移动
						if (startY <= 0)
						{
							startY = BACK_HEIGHT - tableHeight;
						}
						else
						{
							startY -= 3;
						}
						if(ememyY >= tableHeight)
						{
							ememyY = 0;
						}
						else
						{
							ememyY += 5;
						}
						if(ememyX > tableWidth || ememyX < 0)
						{
							ememyX = (tableWidth - enemyPlane.getWidth())/2;
						}
					}
					invalidate();
				}
			};
			new Timer().schedule(new TimerTask()
			{
				@Override
				public void run()
				{
					handler.sendEmptyMessage(0x123);					
				}
				
			}, 0 , 10);
		}
		@Override
		public void onDraw(Canvas canvas)
		{
			// 根据原始位图和Matrix创建新图片
			Bitmap bitmap2 = Bitmap.createBitmap(back, 0, startY
				, tableWidth , tableHeight);
			// 绘制新位图
			canvas.drawBitmap(bitmap2, 0 , 0  , null);
			// 绘制飞机
			canvas.drawBitmap(plane, planeX , planeY  , null);	
			//绘制敌机
			Random rand = new Random();
			//敌机随机的横向左右移动
			ememyX = ememyX + rand.nextInt(20) + (-rand.nextInt(20));
			Bitmap enemyPlaneCopy = Bitmap.createBitmap(enemyPlane);
			canvas.drawBitmap(enemyPlaneCopy, ememyX , ememyY , null);
		}		
		
		//onTouchEvent事件之后会自动调用onDraw事件
		public boolean onTouchEvent(MotionEvent event) { 
			int planeWidth = plane.getWidth();
			int planeHeight = plane.getHeight();
			//让飞机跟随手指移动,并且不能飞出屏幕以外的范围
			if((event.getX() > 0 && event.getX() < tableWidth - planeWidth) && (event.getY() > 0 && event.getY() < tableHeight - planeHeight))
			{
				planeX = event.getX();
				planeY = event.getY(); 
				return true; 
			}
			else
				return false;
	    } 
	}
}



http://www.niftyadmin.cn/n/1411369.html

相关文章

Linux命令:MySQL系列之十三--MySQL备份与还原(针对单张表SELECT备份重要章节)

对于只备份单张表的备份与还原&#xff0c;通过SELECT命令&#xff0c;可以更快速的达到备份和恢复的目的&#xff1b;以及通过此方法把一个数据库中表的数据&#xff0c;导入至另一数据库的表中去。备份格式&#xff1a;SELECT * INTO OUTFILE /PATH/TO/somefile.txtFROM tabl…

初学Android,图形图像之使用drawBitmapMesh扭曲图像(三十二)

Canvas提供了一个方法drawBitmapMesh(Bitmap bitmap, int meshWidth, int meshHeight, float[] verts, int vertOffset, int[] colors,int colorffset,Paint paint) 这个方法可以对bitmap进行扭曲参数说明如下:bitmap     需要扭曲的源位图meshWidth   控制在横向上把该…

目录比较同步助手 Direetory Helper

Direetory Helper 详细介绍 Direetory Helper 是一个用JAVA可视化的目录文件同步助手&#xff0c;可以比较两个目录的结构不同&#xff0c;然后复制不同的数据进行同步。 程序运行需要JRE1.7运行环境。 应用场景&#xff1a; 1.相机卡里照了许多的照片&#xff0c;每次备份都不…

初学Android,图形图像之使用Shader填充图像(三十三)

Shader本身是一个抽象类&#xff0c;它提供了如下实现类 BitmapShader   使用位图平铺的渲染效果 LinearGradient 使用线性渐变来填充图形 RadialGradient 使用圆形渐变来填充图形 SweepGradient 使用角度渐变来填充图形 ComposeShader 使用组合渲染来…

初学Android,图形图像之使用逐帧动画(三十四)

逐帧动画其实跟动画片的原理是一样的&#xff0c;一段时间内连续播放一组图片&#xff0c;使之看起来像在动一样 下面是一个例子&#xff0c;不用专门说明就可以理解了 定义文件的资源名为girl,放在res->anmi目录下,下面有一个重要的参数 " android:oneshot"false…

memset 与 memcpy

1. memset 需要的头文件 在C中 <string.h> 在C中 <cstring> 原型&#xff1a; void *memset(void *s, int ch, size_t n); 用法&#xff1a; memset是计算机中C/C语言函数。将s所指向的某一块内存中的前n个字节的内容全部设置为ch指定的ascii值&#xff0c; 第一…

初学Android,图形图像之在指定点(坐标)播放动画(三十五)

在指定地点播放动画&#xff0c;下面是一个爆炸过程的动画&#xff0c;鼠标点击处播放该动画定义动画资源文件blast.xml<?xml version"1.0" encoding"utf-8"?> <!-- 定义动画只播放一次&#xff0c;不循环 --> <animation-list xmlns:and…

Git 常用的几种处理大型二进制文件的组件

Git大文件存储&#xff08;Large File Storage&#xff0c;简称LFS&#xff09;的目标是更好地把“大型二进制文件&#xff0c;比如音频文件、数据集、图像和视频”集成到Git的工作流中。众所周知&#xff0c;Git在存储二 进制文件时效率不高&#xff0c;因为&#xff1a;Git默…