1.需求分析
羊了个羊前期准备用多个数组以及坐标定位,实现图片的移动与删除。
2.功能分析
进行点击,上面的图片消失,并且该点击的图片出现在下面的方框内。
3.总体设计
(1)图形界面模块:
- 调用图形界面库,方便后来的地图设计
- 调用一个背景,放入多个数组
- 调用多个不同的小图片,来表示要消除的部分
(2)声音模块:
- 调用标准Windows库,方便后来的调用mp3文件
- 在源文件夹中放入要使用的音乐
- 调用该mp3,与地图一同启动
(3)系统框架图
4实验代码
#include<easyx.h>
#include<stdio.h>
#include<Windows.h> //播放音乐头文件
#pragma comment(lib,"winmm.lib") //播放音乐库文件
const int WIDTH = 400;
const int HEIGHT = 760;
const int INTERVAL = 48;
IMAGE img_bk;
IMAGE img_item[4];
void loadImg()
{
loadimage(&img_bk, "images/bk.jpg", WIDTH, HEIGHT);
loadimage(img_item + 0, "images/cao.png", 48, 48);
loadimage(img_item + 1, "images/yumin.png", 48, 48);
loadimage(img_item + 2, "images/shu.png", 48, 48);
}
int main()
{
initgraph(WIDTH, HEIGHT, INTERVAL);
loadImg();
//播放音乐
mciSendString(_T("open mcc/yang.mp3"), 0, 0, 0);
mciSendString(_T("play mcc/yang.mp3"), 0, 0, 0);
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;
}
5.实验结果
资源获取:
https://pan.baidu.com/s/1SysTu_NgsfLh_Z8x-i5mxg
提取码:pp4t
内含图像库安装软件,以及全套图片资源,若链接失效可以评论或者私信 更新
希望可以点个赞!!!!!