博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
J2ME伪高手先锋开讲:扫雷游戏的设计(转)
阅读量:2449 次
发布时间:2019-05-10

本文共 5598 字,大约阅读时间需要 18 分钟。

J2ME伪高手先锋开讲:扫雷游戏的设计(转)[@more@]

  首先我要装得像高手一样,来假装把系统稍微分析一下。

  

  一般,按照java得开发模式,这种程序一般是分为三个模块来开发。

  

  如下三个:

  

  一个程序运作的主文件,也就是一个midlet的继承;

  

  一个界面的表示类,也就是一个canvas的继承,界面上应该有些菜单,如new、exit 什么的,那就应该要 implements一个 commandListener消息监听类(大家可以把java的消息监听理解为一个线程,一直像倭寇那样对看得顺眼的东西虎视耽耽,当然这里指的是他所能触及到的消息,当收到消息的时候,会调用一个抽象函数public void commandAction(Command c, Displayable d),而这个抽象函数使得我们可以通过对他的实现来处理收到的消息,即消息响应)

  

  最后一个当然就是与界面无关的逻辑单元了,在这里我们定义整个游戏的逻辑,做到逻辑与界面分开。这是我学java的最大收获,呵呵。

  

  首先正式开始第一讲

  

  我的设想是,扫雷的地图一般是一个矩形,因为,圆形屏幕的手机看起来蛮变态的,没有必要迁就他,所以,我用一个a*b的二维数组就完全可以表示整个地图。

  

  有了地图以后地图里面的类容自然就有一部分是表示地雷啦,既然这样,那不如就这样

  

  /**

  

  * 20 标志该位置为地雷

  

  * <=10的数字表示未翻开的方块及周围的地雷数目

  

  * >=10的数字表示已翻开的方块及周围的地雷数目

  

  * */

  

  表示方法就出来了,逻辑也明朗起来了。

  

  我要将某个块翻开,只要将他加上10就可以了。

  

  Java编程第一步,当然是先要class啊

  

  package games;

  

  import java.util.Random;

  

  import java.lang.Math;

  

  class gamelogic {

  

  /**表示一个10*10的棋盘*/

  

  private int[][] pan = new int;

  

  private Random random;//一个随机变量,主要作用是用来指定哪些位置为地雷

  

  private int BombNum = 0; //统计地雷总数

  

  /**游戏是否结束*/

  

  private boolean GameOver;

  

  接下来就是要初始化地图了,地图首先要扔一个雷在上面啊,不然怎么叫扫雷呢,扔完了地雷以后接下来当然是遍历一次地图(我们还是很仁慈地,我们得告诉扫雷的同志,某某位置,有多少雷,比如这样:"01、01、12点中方向有地雷,14点钟方向有幺鸡,2点钟方向有东风之类的啊")。

  

  /**初始化数组,生成地图*/

  

  public void InitArray() {

  for (int i = 0; i < 8; i++) {

  for (int j = 0; j < 8; j++) {

  pan[i][j] = 0;

  }

  }

  

  RandomArray();

  CountBomb();

  BombNum = Bomb();

  }

  

  /**统计地雷总数

  * @return int 返回地雷总数 */

  

  private int Bomb() {

  int count = 0;

  for (int i = 0; i < 8; i++) {

  for (int j = 0; j < 8; j++) {

  if (pan[i][j] == 20) {

  count += 1;

  }

  }

  }

  

  return count;

  }

  

  /**随机决定地雷的位置*/

  

  private void RandomArray() {

  int i, j, k;

  

  // 先扔15个左右的地雷吧,注意,这里不一定有15个哦,因为随机值可能重复,我不管啦

  for (int r = 0; r < 15; r++) {

  k = java.lang.Math.abs(random.nextInt()) % 64; //random.nextInt(100);

  i = k / 8;

  j = k % 8;

  this.pan[i][j] = 20; //指定该位置为地雷

  }

  

  }

  

  /**统计棋盘上的数据*/

  

  private void CountBomb() {

  for (int i = 0; i < 8; i++) {

  for (int j = 0; j < 8; j++) {

  int count = 0;

  

  //当需要检测的单元格本身无地雷的情况下,统计周围的地雷个数

  if (pan[i][j] != 20) {

  if ( (i - 1 >= 0) && (j - 1 >= 0)) {

  if (pan[i - 1][j - 1] == 20) {

  count += 1; //检测左上方空格是否是地雷

  }

  }

  

  if ( (i - 1 >= 0)) {

  if (pan[i - 1][j] == 20) {

  count += 1; //检测上方空格是否为地雷

  }

  }

  

  if ( (i - 1 >= 0) && (j + 1 <= 7)) {

  if (pan[i - 1][j + 1] == 20) {

  count += 1; //检测右上方是否为地雷

  }

  }

  

  if ( (j - 1 >= 0)) {

  if (pan[i][j - 1] == 20) {

  count += 1; //检测左边是否为地雷

  }

  }

  

  if ( (i >= 0) && (j + 1 <= 7)) {

  if (pan[i][j + 1] == 20) {

  count += 1; //右边

  }

  }

  

  if ( (j - 1 >= 0) && (i + 1 <= 7)) {

  if (pan[i + 1][j - 1] == 20) {

  count += 1; //左下

  }

  }

  

  if ( (i + 1 <= 7)) {

  if (pan[i + 1][j] == 20) {

  count += 1; //下

  }

  }

  

  if ( (j + 1 <= 7) && (i + 1 <= 7)) {

  if (pan[i + 1][j + 1] == 20) {

  count += 1; //右下

  }

  }

  

  pan[i][j] = count;

  }

  }

  }

  }

  

  /**检测已经被揭开的位置总和

  

  * @return 返回被揭开的数量 */

  

  private int countOpen() {

  int count = 0;

  for (int i = 0; i < 8; i++) {

  for (int j = 0; j < 8; j++) {

  if (pan[i][j] < 20 && pan[i][j] > 9) {

  count += 1;

  }

  }

  }

  

  return count;

  }

  

  /**检测是否胜利

  

  * @return 是否胜利boolean值 */

  

  public boolean isWin() {

  

  // System.out.println(BombNum +""+ countOpen());

  if ( (BombNum + countOpen()) == 64) {

  this.GameOver = true;

  return true;

  }

  else {

  return false;

  }

  }

  

  /**选中棋盘上的位置,并翻开

  

  * @param matrix 位置 */

  

  public void openpan(int matrix) {

  switch (getBomb(matrix)) {

  case 20: //当选中的位置为地雷,游戏结束

  setGameOver();

  break;

  case 0:

  isNull(matrix); //当选中的位置为空,则翻开周围的地图

  break;

  default:

  this.isNotNull(matrix); //否则,翻开当前位置,并作上翻开的标记

  }

  }

  

  /**当选中的位置为空,则翻开周围的地图

  

  * @param matrix 位置 */

  

  private void isNull(int matrix) {

  int i, j;

  i = matrix / 8;

  j = matrix % 8;

  

  if (pan[i][j] < 9) {

  pan[i][j] += 10;

  }

  

  if ( (i - 1 >= 0) && (j - 1 >= 0)) { //检测左上方空格是否是空

  if (pan[i - 1][j - 1] == 0) {

  isNull( (i - 1) * 8 + (j - 1));

  }

  if (pan[i - 1][j - 1] < 9) {

  pan[i - 1][j - 1] += 10;

  }

  }

  

  if ( (i - 1 >= 0)) { //检测上方空格是否为空

  if (pan[i - 1][j] == 0) {

  isNull( (i - 1) * 8 + j);

  }

  if (pan[i - 1][j] < 9) {

  pan[i - 1][j] += 10;

  }

  }

  

  if ( (i - 1 >= 0) && (j + 1 <= 7)) { //检测右上方是否为空

  if (pan[i - 1][j + 1] == 0) {

  isNull( (i - 1) * 8 + (j + 1));

  }

  if (pan[i - 1][j + 1] < 9) {

  pan[i - 1][j + 1] += 10;

  }

  }

  

  if ( (j - 1 >= 0)) { //检测左边是否为空

  if (pan[i][j - 1] == 0) {

  isNull(i * 8 + (j - 1));

  }

  if (pan[i][j - 1] < 9) {

  pan[i][j - 1] += 10;

  }

  }

  

  if ( (i >= 0) && (j + 1 <= 7)) { //右边

  if (pan[i][j + 1] == 0) {

  isNull(i * 8 + (j + 1));

  }

  if (pan[i][j + 1] < 9) {

  pan[i][j + 1] += 10;

  }

  }

  

  if ( (j - 1 >= 0) && (i + 1 <= 7)) { //左下

  if (pan[i + 1][j - 1] == 0) {

  isNull( (i + 1) * 8 + (j - 1));

  }

  if (pan[i + 1][j - 1] < 9) {

  pan[i + 1][j - 1] += 10;

  }

  }

  

  if ( (i + 1 <= 7)) { //下

  if (pan[i + 1][j] == 0) {

  isNull( (i + 1) * 8 + j);

  }

  if (pan[i + 1][j] < 9) {

  pan[i + 1][j] += 10;

  }

  }

  

  if ( (j + 1 <= 7) && (i + 1 <= 7)) { //右下

  if (pan[i + 1][j + 1] == 0) {

  isNull( (i + 1) * 8 + (j + 1));

  }

  if (pan[i + 1][j + 1] < 9) {

  pan[i + 1][j + 1] += 10;

  }

  }

  }

  

  /**选中棋盘上的位置,并翻开当前位置

  

  * @param matrix 位置 */

  

  private void isNotNull(int matrix) {

  int i, j;

  i = matrix / 8;

  j = matrix % 8;

  pan[i][j] += 10;

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/8225414/viewspace-951697/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/8225414/viewspace-951697/

你可能感兴趣的文章
基本SQL命令-您应该知道的数据库查询和语句列表
查看>>
大omega记号_什么是大欧米茄符号?
查看>>
react 使用 mobx_如何使用React和MobX状态树构建基于状态的路由器
查看>>
移动认证_如何在移动设备上实施安全的生物特征认证
查看>>
敏捷开发创始人_开发人员和技术创始人如何将他们的想法转化为UI设计
查看>>
node aws 内存溢出_在AWS Elastic Beanstalk上运行生产Node应用程序的现实
查看>>
我如何在昌迪加尔大学中心组织Google Hash Code 2019
查看>>
子集和与一个整数相等算法_背包问题的一个变体:如何解决Java中的分区相等子集和问题...
查看>>
aws中部署防火墙_如何在AWS中设置自动部署
查看>>
typescript_如何掌握高级TypeScript模式
查看>>
golang底层深入_带有Golang的GraphQL:从基础到高级的深入研究
查看>>
如何选择正确的容器编排以及如何进行部署
查看>>
出现字迹模糊迹象_改变迹象:如何使用动态编程解决竞争性编程问题
查看>>
angular 渐进_如何创建具有Angular和无头CMS的渐进式Web应用程序
查看>>
Dash的快速入门将使您在5分钟内进入“ Hello World”
查看>>
cake php_如何(以及为什么)在Swinject中使用Cake Pattern
查看>>
用户体验改善案例_用户体验案例研究:建立更好的体验(重新设计“和平航空”网站)...
查看>>
nginx mozilla_我发现Mozilla的私人浏览模式存在重大缺陷。
查看>>
databricks_如何开始使用Databricks
查看>>
盖茨比乔布斯_如何使用盖茨比创建您的博客并通过手机进行处理
查看>>