当前位置:首页 » 《随便一记》 » 正文

[C++游戏示例]2048-程序员版_一个神奇的博客

14 人参与  2022年02月28日 16:49  分类 : 《随便一记》  评论

点击全文阅读


[C++游戏示例]2048-程序员版

    • 前言
    • 实现
        • 1.图形引擎
        • 2.算法实现
        • 3.配色
        • 4.数据保存
    • 代码
    • 结束语

前言


欢迎来到匿名用户__ 的博客!

这里是已经八百天没有更新的游戏专栏!

这次,作者准备了2048 的程序!

对于本次程序,可是很特殊哟—

  1. 这是2048-程序员版 ,拥有3种配色模式:程序员版、朝代版、数字版
  2. 本程序使用作者100%亲手制作ggcc_graphics.h伪图形库!!! 哈哈哈,不愧是我

来看一下运行效果:(作者好菜~~~~)
运行效果
是不是和洛谷的评测几乎一样呀~
在这里插入图片描述


实现


1.图形引擎

为了使该程序能在Dev-Cpp下运行-----

作者千辛万苦,历经千难万险,挺过九九八十一难,终于写出的图形引擎~~~

本程序的图形引擎ggcc_graphics下载地址:
C++ 高仿easyX图形库
https://blog.csdn.net/wangxun20081008/article/details/120474107?spm=1001.2014.3001.5501
配置方法:
将图形库程序复制,保存在 Dev-Cpp安装目录下的MinGW64\lib\gcc\x86_64-w64-mingw32\4.9.2\include\c++ 目录,命名为ggcc_graphics.h,编译(只需编译)图形库即可

2.算法实现

本程序使用队列模拟合并格子,这样既可以减少代码行数,又可以减少代码可读性

void op_input(char x) {
	if(x!='w'&&x!='s'&&x!='a'&&x!='d')return;
	queue <int> q[10],ans[10];
	if(x=='w')for(int i=1; i<=size; i++)for(int j=1; j<=size; j++)if(Map[j][i])q[i].push(Map[j][i]);
	if(x=='s')for(int i=1; i<=size; i++)for(int j=size; j>=1; j--)if(Map[j][i])q[i].push(Map[j][i]);
	if(x=='a')for(int i=1; i<=size; i++)for(int j=1; j<=size; j++)if(Map[i][j])q[i].push(Map[i][j]);
	if(x=='d')for(int i=1; i<=size; i++)for(int j=size; j>=1; j--)if(Map[i][j])q[i].push(Map[i][j]);
	for(int i=1; i<=size; i++)for(int j=1; j<=size; j++)Map2[i][j]=Map[i][j];
	memset(Map,0,sizeof(Map));
	for(int i=1; i<=size; i++) {
		int top1,top2,pa;
		if(!q[i].empty()) {
			top1=q[i].front(),q[i].pop();
			while(!q[i].empty()) {
				top2=q[i].front(),q[i].pop();
				if(top1==top2) {
					score+=top1+top2;
					best=max(best,score);
					ans[i].push(top1*2),top1=0;
					if(!q[i].empty())top1=q[i].front(),q[i].pop();
					else break;
				} else ans[i].push(top1),top1=top2;
			}
			ans[i].push(top1);
		}
		if(x=='w'||x=='a')pa=0;
		else pa=size+1;
		if(x=='w')while(!ans[i].empty())Map[++pa][i]=ans[i].front(),ans[i].pop();
		if(x=='s')while(!ans[i].empty())Map[--pa][i]=ans[i].front(),ans[i].pop();
		if(x=='a')while(!ans[i].empty())Map[i][++pa]=ans[i].front(),ans[i].pop();
		if(x=='d')while(!ans[i].empty())Map[i][--pa]=ans[i].front(),ans[i].pop();
	}
	for(int i=1; i<=size; i++)for(int j=1; j<=size; j++)if(Map[i][j]!=Map2[i][j]) {
				int x2=rand()%size+1,y=rand()%size+1;
				while(Map[x2][y])x2=rand()%size+1,y=rand()%size+1;
				Map[x2][y]=2;
				return;
			}
}

3.配色

本程序有三个配色方案:

  1. 程序员版在这里插入图片描述
  2. 朝代版在这里插入图片描述
  3. 数字版在这里插入图片描述

4.数据保存

本程序的最高分可以保存,保存将在游戏结束后进行,所以游戏中途结束没有存档…

关于保存信息,可以参考文章:

C++ 保存数据 https://blog.csdn.net/wangxun20081008/article/details/115033507?spm=1001.2014.3001.5501


代码


程序公示!!!!!!!!!!!!!!!!!!!!!

#include <ggcc_graphics.h>

const int size=4,winsize=size*5+10;
int Map[10][10],Map2[10][10];
int mode=0,score=0,best=0;
map <int,string> nte;
map <int,string> nte2;
map <int,string> nte3;

