C语言开发:如何用130行代码,写出"超火"微信小游戏—羊了个羊?
yund56 2025-05-04 18:18 12 浏览
近日,一款名为“羊了个羊”微信小游戏火爆全网。
凭借简单玩法和不走寻常路的关卡设置,三消小游戏《羊了个羊》,成为《合成大西瓜》《召唤神龙》后的小微游戏新王者。
“其实游戏很简单,就是凑齐三个一样的图案就能点击消除,凑不齐三个的图案先放在底部的七个待选栏位里,如果七个槽位都占满了,游戏就失败了。”游戏第一关其实是玩法教程,但当玩家来到第二关时,难度直线上升。根据官方介绍,“羊了个羊”是一款超难的闯关消除小游戏,通关率不到0.1%。
当然,我们这次可不是为了针对“羊了个羊”的玩法开发出游戏辅助这类的东西,而是说,我们作为学编程的程序员,能不能自己用自己所学知识来开发一个《羊了个羊(仿制版)》呢?那么话不多说,我反正已经试出来了,今天就是来秀秀源码的!(如果有大佬勿怪)
首先我准备了一些东西:
编译器+需要的插件:VS2022/2019,easyX图形库插件(建议安装最新的版本)注:VScode的朋友需要另外配置好环境。
需要准备的图片素材:
如果有需要可以在文章最后找到获取方式!
接下来就来看看我们的源码:
#include<easyx.h>
#include<stdio.h>
const int WIDTH = 400;
const int HEIGHT = 760;
const int INTERVAL = 48;
IMAGE img_bk;
IMAGE img_item[3];
void loadImg()
{
loadimage(&img_bk, "images/bk.jpg", WIDTH, HEIGHT);
loadimage(img_item + 0, "images/cao.png",48,48);
loadimage(img_item + 1, "images/lingdang.png", 48, 48);
loadimage(img_item + 2, "images/shu.png", 48, 48);
}
int main()
{
initgraph(WIDTH, HEIGHT,EW_SHOWCONSOLE);
loadImg();
int map[3][3] = {0};
//初始化地图
for (int r = 0; r < 3; r++)
{
for (int c = 0; c < 3; c++)
{
map[r][c] = r+1; //1 2 3
}
}
//打乱数组
for (int r = 0; r < 3; r++)
{
for (int c = 0; c < 3; c++)
{
int r1 = rand() % 3;
int c1 = rand() % 3;
int t = map[r1][c1];
map[r1][c1] = map[r][c];
map[r][c] = t;
}
}
int store[7] = { 0 };
int offsetX = (WIDTH - (2 * (48 + INTERVAL) + 48)) / 2;
int offsetY = (HEIGHT - (2 * (48 + INTERVAL) + 48)) / 2;
while (true)
{
BeginBatchDraw();
//绘制地图
putimage(0, 0, &img_bk);
//输出图片
for (int r = 0; r < 3; r++)
{
for (int c = 0; c < 3; c++)
{
if(map[r][c])
putimage(offsetX + c * (48 + INTERVAL), offsetY + r * (48 + INTERVAL), img_item + (map[r][c]-1));
}
}
//绘制下面
for (int i = 0; i < 7; i++)
{
if (store[i])
putimage((i * 50)+26, 620, img_item + (store[i]-1));
}
EndBatchDraw();
ExMessage msg = { 0 };
if (peekmessage(&msg) && msg.message == WM_LBUTTONDOWN)
{
//鼠标坐标判断
for (int r = 0; r < 3; r++)
{
for (int c = 0; c < 3; c++)
{
int x = offsetX + c * (48 + INTERVAL);
int y = offsetY + r * (48 + INTERVAL);
//printf("pos(%d,%d)\n", x, y);
//判断鼠标是否点击了图片
if (msg.x > x && msg.x < x + 48 && msg.y>y && msg.y < y + 48)
{
//求出点击的图片对应的数组下标
int col = (msg.x - offsetX) / (48 + INTERVAL);
int row = (msg.y - offsetY) / (48 + INTERVAL);
//printf("row:%d col:%d\n", row, col);
//把点击的图片添加到下面
for (int i = 0; i < 7; i++)
{
if (store[i] == 0)
{
store[i] = map[row][col];
break;
}
}
//如果下面有三个一样的就消除
int cnt = 0;
for (int i = 0; i < 7; i++)
{
if (store[i] == map[row][col])
{
cnt++;
}
}
if (cnt == 3)
{
for (int i = 0; i < 7; i++)
{
if (store[i] == map[row][col])
{
store[i] = 0;
}
}
}
//把点击的图片从map中删除
map[row][col] = 0;
}
}
}
}
}
while (1);
return 0;
}
我可没有私藏哦,想要试试的小伙伴赶紧去拿着源码编译吧!如果遇到问题可以从下面来找我哦~
对啦对啦!另外的话为了帮助大家,轻松,高效学习C语言/C++,我给大家分享我收集的资源,从最零基础开始的,帮助大家在学习C语言的道路上披荆斩棘!可以来我粉丝群领取哦~
编程学习书籍分享:
编程学习视频分享:
整理分享(多年学习的源码、项目实战视频、项目笔记,基础入门教程)最重要的是你可以在群里面交流提问编程问题哦!
对于C/C++感兴趣可以关注小编在后台私信我:【编程交流】一起来学习哦!可以领取一些C/C++的项目学习视频资料哦!已经设置好了关键词自动回复,自动领取就好了!
相关推荐
- Excel表格带单位求和不用愁!2个高效小技巧,轻松搞定!
-
我是【桃大喵学习记】,欢迎大家关注哟~,每天为你分享职场办公软件使用技巧干货!——首发于微信号:桃大喵学习记最近有小伙伴私信提问了个问题:“Excel表格数据带单位,如何快速求和?”。相信很多新手小伙...
- [office] Excel中Sumproduct函数的使用方法-
-
Excel中Sumproduct函数的使用方法-SUMPRODUCT和SUMIFS是Excel的两个最强大的函数,用于从表中返回过滤的数据。SUMPRODUCT功能更强大,但SUMIFS更快。您可以...
- SUMPRODUCT函数:关于多条件求和,不仅仅是SUMIFS,我也行!
-
文章最后有彩蛋!好礼相送!SUMPRODUCT函数,作为excel函数公式中的常用功能之一,运用及其广泛。结合它能够处理数据的功能,函数哥将它称之为多条件求和的函数,你可能有疑问了。SUMIF和SUM...
- Excel函数公式大全之利用MMULT函数计算两个数组矩阵的乘积
-
各位Excel天天学的小伙伴们大家好,欢迎收看Excel天天学出品的excel2019函数公式大全课程。今天我们依旧要学习的是Excel函数中的数学函数MMULT函数,计算两个数组的矩阵乘积。今天这个...
- Excel中的这个“万能函数”你用过吗?一个顶四个,简单又实用
-
Hello,大家好,今天跟大家分享一个Excel中的最强大的求和函数,它就是——SUMPRODUCT函数,很多人都将其称之为“万能函数”,条件求和,条件计数等一些常用的功能他就能轻松搞定,逻辑也非常的...
- 根据关键字条件求和,SUMPRODUCT函数思路清晰!
-
1职场实例小伙伴们大家好,今天我们来讲解一个关于根据关键字进行条件求和的职场真实案例,这是公众号粉丝后台留言咨询的一个问题,下面我们来通过几组简单的数据还原一下真实的办公情景。如下图所示:A列为一列地...
- Excel-万能PRODUCT函数
-
sumproduct除了可以计算乘积之和,还可以实现单条件求和(代替sumif),多条件求和(代替sumifs),单条件计数(代替countif),多条件计数(代替countifs)我总结了一个通用的...
- Excel“王者”级求和函数SUMPRODUCT,职场必学!
-
我是【桃大喵学习记】,欢迎大家关注哟~,每天为你分享职场办公软件使用技巧干货!日常工作中我们经常需要对Excel数据求和、计数,今天就跟大家分享一下Excel“王者”级求和函数SUMPRODUCT,灵...
- SUMPRODUCT函数满足“或”的要求,实现多条件求和!
-
1职场实例小伙伴们大家好,今天我们来继续讲解Excel使用中非常实用且强大的函数:SUMPRODUCT函数,上一次我们讲到了SUMPRODUCT函数实现类似SUMIFS函数多条件求和的功能。而今天我们...
- 整列数据相乘再相加sumproduct函数#excel技巧
-
今天分享一下像这种表格,我想求它的消费,也就是用它的数量去乘以单价去加上。下一个的数量乘以单价要加上,下一个数量乘以单价。如果小白会这样一步一步的去算,去单价去乘以数量,然后加上单价去乘以数量,一个一...
- 双向多条件求和,sumifs彻底不行了,但是sumproduct却能轻松搞定
-
今天我们来解决一个困扰很多Excel新手的问题,它就双向求和,所谓的双向,就是两个方向,如下图所示,我们想要根据【项目】与【费用类别】来实现动态求和效果。【项目】与【费用类别】在数据源中,一个是纵横的...
- Excel函数之Sumproduct,7个经典用法,你真的都了解吗?
-
什么是sumproduct函数以及其基本操作原理?sumproduct函数主要用于对数组中的数值进行相乘后再求和,。该函数最多支持255个参数(数组),这些数组可以是数字单元格引用或区域。它的工作流程...
- WPS-Excel表格sumproduct函数一次性算出相乘相加总额
-
excel表格单纯相加或者相乘大家都会应用,但是有时候我们需要算出相乘相加的总额,这种计算也是可以一次性算出的。今天来教大家怎样在WPS表格中,让数据一次性算出相乘相加的总额,会了这个小技巧,会方便很...
- 大神级Sumproduct公式这么好用,1分钟学会!
-
在工作中,一般用不到Sumprodct函数公式,但是真的好用,我们举工作中的3个场景来说明。1、快速相乘相加如下所示,我们各种商品有一个单价,然后对应有一些数量,我们现在需要快速汇总总金额数据有没有小...
- 万能函数Sumproduct,除了求和和计数外,还可以排名
-
在众多的Excel函数中,能同时完成求和、计数以及排名功能的函数不多,其中Sumproduct就是其中一个。一、万能函数Sumproduct:功能及语法结构。功能:返回相应区域数组乘积的和。语法结...
- 一周热门
- 最近发表
-
- Excel表格带单位求和不用愁!2个高效小技巧,轻松搞定!
- [office] Excel中Sumproduct函数的使用方法-
- SUMPRODUCT函数:关于多条件求和,不仅仅是SUMIFS,我也行!
- Excel函数公式大全之利用MMULT函数计算两个数组矩阵的乘积
- Excel中的这个“万能函数”你用过吗?一个顶四个,简单又实用
- 根据关键字条件求和,SUMPRODUCT函数思路清晰!
- Excel-万能PRODUCT函数
- Excel“王者”级求和函数SUMPRODUCT,职场必学!
- SUMPRODUCT函数满足“或”的要求,实现多条件求和!
- 整列数据相乘再相加sumproduct函数#excel技巧
- 标签列表
-
- filter函数js (37)
- filter函数excel用不了 (73)
- 商城开发 (40)
- 影视网站免费源码最新版 (57)
- 影视资源api接口 (46)
- 网站留言板代码大全 (56)
- java版软件下载 (52)
- java教材电子课本下载 (48)
- java技术的电子书去哪看 (33)
- 0基础编程从什么开始学 (50)
- java是用来干嘛的 (51)
- it入门应该学什么 (55)
- java线上课程 (55)
- 学java的软件叫什么软件 (38)
- 程序开发软件有哪些 (53)
- 软件培训 (59)
- 机器人编程代码大全 (50)
- 少儿编程教程免费 (45)
- 新代系统编程教学 (61)
- 共创世界编程网站 (38)
- 亲测源码 (36)
- 三角函数积分公式表 (35)
- 函数的表示方法 (34)
- 表格乘法的公式怎么设置 (34)
- sumif函数的例子 (34)