本篇文章分享看题目就知道是写给初学者的,学的比较好的小伙伴也可以将自动算法等一些知识给加进去,希望对大家有帮助!

好了,当我们所有的准备工作做好之后,我们就可以来编写我们的C语言连连看游戏了!

其实这个游戏设计起来真的是很简单的一种,本例用到的知识点主要有:数组,结构体,分支结构,图形库函数。

游戏效果展示

 

连连看游戏的效果图大致就是这样(之所以没用本例的,是因为没用图形开发还是有点不好看,嘿嘿~)

编写准备:编译软件(VS2013),连连看图片素材,easyX图形库插件,有需要可以关注笔者微信公众号:C语言编程学习基地,领取相关图片素材可以回复关键字【连连看】即可。

那么接下来就给大家展示我们本期的连连看游戏C语言代码,自己写之前,请一定要获取到相关的必备资料哦!不然你就无法根据代码示例写出来了!

源代码示例

/*
课程内容:练练看,很简单
开发环境:vs2013+easyx图形库
知识点:
数组,结构体,分支结构,图形库函数
*/
#include<stdio.h>
#include<graphics.h>
#define IMG_SIZE 39 //隔一个动物图片的宽度
#define MAX_ANIMAL_NUM 42 //总共的动物数量
#define MAP_SIZE 10 //每行动物的数量
#define WIN_SIZE (MAP_SIZE*IMG_SIZE+2*IMG_SIZE) //定义变量 int a;
IMAGE img_total[];
IMAGE img_animal[MAX_ANIMAL_NUM][];
//地图
int map[MAP_SIZE+][MAP_SIZE+];
//存储两次点击的数组的下标
POINT begin = { -, - }, end = { -, - };
enum STATE
{
BEGIN,
END,
};
int flag = BEGIN;
//游戏初始化
void GameInit()
{
//创建一个图形窗口,贴图片
initgraph(WIN_SIZE, WIN_SIZE,SHOWCONSOLE);
//设置随机数种子
srand(GetTickCount());
//加载图片,如果现实没有重载的函数,就是字符集的问题
loadimage(&img_total[], "./res/animal.bmp");
loadimage(&img_total[], "./res/bk.jpg", WIN_SIZE, WIN_SIZE);
//把整个图片进行分割,保存到新的数组
SetWorkingImage(&img_total[]);
for (int i = ; i < MAX_ANIMAL_NUM; i++)
{
for (int k = ; k < ; k++)
{
getimage(&img_animal[i][k], k*IMG_SIZE, i*IMG_SIZE, IMG_SIZE, IMG_SIZE);
}
}
SetWorkingImage();
//11111 222 3333
//每张图片来10张
int temp = ,_count=;
for (int i = ; i <= MAP_SIZE; i++)
{
for (int k = ; k <= MAP_SIZE; k++)
{
map[i][k] = temp;
if (_count % == )
{
temp++;
}
_count++; }
}
//打乱图片,实际上就是打乱数组数据
for (int i = ; i <= MAP_SIZE; i++)
{
for (int k = ; k <= MAP_SIZE; k++)
{
int temp=map[i][k];
int row = rand() % + ;
int col = rand() % + ;
map[i][k] = map[row][col];
map[row][col] = temp;
}
}
}
//游戏的绘制
void GameDraw()
{
putimage(, , &img_total[]);
for (int i = ; i <= MAP_SIZE; i++)
{
for (int k = ; k <= MAP_SIZE; k++)
{
if (map[i][k]>)
{
//用透明贴图,使图片背景透明
putimage(k*IMG_SIZE, i*IMG_SIZE, &img_animal[map[i][k]][],SRCAND);
putimage(k*IMG_SIZE, i*IMG_SIZE, &img_animal[map[i][k]][],SRCPAINT);
}
}
} }
//鼠标控制消除,获取鼠标消息
void GameMouse()
{
//检测是否有鼠标操作
if (MouseHit())
{
MOUSEMSG msg = GetMouseMsg();
if (msg.uMsg == WM_LBUTTONDOWN )
{
if (flag==BEGIN)
{
begin.x = msg.y / IMG_SIZE;
begin.y = msg.x / IMG_SIZE;
flag = END;
}
else if (flag == END)
{
end.x = msg.y / IMG_SIZE;
end.y = msg.x / IMG_SIZE;
flag = BEGIN;
}
printf("begin(%d,%d),end(%d,%d)\n", begin.x, begin.y, end.x, end.y);
}
}
}
void show()
{
for (int i = ; i <= MAP_SIZE+; i++)
{
for (int k = ; k <= MAP_SIZE+; k++)
{
printf("%2d ",map[i][k]); }
printf("\n");
} }
//判断某一点是否有图片,没有为0
int isBlocked(int x,int y)
{
return map[x][y];
}
//水平方向是否能够消除
bool horizon(POINT begin, POINT end)
{
//不能点击同一个
if (begin.x == end.x &&begin.y == end.y)
{
return false;
}
//检测是否在同一水平方向
if (begin.x != end.x)
{
return false;
}
//求出大小
int m_min = min(begin.y, end.y);
int m_max = max(begin.y, end.y);
for (int i = m_min + ; i < m_max; i++)
{
if (isBlocked(begin.x, i))
{
return false;
}
}
return true;
}
//垂直方向是否能够消除
bool vertical(POINT begin, POINT end)
{
//不能点击同一个
if (begin.x == end.x &&begin.y == end.y)
{
return false;
}
//检测是否在同一垂直方向
if (begin.y != end.y)
{
return false;
}
//求出大小
int m_min = min(begin.x, end.x);
int m_max = max(begin.x, end.x);
for (int i = m_min + ; i < m_max; i++)
{
if (isBlocked(i,begin.y))
{
return false;
}
}
return true;
}
//一个拐点
bool turn_ocne(POINT begin, POINT end)
{
//不能点击同一个
if (begin.x == end.x &&begin.y == end.y)
{
return false;
}
//保存两个拐点信息
POINT temp1 = { begin.x, end.y }, temp2 = { end.x, begin.y };
if (!isBlocked(begin.x, end.y))
{
if (horizon(begin, temp1) && vertical(end, temp1))
{
return true;
} }
if (!isBlocked(end.x, begin.y))
{
if (horizon(end, temp2) && vertical(temp2, begin))
{
return true;
} }
return false;
}
int main()
{
GameInit();
show();
BeginBatchDraw();
while ()
{
GameDraw();
FlushBatchDraw();
GameMouse();
//消除操作,消除就是让数组的值等于0
if (map[begin.x][begin.y] == map[end.x][end.y])
{
if (horizon(begin, end))
{
map[begin.x][begin.y] = ;
map[end.x][end.y] = ;
}
else if (vertical(begin, end))
{
map[begin.x][begin.y] = ;
map[end.x][end.y] = ;
}
else if (turn_ocne(begin, end))
{
map[begin.x][begin.y] = ;
map[end.x][end.y] = ;
} }
}
return ;
}

