新闻中心

EEPW首页 > 嵌入式系统 > 设计应用 > 51单片机+8*8点阵实现的贪食蛇源代码

51单片机+8*8点阵实现的贪食蛇源代码

作者: 时间:2016-11-30 来源:网络 收藏

/*****************
乘方程序
*****************/
uchar mux(uchar temp)
{
if(temp==7)return 128;
if(temp==6)return 64;
if(temp==5)return 32;
if(temp==4)return 16;
if(temp==3)return 8;
if(temp==2)return 4;
if(temp==1)return 2;
if(temp==0)return 1;
return 0;
}
/*****************
显示时钟 显示程序
*****************/
void timer0(uchar k)
{while(k--)
{for(i=0;i{P2=mux(x[i]);P1=255-mux(y[i]);
turnkey(); //上下左右键位处理
delay(TIME); //显示延迟
P2=0x00;P1=0xff;
}}
}
/*****************
主程序
*****************/
void main(void)
{e=SPEED;
P0=0x00;
P1=0xff;
P2=0x00;
P3=0x00;
while(1)
{//if(keyenable==1){P1=0x00;P2=0xff;}else{P1=0xff;P2=0x00;}
for(i=3;ix[0]=4;y[0]=4; //果子
n=3; //蛇长 n=-1
x[1]=1;y[1]=0; //蛇头
x[2]=0;y[2]=0; //蛇尾1
addx=0;addy=0; //位移偏移
//k=1;
while(1){if(keyenable)break;timer0(1);}
while(1)
{timer0(e);
if(knock()){e=SPEED;break;} //判断碰撞
if((x[0]==x[1]+addx)&(y[0]==y[1]+addy)) //是否吃东西
{n++;
if(n==SNAKE+1)
{n=3;e=e-10;
for(i=3;i for(i=3;i }
x[0]=x[n-2];
y[0]=y[n-2];
}
for(i=n-1;i>1;i--){x[i]=x[i-1];y[i]=y[i-1];}
//x[n-1]=x[2];y[n-1]=y[2];
x[1]=x[2]+addx;y[1]=y[2]+addy; //移动
}
}
}

上一页 1 2 下一页

评论


技术专区

关闭