C语言写的俄罗斯方块

上传人:cn****1 文档编号:495348523 上传时间:2023-07-03 格式:DOCX 页数:17 大小:18.14KB
返回 下载 相关 举报
C语言写的俄罗斯方块_第1页
第1页 / 共17页
C语言写的俄罗斯方块_第2页
第2页 / 共17页
C语言写的俄罗斯方块_第3页
第3页 / 共17页
C语言写的俄罗斯方块_第4页
第4页 / 共17页
C语言写的俄罗斯方块_第5页
第5页 / 共17页
点击查看更多>>
资源描述

《C语言写的俄罗斯方块》由会员分享,可在线阅读,更多相关《C语言写的俄罗斯方块(17页珍藏版)》请在金锄头文库上搜索。

1、请大家指教一下,由于自己算法的问题向左位移有些问题 在 TC2 下通过#include#include#include#include#include#include#include#define ESC 0x011b#define UP 0x4800#define DOWN 0x5000#define LEFT 0x4b00#define RIGHT 0x4d00#define SPACE 0x3920#define Y 0x1579#define N 0x316e#define clearkbd(); while(bioskey(1) bioskey(0); /*清空键盘缓冲队列*/voi

2、d update();void messagebox();void process();void initremove();void initinfo();void initbox();void initposition();void next_shape();typedef struct shape /*形状单一状态的记录*/int co8;shape;typedef struct RE_AB /*相对,绝对坐标记录*/ int Rx,Ry;int x1,x2,y1,y2;RE_AB;RE_AB RA;shape p19 = RED,0,1,1,0,1,1,2,1 , /*数组中保证y最大的

3、在最后,以便initposition 使用*/ RED,0,1,1,0,1,1,1,2 , RED,0,0,1,0,2,0,1,1 , RED,0,0,0,1,1,1,0,2 , GREEN,0,0,1,0,2,0,3,0 , GREEN,0,0,0,1,0,2,0,3 , CYAN,0,0,0,1,1,0,1,1 , BROWN,0,0,1,0,1,1,2,1 , BROWN,1,0,0,1,1,1,0,2 , BLUE,1,0,2,0,1,1,0,1 , BLUE,0,0,0,1,1,1,1,2 , MAGENTA,0,0,0,1,0,2,1,2 , MAGENTA,2,0,0,1,1,1

4、,2,1, MAGENTA,0,0,1,0,1,1,1,2 , MAGENTA,0,0,0,1,1,0,2,0 , YELLOW,0,2,1,0,1,1,1,2 , YELLOW,0,0,1,0,2,0,2,1 , YELLOW,1,0,0,0,0,1,0,2, YELLOW,0,0,0,1,1,1,2,1 ,;int nback,nleft,nright,r_f1222,rs1,rs2,xcors,xcorb,ycors,ycorb;/*检查方快有没有左,右,下接触,游戏区内所有格子有无颜色记录数组,rs1形状记录,rs2为 提示框用,记录小格子在游戏区中的位置,按键存储*/void int

5、errupt (*oldint)(); /*系统定时中断*/int count_down=0,count_other=0; /*中断记时*/void interrupt newint() /*设置新的中断程序*/ count_down+;count_other+;oldint();void intenable() /*设置中断向量表,启动新的中断程序*/ oldint=getvect(0x1c);disable();setvect(0x1c,newint);enable();void intrestore() /*恢复中断向量*/ disable();setvect(0x1c,oldint);

6、enable();void HZ12(int xO,int y0,int w,int color,char *s) /*根据字模,在 dos 下显示汉字*/*横坐标,纵坐标,字间隔,汉字颜色,汉字字符串*/ FILE *fp;register char buffer24;register char str2;un sig ned long fpos;/*fpos 为最终偏移动量*/fp=fopen(hzk12,r);/*打开 12*12 汉字苦*/while( *s)/*直到字符串结束为止*/if(* s0)/*汉字输出*/ str0=(*s)-0xa0;str1=*(s+1)-0xa0;fp

