当前位置:七道奇文章资讯编程技术VC/C++编程
日期:2011-03-22 13:54:00  来源:本站整理

简单图形模拟吃豆游戏[VC/C++编程]

赞助商链接



  本文“简单图形模拟吃豆游戏[VC/C++编程]”是由七道奇为您精心收集,来源于网络转载,文章版权归文章作者所有,本站不对其观点以及内容做任何评价,请读者自行判断,以下是其具体内容:

这个程序主如果想了下怎么样让游戏中的仇人自己行走,但是又不会固定在两点往复徘徊,我用的办法是随机方向,并且走的一步不可以和前一部的方向相反,但愿高手们多多指导.也但愿高手们可以指教下编写简单游戏的一些技术.

#include "graphics.h"
    #include "stdlib.h"
    #include "dos.h"
    #include "bios.h"
    #define LEFT 0x4b00
    #define RIGHT 0x4d00
    #define DOWN 0x5000
    #define UP 0x4800
    #define ESC 0x011b
    #define ENTER 0x1c0d
    /*2墙壁,1可以移动地方,3自己,4仇人*/
    int a[15][20]={2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,
                   2,1,1,0,0,0,1,0,1,0,0,0,1,1,1,1,1,1,0,2,
                   2,1,2,2,2,1,1,2,1,1,0,0,0,1,1,4,1,1,0,2,
                   2,1,1,0,2,1,1,2,0,1,1,2,2,2,2,2,0,0,0,2,
                   2,4,1,0,2,1,1,2,1,1,1,0,1,1,1,1,0,1,1,2,
                   2,1,2,1,2,1,1,2,1,3,2,2,1,1,1,1,2,2,1,2,
                   2,1,2,1,2,1,1,1,1,1,1,1,1,0,0,0,1,1,1,2,
                   2,1,2,1,0,1,1,1,1,2,1,0,1,2,2,2,1,1,1,2,
                   2,1,0,1,0,1,2,1,1,2,1,0,1,2,1,1,4,1,1,2,
                   2,1,0,2,0,1,2,1,1,2,1,0,1,2,1,1,1,1,1,2,
                   2,1,0,2,1,1,2,1,1,2,1,0,2,2,1,0,0,0,1,2,
                   2,1,1,2,1,1,2,1,1,2,1,0,2,1,1,2,2,1,1,2,
                   2,1,2,2,1,2,2,1,1,1,1,0,1,4,1,2,0,0,1,2,
                   2,1,0,0,0,0,0,4,0,1,1,0,1,1,1,1,0,0,1,2,
            2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2,2};/*数组就是地图*/
    strUCt play /*游戏中人物的构造体*/
    {
     int x;
     int y;
    };
    struct play you,them[5];
    int sum=0;/*统计吃的豆子个数,吃满50颗就算成功*/
    int xx[5][2];/*判断仇人方向用的构造体*/
    int false=0;
    void TimeDelay(unsigned long microsec) /*延时函数 传入微秒数*/
    {
     union REGS r;
     r.h.ah=0x86;
     r.x.cx=microsec>>16;
     r.x.dx=microsec;
     int86(0x15,&r,&r);
    }
    drawblackdou(int x,int y)/*吃豆子的函数*/

    begain()/*开始函数*/
    {int i,j;
     sleep(1);
     for(i=0;i<15;i++)
      for(j=0;j<20;j++)
       if(a[i][j]==2)/*代表墙壁*/
        {
         setfillstyle(SOLID_FILL,BLUE);
         bar(100+j*20-10,100+i*20+10,100+j*20+10,100+i*20-10);
        }
       else if(a[i][j]==3)/*代表自己*/
        {
         setcolor(RED);
         circle(100+j*20,100+i*20,9);
        }
       else if(a[i][j]==4)/*代表仇人*/
        {
         setcolor(GREEN);
         circle(100+j*20,100+i*20,9);
        }
       else if(a[i][j]==0)/*代表豆子*/
       {
        setcolor(YELLOW);
        circle(100+j*20,100+i*20,3);
       }
     you.x=5;you.y=9;/*仇人也自己的开始坐标*/
     them[0].x=2;them[0].y=15;
     them[1].x=4;them[1].y=1;
     them[2].x=8;them[2].y=16;
     them[3].x=12;them[3].y=13;
     them[4].x=13;them[4].y=7;
    }
    void movethem(struct play *them)/*仇人移动的历程*/
    {int i,loop;
     randomize();
     for(i=0;i<5;i++)
     {
     if(you.x==them[i].x&&(them[i].y+1)==you.y)
       them[i].y++;
     else if(you.x==them[i].x&&(them[i].y-1)==you.y)
       them[i].y--;
     else if(you.y==them[i].y&&(them[i].x+1)==you.x)
      them[i].x++;
     else if(you.y==them[i].y&&(them[i].x-1)==you.x)/*只要掌握者在身边就当即靠上去*/
      them[i].x--;
     else
     {
     loop:
       xx[i][0]=rand()%4+1;/*这里的方向采纳随机赋值,原则是新的方向不可以和本来的方向相反*/
       if(xx[i][0]==1&&xx[i][1]==2xx[i][0]==2&&xx[i][1]==1)
        goto loop;
       if(xx[i][0]==3&&xx[i][1]==4xx[i][0]==4&&xx[i][1]==3)
        goto loop;
       xx[i][1]=xx[i][0];
      if(xx[i][0]==1)/*四个方向*/
       {them[i].x--;
        if(a[them[i].x][them[i].y]==2)/*假如碰墙壁的话就回到本来的地方等候随机的方向*/
        {them[i].x++;goto loop;}
       }
      else if(xx[i][0]==2)
       {them[i].x++;
        if(a[them[i].x][them[i].y]==2)
        {them[i].x--;goto loop;}
       }
      else if(xx[i][0]==3)
       {them[i].y++;
        if(a[them[i].x][them[i].y]==2)
        {them[i].y--;goto loop;}
       }
      else if(xx[i][0]==4)
       {them[i].y--;
        if(a[them[i].x][them[i].y]==2)
        {them[i].y++;goto loop;}
       }
      }
     }
    }
    fun(struct play *them)/*移动中的判断*/
    {
     int i;
     setcolor(0);/*把仇人的老位置删除*/
       for(i=0;i<5;i++)
        circle(them[i].y*20+100,them[i].x*20+100,9);
      movethem(them);/*按照掌握者的位置来决意仇人的移动方向*/
    }
    win()/*成功的话*/
    {
     cleardevice();
     settextstyle(0,0,4);
     while(!kbhit())
     {
      setcolor(rand()%13+1);
       outtextxy(200,200,"YOU WIN!");
      delay(1000);
     }
    }
    false1()/*失利画面*/
    {
     cleardevice();
     settextstyle(0,0,4);
     while(!kbhit())
     {
      setcolor(rand()%13+1);
       outtextxy(180,200,"GAME OVER!");
      delay(1000);
     }
    }
    loseyes()/*判断能否失利*/
    {int i;
     for(i=0;i<5;i++)
       if(them[i].x==you.x&&them[i].y==you.y)
       false=1;/*假如失利的话*/
    }
 main()
    {int gd=DETECT,gm;
     int key,i;
     initgraph(&gd,&gm,"c:tc");
      cleardevice();
     begain();/*开始画面*/
     while(1)
     {
      while(!kbhit())
       {
      setcolor(GREEN);/*重画仇人*/
      for(i=0;i<5;i++)
       circle(them[i].y*20+100,them[i].x*20+100,9);
      TimeDelay(280000);
       fun(them);/*处理仇人*/
      for(i=0;i<5;i++)
       if(them[i].x==you.x&&them[i].y==you.y)
       false=1;/*假如失利的话*/
      loseyes();/*判断能否失利*/
      if(false)
        break;
       }
      if(false)
        break;
      key=bioskey(0);
      setcolor(0);/*把自己本来位置的人给删撤除*/
      circle(100+you.y*20,100+you.x*20,9);
       if(key==ESC)
        break;
       else if(key==UP)/*这里开始的判断主如果能否吃到豆子和碰到墙壁*/
        {you.x--;
         if(a[you.x][you.y]==2) you.x++;
         else if(a[you.x][you.y]==0)
         drawblackdou(you.x,you.y);}
       else if(key==DOWN)
        {you.x++;if(a[you.x][you.y]==2) you.x--;
         else if(a[you.x][you.y]==0)
         drawblackdou(you.x,you.y);}
       else if(key==RIGHT)
        {you.y++;if(a[you.x][you.y]==2) you.y--;
         else if(a[you.x][you.y]==0)

         drawblackdou(you.x,you.y);}
       else if(key==LEFT)
        {you.y--;if(a[you.x][you.y]==2) you.y++;
         else if(a[you.x][you.y]==0)
         drawblackdou(you.x,you.y);}
         if(sum==50)
          break;
      setcolor(RED);/*履行了一次键盘后再画出自己的位置*/
      circle(100+you.y*20,100+you.x*20,9);
      loseyes();/*自己走上去碰到仇人的大概*/
       if(false)
        break;
     }
     if(sum==50)/*吃满豆子了*/

     if(false)

     closegraph();
    }


  以上是“简单图形模拟吃豆游戏[VC/C++编程]”的内容,如果你对以上该文章内容感兴趣,你可以看看七道奇为您推荐以下文章:
  • 简单图形模拟吃豆游戏
  • 本文地址: 与您的QQ/BBS好友分享!
    • 好的评价 如果您觉得此文章好,就请您
        0%(0)
    • 差的评价 如果您觉得此文章差,就请您
        0%(0)

    文章评论评论内容只代表网友观点,与本站立场无关!

       评论摘要(共 0 条,得分 0 分,平均 0 分) 查看完整评论
    Copyright © 2020-2022 www.xiamiku.com. All Rights Reserved .