Java实现简单的扫雷小程序

这篇文章主要为大家详细介绍了Java实现简单的扫雷小程序,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

前两天看了个扫雷的视频,于是自己跟着做了下,感觉还不是很难。

初学Java的同学可以尝试自己操作下Java小程序

这样子才能提高自己的理解能力和编程水平

不用多说了,直接上代码吧!

具体代码操作如下:

import java.awt.BorderLayout; import java.awt.Color; import java.awt.Container; import java.awt.GridLayout; import java.awt.event.ActionEvent; import java.awt.event.ActionListener; import java.util.Random; import javax.swing.JButton; import javax.swing.JFrame; import javax.swing.*; public class saolei implements ActionListener { JFrame frame=new JFrame("扫雷游戏"); JButton reset=new JButton("重来"); Container container=new Container(); //游戏数据结构 final int row=20; final int col=20; final int leiCount=30; JButton [][] buttons=new JButton[row][col]; int [][] counts=new int[row][col]; final int LEICODE=10; // 构造函数 public saolei(){ //1、设置窗口 frame.setSize(900, 800); frame.setResizable(true);//是否可改变窗口大小 frame.setDefaultCloSEOperation(JFrame.EXIT_ON_CLOSE); frame.setLayout(new BorderLayout()); //2、添加重来按钮 addResetButton(); //添加按钮 addButtons(); //埋雷 addLei(); //添加雷的计算 calcNeiboLei(); frame.setVisible(true); } public void addResetButton(){ reset.setBackground(Color.green); reset.setopaque(true); reset.addActionListener(this); frame.add(reset,BorderLayout.norTH); } public void addLei(){ Random rand=new Random(); int randRow,randCol; for(int i=0;i0 && j>0 && counts[i-1][j-1]==LEICODE) count++; if(i>0&&counts[i-1][j]==LEICODE) count++; if(i>0 && j0 && counts[i][j-1]==LEICODE) count++; if(j0&&counts[i+1][j-1]==LEICODE) count++; if(i0 && j>0 && counts[i-1][j-1]!=LEICODE) openCell(i-1, j-1); if(i>0&&counts[i-1][j]!=LEICODE) openCell(i-1, j); if(i>0 && j0 && counts[i][j-1]!=LEICODE) openCell(i, j-1); if(j0&&counts[i+1][j-1]!=LEICODE) openCell(i+1, j-1); if(i

大致具体的代码和结果如下

更多精彩游戏,请参考专题《java经典小游戏》

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

HashMap是Java中最常用的集合类框架,也是Java语言中非常典型...
在EffectiveJava中的第 36条中建议 用 EnumSet 替代位字段,...
介绍 注解是JDK1.5版本开始引入的一个特性,用于对代码进行说...
介绍 LinkedList同时实现了List接口和Deque接口,也就是说它...
介绍 TreeSet和TreeMap在Java里有着相同的实现,前者仅仅是对...
HashMap为什么线程不安全 put的不安全 由于多线程对HashMap进...