C++从零开始实现俄罗斯方块,vc6.0就可以实现

C++从零开始实现俄罗斯方块,vc6.0就可以实现

C++从零开始实现俄罗斯方块,vc6.0就可以实现

老规矩,废话不多说,直接上效果图
在这里插入图片描述
1首先我们需要知道游戏一共有多少种俄罗斯方块。并且需要定义这些方块

const int sharp[15][8]=	 //组成图形的各个点的各个坐标,先纵后横
{
   
{
   0,0,1,0,2,0,3,0},{
   0,0,0,1,0,2,0,3},//条形(一个打横,一个打竖)
{
   0,0,1,0,0,1,1,1},// 方块
{
   0,0,1,0,1,1,1,2},{
   0,1,1,1,2,0,2,1},{
   0,0,0,1,0,2,1,2},{
   0,0,0,1,1,0,2,0},//L形
{
   1,0,1,1,1,2,0,2},{
   0,0,0,1,1,1,2,1},{
   0,0,0,1,0,2,1,0},{
   0,0,1,0,2,0,2,1},//T形
{
   0,0,0,1,1,1,1,2},{
   0,1,1,0,1,1,2,0},//z1形
{
   0,1,0,2,1,0,1,1},{
   0,0,1,0,1,1,2,1}//z2形
};

2旋转,也就是按上下,图形变换而已。
按照上面的规则,条形只能变成下一个条形,方形不能变,L形只能变成L形。

3游戏update,下落更新

void Games::Updata()					//更新函数
{
   
	int i, flag;
	int nx, ny;
	for(i = 0; i < 4; i++)
	{
   
		nx = pt[0] + sharp[id][i * 2];
		ny = pt[1] + sharp[id][i * 2 + 1];
		SetPos((ny + 1) * 2, nx + 1);
		SetColor(0);
		cout << "■";
		map[nx][ny] = 1;					
	}

	if(pt[0] < top)
		top = pt[0];					//最高点的更新

	for(i = pt[0]; i < pt[0] + high[id]; i++)			//消除行
	{
   
		flag = 1;
		for(int j = 0; j < 13; j++)					//判定某一行是否满, 用flag来标记
			if(map[i][j] == 0)
				flag = 0;
		if(flag == 1)
		{
   
			for(int z = i; z >= top; z--)
			{
   
				for(int p = 0; p < 13; p++)
				{
   
					map[z][p] = map[z - 1][p];
					SetPos((p + 1) * 2, z + 1);
					if(map[z][p] == 1)
						cout << "■";
					else cout << " ";

				}
			}

		}
	}
}

//擦图形和画图形。如果下落过程中,本来有”■”需要变成“ ”。而原来为“ ”的需要画出”■”

void Games::Draw(int x, int y, int num)				//画图形
{
   
	int nx, ny;

	for(int i = 0; i < 4; i++)
	{
   
		nx = x + sharp[num][2 * i];
		ny = y + sharp[num][2 * i + 1];
		SetPos((ny + 1) * 2, nx + 1);
		SetColor(i + 1);
		cout << "■";
	}
}

void Games::ClearDraw(int x, int y, int num)				//为更新图形的位置清除图形
{
   
	int nx, ny;

	for(int i = 0; i < 4; i++)
	{
   
		nx = x + sharp[num][2 * i];
		ny = y + sharp[num][2 * i + 1];
		SetPos((ny + 1) * 2, nx + 1);
		cout << " ";
	}
}

其实原理很简单,用数组控制图形画出来,和擦除。然后再判断是否在一行中满格就可以消除得分。

需要完整代码的小伙伴可以联系我q:2316773638

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/2858.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • mapminmax 用法

    mapminmax 用法mapminmax是MATLAB实现归一化的工具包,默认:(1)将矩阵的每行分别进行归一化;(2)每行的最大值最小值作为每行归一化的xmin和xmax;(3)将数据归一化到[-1,1].若要将数据归一化到0到1之间,即y∈[0,1],使用b=mapminmax(a,0,1);若给与确定的最大值和最小值作为每行的xmin和xmax,使用:b= mapminmax(a,0,1);PS.xmin…

    2022年6月30日
    23
  • drwtsn32.exe 遇到问题须要关闭。我们对此引起的不便表示抱歉

    drwtsn32.exe 遇到问题须要关闭。我们对此引起的不便表示抱歉

    2021年12月15日
    43
  • 手把手从零开始学习树莓派教程

    手把手从零开始学习树莓派教程项目开始时间:2021/4/1119:43树莓派4b文章目录1.树莓派系统下载2.操作系统移植3.树莓派联网1.树莓派系统下载这里使用raspbian-buster-full系统,官网速度太慢,使用清华镜像下载也很慢,官网下载种子,然后用迅雷下载比较快。解压后8个g,我用的32gsd卡2.操作系统移植用win32diskimager工具把操作系统写入SD卡,插入树莓派中,启动毫无响应,将sd卡从树莓派上拔下,用读卡器再次插入电脑usb口,显示类似这样:在网上找了很多办法,都不能解决,

    2022年10月14日
    3
  • 伽马校正_预估校正算法

    伽马校正_预估校正算法自动伽马校正(AutoGammaCorrection)算法目录文章目录自动伽马校正(AutoGammaCorrection)算法目录理论代码实现参考资料理论在对图像进行处理过程中,查找到一篇对图像进行自动gamma校正的论文,论文名称及链接见参考文献1.文章的核心描述如下:Averageofbrightnessissimpleelementthatcanbecomputedintheleastamountoftime.Basicapproachin

    2022年9月1日
    6
  • SSL 中证书能否够使用IP而不是域名[通俗易懂]

    SSL 中证书能否够使用IP而不是域名

    2022年1月23日
    63
  • cv2.read 与cv2.imread的区别_vc泡腾片不能和什么一起吃

    cv2.read 与cv2.imread的区别_vc泡腾片不能和什么一起吃1、cv2.imread()接口读图像,读进来直接是BGR格式数据格式在0~255需要特别注意的是图片读出来的格式是BGR,不是我们最常见的RGB格式,颜色肯定有区别。2、cv2.cvtColor(p1,p2)是颜色空间转换函数,p1是需要转换的图片,p2是转换成何种格式。cv2.COLOR_BGR2RGB将BGR格式转换成RGB格式cv2.COLOR_BGR2GRAY将…

    2022年10月15日
    1

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号