前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >C++从零开始实现俄罗斯方块,vc6.0就可以实现

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

作者头像
全栈程序员站长
发布2021-04-07 15:12:39
4070
发布2021-04-07 15:12:39
举报
文章被收录于专栏:全栈程序员必看

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

老规矩,废话不多说,直接上效果图

1首先我们需要知道游戏一共有多少种俄罗斯方块。并且需要定义这些方块

代码语言:javascript
复制
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,下落更新

代码语言:javascript
复制
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 << " ";

				}
			}

		}
	}
}

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

代码语言:javascript
复制
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 << " ";
	}
}

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

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2021年3月12日 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • C++从零开始实现俄罗斯方块,vc6.0就可以实现
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档