基本信息
源码名称:c#扫雷经典版(wpf)
源码大小:3.00M
文件格式:.zip
开发语言:C#
更新时间:2020-01-08
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 4 元×
微信扫码支付:4 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
1、正常扫雷功能,游戏计时,
2、两种模式:①点击开始游戏直接开始普通模式,过一关游戏雷数增加,行和列增加;
②菜单栏选择初级难度、中级难度和高级难度;
3、右键点击插旗功能
4、游戏失败后点击重新开始刷新地图重新开始
5、通关后点击下一关进入下一关
void CountMine(int i,int j,Image img) { if (bomOrgo[i,j]==true) { return; } bomOrgo[i,j] = true; //创建一个变量来接收地雷数 int count = 0; //判断当前位置四周的八个方向是否为雷,如果是则count if (IsBoom(i - 1, j - 1)) { count ; } if (IsBoom(i-1,j)) { count ; } if (IsBoom(i - 1, j 1)) { count ; } if (IsBoom(i, j-1)) { count ; } if (IsBoom(i , j 1)) { count ; } if (IsBoom(i 1, j-1)) { count ; } if (IsBoom(i 1, j)) { count ; } if (IsBoom(i 1, j 1)) { count ; } //递归思想:判断如果当前位置的8个方向都没有雷,则再以八个方向为中心重复调用自己这个方法往外判断 if (count==0) { GameBG.Children.Remove(img); //外部if保证数组不超出索引 if (i>0) { CountMine(i - 1, j,images[i-1,j]); if (j>0) { CountMine(i-1,j-1, images[i - 1, j-1]); } } if (i<maps.GetLength(0)-1) { CountMine(i 1, j,images[i 1, j]); } if (i>0&&j<maps.GetLength(1)-1) { CountMine(i - 1, j 1, images[i - 1, j 1]); } if (j<maps.GetLength(1)-1) { CountMine(i , j 1, images[i, j 1]); } if (j>0) { CountMine(i, j - 1, images[i , j-1]); } if (i < maps.GetLength(1)-1&&j>0) { CountMine(i 1, j - 1, images[i 1, j-1]); } if (i < maps.GetLength(0)-1&& j < maps.GetLength(1)-1) { CountMine(i 1, j 1, images[i 1, j 1]); } } else { //移除该处图片 GameBG.Children.Remove(img); //实例化label Label lb = new Label(); lb.Content = count.ToString(); //将label设置网格的相应位置处 Grid.SetRow(lb, i); Grid.SetColumn(lb, j); lb.FontSize = 24; //设置label水平居中 lb.HorizontalContentAlignment = HorizontalAlignment.Center; //设置label竖直居中 lb.VerticalContentAlignment = VerticalAlignment.Center; GameBG.Children.Add(lb); } }