void EvaluationStatus(int x,int y,int a,int mod) {
	string str;
	if(mode==0) {
		str=nte[a];
		setbkmode(1),settextcolor(WHITE);
		if(str=="RI ")setfillcolor(RGB(120,120,120));
		else if(str=="CE ")setfillcolor(RGB(253,208,0));
		else if(str=="UKE")setfillcolor(RGB(13,49,66));
		else if(str=="TLE")setfillcolor(RGB(27,62,143));
		else if(str=="MLE")setfillcolor(RGB(27,62,143));
		else if(str=="OLE")setfillcolor(RGB(27,62,143));
		else if(str=="RE ")setfillcolor(RGB(138,0,138));
		else if(str=="WA ")setfillcolor(RED);
		else if(str=="PC ")setfillcolor(RGB(236,118,0));
		else if(str=="AC ")setfillcolor(GREEN);
		else if(str=="AK ")setfillcolor(BLUE);
		else setfillcolor(RGB(56,56,56));
	} else if(mode==1) {
		str=nte2[a];
		setbkmode(1),settextcolor(WHITE);
		if(str=="商")setfillcolor(RGB(236,227,226)),settextcolor(BLACK);
		else if(str=="周")setfillcolor(RGB(233,219,178)),settextcolor(BLACK);
		else if(str=="秦")setfillcolor(RGB(238,171,130));
		else if(str=="汉")setfillcolor(RGB(250,147,83));
		else if(str=="唐")setfillcolor(RGB(250,114,83));
		else if(str=="宋")setfillcolor(RGB(243,82,46));
		else if(str=="元")setfillcolor(RGB(247,218,138));
		else if(str=="明")setfillcolor(RGB(244,205,102));
		else if(str=="清")setfillcolor(RGB(249,203,80));
		else if(str=="民")setfillcolor(RGB(249,201,72));
		else if(str=="now")setfillcolor(RGB(249,198,63));
		else setfillcolor(RGB(204,190,179));
	} else if(mode==2) {
		str=change_its(a);
		setbkmode(1),settextcolor(WHITE);
		if(str=="2")setfillcolor(RGB(236,227,226)),settextcolor(BLACK);
		else if(str=="4")setfillcolor(RGB(233,219,178)),settextcolor(BLACK);
		else if(str=="8")setfillcolor(RGB(238,171,130));
		else if(str=="16")setfillcolor(RGB(250,147,83));
		else if(str=="32")setfillcolor(RGB(250,114,83));
		else if(str=="64")setfillcolor(RGB(243,82,46));
		else if(str=="128")setfillcolor(RGB(247,218,138));
		else if(str=="256")setfillcolor(RGB(244,205,102));
		else if(str=="512")setfillcolor(RGB(249,203,80));
		else if(str=="1024")setfillcolor(RGB(249,201,72));
		else if(str=="2048")setfillcolor(RGB(249,198,63));
		else setfillcolor(RGB(204,190,179));
	}
	solidrectangle(x,y,x+4,y+4);
	if(str!="  "&&str!="0")outtextxy(x+2-(str.size()/4),y+2,str);
}

void init() {
	nte[0]="   ",nte[2]="RI ",nte[4]="CE ",nte[8]="UKE";
	nte[16]="TLE",nte[32]="MLE",nte[64]="OLE",nte[128]="RE ";
	nte[256]="WA ",nte[512]="PC ",nte[1024]="AC ",nte[2048]="AK ";
	nte2[0]="   ",nte2[2]="商",nte2[4]="周",nte2[8]="秦";
	nte2[16]="汉",nte2[32]="唐",nte2[64]="宋",nte2[128]="元";
	nte2[256]="明",nte2[512]="清",nte2[1024]="民",nte2[2048]="now";
	initgraph(size*5+10,size*5+10,false),srand(time(0));
}

int check() {
	int s=0;
	for(int i=1; i<=size; i++)for(int j=1; j<=size; j++)if(Map[i][j]==2048)return -1;
	for(int i=1; i<=size; i++)for(int j=1; j<=size; j++)
			if(Map[i][j]==Map[i-1][j]||Map[i][j]==Map[i+1][j]
			        ||Map[i][j]==Map[i][j-1]||Map[i][j]==Map[i][j+1])return 1;
			else if(Map[i][j])s++;
	return s!=size*size;
}

