




已阅读5页,还剩19页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
/*-chess.c-*/#include dos.h#include stdio.h/*-*/#define RED 7#define BLACK 14#define true 1#define false 0#define SELECT 0#define MOVE 1#define RED_UP 0x1100#define RED_DOWN 0x1f00#define RED_LEFT 0x1e00#define RED_RIGHT 0x2000#define RED_DO 0x3900#define RED_UNDO 0x1000#define BLACK_UP 0x4800#define BLACK_DOWN 0x5000#define BLACK_LEFT 0x4b00#define BLACK_RIGHT 0x4d00#define BLACK_DO 0x1c00#define BLACK_UNDO 0x2b00#define ESCAPE 0x0100#define RED_JU 1#define RED_MA 2#define RED_XIANG 3#define RED_SHI 4#define RED_JIANG 5#define RED_PAO 6#define RED_BIN 7#define BLACK_JU 8#define BLACK_MA 9#define BLACK_XIANG 10#define BLACK_SHI 11#define BLACK_JIANG 12#define BLACK_PAO 13#define BLACK_BIN 14/*-*/int firsttime=1;int savemode;char page_new=0,page_old=0;int finish=false,turn=BLACK,winner=0;int key;int redstate=SELECT,blackstate=SELECT;int board109;/*-*/char *chessfile15=,bmprju.wfb,bmprma.wfb,bmprxiang.wfb,bmprshi.wfb,bmprjiang.wfb,bmprpao.wfb,bmprbin.wfb,bmpbju.wfb,bmpbma.wfb,bmpbxiang.wfb,bmpbshi.wfb,bmpbjiang.wfb,bmpbpao.wfb,bmpbbin.wfb;char *boardfile109= bmp11.wfb,bmp1t.wfb,bmp1t.wfb,bmp14.wfb,bmp15.wfb,bmp16.wfb,bmp1t.wfb,bmp1t.wfb,bmp19.wfb, bmp21.wfb,bmp2c.wfb,bmp2c.wfb,bmp24.wfb,bmp25.wfb,bmp26.wfb,bmp2c.wfb,bmp2c.wfb,bmp29.wfb, bmp21.wfb,bmp3a.wfb,bmp3t.wfb,bmp34.wfb,bmp3t.wfb,bmp36.wfb,bmp3t.wfb,bmp3a.wfb,bmp29.wfb, bmp41.wfb,bmp4t.wfb,bmp4a.wfb,bmp4t.wfb,bmp4a.wfb,bmp4t.wfb,bmp4a.wfb,bmp4t.wfb,bmp49.wfb, bmp51.wfb,bmp52.wfb,bmp5t.wfb,bmp54.wfb,bmp5t.wfb,bmp56.wfb,bmp5t.wfb,bmp58.wfb,bmp59.wfb, bmp61.wfb,bmp62.wfb,bmp6t.wfb,bmp64.wfb,bmp6t.wfb,bmp66.wfb,bmp6t.wfb,bmp68.wfb,bmp69.wfb, bmp71.wfb,bmp7t.wfb,bmp7a.wfb,bmp7t.wfb,bmp7a.wfb,bmp7t.wfb,bmp7a.wfb,bmp7t.wfb,bmp79.wfb, bmp81.wfb,bmp8a.wfb,bmp8t.wfb,bmp84.wfb,bmp85.wfb,bmp86.wfb,bmp8t.wfb,bmp8a.wfb,bmp89.wfb, bmp91.wfb,bmp9t.wfb,bmp9t.wfb,bmp9t.wfb,bmp95.wfb,bmp9t.wfb,bmp9t.wfb,bmp9t.wfb,bmp99.wfb, bmp101.wfb,bmp102.wfb,bmp102.wfb,bmp104.wfb,bmp105.wfb,bmp106.wfb,bmp108.wfb,bmp108.wfb,bmp109.wfb;char cursor1414=0,0,0,0,0,0,0,0,0,0,0,0,1,1,0,0,0,0,0,0,0,0,0,0,0,1,1,1,0,255,255,255,255,255,255,255,0,0,1,1,1,1,0,255,255,255,255,255,255,0,0,1,1,1,1,1,0,255,255,255,255,255,255,0,0,1,1,1,1,1,0,255,255,255,255,255,255,255,0,0,1,1,1,1,0,255,255,255,255,255,255,255,255,0,0,1,1,1,0,255,255,255,255,255,255,255,255,255,0,0,1,1,0,255,255,0,255,255,255,255,255,255,255,0,0,1,0,255,0,1,1,0,255,255,255,255,255,255,255,0,0,0,1,1,1,1,0,255,255,255,255,255,0,1,0,1,1,1,1,1,1,0,255,255,255,0,1,1,1,1,1,1,1,1,1,1,0,255,0,1,1,1,1,1,1,1,1,1,1,1,1,0,1,1,1,1;struct pos int x; int y;position109,redcurpos,redtemppos,redoldpos,blackcurpos,blacktemppos,blackoldpos;/*-*/selectpage(register char page) /*换页函数*/ union REGS r; r.x.ax=0x4f05; r.x.bx=0; r.x.dx=page; /*选择页面*/ int86(0x10,&r,&r);unsigned char set_SVGA_mode(int vmode) /*设置SVGA屏幕模式*/ union REGS r; r.x.ax=0x4f02; r.x.bx=vmode; int86(0x10,&r,&r); return(r.h.ah);unsigned int get_SVGA_mode() /*获取当前SVGA屏幕模式*/ union REGS r; r.x.ax=0x4f03; int86(0x10,&r,&r); return(r.x.bx);drawbmp(int start_x,int start_y,char filename) char buffer640; int i,j,k,n,r,g,b,width,length; long position; FILE *fp; if(fp=fopen(filename,rb)=NULL) printf(Error! Cant open file!); getch(); return; fseek(fp,28,SEEK_SET); fread(&i,2,1,fp); if(i!=8) /*检查是否为256色位图*/ puts(Error!Cant find bitmap!); fclose(fp); getch(); exit(0); fseek(fp,18,SEEK_SET); fread(&width,4,1,fp); fread(&length,4,1,fp); if(firsttime) fseek(fp,54,SEEK_SET); for(i=0;i2); /*右移是要转化为VGA的6位寄存器形式*/ outportb(0x3c9,g2); outportb(0x3c9,b2); fgetc(fp); else fseek(fp,300,SEEK_SET); k=(width%4)?(4-width%4):0; /*宽度修正值*/ for(j=length-1+start_x;j=start_x;j-) fread(buffer,width,1,fp); for(i=start_y,n=0;iwidth+start_y;i+,n+) position=j*640l+i; /*计算要显示点的显存位置*/ page_new=position/65536; /*计算显示页*/ if(page_new!=page_old) /*当显示页不同时更换页面,提高一定的输出速度*/ selectpage(page_new);page_old=page_new; pokeb(0xa000,position%65536,buffern); /*写到显存位置*/ fseek(fp,k,SEEK_CUR); /*每行绘制完后修正宽度*/ fclose(fp);init() savemode=get_SVGA_mode(); /*先保存原来的屏幕模式*/ set_SVGA_mode(0x101); /*硬件无关性初始化屏幕为640*480 256色模式*/end() set_SVGA_mode(savemode); /*恢复屏幕*/*-*/initpos() int i,j; for(i=0;i10;i+) for (j=0;j9;j+) positionij.x=35+i*39; positionij.y=43+j*40; initchessmap() board00=BLACK_JU; board01=BLACK_MA; board02=BLACK_XIANG; board03=BLACK_SHI; board04=BLACK_JIANG; board05=BLACK_SHI; board06=BLACK_XIANG; board07=BLACK_MA; board08=BLACK_JU; board21=BLACK_PAO; board27=BLACK_PAO; board30=BLACK_BIN; board32=BLACK_BIN; board34=BLACK_BIN; board36=BLACK_BIN; board38=BLACK_BIN; board90=RED_JU; board91=RED_MA; board92=RED_XIANG; board93=RED_SHI; board94=RED_JIANG; board95=RED_SHI; board96=RED_XIANG; board97=RED_MA; board98=RED_JU; board71=RED_PAO; board77=RED_PAO; board60=RED_BIN; board62=RED_BIN; board64=RED_BIN; board66=RED_BIN; board68=RED_BIN;initdrawchess() int i,j; for(i=0;i10;i+) for(j=0;j=x;j-,m-) for(i=y,n=0;i=x;j-,m-) for(i=y,n=0;i=RED_JU&boardxy=RED_JU&boardxy=5) if(y!=oldy|(oldx-x)!=1) return 0; else if(x=(oldx-1)&y=oldy) return 1; else if(x=oldx&y=(oldy+1) return 1; else if(x=oldx&y=(oldy-1) return 1; else return 0; break; case RED_JIANG: /*完成*/ if(x!=oldx&y!=oldy) return 0; if(x!=oldx) if(x-oldx)1|(oldx-x)1) return 0; else if(x1|(oldy-y)1) return 0; else if(y5) return 0; break; case RED_JU: /*完成*/ if(x!=oldx&y!=oldy) return 0; else if(x!=oldx) min=(xoldx)?oldx:x; max=(xoldx)?x:oldx; for(i=min+1;ioldy)?oldy:y; max=(yoldy)?y:oldy; for(i=min+1;ioldx)?oldx:x; max=(xoldx)?x:oldx; for(i=min+1;ioldy)?oldy:y; max=(yoldy)?y:oldy; for(i=min+1;ioldx)?oldx:x; max=(xoldx)?x:oldx; for(i=min+1,j=0;ioldy)?oldy:y; max=(yoldy)?y:oldy; for(i=min+1,j=0;imax;i+) if(boardxi!=0) j+; if(j!=1) return 0; break; case RED_SHI: /*完成*/ if(oldx=9|oldx=7) if(x!=8|y!=4) return 0; else if(oldx=8) if(x=9&y=3) return 1; else if(x=9&y=5) return 1; else if(x=7&y=3) return 1; else if(x=7&y=5) return 1; else return 0; else return 0; break; case RED_XIANG: /*完成*/ if(x0) redcurpos.x-; x=positionredtemppos.xredtemppos.y.x; y=positionredtemppos.xredtemppos.y.y; if(boardredtemppos.xredtemppos.y=0) drawbmp(x,y,boardfileredtemppos.xredtemppos.y); else if(!(redtemppos.x=redoldpos.x&redtemppos.y=redoldpos.y&redstate=MOVE) n=boardredtemppos.xredtemppos.y; drawbmp(x,y,chessfilen); if(redtemppos.x=redoldpos.x&redtemppos.y=redoldpos.y&redstate=MOVE) drawselecursor(redoldpos); drawcursor(redcurpos); redtemppos.x=redcurpos.x; redtemppos.y=redcurpos.y; reddown() int x,y,n; if(redcurpos.x0) redcurpos.y-; x=positionredtemppos.xredtemppos.y.x; y=positionredtemppos.xredtemppos.y.y; if(boardredtemppos.xredtemppos.y=0) drawbmp(x,y,boardfileredtemppos.xredtemppos.y); else if(!(redtemppos.x=redoldpos.x&redtemppos.y=redoldpos.y&redstate=MOVE) n=boardredtemppos.xredtemppos.y; drawbmp(x,y,chessfilen); if(redtemppos.x=redoldpos.x&redtemppos.y=redoldpos.y&redstate=MOVE) drawselecursor(redoldpos); drawcursor(redcurpos); redtemppos.x=redcurpos.x; redtemppos.y=redcurpos.y; redright() int x,y,n; if(redcurpos.y8) redcurpos.y+; x=positionredtemppos.xredtemppos.y.x; y=positionredtemppos.xredtemppos.y.y; if(boardredtemppos.xredtemppos.y=0) drawbmp(x,y,boardfileredtemppos.xredtemppos.y); else if(!(redtemppos.x=redoldpos.x&redtemppos.y=redoldpos.y&redstate=MOVE) n=boardredtemppos.xredtemppos.y; drawbmp(x,y,chessfilen); if(redtemppos.x=redoldpos.x&redtemppos.y=redoldpos.y&redstate=MOVE) drawselecursor(redoldpos); drawcursor(redcurpos); redtemppos.x=redcurpos.x; redtemppos.y=redcurpos.y; reddo() int i,j,x,y,n; if(redstate=SELECT&redcanselect() if(boardredcurpos.xredcurpos.y0) redstate=MOVE; drawselecursor(redcurpos); redoldpos.x=redcurpos.x; redoldpos.y=redcurpos.y; else if(redstate=MOVE&redcanmove() x=positionredoldpos.xredoldpos.y.x; y=positionredoldpos.xredoldpos.y.y; drawbmp(x
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 梳理缝编非织造布制作工成本控制考核试卷及答案
- 漆器彩绘雕填工抗压考核试卷及答案
- 辐射废物处理技术风险评估与管理分析报告
- 重庆学校活动设备策划方案
- 碳排放交易员专项考核试卷及答案
- 义诊咨询工作方案
- 大型养路机械司机适应性考核试卷及答案
- 校园招聘效果追踪报告
- 学前儿童发展心理学考试真题
- 含氟烯烃生产工理念考核试卷及答案
- 外科患者的营养支持-肠内营养(外科课件)
- 城乡规划管理与法规系列讲座课件-城市规划依法行政案例
- 浙江省强基联盟2024-2025学年高一上学期10月联考语文试题(解析版)
- 影响分娩的因素及分娩机制演示
- 《酶切连接与转化》课件
- 超市整体装修升级方案
- (高清版)DB43∕T 1591-2019 锂电池正极材料单位产品能源消耗限额及计算方法
- 仅销售预包装食品经营者备案信息采集表
- EDA技术概述获奖课件
- 《可摘局部义齿工艺技术》考试复习题库(带答案)
- DL∕T 1919-2018 发电企业应急能力建设评估规范
评论
0/150
提交评论