版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、Android游戏开发之旅一长按Button原理今天Android123开始新的Android游戏开发之旅系列,主要从控制方法(按键、轨迹球、触屏、重力感应、摄像头、话筒气流、光线亮度)、图形View(高效绘图技术如双缓冲)、音效(游戏音乐)以及最后的OpenGL ES(Java层)和NDK的OpenGL和J2ME游戏移植到Android方法,当然还有一些游戏实现惯用方法,比方地图编辑器,在Android OpenGL如何使用MD2文件,个部分讲述下Android游戏开发的过程最终实现一个比拟完整的游戏引擎。相信大家都清楚AndroidMarket下载量比拟好的都是游戏,未来网游的开展相信An
2、droid使用的Java在这方面有比iPhone有更低的入门门槛。对于很多游戏使用屏幕控制一般需要考虑长按事件,比方在动作类的游戏中需要长按发射武器,结合Android Button模型,我们实现一个带图片的Button的长按,为了更清晰的显示原理,Android开发网这里使用ImageButton作为基类public class RepeatingImageButton extends ImageButton private long mStartTime; /记录长按开始private int mRepeatCount; /重复次数计数private RepeatListener mLis
3、tener;private long mInterval = 500; /Timer触发间隔,即每0.5秒算一次按下public RepeatingImageButton(Context context) this(context, null);publicRepeatingImageButton(Contextcontext,AttributeSetattrs)this(context,attrs,android.R.attr.imageButtonStyle);public RepeatingImageButton(Context context, AttributeSet attrs,
4、int defStyle) super(context, attrs,defStyle);setFocusable(true); /允许获得焦点setLongClickable(true); /启用长按事件public void setRepeatListener(RepeatListener l, long interval) /实现重复按下事件listenermListener = l;mInterval = interval;Overridepublic boolean performLongClick() mStartTime = SystemClock.elapsedRealtime
5、();mRepeatCount = 0;post(mRepeater);return true;Overridepublic boolean onTouchEvent(MotionEvent event) if (event.getAction() = MotionEvent.ACTION_UP) /本方法原理同onKeyUp的一样,这里处理屏幕事件,下面的onKeyUp处理Android上的物理按键事件removeCallbacks(mRepeater);if (mStartTime != 0) doRepeat(true);mStartTime = 0;return super.onTou
6、chEvent(event);/处理导航键事件的中键或轨迹球按下事件Overridepublic boolean onKeyDown(int keyCode, KeyEvent event) switch (keyCode) case KeyEvent.KEYCODE_DPAD_CENTER:case KeyEvent.KEYCODE_ENTER:super.onKeyDown(keyCode, event); return true;return super.onKeyDown(keyCode, event);/当按键弹起通知长按结束Overridepublic boolean onKeyU
7、p(int keyCode, KeyEvent event) switch (keyCode) case KeyEvent.KEYCODE_DPAD_CENTER:case KeyEvent.KEYCODE_ENTER:removeCallbacks(mRepeater); /取消重复listener捕获if (mStartTime != 0) doRepeat(true); /如果长按事件累计时间不为0那么说明长按了mStartTime = 0; /重置长按计时器return super.onKeyUp(keyCode, event);private Runnable mRepeater =
8、 new Runnable() /在线程中判断重复public void run() doRepeat(false);if (isPressed() postDelayed(this, mInterval); /计算长按后延迟下一次累加 ;private void doRepeat(boolean last) long now = SystemClock.elapsedRealtime();if (mListener != null) mListener.onRepeat(this, now - mStartTime, last ? -1 : mRepeatCount+);下面是重复Butto
9、n Listener接口的定义,调用时在Button中先使用setRepeatListener()方法实现RepeatListener接口public interface RepeatListener void onRepeat(View v, long duration, int repeatcount); /参数一为用户传入的Button对象,参数二为延迟的毫秒数,第三位重复次数回调。Android游戏开发之旅二View和SurfaceView在Android游戏当中充当主要的除了控制类外就是显示类,在J2ME中我们用Display和Canvas来实现这些,而Google Android中
10、涉及到显示的为view类,Android游戏开发中比拟重要和复杂的就是显示和游戏逻辑的处理。这里我们说下android.view.View和android.view.SurfaceViewSurfaceView是从View基类中派生出来的显示类,直接子类有GLSurfaceView和VideoView,可以看出GL和视频播放以及Camera摄像头一般均使用SurfaceView,到底有哪些优势呢?SurfaceView可以控制外表的格式,比方大小,显示在屏幕中的位置,最关键是的提供了SurfaceHolder类,使用getHolder方法获取,相关的有Canvas lockCanvas()Ca
11、nvas lockCanvas(Rect dirty)、void removeCallback(SurfaceHolder.Callback callback)、voidunlockCanvasAndPost(Canvas canvas)控制图形以及绘制,而在SurfaceHolder.Callback接口回调中可以通过下面三个抽象类可以自己定义具体的实现,比方第一个更改格式和显示画面。abstract void surfaceChanged(SurfaceHolder holder, int format, int width, int height) abstract voidsurfac
12、eCreated(SurfaceHolder holder)abstract void surfaceDestroyed(SurfaceHolder holder)对于Surface相关的,Android底层还提供了GPU加速功能,所以一般实时性很强的应用中主要使用SurfaceView而不是直接从View构建, 同时Android123未来后面说到的OpenGL中的GLSurfaceView也是从该类实现。Android游戏开发之旅三View类详解在Android游戏开发之旅二中我们讲到了View和SurfaceView的区别, 今天Android123从View类开始着重的介绍Androi
13、d图形显示基类的相关方法和注意点。自定义View的常用方法:onFinishInflate()当View中所有的子控件均被映射成xml后触发onMeasure(int, int)确定所有子元素的大小onLayout(boolean, int, int, int, int)当View分配所有的子元素的大小和位置时触发onSizeChanged(int, int, int, int)当view的大小发生变化时触发onDraw(Canvas) view渲染内容的细节onKeyDown(int, KeyEvent)有按键按下后触发onKeyUp(int, KeyEvent)有按键按下后弹起时触发onT
14、rackballEvent(MotionEvent)轨迹球事件onTouchEvent(MotionEvent)触屏事件onFocusChanged(boolean, int, Rect)当View获取或失去焦点时触发onWindowFocusChanged(boolean)当窗口包含的view获取或失去焦点时触发onAttachedToWindow()当view被附着到一个窗口时触发onDetachedFromWindow()当view离开附着的窗口时触发,Android123提示该方法和onAttachedToWindow()是相反的。onWindowVisibilityChanged(i
15、nt)当窗口中包含的可见的view发生变化时触发以上是View实现的一些根本接口的回调方法,一般我们需要处理画布的显示时,重写onDraw(Canvas)用的的是最多的:Overrideprotected void onDraw(Canvas canvas) /这里我们直接使用canvas对象处理当前的画布,比方说使用Paint来选择要填充的颜色Paint paintBackground = new Paint();paintBackground.setColor(getResources().getColor(R.color.xxx);/从Res中找到名为xxx的color颜色定义canva
16、s.drawRect(0, 0, getWidth(), getHeight(), paintBackground); /设置当前画布的背景颜色为paintBackground中定义的颜色,以0,0作为为起点, 以当前画布的宽度和高度为重点即整块画布来填充。具体的请查看Android123未来讲到的Canvas和Paint,在Canvas中我们可以实现画路径,Paint作为绘画方式的对象可以设置颜色,大小,甚至字体的类型等等。当然还有就是处理窗口复原状态问题(一般用于横竖屏切换),除了在Activity中可以调用外,开发游戏时我们尽量在View中使用类似Overrideprotected Pa
17、rcelable onSaveInstanceState() Parcelable p = super.onSaveInstanceState();Bundle bundle = new Bundle();bundle.putInt(x, pX);bundle.putInt(y, pY);bundle.putParcelable(android123_state, p);return bundle;Overrideprotected void onRestoreInstanceState(Parcelable state) Bundle bundle = (Bundle) state;doso
18、mething(bundle.getInt(x), bundle.getInt(y); /获取刚刚存储的x和y信息super.onRestoreInstanceState(bundle.getParcelable(android123_state); return;在View中如果需要强制调用绘制方法onDraw,可以使用invalidate()方法,它有很多重载版本,同时在线程中的postInvailidate()方法将在Android游戏开发之旅六中的自定义View完整篇讲到。Android游戏开发之旅四Canvas和Paint实例昨天我们在Android游戏开发之旅三View详解中提到了
19、onDraw方法,有关详细的实现我们今天主要说下Android的Canvas和Paint对象的使用实例。Canvas类主要实现了屏幕的绘制过程,其中包含了很多实用的方法,比方绘制一条路径、区域、贴图、画点、画线、渲染文本,下面是Canvas类常用的方法,当然Android开发网提示大 家很多方法有不同的重载版本,参数更灵活。void drawRect(RectF rect, Paint paint)/绘制区域,参数一为RectF一个区域void drawPath(Path path, Paint paint) /绘制一个路径,参数一为Path路径对象void drawBitmap(Bitmap
20、 bitmap, Rect src, Rect dst, Paint paint)/贴图,参数一就是我们常规的Bitmap对象,参数二是源区域(Android123提示这里是bitmap),参数三是目标区域(应该在canvas的位置和大小),参数四是Paint画刷对象,因为用到了缩放和拉伸的可能,当原始Rect不等于目标Rect时性能将会有大幅损失。void drawLine(float startX, float startY, float stopX, float stopY, Paint paint)/画线,参数一起始点的x轴位置,参数二起始点的y轴位置,参数三终点的x轴水平位置,参数四
21、y轴垂直位 置,最后一个参数为Paint画刷对象。void drawPoint(float x, float y, Paint paint) /画点,参数一水平x轴,参数二垂直y轴,第三 个参数为Paint对象。void drawText(String text, float x, float y, Paint paint)渲染文本,Canvas类除了上面的还可以描绘文字,参数一是String类型的文本,参数二x轴,参数三y轴,参数四是Paint对象。void drawTextOnPath(String text, Path path, float hOffset, float vOffset
22、, Paint paint) /在路径上绘制文本,相对于上面第二个参数是Path路径对象从上面来看我们可以看出Canvas绘制类比拟简单同时很灵活,实现一般的方法通常没有问题,同时可以叠加的处理设计出一些效果,不过细心的网友可能发现最后一个参数均为Paint对象如果我们把Canvas当做绘画师来看,那么Paint就是我们绘画的工具,比方画笔、画刷、颜料 等等。Paint类常用方法:void setARGB(int a, int r, int g, int b)设置Paint对象颜色,参数一为alpha透明通道void setAlpha(int a)设置alpha不透明度,范围为0255void
23、 setAntiAlias(boolean aa)/是否抗锯齿void setColor(int color)/设置颜色, 这里Android内部定义的有Color类包含了一些常见颜色定义.void setFakeBoldText(boolean fakeBoldText) /设置伪粗体文本void setLinearText(boolean linearText) /设置线性文本PathEffect setPathEffect(PathEffect effect)/设置路径效果Rasterizer setRasterizer(Rasterizer rasterizer) /设置光栅化Type
24、face setTypeface(Typeface typeface) /设置字体,Typeface包含了字体的类型,粗细,还有倾斜、颜色等。void setUnderlineText(boolean underlineText)/设置下划线最终Canvas和Paint在onDraw中直接使用Overrideprotected void onDraw(Canvas canvas) Paint paintRed=new Paint();paintRed.setColor(Color.Red);canvas.drawPoint(11,3,paintRed); /在坐标11,3上画一个红点下一次An
25、droid123将会具体讲到强大的Path路径,和字体Typeface相关的使用。Android游戏开发之旅(五)Path和Typeface今天我们继续处理上次Android游戏开发之旅(四)Canvas和Paint实例 中提到的Path路径和Typeface字体两个类。对于Android游戏开发或者说2D绘图中来讲Path路径可以用强大这个词来形容。在Photoshop中我们可能还记得使用钢笔工具绘制路径的方法。Path路径类在位于android.graphics.Path中,Path的构造方法比拟简单,如下Path cwj=new Path(); /构造方法Shader setShader
26、(Shader shader) voidsetTextAlign(Paint.Align align) voidsetTextScaleX(float scaleX) voidsetTextSize(float textSize)/设置阴影/设置文本对齐/设置文本缩放倍数,1.0f为原始/设置字体大小复制代码下面我们画一个封闭的原型路径,我们使用Path类的addCircle方法cwj.addCircle(10,10,50,Direction.CW); /参数一为x轴水平位置,参数二为y轴垂直位置,第三个参数为圆形的半径,最后是绘制的方向,CW为顺时针方向,而CCW是逆时针方向复制代码结合An
27、droid上次提到的Canvas类中的绘制方法drawPath和drawTextOnPath,我们继续可以在onDraw中参加。canvas.drawPath(cwj,paintPath); /Android123提示大家这里paintPath为路径的画刷颜色,可以见下文完整的源代码。canvas.drawTextOnPath(Android123 - CWJ,cwj,0,15,paintText); /将文字绘制到路径中去,复制代码有关drawTextOnPath的参数如下:方法原型public void drawTextOnPath (String text, Path path, flo
28、at hOffset, float vOffset, Paint paint)复制代码参数列表text为需要在路径上绘制的文字内容。path将文字绘制到哪个路径。hOffset距离路径开始的距离vOffset离路径的上下高度,这里Android开发网提示大家,该参数类型为float浮点型,除了精度为8位小数外,可以为正或负,当为正时文字在路径的圈里面,为负时在路径的圈外面。paint最后仍然是一个Paint对象用于制定Text本文的颜色、字体、大小等属性。下面是我们的onDraw方法中如何绘制路径的演示代码为:Overrideprotected void onDraw(Canvas canva
29、s) Paint paintPath=new Paint();Paint paintText=new Paint();paintPath.setColor(Color.Red); /路径的画刷为红色paintText.setColor(Color.Blue); /路径上的文字为蓝色Path pathCWJ=new Path();pathCWJ.addCircle(10,10,50,Direction.CW); /半径为50px,绘制的方向CW为顺时针canvas.drawPath(pathCWJ,paintPath);canvas.drawTextOnPath(Android123 - CWJ
30、,pathCWJ,0,15,paintText); /在路径上绘制文字复制代码 有关路径类常用的方法如下void addArc(RectF oval, float startAngle, float sweepAngle) /为路径添加一个多边形void addCircle(float x, float y, float radius, Path.Direction dir) /void addOval(RectF oval, Path.Direction dir) /添加椭圆形void addRect(RectF rect, Path.Direction dir) /添加一个区域void a
31、ddRoundRect(RectF rect, float radii, Path.Direction dir) /boolean isEmpty() /判断路径是否为空void transform(Matrix matrix) /应用矩阵变换void transform(Matrix matrix, Path dst) /应用矩阵变换并将结果放到新的路径中,即第二个参 数。复制代码有关路径的高级效果大家可以使用PathEffect类, 有关路径的更多实例Android123将在今后的游戏开发实战中讲解道。Typeface字体类给path添加圆圈添加一个圆角区域平时我们在TextView中需要
32、设置显示的字体可以通过TextView中的setTypeface方法来指定一个Typeface对象,因为Android的字体类比拟简单,我们列出所有成员方法static Typeface create(Typeface family, int style) /静态方法,参数一为字体类型这里是Typeface的静态定义,如宋体,参数二风格,如粗体,斜体static Typeface create(String familyName, int style) /静态方法,参数一为字体名的字符串,参数二为风格同上,这里我们推荐使用上面的方法。static Typeface createFromAsse
33、t(AssetManager mgr, String path) /静态方法,参数一为AssetManager对象,主要用于从APK的assets文件夹中取出字体,参数二为相对于Android工程下的assets文件夹中的外挂字体文件的路径。static Typeface createFromFile(File path) /以是sdcard中的某个字体文件static Typeface createFromFile(String path) /static Typeface defaultFromStyle(int style) / intgetStyle() /获取当前字体风格final
34、boolean isBold() /判断当前是否为粗体final boolean isItalic() /判断当前风格是否为斜体复制代码 本类的常量静态定义,首先为字体类型名称Typeface DEFAULTTypeface DEFAULT_BOLDTypeface MONOSPACETypeface SANS_SERIFTypeface SERIF字体风格名称int BOLDint BOLD_ITALICint ITALICint NORMAL明天我们将在Android游戏开发之旅六自定义View一文中具体讲解onDraw以及什么时候会触发绘制方法,来实现我们自定义或子类化控件。静态方法,从
35、文件系Android游戏开发之旅六自定义View有关Android的自定义View的框架今天我们一起讨论下,对于常规的游戏,我们在View中需要处理以下几种问题: 1.控制事件2.刷新View 3.绘制View1.对于控制事件今天我们只处理按键事件onKeyDown, 以后的文章中将会讲到屏幕触控的具体处理onTouchEvent以及Sensor重力感应等方法。2.刷新view的方法这里主要有invalidate(int l, int t, int r, int b)刷新局部,四个参数分别为左、上、右、下。整个view刷新invalidate(),刷新一个矩形区域invalidate(Rect
36、 dirty),刷新一个特性Drawable,invalidateDrawable(Drawable drawable), 执行invalidate类的方法将会设置view为无效,最终导致onDraw方法被重新调用。由于今天的view比拟简单,Android123提示大家如果在线程中刷新,除了使用handler方式外, 可以在Thread中直接使用postInvalidate方法来实现。3.绘制View主要是onDraw()中通过形参canvas来处理,相关的绘制主要有drawRect、drawLine、drawPath等等。view方法内部还重写了很多接口,其回调方法可以帮助我们判断出vie
37、w的位置和大小,比方onMeasure(int, int) Called to determine the size requirements for thisview and all of its children.、onLayout(boolean, int, int, int, int) Called when this view should assigna size and position to all of its children和onSizeChanged(int, int, int, int) Called when the size ofthis view has cha
38、nged.具体的作用,大家可以用Logcat获取当view变化时每个形参的变动。下面cwjView是我们为今后游戏设计的一个简单自定义View框架,我们可以看到在Android平台自定义view还是很简单的,同时Java支持多继承可以帮助我们不断的完善复杂的问题。public class cwjView extends View public cwjView(Context context) super(context);setFocusable(true); /允许获得焦点setFocusableInTouchMode(true); /获取焦点时允许触控Overrideprotected P
39、arcelable onSaveInstanceState() /处理窗口保存事件Parcelable pSaved = super.onSaveInstanceState();Bundle bundle = new Bundle();/dosomething return bundle;Overrideprotected void onRestoreInstanceState(Parcelable state) /处理窗口复原事件Bundle bundle = (Bundle) state;/dosomethingsuper.onRestoreInstanceState(bundle.get
40、Parcelable(cwj);return;Overrideprotected void onSizeChanged(int w, int h, int oldw, int oldh) /处理窗口大小变化事件super.onSizeChanged(w, h, oldw, oldh);Overrideprotected void onMeasure (int widthMeasureSpec, int heightMeasureSpec)super.onMeasure(widthMeasureSpec, heightMeasureSpec); /如果不让父类处理记住调用setMeasuredD
41、imensionOverrideprotected void onLayout (boolean changed, int left, int top, int right, int bottom) super.onLayout (changed,left,top, ight,bottom) ;Overrideprotected void onDraw(Canvas canvas) Paint bg = new Paint();bg.setColor(Color.Red);canvas.drawRect(0, 0, getWidth()/2, getHeight()/2, bg); /将vie
42、w的左上角四分之一填充为 红色Overridepublic boolean onTouchEvent(MotionEvent event) return super.onTouchEvent(event); /让父类处理屏幕触控事件Overridepublic boolean onKeyDown(int keyCode, KeyEvent event) /处理按键事件,响应的轨迹球事件为public boolean onTrackballEvent (MotionEvent event)switch (keyCode) case KeyEvent.KEYCODE_DPAD_UP:break;c
43、ase KeyEvent.KEYCODE_DPAD_DOWN:break;case KeyEvent.KEYCODE_DPAD_LEFT:break;case KeyEvent.KEYCODE_DPAD_RIGHT:break;case KeyEvent.KEYCODE_DPAD_CENTER: /处理中键按下break;default:return super.onKeyDown(keyCode, event);return true;上面我们可以看到onMeasure使用的是父类的处理方法,如果我们需要解决自定义View的大小,可以尝试下面的方法Overrideprotected void
44、 onMeasure (int widthMeasureSpec, int heightMeasureSpec) height = View.MeasureSpec.getSize(heightMeasureSpec);width = View.MeasureSpec.getSize(widthMeasureSpec);setMeasuredDimension(width,height);/这里面是原始的大小,需要重新计算可以修改本/dosomethingAndroid游戏开发之旅七自定义SurfaceView今天我们说下未来的Android游戏引擎模板架构问题,对于游戏我们还是选择Surfa
45、ceView,相关的原因Android123已经在Android游戏开发之旅二View和SurfaceView中说的很清楚了, 这里我们直接继承SurfaceView,实现SurfaceHolder.Callback接口,处理surfaceCreated、surfaceChanged以及surfaceDestroyed方法,这里我们并没有把按键控制传入,最终游戏的控制方面仍然由View内部类处理比拟好,有关SurfaceView的具体我们可以参见Android开源项目的Camera中有关画面捕捉以及VideoView的控件实现大家可以清晰了解最终的用意。public class cwjView
46、 extends SurfaceView implements SurfaceHolder.Callback public cwjView(Context context, AttributeSet attrs) super(context, attrs);SurfaceHolder holder=getHolder(); holder.addCallback(this);setFocusable(true); public void surfaceChanged(SurfaceHolder holder, int format, int width, int height) public v
47、oid surfaceCreated(SurfaceHolder holder) public void surfaceDestroyed(SurfaceHolder holder) Overridepublic void onWindowFocusChanged(boolean hasWindowFocus) Android游戏开发之旅八SurfaceView类实例有关SurfaceView我们将通过三个系统自带的例子来深入掌握Android绘图必会的SurfaceView今天我们以SDK中的Sample游戏lunarlander中的LunarView具体实现,Android123建议大家导
48、入该游戏工程到你的Eclipse然后自己编译先玩一下这个游戏,然后再看代码比拟好理解。class LunarView extends SurfaceView implements SurfaceHolder.Callback class LunarThread extends Thread /* Difficulty setting constants*/public static final int DIFFICULTY_EASY = 0;public static final int DIFFICULTY_HARD = 1;public static final int DIFFICULT
49、Y_MEDIUM = 2;/* Physics constants*/public static final int PHYS_DOWN_ACCEL_SEC = 35;public static final int PHYS_FIRE_ACCEL_SEC = 80;public static final int PHYS_FUEL_INIT = 60;public static final int PHYS_FUEL_MAX = 100;public static final int PHYS_FUEL_SEC = 10;public static final int PHYS_SLEW_SE
50、C = 120; / degrees/second rotatepublic static final int PHYS_SPEED_HYPERSPACE = 180;public static final int PHYS_SPEED_INIT = 30;public static final int PHYS_SPEED_MAX = 120;/* State-tracking constants*/public static final int STATE_LOSE = 1;public static final int STATE_PAUSE = 2;public static fina
51、l int STATE_READY = 3;public static final int STATE_RUNNING = 4;public static final int STATE_WIN = 5;/* Goal condition constants*/public static final int TARGET_ANGLE = 18; / this angle means crashpublic static final int TARGET_BOTTOM_PADDING = 17; / px below gearpublic static final int TARGET_PAD_
52、HEIGHT = 8; / how high above groundpublic static final int TARGET_SPEED = 28; / this speed means crashpublic static final double TARGET_WIDTH = 1.6; / width of target /* UI constants (i.e. the speed & fuel bars)*/public static final int UI_BAR = 100; / width of the bar(s)public static final int
53、UI_BAR_HEIGHT = 10; / height of the bar(s) private static final StringKEY_DIFFICULTY = mDifficulty;private static final String KEY_DX = mDX;private static final String KEY_DY = mDY;private static final String KEY_FUEL = mFuel;private static final String KEY_GOAL_ANGLE = mGoalAngle;private static fin
54、al String KEY_GOAL_SPEED = mGoalSpeed;private static final String KEY_GOAL_WIDTH = mGoalWidth;private static final String KEY_GOAL_X = mGoalX;private static final String KEY_HEADING = mHeading;private static final String KEY_LANDER_HEIGHT = mLanderHeight;private static final String KEY_LANDER_WIDTH
55、= mLanderWidth;private static final String KEY_WINS = mWinsInARow;private static final String KEY_X = mX;private static final String KEY_Y = mY;/* Member (state) fields*/* The drawable to use as the background of the animation canvas */ private Bitmap mBackgroundImage;/* Current height of the surfac
56、e/canvas.* see #setSurfaceSize*/private int mCanvasHeight = 1;/* Current width of the surface/canvas.* see #setSurfaceSize*/private int mCanvasWidth = 1;/* What to draw for the Lander when it has crashed */ private Drawable mCrashedImage;/*Current difficulty - amount of fuel, allowed angle, etc. Def
57、ault is MEDIUM.*/private int mDifficulty;/* Velocity dx. */ private double mDX;/* Velocity dy. */ private double mDY;/* Is the engine burning? */ private boolean mEngineFiring;/* What to draw for the Lander when the engine is firing */ private Drawable mFiringImage;/* Fuel remaining */ private doubl
58、e mFuel;/* Allowed angle. */ private int mGoalAngle;/* Allowed speed. */ private int mGoalSpeed;/* Width of the landing pad. */ private int mGoalWidth;/* X of the landing pad. */ private int mGoalX;/* Message handler used by thread to interact with TextView */ private Handler mHandler;/* Lander head
59、ing in degrees, with 0 up, 90 right. Kept in the range * 0.360.*/private double mHeading;/* Pixel height of lander image. */private int mLanderHeight;/* What to draw for the Lander in its normal state */ private Drawable mLanderImage;/* Pixel width of lander image. */ private int mLanderWidth;/* Use
60、d to figure out elapsed time between frames */ private long mLastTime;/* Paint to draw the lines on screen. */ private Paint mLinePaint;/* Bad speed-too-high variant of the line color. */ private Paint mLinePaintBad;/* The state of the game. One of READY, RUNNING, PAUSE, LOSE, or WIN */ private int mMode;/* Cu
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
评论
0/150
提交评论