登录|立即注册|使用QQ帐号登录
论坛 > 51单片机
发帖|
看6280|回3|收藏
楼主 ID:150187 只看他
2016-11-25 18:21
使用51单片机与点阵组成的贪吃蛇游戏

贪吃蛇游戏的仿真原理图:
请大家多多指教 0.png
贪吃蛇pcb
0.png 0.png 0.png

所有资料下载:
贪吃蛇.zip (11.28 MB)
(下载次数: 52, 2016-11-25 18:21 上传)

下载积分: 黑币 -5



以下是部分单片机代码预览:

代码:

  1. #include <reg51.h>
  2. #define uchar unsigned char
  3. #define SNAKE 20                 //×î′ó3¤¶è
  4. #define TIME 50                 //ÏÔê¾Ñóê±ê±¼ä
  5. #define SPEED 71               //Ëù¶è¿ØÖÆ
  6. //#define  keyenable 1
  7. sbit keyenable=P3^6;                        //·½Ïòê1Äü
  8. /*sbit keyx=P0^1;                                        //×óóò
  9. sbit keyy=P0^2;                                        //éÏÏ        */
  10. //sbit up=P0^0;
  11. sbit up=P3^3;       //down
  12. sbit down=P3^1;
  13. sbit right=P3^2;
  14. sbit left=P3^4;
  15. uchar x[SNAKE+1];
  16. uchar y[SNAKE+1];         
  17. uchar time,n,i,e;              //Ñóê±ê±¼ä£¬μ±Ç°éß3¤£¬í¨óÃÑ-»·±äá¿£¬μ±Ç°Ëù¶è               
  18. char addx,addy;                //λòÆÆ«òÆá¿
  19. /********************
  20. Ñóê±3ìDò
  21. *********************/
  22. void delay(char MS)
  23. {
  24. char us,usn;
  25. while(MS!=0)
  26. {
  27. usn = 0;
  28. while(usn!=0)
  29. {
  30. us=0xff;
  31. while (us!=0){us--;};
  32. usn--;
  33. }
  34. MS--;
  35. }
  36. }
  37. /*******************************************
  38. ÅD¶ÏÅö×2
  39. *******************************************/
  40. bit knock()
  41. {bit k;
  42. k=0;
  43. if(x[1]>7||y[1]>7)k=1;                             //×2ǽ
  44. for(i=2;i<n;i++)if((x[1]==x[i])&(y[1]==y[i]))k=1;  //×2×Ô¼o
  45. return k;
  46. }
  47. /*****************
  48. éÏÏÂ×óóò¼üλ′|àí
  49. *****************/
  50. void turnkey()// interrupt 0 using 2  
  51. {//up=1;
  52. if(keyenable)
  53. {
  54. if(left){addy=0;if(addx!=1)addx=-1; else addx=1;}
  55. if(right){addy=0;if(addx!=-1)addx=1; else addx=-1;}
  56. if(up){addx=0;if(addy!=-1)addy=1; else addy=-1;}
  57. if(down){addx=0;if(addy!=1)addy=-1; else addy=1;}
  58. /*if(keyy)
  59. {addy=0;                                   //×óóò
  60. if(keyx)if(addx==-1)addx=-1; else addx=1;  //×ó
  61. else
  62. if(addx==1)addx=1; else addx=-1;           //óò
  63. }
  64. else
  65. {addx=0;                                   //éÏÏÂ
  66. if(keyx)if(addy==1)addy=1; else addy=-1;   //ÏÂ
  67. else
  68. if(addy==-1)addy=-1; else addy=1;          //éÏ         
  69. } */
  70. }
  71. }
  72. /*****************
  73. 3Ë·½3ìDò
  74. *****************/
  75. uchar mux(uchar temp)
  76. {
  77. if(temp==7)return 128;
  78. if(temp==6)return 64;
  79. if(temp==5)return 32;
  80. if(temp==4)return 16;
  81. if(temp==3)return 8;
  82. if(temp==2)return 4;
  83. if(temp==1)return 2;
  84. if(temp==0)return 1;
  85. return 0;
  86. }
  87. /*****************
  88. ÏÔê¾ê±Öó ÏÔê¾3ìDò
  89. *****************/
  90. void timer0(uchar k)
  91. {while(k--)
  92. {for(i=0;i<SNAKE+1;i++)
  93. {P2=mux(x[i]);P1=255-mux(y[i]);
  94. turnkey();                     //éÏÏÂ×óóò¼üλ′|àí
  95. delay(TIME);                   //ÏÔê¾Ñó3ù
  96. P2=0x00;P1=0xff;
  97. }}
  98. }
  99. /*****************
  100. Ö÷3ìDò
  101. *****************/        
  102. void main(void)
  103. {e=SPEED;
  104. P0=0x00;
  105. P1=0xff;
  106. P2=0x00;
  107. P3=0x00;
  108. while(1)      
  109. {//if(keyenable==1){P1=0x00;P2=0xff;}else{P1=0xff;P2=0x00;}
  110. for(i=3;i<SNAKE+1;i++)x[i]=100;for(i=3;i<SNAKE+1;i++)y[i]=100;//3õê¼»ˉ
  111. x[0]=4;y[0]=4;                                                //1û×ó                           
  112. n=3;                                                          //éß3¤ n=-1
  113. x[1]=1;y[1]=0;                                                //éßí·
  114. x[2]=0;y[2]=0;                                                //éßÎ21
  115. addx=0;addy=0;                                                //λòÆÆ«òÆ
  116. //k=1;
  117. while(1){if(keyenable)break;timer0(1);}
  118. while(1)         
  119.   {timer0(e);
  120.    if(knock()){e=SPEED;break;}                          //ÅD¶ÏÅö×2
  121.         if((x[0]==x[1]+addx)&(y[0]==y[1]+addy))         //êÇ·ñ3Ô¶«Î÷
  122.            {n++;
  123.                    if(n==SNAKE+1)
  124.                    {n=3;e=e-10;
  125.                    for(i=3;i<SNAKE+1;i++)x[i]=100;
  126.            for(i=3;i<SNAKE+1;i++)y[i]=100;
  127.                    }
  128.            x[0]=x[n-2];
  129.            y[0]=y[n-2];
  130.            }
  131.     for(i=n-1;i>1;i--){x[i]=x[i-1];y[i]=y[i-1];}        
  132.     //x[n-1]=x[2];y[n-1]=y[2];
  133.     x[1]=x[2]+addx;y[1]=y[2]+addy;                     //òƶˉ
  134.   }                                                
  135. }                        
  136. }


沙发 ID:158074 只看他
2016-12-27 15:53
??
板凳 ID:158080 只看他
2016-12-27 16:30
??这没PCD图啊
地板 ID:158130 只看他
2016-12-27 19:02

 这没PCD图啊

51黑电子论坛

Powered by Discuz! X3.1

首页|标准版|触屏版|电脑版