Android 实现扫雷小游戏实例代码
发布时间 - 2026-01-10 22:05:18 点击率:次Android 实现扫雷小游戏实例

最近学习Android 应用编程,抽空做个小应用,大家熟悉的扫雷应用,练手用,
以下是实现代码:
MainActivity 类
public class MainActivity extends Activity implements OnClickListener,
OnLongClickListener {
// 最外层布局
LinearLayout textviews;
LinearLayout buttons;
int[][] map = new int[10][10];
// 用来隐藏所有Button
List<Button> buttonList = new ArrayList<Button>();
// -1
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
textviews = (LinearLayout) findViewById(R.id.textviews);
buttons = (LinearLayout) findViewById(R.id.buttons);
initData();
initView();
}
Set<Integer> random地雷;
private void initData() {
// 10个地雷 显示* 数组中是-1
// 90个 雷的边上是数字,其他是空白 0 1-8
// 100个数字 从里面随机取走10个
// 初始化
for (int i = 0; i < 10; i++) {
for (int j = 0; j < 10; j++) {
map[i][j] = 0;
}
}
// 抽取100个数 99
random地雷 = getRandom();
// 丢入map
for (Integer integer : random地雷) {
int hang = integer / 10;// 98
int lie = integer % 10;
// 所有的地雷用-1代替
map[hang][lie] = -1;
}
// 为所有的空白地点去设置数值
for (int i = 0; i < 10; i++) {
for (int j = 0; j < 10; j++) {
if (map[i][j] == -1)
continue; // 继续下次循环
int sum = 0;
// 左上角
if (i != 0 && j != 0) {// 防止下标越界
if (map[i - 1][j - 1] == -1)
sum++;
}
// 上面
if (j != 0) {
if (map[i][j - 1] == -1)
sum++;
}
// 右上角
if (j != 0 && i != 9) {
if (map[i + 1][j - 1] == -1)
sum++;
}
// 左边
if (i != 0) {
if (map[i - 1][j] == -1)
sum++;
}
// 右边
if (i != 9) {
if (map[i + 1][j] == -1)
sum++;
}
// 左下角
if (j != 9 && i != 0) {
if (map[i - 1][j + 1] == -1)
sum++;
}
if (j != 9) {
if (map[i][j + 1] == -1)
sum++;
}
if (j != 9 && i != 9) {
if (map[i + 1][j + 1] == -1)
sum++;
}
map[i][j] = sum;
}
}
// 打印看看
for (int i = 0; i < 10; i++) {
for (int j = 0; j < 10; j++) {
System.out.print(map[i][j] + " ");
}
System.out.println();
}
}
private Set<Integer> getRandom() {
// 没有重复的
Set<Integer> set = new HashSet<Integer>();
while (set.size() != 10) {
int random = (int) (Math.random() * 100);
set.add(random);
}
return set;
}
// 创建视图
private void initView() {
int width = getResources().getDisplayMetrics().widthPixels / 10;
LinearLayout.LayoutParams params = new LinearLayout.LayoutParams(width,
width);
for (int i = 0; i < 10; i++) {
// 每一条的布局
LinearLayout tvs = new LinearLayout(this);
tvs.setOrientation(LinearLayout.HORIZONTAL);
LinearLayout btns = new LinearLayout(this);
btns.setOrientation(LinearLayout.HORIZONTAL);
// 添加内层的100个按钮和文本
for (int j = 0; j < 10; j++) {
// 底层的TextView
TextView tv = new TextView(this);
tv.setBackgroundResource(R.drawable.textview_bg);
tv.setLayoutParams(params);
tv.setGravity(Gravity.CENTER);
if (map[i][j] == -1)
tv.setText("*");
else if (map[i][j] != 0)
tv.setText(map[i][j] + "");
tvs.addView(tv);
// 底层的Button
Button btn = new Button(this);
btn.setBackgroundResource(R.drawable.button);
btn.setLayoutParams(params);
btn.setTag(i * 10 + j);
btn.setOnClickListener(this);
btn.setOnLongClickListener(this);
buttonList.add(btn);
btns.addView(btn);
}
textviews.addView(tvs);
buttons.addView(btns);
}
}
@Override
public void onClick(View v) {
int id = (Integer) v.getTag();
int hang = id / 10;
int lie = id % 10;
// 隐藏按钮,显示底下的数据
v.setVisibility(View.INVISIBLE);
isOver(hang, lie);
// 判断点击的是否是一个数字
if (map[hang][lie] == 0) {
// 开始递归
显示周围所有的空白(hang, lie);
}
if (isWin()) {
Toast.makeText(this, "游戏胜利", Toast.LENGTH_SHORT).show();
}
}
// 显示周围所有的button
public void 显示周围所有的空白(int i, int j) {
// 检测周围的元素,如果为0 继续调用自身,并且显示
// 不是,就显示button
// 从左上角开始
// 左上角
// 先显示自己
buttonList.get(i * 10 + j).setVisibility(View.INVISIBLE);
if (i != 0 && j != 0) {// 防止下标越界
if (map[i - 1][j - 1] == 0) {
if (判断是否需要递归(i - 1, j - 1))
显示周围所有的空白(i - 1, j - 1);
} else {
隐藏button(i - 1, j - 1);
}
}
// 上面
if (j != 0) {
if (map[i][j - 1] == 0) {
if (判断是否需要递归(i, j - 1))
显示周围所有的空白(i, j - 1);
} else {
隐藏button(i, j - 1);
}
}
// 右上角
if (j != 0 && i != 9) {
if (map[i + 1][j - 1] == 0) {
if (判断是否需要递归(i + 1, j - 1))
显示周围所有的空白(i + 1, j - 1);
} else {
隐藏button(i + 1, j - 1);
}
}
// 左边
if (i != 0) {
if (map[i - 1][j] == 0) {
if (判断是否需要递归(i - 1, j))
显示周围所有的空白(i - 1, j);
} else {
隐藏button(i - 1, j);
}
}
// 右边
if (i != 9) {
if (map[i + 1][j] == 0) {
if (判断是否需要递归(i + 1, j))
显示周围所有的空白(i + 1, j);
} else {
隐藏button(i + 1, j);
}
}
// 左下角
if (j != 9 && i != 0) {
if (map[i - 1][j + 1] == 0) {
if (判断是否需要递归(i - 1, j + 1))
显示周围所有的空白(i - 1, j + 1);
} else {
隐藏button(i - 1, j + 1);
}
}
if (j != 9) {
if (map[i][j + 1] == 0) {
if (判断是否需要递归(i, j + 1))
显示周围所有的空白(i, j + 1);
} else {
隐藏button(i, j + 1);
}
}
if (j != 9 && i != 9) {
if (map[i + 1][j + 1] == 0) {
if (判断是否需要递归(i + 1, j + 1))
显示周围所有的空白(i + 1, j + 1);
} else {
隐藏button(i + 1, j + 1);
}
}
}
private void 隐藏button(int i, int j) {
int 位置 = i * 10 + j;
buttonList.get(位置).setVisibility(View.INVISIBLE);
}
boolean 判断是否需要递归(int hang, int lie) {
// 判断是否是现实的
int 位置 = hang * 10 + lie;
if (buttonList.get(位置).getVisibility() == View.INVISIBLE)
return false;
else
return true;
}
private boolean isOver(int hang, int lie) {
// OVER
if (map[hang][lie] == -1) {
Toast.makeText(this, "GameOver", Toast.LENGTH_SHORT).show();
for (int i = 0; i < buttonList.size(); i++) {
buttonList.get(i).setVisibility(View.INVISIBLE);
}
return true;
}
return false;
}
// 最多10个旗子
List<Integer> 旗子 = new ArrayList<Integer>();
@Override
public boolean onLongClick(View v) {
// 插旗子
// 1. 有了旗子 就取消
// 2. 没有就插旗
Button btn = (Button) v;
int tag = (Integer) v.getTag();
if (旗子.contains(tag)) {
// 如果使用drawableTop 对应的java代码的方法
// setCompoundDrawablesWithIntrinsicBounds
btn.setText("");
// int ArrayList.remove(int);//下标
旗子.remove((Integer) tag);
} else {
// 没有插旗就需要插旗,判断数量是否超过了上限
if (旗子.size() != 10) {
旗子.add(tag);
btn.setText("∉ " + 旗子.size());
btn.setTextColor(Color.RED);
} else {
Toast.makeText(this, "没有旗子了", Toast.LENGTH_SHORT).show();
}
}
// 消耗事件,
return true;
}
// 是否胜利
public boolean isWin() {
int sum = 0;
for (int i = 0; i < buttonList.size(); i++) {
if (buttonList.get(i).getVisibility() == View.INVISIBLE)
sum++;
}
if (sum == 90)
return true;
return false;
}
}
xml
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:gravity="center"
android:orientation="vertical" >
<FrameLayout
android:id="@+id/framelayout"
android:layout_width="match_parent"
android:layout_height="wrap_content" >
<LinearLayout
android:id="@+id/textviews"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" />
<LinearLayout
android:id="@+id/buttons"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:orientation="vertical" >
</LinearLayout>
</FrameLayout>
</LinearLayout>
感谢阅读,希望能帮助到大家,谢谢大家对本站的支持!
# Android
# 扫雷
# 小游戏
# 实现扫雷小游戏
# Android小游戏扫雷
# Android高仿2048小游戏实现代码
# 最常见的猜拳小游戏Android代码实现
# Android实现2048小游戏
# Android 实现抖音小游戏潜艇大挑战的思路详解
# 递归
# 判断是否
# 是一个
# 他是
# 最多
# 希望能
# 做个
# 谢谢大家
# 边上
# 取走
# 组中
# 下次
# 最外层
# 超过了
# id
# initData
# Integer
# findViewById
# private
# random
相关栏目:
【
网站优化151355 】
【
网络推广146373 】
【
网络技术251813 】
【
AI营销90571 】
相关推荐:
PHP 500报错的快速解决方法
昵图网官方站入口 昵图网素材图库官网入口
如何用PHP工具快速搭建高效网站?
Laravel如何编写单元测试和功能测试?(PHPUnit示例)
利用python获取某年中每个月的第一天和最后一天
如何快速生成高效建站系统源代码?
简历没回改:利用AI润色让你的文字更专业
作用域操作符会触发自动加载吗_php类自动加载机制与::调用【教程】
JavaScript如何实现错误处理_try...catch如何捕获异常?
Laravel如何实现多对多模型关联?(Eloquent教程)
重庆市网站制作公司,重庆招聘网站哪个好?
简历在线制作网站免费版,如何创建个人简历?
Laravel怎么配置不同环境的数据库_Laravel本地测试与生产环境动态切换【方法】
mc皮肤壁纸制作器,苹果平板怎么设置自己想要的壁纸我的世界?
网站制作大概要多少钱一个,做一个平台网站大概多少钱?
Laravel Pest测试框架怎么用_从PHPUnit转向Pest的Laravel测试教程
香港网站服务器数量如何影响SEO优化效果?
Linux系统命令中screen命令详解
湖南网站制作公司,湖南上善若水科技有限公司做什么的?
如何在宝塔面板中修改默认建站目录?
uc浏览器二维码扫描入口_uc浏览器扫码功能使用地址
教你用AI将一段旋律扩展成一首完整的曲子
,交易猫的商品怎么发布到网站上去?
java获取注册ip实例
javascript读取文本节点方法小结
如何续费美橙建站之星域名及服务?
Laravel如何清理系统缓存命令_Laravel清除路由配置及视图缓存的方法【总结】
微信推文制作网站有哪些,怎么做微信推文,急?
谷歌Google入口永久地址_Google搜索引擎官网首页永久入口
Laravel如何获取当前登录用户信息_Laravel Auth门面使用与Session用户读取【技巧】
Laravel如何创建自定义中间件?(Middleware代码示例)
Laravel Telescope怎么调试_使用Laravel Telescope进行应用监控与调试
在线制作视频网站免费,都有哪些好的动漫网站?
Laravel如何处理和验证JSON类型的数据库字段
Laravel如何实现多级无限分类_Laravel递归模型关联与树状数据输出【方法】
公司网站制作价格怎么算,公司办个官网需要多少钱?
Bootstrap CSS布局之列表
JS中对数组元素进行增删改移的方法总结
Laravel怎么实现模型属性转换Casting_Laravel自动将JSON字段转为数组【技巧】
车管所网站制作流程,交警当场开简易程序处罚决定书,在交警网站查询不到怎么办?
图册素材网站设计制作软件,图册的导出方式有几种?
使用Dockerfile构建java web环境
ChatGPT怎么生成Excel公式_ChatGPT公式生成方法【指南】
html5如何设置样式_HTML5样式设置方法与CSS应用技巧【教程】
清除minerd进程的简单方法
UC浏览器如何切换小说阅读源_UC浏览器阅读源切换【方法】
如何用好域名打造高点击率的自主建站?
焦点电影公司作品,电影焦点结局是什么?
Laravel怎么创建自己的包(Package)_Laravel扩展包开发入门到发布
JavaScript Ajax实现异步通信

