C语言新手写扫雷攻略3
界面绘制好后,雷数也布置了,接下来就是游戏的运行过程了,今天先不说具体过程,再来看看需要用到的辅助函数
先是简单的画红旗,鼠标右键的功能是画红旗,至此我们都是在使用函数自己绘图,效率是低,但有助于理解
void DrawRedFlag(int i, int j)
{
setfillstyle(BS_SOLID);
setfillcolor(RED);
bar(8 + j * 20, 35 + i * 20, 8 + j * 20 + 5, 35 + i * 20 + 5);
setcolor(BLACK);
line(8 + j * 20, 35 + i * 20, 8 + j * 20, 35 + i * 20 + 10);
}
里面的坐标算好偏移,可以根据自己游戏的位置自行计算偏移坐标
接下来是重要的雷数统计,统计的是一个格子周围的八个格子的雷数
int MineStatistics(int i, int j)/*统计每个格子周围的雷数*/
{
int nNUM = 0;
if (i == 0 && j == 0)/*左上角格子的统计*/
{
if (Mine[0][1].num == 1)
nNUM++;
if (Mine[1][0].num == 1)
nNUM++;
if (Mine[1][1].num == 1)
nNUM++;
}
else
if (i == 0 && j == 9)/*右上角格子的统计*/
{
if (Mine[0][8].num == 1)
nNUM++;
if (Mine[1][9].num == 1)
nNUM++;
if (Mine[1][8].num == 1)
nNUM++;
}
else
if (i == 9 && j == 0)/*左下角格子的统计*/
{
if (Mine[8][0].num == 1)
nNUM++;
if (Mine[9][1].num == 1)
nNUM++;
if (Mine[8][1].num == 1)
nNUM++;
}
else
if (i == 9 && j == 9)/*右下角格子的统计*/
{
if (Mine[9][8].num == 1)
nNUM++;
if (Mine[8][9].num == 1)
nNUM++;
if (Mine[8][8].num == 1)
nNUM++;
}
else if (j == 0)/*左边第一列格子的统计*/
{
if (Mine[i][j + 1].num == 1)
nNUM++;
if (Mine[i + 1][j].num == 1)
nNUM++;
if (Mine[i - 1][j].num == 1)
nNUM++;
if (Mine[i - 1][j + 1].num == 1)
nNUM++;
if (Mine[i + 1][j + 1].num == 1)
nNUM++;
}
else if (j == 9)/*右边第一列格子的统计*/
{
if (Mine[i][j - 1].num == 1)
nNUM++;
if (Mine[i + 1][j].num == 1)
nNUM++;
if (Mine[i - 1][j].num == 1)
nNUM++;
if (Mine[i - 1][j - 1].num == 1)
nNUM++;
if (Mine[i + 1][j - 1].num == 1)
nNUM++;
}
else if (i == 0)/*第一行格子的统计*/
{
if (Mine[i + 1][j].num == 1)
nNUM++;
if (Mine[i][j - 1].num == 1)
nNUM++;
if (Mine[i][j + 1].num == 1)
nNUM++;
if (Mine[i + 1][j - 1].num == 1)
nNUM++;
if (Mine[i + 1][j + 1].num == 1)
nNUM++;
}
else if (i == 9)/*最后一行格子的统计*/
{
if (Mine[i - 1][j].num == 1)
nNUM++;
if (Mine[i][j - 1].num == 1)
nNUM++;
if (Mine[i][j + 1].num == 1)
nNUM++;
if (Mine[i - 1][j - 1].num == 1)
nNUM++;
if (Mine[i - 1][j + 1].num == 1)
nNUM++;
}
else/*普通格子的统计*/
{
if (Mine[i - 1][j].num == 1)
nNUM++;
if (Mine[i - 1][j + 1].num == 1)
nNUM++;
if (Mine[i][j + 1].num == 1)
nNUM++;
if (Mine[i + 1][j + 1].num == 1)
nNUM++;
if (Mine[i + 1][j].num == 1)
nNUM++;
if (Mine[i + 1][j - 1].num == 1)
nNUM++;
if (Mine[i][j - 1].num == 1)
nNUM++;
if (Mine[i - 1][j - 1].num == 1)
nNUM++;
}
return nNUM;/*把格子周围一共有多少雷数的统计结果返回*/
}
这个功能的返回值就是这个各自周围的雷数,也就是扫雷点开后显示的数字
不是每个格子都有雷,还有连续的区域是没有雷的,所以要现实空白的格子
void ShowWhite(int i, int j)/*显示无雷区的空白部分*/
{
if (Mine[i][j].flag == 1 || Mine[i][j].num == 0)/*如果有红旗或该格处理过就不对该格进行任何判断*/
return;
mineNUM--;/*显示过数字或者空格的格子就表示多处理了一个格子,当所有格子都处理过了表示胜利*/
if (Mine[i][j].roundnum == 0 && Mine[i][j].num != 1)/*显示空格*/
{
DrawEmpty(i, j, 1, WHITE);
Mine[i][j].num = 0;
}
else
if (Mine[i][j].roundnum != 0)/*输出雷数*/
{
DrawEmpty(i, j, 1, WHITE);
_stprintf_s(randmineNUM, _T("%d"), Mine[i][j].roundnum);
setcolor(RED);
outtextxy(6 + j * 20, 32 + i * 20, randmineNUM);
Mine[i][j].num = 0;/*已经输出雷数的格子用0表示已经用过这个格子*/
return;
}
/*8个方向递归显示所有的空白格子*/
if (i != 0 && Mine[i - 1][j].num != 1)
ShowWhite(i - 1, j);
if (i != 0 && j != 9 && Mine[i - 1][j + 1].num != 1)
ShowWhite(i - 1, j + 1);
if (j != 9 && Mine[i][j + 1].num != 1)
ShowWhite(i, j + 1);
if (j != 9 && i != 9 && Mine[i + 1][j + 1].num != 1)
ShowWhite(i + 1, j + 1);
if (i != 9 && Mine[i + 1][j].num != 1)
ShowWhite(i + 1, j);
if (i != 9 && j != 0 && Mine[i + 1][j - 1].num != 1)
ShowWhite(i + 1, j - 1);
if (j != 0 && Mine[i][j - 1].num != 1)
ShowWhite(i, j - 1);
if (i != 0 && j != 0 && Mine[i - 1][j - 1].num != 1)
ShowWhite(i - 1, j - 1);
}
这些是辅助函数,基本就这些!
C语言新手写扫雷攻略3的更多相关文章
- C语言新手写扫雷攻略1
工欲善其事,必先利其器,首先要准备好开发环境,既然是C语言,那就不是WinAPI的扫雷,就是纯的C语言开发,但是以前的C都是TC开发的,现在用肯定是过时很久了,但是也是有解决办法的,某些大神开发出Ea ...
- C语言新手写扫雷攻略4
今天写的是游戏过程的函数,基本的算法前面都解释过了,今天是实现基本的功能 补充一下前面需要用到的头文件 #include<conio.h> //_kbhit() #include<s ...
- C语言新手写扫雷攻略2
接下来是游戏的功能设计,要有扫雷的基本功能,左键点击雷区,右键红旗标记,并且可以统计雷数,可以重新开始,以下是游戏的功能初始 void Game(void) { while (1) { if (FLA ...
- C语言新手写扫雷源代码
今天发布源代码,由于写在一个文件里非常乱,所以分三个文件写 绘图和鼠标函数graph.h /*绘图与鼠标相关函数*/ #include<graphics.h> #include <e ...
- 某Facebook工程师写的攻略。
Chapter 1 Interesting read, but you can skip it. Chapter 2 2.1 Insertion Sort - To be honest you sho ...
- 寒城攻略:Listo 教你用Swift 语言编写 IOS 平台流媒体播放器
先展示播放器效果: 依然继承 Listo 本人的强迫症,还是从最初到完毕完整的写一个攻略来记录一下,这里声明 Listo 本人也是看了非常多的戴维营攻略才总结分享给大家这一篇攻略的. 首先,Lis ...
- Nazo解密游戏攻略
啊,终于腾出时间来玩这个游戏了,顺手写一下攻略吧…… 第0关:http://cafebabe.cc/nazo/ 第一关:第一关很简单 点一下就好了 http://cafebabe.cc/nazo/le ...
- 写给C语言新手的话
首先声明啊,写这个是因为一些加我QQ的朋友问我学习经验,我才写的. 另外,如果是二级党,那么请用谭浩强老师的书.然后你就可以不用看了.倒不是有偏见,而是我写的这个东西,根本不是为了考试,而是为了和新手 ...
- Davinci DM6446开发攻略-UBOOT-2009.03移植2 nand flash的烧写
很长一段时间没有更新博客了,是因为要推出新开发方案和做好客户服务工作,忙得不易乐乎.有关DAVINCI U-BOOT的移植,以前写过一篇u-boot-1.3.4(2008年的),其实和这个u-bo ...
随机推荐
- centos7实现ssh免秘钥分发
centos7的秘钥分发与centos6的秘钥分发还有点不一样,今天在给朋友排坑,在网上找了半天,也没有一个好解决方法,就只能自己研究,今天就把我解决的问题分享出来:那么如何实现centos7秘钥分发 ...
- 大碗宽面Beta迭代阶段第十二周会议记录
本周一晚上我们在熟悉的宿舍楼一楼大厅进行了本周的小组会议. 对于上周的任务,前端的同学修改统一了导航栏和footer,在课程评价界面中添加了“添加评论”功能,其中含有,是否修改过该课程的单选框,评论, ...
- cms网站模板收集
Dedecms模板 1.魔客吧 ----- dedecms .wordpress .discuz.shopnc.ecshop等模板都有 eg: html5绿色响应式企业网页模板 2.绘艺素材 -- ...
- TopCoder - 15135 LongPalindromes
https://vjudge.net/problem/TopCoder-15135 之前做过:本质不同的回文子序列个数 本题:位置不同即为不同. 如果还是设$f[l][r]$表示$l$,$r$结尾,就 ...
- 探索Redis设计与实现2:Redis内部数据结构详解——dict
本文转自互联网 本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial ...
- Oracle数据库中,sql中(+)(-)的含义
SELECT *FROM TABLE1 A,TABLE2 B WHERE A.ID(+)=B.ID; 右连接=RIGHT JOIN SELECT *FROM TABLE1 A,TABLE2 B WHE ...
- (转)C语言指针5分钟教程
转:http://blog.jobbole.com/25409/ 指针.引用和取值 什么是指针?什么是内存地址?什么叫做指针的取值?指针是一个存储计算机内存地址的变量.在这份教程里“引用”表示计算机内 ...
- SQL之in和like的连用实现范围内的模糊查询
我们知道in可以实现一个范围内的查询,like可以实现模糊查询, 如 select *where col like 123%但是我们如果有一列attri,如123,132,165... 我们想实现12 ...
- Dubbo入门到精通学习笔记(十八):使用Redis3.0集群实现Tomcat集群的Session共享
文章目录 1.单节点访问http://192.168.1.61:8082/pay-web-boss/: 2.增加多一个消费者节点:192.168.1.62,以同样的方式部署pay-web-boss工程 ...
- Gym 102021D : Down the Pyramid(思维)
Do you like number pyramids? Given a number sequence that represents the base, you are usually suppo ...