void op_input(char x) {
	if(x!='w'&&x!='s'&&x!='a'&&x!='d')return;
	queue <int> q[10],ans[10];
	if(x=='w')for(int i=1; i<=size; i++)for(int j=1; j<=size; j++)if(Map[j][i])q[i].push(Map[j][i]);
	if(x=='s')for(int i=1; i<=size; i++)for(int j=size; j>=1; j--)if(Map[j][i])q[i].push(Map[j][i]);
	if(x=='a')for(int i=1; i<=size; i++)for(int j=1; j<=size; j++)if(Map[i][j])q[i].push(Map[i][j]);
	if(x=='d')for(int i=1; i<=size; i++)for(int j=size; j>=1; j--)if(Map[i][j])q[i].push(Map[i][j]);
	for(int i=1; i<=size; i++)for(int j=1; j<=size; j++)Map2[i][j]=Map[i][j];
	memset(Map,0,sizeof(Map));
	for(int i=1; i<=size; i++) {
		int top1,top2,pa;
		if(!q[i].empty()) {
			top1=q[i].front(),q[i].pop();
			while(!q[i].empty()) {
				top2=q[i].front(),q[i].pop();
				if(top1==top2) {
					score+=top1+top2;
					best=max(best,score);
					ans[i].push(top1*2),top1=0;
					if(!q[i].empty())top1=q[i].front(),q[i].pop();
					else break;
				} else ans[i].push(top1),top1=top2;
			}
			ans[i].push(top1);
		}
		if(x=='w'||x=='a')pa=0;
		else pa=size+1;
		if(x=='w')while(!ans[i].empty())Map[++pa][i]=ans[i].front(),ans[i].pop();
		if(x=='s')while(!ans[i].empty())Map[--pa][i]=ans[i].front(),ans[i].pop();
		if(x=='a')while(!ans[i].empty())Map[i][++pa]=ans[i].front(),ans[i].pop();
		if(x=='d')while(!ans[i].empty())Map[i][--pa]=ans[i].front(),ans[i].pop();
	}
	for(int i=1; i<=size; i++)for(int j=1; j<=size; j++)if(Map[i][j]!=Map2[i][j]) {
				int x2=rand()%size+1,y=rand()%size+1;
				while(Map[x2][y])x2=rand()%size+1,y=rand()%size+1;
				Map[x2][y]=2;
				return;
			}
}

void print_game() {
	if(mode==0)setbkcolor(BLACK);
	else if(mode==1)setbkcolor(RGB(248,244,234));
	else if(mode==2)setbkcolor(RGB(248,244,234));
	else if(mode==3)setbkcolor(RGB(248,244,234));
	cleardevice();
	if(mode==0)setfillcolor(RGB(30,30,30)),settextcolor(RGB(150,150,150));
	if(mode==1)setfillcolor(RGB(173,156,135)),settextcolor(RGB(203,194,173));
	if(mode==2)setfillcolor(RGB(173,156,135)),settextcolor(RGB(203,194,173));
	if(mode==3)setfillcolor(RGB(173,156,135)),settextcolor(RGB(203,194,173));
	solidrectangle(winsize-10,2,winsize-6,4);
	solidrectangle(winsize-16,2,winsize-12,4);
	solidrectangle(winsize-22,2,winsize-18,4);
	setbkmode(1);
	outtextxy(winsize-9,2," score");
	outtextxy(winsize-15,2," best");
	outtextxy(winsize-21,2," mode");
	outtextxy(winsize/2-10,winsize-1,"Space 更改模式  Use Space to change mode");
}

int main() {
	ifstream fr;
	ofstream fw;
	init();
	Map[rand()%size+1][rand()%size+1]=2;
	memset(Map2,-1,sizeof(Map2));
	settitle("2048 For Programmer");
	print_game();
	NewFolder("C:\\ggcc_saves");
	fr.open("C:\\ggcc_saves\\2048saves.txt");
	fr>>best;
	fr.close();
	do {
		settextcolor(WHITE);
		string s=change_its(score),b=change_its(best),m;
		if(mode==0)m="程序员";
		else if(mode==1)m="朝代版";
		else if(mode==2)m="数字版";
		outtextxy(winsize-8-(s.size()/4),4,s+' ');
		outtextxy(winsize-14-(b.size()/4),4,b+' ');
		outtextxy(winsize-21,4,m);
		for(int i=1; i<=size; i++)for(int j=1; j<=size; j++)
				if(Map[i][j]!=Map2[i][j])EvaluationStatus(j*5,i*5+2,Map[i][j],mode);
		char get=getch();
		if(get==' ') {
			mode=(mode+1)%3;
			print_game();
			memset(Map2,-1,sizeof(Map2));
		} else op_input(tolower(get));
	} while(check()==1);
	settextcolor(WHITE);
	string s=change_its(score),b=change_its(best),m;
	if(mode==0)m="程序员";
	else if(mode==1)m="朝代版";
	else if(mode==2)m="数字版";
	outtextxy(winsize-8-(s.size()/4),4,s+' ');
	outtextxy(winsize-14-(b.size()/4),4,b+' ');
	outtextxy(winsize-21,4,m);
	for(int i=1; i<=size; i++)for(int j=1; j<=size; j++)
			EvaluationStatus(j*5,i*5+2,Map[i][j],mode);
	setbkmode(0),setbkcolor(BLUE);
	NewFolder("C:\\ggcc_saves");
	fw.open("C:\\ggcc_saves\\2048saves.txt");
	fw<<best;
	fw.close();
	if(check()==-1)outtextxy(12,15,"You win!"),Sleep(1000000);
	else outtextxy(10,15,"Emmm.You failed..."),Sleep(1000000);
}

结束语

作者终于将游戏写完了,准备去准备下一个游戏了,如果你觉得不搓,欢迎来我的博客,学习更多有趣的东西~~~

在这里插入图片描述


点击全文阅读


本文链接:http://zhangshiyu.com/post/35533.html

程序  图形  程序员  
<< 上一篇 下一篇 >>

  • 评论(0)
  • 赞助本站

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。

关于我们 | 我要投稿 | 免责申明

Copyright © 2020-2022 ZhangShiYu.com Rights Reserved.豫ICP备2022013469号-1