7、os=(str0-1)*94+(str1-1)*24L;/*计算汉字在 hzk12 的偏移量*/fseek(fp,fpos,SEEK_SET);/* 指针移动到当前位置*/fread(buffe r,24,1,fp);/*读取一个汉字到数组中*/for (i=0;iv12;i+)/*12 行*/for (j=0;j(7-k)&0x1)! = NULL)/* 是一就画点*/putpixel(x0+8*j+k,y0+i,color);s+ = 2;/* 一个汉字占两个字节,现在将指针移动两个字节*/x0+=w;/*显示坐标也按照间隔移动*/else/ *显示非汉字字符*/ settextstyle

8、(0,0,1);setcolor(color);str0=*s;str1=0;outtextxy(x0,y0+3,st r);/*显示单个字符*/x0+=w-7;/*显示单个字符后的x坐标变化*/s+ + ;/ *指针移动到下一个字节*/fclose(fp);void translation() /*把相对坐标解释为绝对坐标*/ if(RA.Rx=1) RA.x1=1; RA.x2=16; else RA.x1=16*(RA.Rx-1); RA.x2=16*RA.Rx; if(RA.Ry=1) RA.y1=1; RA.y2=16; else RA.y1=16*(RA.Ry-1); RA.y2=

9、16*RA.Ry; int check_b() /*检查是否到达低部*/ int x,y,i,zf=0; /*zf 为是否有颜色填充记录*/ for(i=0;i=6)zf+=r_fx-15y-6+1;if(zf=0)return 1;elsereturn 0;int finish() int tfull=0,i; /*判断顶层空间是否有填充*/ for(i=1;i11;i+)tfull+=r_fi1;if(tfull!=0)ret urn 1; /* 告诉 judge()可以结束了*/int check_l() /*检查形状是否与左接触*/for(i=0;i6)zf+=r_fx-15-1y-6

10、; if(y=6&x=16)zf+=1;if(zf=0)return 1;elsereturn 0;int check_r() /*检查形状是否与右接触*/ /*zf 为是否有颜色填充记录*/int x,y,i,zf=0; /*zf 为是否有颜色填充记录*/ for(i=0;i6)zf+=r_fx-15+1y-6; if(y=6&x=25)zf+=1;if(zf=0)return 1;elsereturn 0;void check_touch() nback=check_b();nleft=check_l();nright=check_r();void draw(int cb) /*画形状,c

11、b=1以填充色画形状,cb=2以背景色画形状,cb=3以白色画形状*/ int i,recordx=RA.Rx,recordy=RA.Ry;for(i=0;i7;i+,i+) RA.Rx+=prs1.coi;RA.Ry+=prs1.coi+1;if(RA.Ry=6) RA.Rx=recordx;RA.Ry=recordy;continue;translation();if(cb=1)setfillstyle(1,prs1.attr);elseif(cb=2)setfillstyle(1,BLACK);elseif(cb=3) setfillstyle(1,WHITE);r_fRA.Rx-15R

12、A.Ry-6=1; /*置对应数组标记元素*/bar(RA.x1+1,RA.y1+1,RA.x2-1,RA.y2-1);RA.Ry=recordy;void mov(int key) /*向下,左,右移动方块*/ draw(2);if(key=LEFT&nleft)RA.Rx-;elseif(key=RIGHT&nright)RA.Rx+;elseRA.Ry+;nback=check_b();if(nback) /*判断形状有没有到达底部,有就将其颜色变为白色*/draw(1);elsedraw(3);void change() /*变换形状*/ int status=rs1,buffer,i

13、,x,y,zf=0;if(prs1.attr=prs1+1.attr)rs1+;elsewhile(prs1.attr=prs1-1.attr)rs1-;for(i=0;i6)zf+=r_fx-15y-6;if(zf!=0)rs1=status;buffer=rs1;rs1=status;status=buffer;draw(2);buffer=rs1;rs1=status;status=buffer;nback=check_b(); /*判断变化后的形状是不是到达了低部,这个检查是十分必要的*/if(nback)draw(1);elsedraw(3);void accelerate() if(count_down=1) check_touch(); /*消除上一步动作对方块状态的影响*/count_down=0;if(nback) /*0表示到达底部,1 表示

展开阅读全文
相关资源
相关搜索

当前位置:首页 > 学术论文 > 其它学术论文

电脑版 |金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号