已结贴√

问题点数:5 回复次数:6

俄罗斯方块消除满格问题,消除一行后出了问题

#include

#include

#include

#include

#include

#define S1 60  //初始位置(S1,S1)

#define S2 20  //单位大小

#define M 18  //宽度多少单位

#define N 23  //高度多少单位

#define Width 600

#define Henght 700

IMAGE img,img1,img2,img3,img4,img5,img6,img7,img8,img9,img10,img11;

int b,f,p,q,q2,number,count1,count2,count3,c[5],d[5],cc[5],dd[5];

int Time=15;

int number2=0;

int count4=0;

int get=0;

struct Barrier

{

int x;

int y;

IMAGE z;

}barrier[M+1][N+1],barrier2[M+1][N+1],coor1;

typedef struct Barrier coor;

//顺时针旋转90度函数

coor rotate(int x,int y,int x0,int y0)

{

int x1,y1;

x1=y0-y+x0;

y1=x-x0+y0;

coor1.x=x1;

coor1.y=y1;

return coor1;

}

void rotate2()

{

for (b=0;b<4;b++)

{

c[b]=c[b]+S2*1/2;d[b]=d[b]+S2*1/2;

rotate(c[b],d[b],c[4],d[4]);

c[b]=coor1.x-S2*1/2;

d[b]=coor1.y-S2*1/2;

}

}

//左移右移函数

void  Move(int i)

{

for (b=0;b<5;b++)

c[b]=c[b]+S2*i;

}

//恢复变换前坐标的函数

void Restore()

{

for (b=0;b<5;b++)

{

c[b]=cc[b];

d[b]=dd[b];

}

}

//判断旋转或左移或右移后是否重叠

void room()

{

count2=0;

for (b=0;b<4;b++)

for (f=0;f<2;f++)

{

p=c[b];q=d[b]-(d[b]-S1)%S2+S2*f;

if (barrier[(p-S1)/S2][(q-S1)/S2].x==p && barrier[(p-S1)/S2][(q-S1)/S2].y==q)

count2++;

}

if (count2!=0)

count1--;

}

//初始化图形函数

void Ding()

{

c[0]=S1+9*S2;     d[0]=S1+S2;

c[1]=c[0];         d[1]=d[0]+S2;

c[2]=c[1];         d[2]=d[1]+S2;

c[3]=c[1]+S2;     d[3]=d[1];

c[4]=c[1]+(1.0/2)*S2;d[4]=d[1]+(1.0/2)*S2;

}

void RightL()

{

c[0]=S1+9*S2;     d[0]=S1+S2;

c[1]=c[0]+S2;     d[1]=d[0];

c[2]=c[1];         d[2]=d[1]+S2;

c[3]=c[1];         d[3]=d[2]+S2;

c[4]=c[0]+S2*1.0/2;d[4]=d[0]+(3.0/2)*S2;

}

void LeftL()

{

c[0]=S1+8*S2;     d[0]=S1+S2;

c[1]=c[0];         d[1]=d[0]+S2;

c[2]=c[0];         d[2]=d[1]+S2;

c[3]=c[0]+S2;     d[3]=d[0];

c[4]=c[0]+(3.0/2)*S2;d[4]=d[0]+(3.0/2)*S2;

}

void LeftZ()

{

c[0]=S1+10*S2;   d[0]=S1+S2;

c[1]=c[0];       d[1]=d[0]+S2;

c[2]=c[0]-S2;    d[2]=d[1];

c[3]=c[2];       d[3]=d[2]+S2;

c[4]=c[2]+(1.0/2)*S2;d[4]=d[2]+(1.0/2)*S2;

}

void RightZ()

{

c[0]=S1+8*S2;     d[0]=S1+S2;

c[1]=c[0];         d[1]=d[0]+S2;

c[2]=c[1]+S2;     d[2]=d[1];

c[3]=c[2];         d[3]=d[2]+S2;

c[4]=c[2]+(1.0/2)*S2;d[4]=d[2]+(1.0/2)*S2;

}

void Square()

{

c[0]=S1+8*S2;     d[0]=S1+S2;

c[1]=c[0]+S2;     d[1]=d[0];

c[2]=c[0];         d[2]=d[0]+S2;

c[3]=c[1];         d[3]=d[2];

}

void Yi()