以上就是分享给大家的全部的C语言代码,希望能够对大家有帮助~

自学C/C++编程难度很大,不妨和一些志同道合的小伙伴一起学习成长!

C语言C++编程学习交流圈子,【点击进入】微信公众号:C语言编程学习基地

有一些源码和资料分享,欢迎转行也学习编程的伙伴,和大家一起交流成长会比自己琢磨更快哦!

C/C++编程笔记:C语言实现连连看游戏,小白练手项目(源码分享)的更多相关文章

  1. C/C++编程笔记:C语言开发球球大作战(源码分享),你想试试吗?

    游戏背景 <球球大作战>是Superpop一款自主研du发的免费手机网络游戏. 以玩家间的实时互动PK产生游戏乐趣为设计宗旨,通过简单的规则将玩家操作直接转化为游戏策略,体验智谋碰撞的战斗 ...

  2. C/C++编程笔记:流行的数字游戏【2048】,C语言400行源代码分享

    游戏介绍 你玩过2048吗?2048是一款流行于各大网页和手机的数字游戏,手机安卓版推出的是<挑战2048>,之后的版本中还加入了双人对战的游戏模式,更加受到玩家的热捧. 2048的游戏规 ...

  3. 编译哈工大语言技术平台云LTP(C++)源码及LTP4J(Java)源码

    转自:编译哈工大语言技术平台云LTP(C++)源码及LTP4J(Java)源码 JDK:java version “1.8.0_31”Java(TM) SE Runtime Environment ( ...

  4. python编程从入门到实践 alien invasion 项目源码

    现在上传一个 python编程从入门到实践 alien invasion 项目源码 以供大家学习参考 跟官方版本可能不太一样,因为是自己写的 也算是给新手一个参考 我用的环境是pycharm 可能需要 ...

  5. C/C++编程笔记:C语言写推箱子小游戏,大一学习C语言练手项目

    C语言,作为大多数人的第一门编程语言,重要性不言而喻,很多编程习惯,逻辑方式在此时就已经形成了.这个是我在大一学习 C语言 后写的推箱子小游戏,自己的逻辑能力得到了提升,在这里同大家分享这个推箱子小游 ...

  6. C/C++编程笔记:C语言成绩管理系统!链式结构的管理系统源码分享

    最近很多同学因为学校的要求,需要完成自己的那个C语言课程设计,于是就有很多人私信或者加我私聊我,问的最多的还是<学生成绩管理系统>,其实当你项目写多了你就会发现:其实各类的管理系统都离不开 ...

  7. 基于python语言的tensorflow的‘端到端’的字符型验证码识别源码整理(github源码分享)

    基于python语言的tensorflow的‘端到端’的字符型验证码识别 1   Abstract 验证码(CAPTCHA)的诞生本身是为了自动区分 自然人 和 机器人 的一套公开方法, 但是近几年的 ...

  8. 并发编程(十二)—— Java 线程池 实现原理与源码深度解析 之 submit 方法 (二)

    在上一篇<并发编程(十一)—— Java 线程池 实现原理与源码深度解析(一)>中提到了线程池ThreadPoolExecutor的原理以及它的execute方法.这篇文章是接着上一篇文章 ...

  9. 并发编程(七)——AbstractQueuedSynchronizer 之 CountDownLatch、CyclicBarrier、Semaphore 源码分析

    这篇,我们的关注点是 AQS 最后的部分,共享模式的使用.本文先用 CountDownLatch 将共享模式说清楚,然后顺着把其他 AQS 相关的类 CyclicBarrier.Semaphore 的 ...

随机推荐

  1. 文件读取一些payload

    Windows: C:boot.ini //查看系统版本 C:WindowsSystem32inetsrvMetaBase.xml //IIS配置文件 C:Windowsrepairsam //存储系 ...

  2. Unity音量可视化——粒子随声浪跳动

    起初是看到这么一篇博客 Shader特效-- 音符跳动,效果如下图 具体的shader代码就不贴在这里了,他的博客里都有. 处理音频的关键代码如下: private int m_NumSamples ...

  3. 目录(Django开发)

    python网络编程-socket编程 Django 笔记分享 Django之[基础篇] Django之[进阶篇] Django之 url组件 Django之 Models组件 Django之 adm ...

  4. Python之爬虫(十五) Scrapy框架的命令行详解

    这篇文章主要是对的scrapy命令行使用的一个介绍 创建爬虫项目 scrapy startproject 项目名例子如下: localhost:spider zhaofan$ scrapy start ...

  5. java大数据最全课程学习笔记(1)--Hadoop简介和安装及伪分布式

    Hadoop简介和安装及伪分布式 大数据概念 大数据概论 大数据(Big Data): 指无法在一定时间范围内用常规软件工具进行捕捉,管理和处理的数据集合,是需要新处理模式才能具有更强的决策力,洞察发 ...

  6. 也来谈谈python编码

    一.coding:utf-8 让我们先来看一个示例,源码文件是utf-8格式: print('你好 python') 当使用python2执行该程序时会收到一下报错: File "./hel ...

  7. Cyber Security - Palo Alto Firewall Objects Addresses, Services, and Groups(1)

    Address Objects and Groups Creating address objects. Organizing address objects with address groups ...

  8. echarts 踩坑 : 为什么触摸柱状图的时后柱子不见了?原来是color的锅!

    今天发现一个奇怪的问题. 当我的鼠标触摸柱状图的时候,柱状图就消失了. 后来发现是颜色的设置有问题. color: ['rgba(68,238,224)', 'rgba(17,215,255)', ' ...

  9. MySQL数据库的安装方法

  10. 3.OSPF协议及链路状态算法

    OSPF的特点: 1.使用洪泛法向自治系统内所有路由器发送信息,即路由器通过输出端口向所有相邻的路由器发送信息,而每一个相邻路由器又再次将此信息发往其所有的相邻路由器.最终整个区域内所有路由器都得到了 ...