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

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)
blank

相关推荐

  • harbor

    harbor

  • 数据库oracle和mysql的区别_sql和mysql哪个用的多

    数据库oracle和mysql的区别_sql和mysql哪个用的多1、Oracle是大型数据库,而MySQL是中小型数据库。但是MySQL是开源的,但是Oracle是收费的,而且比较贵。2、Oracle的内存占有量非常大,而mysql非常小3、MySQL支持主键自增长,指定主键为autoincrement,插入时会自动增长。Oracle主键一般使用序列。4、MySQL字符串可以使用双引号包起来,而Oracle只可以单引号5、MySQL分页用li…

  • choropleth map_Mapsource

    choropleth map_Mapsource简介MapStruct是满足JSR269规范的一个Java注解处理器,用于为JavaBean生成类型安全且高性能的映射。它基于编译阶段生成get/set代码,此实现过程中没有反射,不会造成额外的性能损失。您所要做的就是定义一个mapper接口(@Mapper),该接口用于声明所有必须的映射方法。在编译期间MapStruct会为该接口自动生成实现类。该实现类使用简单的Java方法调用来映射source-target对象,在此过程中没有反射或类似的行为发生。性能优点与手工编..

    2022年10月26日
  • python字符编码

    python字符编码

    2021年10月22日
  • jetbrains全家桶激活码 淘宝上卖的怎么来的【2021最新】

    (jetbrains全家桶激活码 淘宝上卖的怎么来的)JetBrains旗下有多款编译器工具(如:IntelliJ、WebStorm、PyCharm等)在各编程领域几乎都占据了垄断地位。建立在开源IntelliJ平台之上,过去15年以来,JetBrains一直在不断发展和完善这个平台。这个平台可以针对您的开发工作流进行微调并且能够提供…

  • python lasso回归分析_解析python实现Lasso回归「建议收藏」

    python lasso回归分析_解析python实现Lasso回归「建议收藏」Lasso原理Lasso与弹性拟合比较python实现importnumpyasnpimportmatplotlib.pyplotaspltfromsklearn.metricsimportr2_score#defmain():#产生一些稀疏数据np.random.seed(42)n_samples,n_features=50,200X=np.random.ran…

发表回复

您的电子邮箱地址不会被公开。

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