首页 > 学院 > 开发设计 > 正文

MIDP1.0游戏完整实现-双人扫雷1.0(一)

2019-11-18 14:54:31
字体:
来源:转载
供稿:网友

  作者:yinowl
2005年2月

前言
我的上一篇也是第一篇文章《J2ME-MIDP1.0小游戏入门-五子棋》贴出以后,有好多的朋友发邮件、加QQ、加MSN和我聊有关J2ME的内容,我很开心也很感慨,开心并不是因为自己文章写得如何如何而有很多人联系我,而是有这么多的朋友在学J2ME,我原来以为现在已经没有人再会联系文章的作者,看来我错了;感慨是因为,我知道我的第一篇文章其实很差的,从大家的反应,我能感觉出网上的原创资料的缺乏,官方或者书籍虽然权威且,但总感觉学的时候和实际的情况有点距离,我在看这些资料的时候,也经常会想,实际游戏开发公司里为怎么处理、会怎么写这个代码、程序的结构流程会怎么样等等。原创文章的最大有点就是它包含了作者的经验,实际开发中的经验。介于大家对我的支持并且网上原创文章有限,我非常乐意继续写一些自己的经验和技术,充实我们的中文资源。所以我接着写了这篇文档,文档内容即程序的开发过程都是真实的,不是为写文章而写文章,完全是近一段时间里先完成的程序,现在再把它写成教学文章。
愿大家学J顺利,多多交流(MSN:yinowl@163.com QQ:47599318 E-mail:yinowl@163.com

注重
平台:这个游戏我是在 Nokia 的平台上设计的,也就是说使用了 FullCanvas 类以及针对Nokia-60系列(7650)的屏幕设计的,稍作修改就能运行在其他型号的手机上(我已经制作了 Siemens-C65Nokia-7210 ,以及所有支持标准midp1.0/2.0、屏幕128 x 128的手机的几个移植版本,有需要可以和我联系)
代码:同我的前一篇文章《J2ME-MIDP1.0小游戏入门-五子棋》一样,代码列出解释的形式仿照《J2ME Game PRogramming》一书,按照程序功能思路给出相关代码,一个文件的代码会根据功能在不同的小节给出,文章结束了,代码也就完整了。这不同于通常书中的代码以文件为单位一次全部给出,我认为这样更有助于让大家了解一个程序从设计到最后完成的思路。

游戏介绍
扫雷这个游戏大家一定再熟悉不过了,但这个双人扫雷游戏的扫雷新玩法大家可能就没见过了,其实这就是MSN软件中的一个网络联机小游戏,大家天天在使用MSN,但都很少注重或玩MSN中的游戏吧,可以说我就是把MSN上的联机双人扫雷移植到的手机上,一模一样。假如你现在不方便上网或者没有人和你联机看一下这个游戏的界面和玩法,没关系,我现在就来介绍一下,游戏区(雷区)中一共有 16 x 16 共256个格子,其中有52颗雷,操作除了上下左右键(当然电脑上是用鼠标点的)只需要一个挖雷键,你要做的是挖出雷,而不是用另一个键去标示雷。两个玩家,一方开始挖雷,假如挖到(点到)雷,则加一分,没挖到,就和经典的扫雷一样,显示这个位置四周一圈有几个雷,假如一个雷都没有,和经典的扫雷一样,会把和这一格相连的所有四周没有雷的格子和再外面一圈格子打开,然后另一位玩家挖雷,谁先挖到半数以上(大于26颗)的雷谁就获胜,其实很简单吧,游戏的界面如下:

 MIDP1.0游戏完整实现-双人扫雷1.0(一)(图一)  MIDP1.0游戏完整实现-双人扫雷1.0(一)(图二) 

 MIDP1.0游戏完整实现-双人扫雷1.0(一)(图三)  MIDP1.0游戏完整实现-双人扫雷1.0(一)(图四) 

游戏逻辑设计
数据结构:这个游戏属于二维棋类游戏,所以我们自然而然想到设计一个 Bomb 类表示每一颗雷位,用一个Bomb类型的二维数组表示整个雷区的所有雷位,每一个雷位(即每一个Bomb实例)包含一个表示该雷位是否是雷的boolean类型的变量,一个表示该雷位是否已被挖的boolean类型的变量,一个表示是否是被玩家一挖的boolean类型的变量(否表示是被玩家二挖),一个表示该雷位四周八个雷位共有几颗雷的int类型变量。这样整个雷区的状态就完全被描述出来了,然后就根据这个二维表来绘制游戏界面
游戏流程:整个游戏只使用唯一一个 FullCanvas 类,用唯一一个表示状态的变量来控制整个游戏的状态,整个游戏也只使用本身的唯一线程
玩家切换:用一个boolean类型的变量来表示当前执行的玩家,用游戏的外框颜色及右下角的旗子颜色来表示出来

接下来就开始具体介绍并列出游戏程序的各部分代码,文章的结束,整个游戏也就完成了



发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表