零打碎敲学Android(一)—用什么来替代Graphics 二

3、Android的窗口构成,即Activity + View = Form。

Android以Activity类作为窗体容器,以View(或SurfaceView等)绘制所有的按钮及界面,以AndroidManifest.xml配置相关的初始化资源,Android图形应用的一切通过它们衍生开来。

由于Android的线程安全机制并不等同于标准Java应用,invalidate()不能循环绘制View(偶实际试验了,丢到Thread里就 死|||),所以View的图形绘制需要通过Handler处理,它将在函数内实现了一个类似于递归的循环线程,结构如下(具体实现请见Android提 供的snake示例):

sendMessageDelayed->handleMessage->handleMessage 再次呼叫 sendMessageDelayed->handleMessage 被呼叫->循环

这种线程结构虽然简单且高效,但是很多常见的线程手段却无法在其中实现,因此只适合简单的应用(比如计时器,定时绘图等),复杂的线程结构则需要SurfaceView。

SurfaceView是View的子类,它继承自View。与只能使用Handler方式循环绘制图像的View不同,SurfaceView通过调用 一对lockCanvas()和unlockCanvasAndPost()进行绘图,具体实现可见Google提供的LunarLander示例。

根据鄙人实测,View的Handler方式较SurfaceView的lockCanvas()与unlockCanvasAndPost()方式FPS为高,惟独可控性太差,本人推荐在简单应用使用View,在复杂应用使用SurfaceView。

另外xml中屏幕纵、横核定项如下:

screenOrientation=”portrait” 纵向屏幕

screenOrientation=”landscape” 横向屏幕

与之对应的代码设定方式是在Activity中 setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_PORTRAIT)与 setRequestedOrientation(ActivityInfo.SCREEN_ORIENTATION_LANDSCAPE)

PS:Android中所有图形设备都基于OpenGL ES,默认存在Z-Buffer,绝对不会出现Java桌面应用中的闪烁问题,算是一项进步。

下面我给出一个简单的Android绘图示例,也是LGame-Simple在Android中的最初原型代码,我们可以看到Android与标准Java桌面应用的差异实际上是极为细微的。
源码下载地址:http://code.google.com/p/loon-simple/downloads/list
PS:此用例中所有[LA]开头Java文件为Android下专用,否则皆为LGame-Simple通用。

LAGameView.java(对应LGame-Simple中的GameView)

 

LAScreen.java(对应LGame-Simple中的Screen)

 

 

Main.java(启动类)

 

ScreenTest.java(测试类)

 

横屏效果:

 

纵屏效果:

 

 

源码下载地址:http://code.google.com/p/loon-simple/downloads/list

可以看到,此示例虽为LGame-Simple的简写,但最基础的功能已经实现,我们仅需设定一个继承自LAScreen的游戏屏幕,就可以同LGame-Simple中一样,分模块开发游戏,并且随意更换当前游戏模块及更替按键设定了。

实际上如果您愿意,即使偶不出Android版的LGame-Simple,将其自行移植到Android上的难度也绝对比您所想象的要小得多(当然,Android版偶是肯定会出的^.^)

————————————天下大势,分久必合,合久必分—————————————

事实上Android与标准Java应用近乎一致,唯独在多线程方面有些“恶心”,比如View中的invalidate()函数只能在Handler中 做类似递归的handleMessage与sleep相互调 用,Thread.currentThread().getContextClassLoader()也无法获得jar内部资源,感觉上就像Google 要强制你学习它那套samples应用,而不能更改一样。

把LGame-Simple移植到Android上比我想象的要简单,刚刚又试验了一下,除了有关图形接口与线程的部分,其余直接copy过来就可以用, 甚至连代码都不必改,所以12月出LGame-Simple的Android版肯定没问题。(事实上,如果偶现在开始什么都不干只写这个的话,大约5天左 右就可以搞定……可惜不现实……)

另外偶可能尝试开发一个函数移植器,看看能不能做到PC与Android上的LGame-Simple游戏间自动代码转换,目前看来可行性蛮高的。

发表评论

电子邮件地址不会被公开。 必填项已用*标注