龙空技术网

程序员用Java实现扫雷小游戏,引来广大网友狂点赞,直呼屌炸天!

胖胖冲鸭 236

前言:

现在我们对“扫雷游戏中也有递归问题”都比较注意,看官们都想要分析一些“扫雷游戏中也有递归问题”的相关知识。那么小编在网上搜集了一些对于“扫雷游戏中也有递归问题””的相关资讯,希望朋友们能喜欢,各位老铁们一起来了解一下吧!

扫雷游戏想必大家都玩过,但有没有想过自己开发呢?Java开发过许多小游戏,其中扫雷给小白来练手非常适合不过了。

话不多说,首先展示一下游戏界面:

​实现过程如下:

首先设计一个二维数组,用于存放雷和周围八个格子雷的个数,再定义两个一维数组分别存放雷的X和Y坐标,布雷,记录周围八个格子雷的个数。

小编整理了一份java学习资料,私信回复【01】,获取源码。

我使用的是EditPlus(新建Java项目Boom,新建package:boom,新建Class:Block)

代码:

建立一个顶层容器JFrame,上面添加一个JPanel——JpMain,使用BorderLayout布局North为重新开始按钮,Center为雷区(新建一个对象,把雷区进行了封装),South为选择难度区域(任然使用一个JPanel,上面添加JRadioButton单选器),顶层容器代码:

(在Boom项目下新建Class,命名为SuperJpanel。)

代码:

创建一个对象——雷区对象的初始化,整个雷区使用一个JPanel包含,这个JPanel使用GridLayout布局方式,雷区有多少个格子就添加多少个JPanel,使用卡片布局方式,每个JPanel中有两个卡片,第一个卡片为按钮,第二张卡片为JLabel——用于显示雷,周围雷的个数。

(新建Class命名为CenterJpanel)

PS:将遍历周围八个数组封装成方法,再递归调用,最后发现因为递归层次太多极其容易卡死,所以不得不另想办法,最后想到了使用队列,把每个0的点放入队列,直到判断到不为0的地方。

代码:

​新建Class ——BoomMain 勾选产生主函数

主函数,初始化一个SuperJpanel对象

代码:

标签: #扫雷游戏中也有递归问题