{

c[0]=S1+7*S2;d[0]=S1+S2;

c[1]=c[0]+S2;d[1]=d[0];

c[2]=c[1]+S2;d[2]=d[1];

c[3]=c[2]+S2;d[3]=d[2];

}

//画边框

void Region()

{

IMAGE img1;

IMAGE img2;

initgraph(Width,Henght);

setbkcolor(GREEN);

cleardevice();

loadimage(&img3,"D:\\C共享\\俄罗斯方块\\images\\GameRegionRim2.jpg");

putimage(S1,S1,&img3);

getimage(&img3,S1,S1,S2,S2);

loadimage(&img4,"D:\\C共享\\俄罗斯方块\\images\\square_blue.jpg");

putimage(S1,S1,&img4);

getimage(&img4,S1,S1,S2,S2);

loadimage(&img5,"D:\\C共享\\俄罗斯方块\\images\\square_darkBlue.jpg");

putimage(S1,S1,&img5);

getimage(&img5,S1,S1,S2,S2);

loadimage(&img6,"D:\\C共享\\俄罗斯方块\\images\\square_green.jpg");

putimage(S1,S1,&img6);

getimage(&img6,S1,S1,S2,S2);

loadimage(&img7,"D:\\C共享\\俄罗斯方块\\images\\square_orange.jpg");

putimage(S1,S1,&img7);

getimage(&img7,S1,S1,S2,S2);

loadimage(&img8,"D:\\C共享\\俄罗斯方块\\images\\square_purple.jpg");

putimage(S1,S1,&img8);

getimage(&img8,S1,S1,S2,S2);

loadimage(&img9,"D:\\C共享\\俄罗斯方块\\images\\square_red.jpg");

putimage(S1,S1,&img9);

getimage(&img9,S1,S1,S2,S2);

loadimage(&img10,"D:\\C共享\\俄罗斯方块\\images\\square_yellow.jpg");

putimage(S1,S1,&img10);

getimage(&img10,S1,S1,S2,S2);

loadimage(&img2,"E:\\Image\\c.jpg",Width,Henght);

putimage(0,0,&img2);

getimage(&img,S1+S2,S1+S2,(M-1)*S2,(N-1)*S2);

for (p=S1;p

{

q=S1;

putimage(p,q,&img3);

barrier[(p-S1)/S2][(q-S1)/S2].x=p;

barrier[(p-S1)/S2][(q-S1)/S2].y=q;

q=S1+N*S2;

putimage(p,q,&img3);

barrier[(p-S1)/S2][(q-S1)/S2].x=p;

barrier[(p-S1)/S2][(q-S1)/S2].y=q;

}

for (q=S1;q

{

p=S1;

putimage(p,q,&img3);

barrier[(p-S1)/S2][(q-S1)/S2].x=p;

barrier[(p-S1)/S2][(q-S1)/S2].y=q;

p=S1+M*S2;

putimage(p,q,&img3);

barrier[(p-S1)/S2][(q-S1)/S2].x=p;

barrier[(p-S1)/S2][(q-S1)/S2].y=q;

}

settextstyle(25, 0, _T("宋体"));

outtextxy(20,600,_T("  Ver 1.0             Your Score :               Made By Yao"));

}

void RandNumber()

{

number=(int)(rand()%7+4);

}

void Action()

{

int a;

char e;

for (;;)

{

count1=0;

getimage(&img1,S1+S2,S1+S2,(M-1)*S2,(N-1)*S2);

BeginBatchDraw();

RandNumber();

if (number==4)

{img11=img4;    Yi();}

else if (number==5)

{img11=img5;    LeftZ();    }

else if (number==6)

{img11=img6;    Ding();     }

else if (number==7)

{img11=img7;    RightZ();     }

else if (number==8)

{img11=img8;    Square();}

else if (number==9)

{img11=img9;    LeftL();}

else

{img11=img10;    RightL();  }

for (a=0;;a++)

{

for (b=0;b<4;b++)

putimage(c[b],d[b],&img11);

if (kbhit())

{

e=getch();

if (isascii(e))

goto loop;

else

loop:        e=getch();

switch(e)

{

case 72:

{

if (number==8)

goto loop2;

if (number==4)

{

count1++;

if (count1%2==1)

{

c[0]=c[0]+S2;d[0]=d[0]-S2;

c[1]=c[1];d[1]=d[1];

c[2]=c[2]-S2;d[2]=d[2]+S2;

c[3]=c[3]-2*S2;d[3]=d[3]+2*S2;

}

if (count1%2==0)

{

c[0]=c[0]-S2;d[0]=d[0]+S2;

c[1]=c[1];d[1]=d[1];

c[2]=c[2]+S2;d[2]=d[2]-S2;

c[3]=c[3]+2*S2;d[3]=d[3]-2*S2;

}

}

else

rotate2();

room();

if (count2!=0)

Restore();

break;

}

case 75:

{

Move(-1);

room();

if (count2!=0)

Restore();

break;

}

case 77:

{

Move(1);

room();

if (count2!=0)

Restore();

break;

}

case 80:

number2=20;

break;

}

}

//判断是否碰到下面的障碍物:

if ((S2+a)%S2==0)

{

count2=0;

for (b=0;b<4;b++)

{

p=c[b];q=d[b]+S2;

if (barrier[(p-S1)/S2][(q-S1)/S2].x==p && barrier[(p-S1)/S2][(q-S1)/S2].y==q)

{

for (f=0;f<4;f++)

{

p=c[f];q=d[f];

barrier[(p-S1)/S2][(q-S1)/S2].x=p;

barrier[(p-S1)/S2][(q-S1)/S2].y=q;

barrier[(p-S1)/S2][(q-S1)/S2].z=img11;

}

count2++;

break;

}

}

if (count2!=0)

break;

}

loop2:        for (b=0;b<5;b++)

{

d[b]=d[b]+1;//

cc[b]=c[b];//   切记 : 三者顺序不能颠倒

dd[b]=d[b];//

}

FlushBatchDraw();

if (number2>0)

goto loop3;

else

Sleep(Time);

loop3:        number2--;

putimage(S1+S2,S1+S2,&img1);

}

EndBatchDraw();

//判断某一行是否填满

for (q=1;q

{

count3=0;

for (p=1;p

if (barrier[p][q].x==S1+p*S2 && barrier[p][q].y==S1+q*S2)

count3++;

if (count3==M-1)

break;

}

if (count3==M-1)

{

get=q-1;  //用来接收哪一行满了

count4++;

putimage(S1+S2,S1+S2,&img);

for (p=1;p

for (q=1;q

if (barrier[p][q].x==S1+p*S2 && barrier[p][q].y==S1+q*S2)

{

barrier2[p][q+1].x=S1+p*S2;

barrier2[p][q+1].y=S1+(q+1)*S2;

barrier2[p][q+1].z=barrier[p][q].z;

barrier[p][q].x=0;

barrier[p][q].y=0;

}

//擦除填满的一行

for (p=1;p

{

barrier[p][get].x=0;

barrier[p][get].x=0;

}

for (p=1;p

for (q=1;q

if (barrier2[p][q].x==S1+p*S2 && barrier2[p][q].y==S1+q*S2)

{

barrier[p][q].x=barrier2[p][q].x;

barrier[p][q].y=barrier2[p][q].y;

barrier[p][q].z=barrier2[p][q].z;

}

for (p=1;p

for (q=1;q

putimage(barrier[p][q].x,barrier[p][q].y,&barrier[p][q].z);

}

}

}

void main()

{

srand((unsigned)time(NULL));

Region();

Action();

getch();

}

C语言俄罗斯方块删除某一行,俄罗斯方块消除满格问题,消除一行后出了问题...相关推荐

  1. 用C语言写一个简单的俄罗斯方块(基于Windows窗口编程)

    目录 1. 列出需要的头文件,结构体,全局变量和函数 2. 设计窗口和显示窗口 3. 消息处理函数 4. 实现俄罗斯方块的主要功能 4.1 绘制图形 4.2 创建方块 4.3 方块下落 4.4 方块左 ...

  2. win32俄罗斯方块c++语言 vs2012源代码,C++实现俄罗斯方块

    本文实例为大家分享了C++实现俄罗斯方块的具体代码,供大家参考,具体内容如下 工具:vc++2010,图库:EasyX 先看效果图片 纯手写,没有面向对象思想,看全部源码 #include #incl ...

  3. python俄罗斯方块的消除算法_1.1.3python tkinter实现俄罗斯方块基础版-生成、移动、固定、消除...

    1.随机生成俄罗斯方块 这里需要导入python自带的随机库random 使用其中的choice方法,从俄罗斯方块形状列表中随机选出一个. 该方法源码说明如图 首先我们需要删除原来的位于game_lo ...

  4. java双人俄罗斯方块_双人版俄罗斯方块

    改进 1. 方块旋转修改 2. 实现没达到一个成绩等级进行加速并且保持速度直到下一次加速(使用两个定时器) 3. 实现两个人分别暂停 4. 界面优化 图片大家网上自己搜索一下 ------------ ...

  5. 基于android环境的俄罗斯方块,基于Android的俄罗斯方块的设计和实现完整版.doc

    TOC \o "1-3" \h \z \u 摘要Ⅰ AbstractⅡ 一 引言1 二 Android平台介绍2 2.1 平台背景概述2 2.2 系统概述2 2.3 Android ...

  6. ACMNO.34 C语言-格式输出 请设计输出实数的格式,包括:⑴一行输出一个实数;⑵一行内输出两个实数;⑶一行内输出三个实数。实数用6.2f格式输出。

    题目描述 请设计输出实数的格式, 包括: ⑴一行输出一个实数:⑵一行内输出两个实数:⑶一行内输出三个实数. 实数用"6.2f"格式输出. 输入 一个实数,float范围 输出 输出 ...

  7. Swift3.0语言教程删除字符与处理字符编码

    Swift3.0语言教程删除字符与处理字符编码 Swift3.0语言教程删除字符 Swift3.0语言教程删除字符与处理字符编码,在字符串中,如果开发者有不需要使用的字符,就可以将这些字符删除.在NS ...

  8. Android之解决多语言适配部分TextView内容左对齐和内容一行不排满就到第二行问题

    1 问题 1.多语言适配部分TextView内容左对齐 2.内容一行不排满就到第二行问题 2 解决办法 问题1.在TextView里面加入下面参数 android:gravity="cent ...

  9. r语言中删除向量的某些元素_R中的向量

    r语言中删除向量的某些元素 Vectors in R are the fundamental data types. This is because the R compiler treats all ...

最新文章

  1. 网站真分页js代码该怎么写?
  2. mysql 密码 特殊符号_MySQL数据库之mysql设置复杂密码中含$特殊符号导致无法命令行登录...
  3. canvas学习笔记(下篇) -- canvas入门教程--保存状态/变形/旋转/缩放/矩阵变换/综合案例(星空/时钟/小球)...
  4. Python之Pandas:利用Pandas函数实现对表格文件的查之高级查询(类似sql,分组查询等)之详细攻略
  5. ITK:修剪二进制图像
  6. 匹配正则_Day233:正则表达式匹配方法 match()
  7. windows客户端性能测试之内存泄露检查工具umdh.exe
  8. python代码300行程序_python小工具,15行代码秒出工资条
  9. 微信“欲封”百度;AI 主播入职新华社;今日头条遭狠罚 | 极客头条
  10. 免费学python的网课-学习python的时候观看网课学习还是买书学习效率高?
  11. python日历下拉框_selenium+Python(Js处理日历控件)
  12. 敏捷开发案例:用白板解决项目管理和团队沟通
  13. Maven的安装与配置教程
  14. 数论入门基础(同余定理/费马小定理/扩展欧几里德算法/中国剩余定理)~
  15. shell 脚本获取时间戳
  16. Vim插件(三) Terminal 终端
  17. C++链表偶数在前,奇数在后的简单方法
  18. 知己知己,JAVA不待!
  19. java中 int、char、long各占多少字节数
  20. flask 开启debug 以及development模式

热门文章

  1. 配置容错组件 Sentinel(五)
  2. 保健中药不贵胜过市面上的保健品
  3. java.util.Date java.sql.Date
  4. Drafting and Revision: Laplacian Pyramid Network for Fast High-Quality Artistic Style Transfer--T Li
  5. android mediaplayer 实现歌曲边播放边下载
  6. Mac 下面安装 Git 步骤
  7. 香蕉皮的妙用(想歪的去面壁)(不管有没有用,先记下再说)
  8. PyCharm中import显示灰色解决方案
  9. 【腾讯云的1001种玩法】个人网站如何开启HTTPS?
  10. Java collection集合截断