专家
公告
财富商城
电子网
旗下网站
首页
问题库
专栏
标签库
话题
专家
NEW
门户
发布
提问题
发文章
51单片机
上传16X16点阵贪吃蛇游戏源代码,有点小错误,求助万能的ourdev
2020-01-23 14:45
发布
×
打开微信“扫一扫”,打开网页后点击屏幕右上角分享按钮
站内问答
/
51单片机
7444
5
5
这游戏不是本人原创的,但忘记从哪里弄来的了,用google和百度都找不到根了。今天突然兴起拿出来试玩,经过大半天的“调试”基本功能都正常,只是四周边缘不对,本应该是上下左右是游戏边缘的(蛇碰了就死掉),但现在不是,上下边缘是正确,就是没有左右边缘,本人不才看了许久不得答案,请ourdev的大侠们帮帮我。先谢谢了!
(原文件名:tcs.jpg)
程序在下面。
友情提示:
此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。
该问题目前已经被作者或者管理员关闭, 无法添加新回复
4条回答
pangjineng
1楼-- · 2020-01-23 17:07
#include <reg51.h>
#include <intrins.h>
#include "key.h"
#define uchar unsigned char
#define uint unsigned int
#define SNAKE 20 //最大长度
#define PINGMUCHANGDU 16 //屏幕长最大长度
#define PINGMUKUANDU 16 //屏幕宽最大长度
#define BLKN 2 //列锁存器数
#define ABCD138 P2
sbit SDATA_595=P3^0; //串行数据输入
sbit SCLK_595 =P3^1; //移位时钟脉冲
sbit RCK_595 =P3^2; //输出锁存器控制脉冲
sbit G_74138 =P3^4; //显示允许控制信号端口
uchar xshu[SNAKE],yshu[SNAKE];
uint speed=200;
uchar temp,pianyi;
uchar changdu;
uchar i,k,j;
uchar suijix,suijiy;
uchar data dispram[32]={0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF}; //显示缓存
void delay(uint);
void yanshi(uint);
/*******************************************************
* *
* 显示函数 *
* *
*******************************************************/
void play(uchar xi,uchar yi)
{
uchar pianyi1;
if(xi>7)
{
pianyi1=0x01<<(15-xi);
pianyi=~pianyi1;
dispram[2*yi+1]&=pianyi;
}
if(xi<8)
{
pianyi1=0x01<<(7-xi);
pianyi=~pianyi1;
dispram[2*yi]&=pianyi;
}
}
/*******************************************************
* *
* 熄灭函数 *
* *
*******************************************************/
void mie(uchar xi,uchar yi)
{
uchar pianyi1;
if(xi>7)
{
pianyi1=0x01<<(15-xi);
dispram[2*yi+1]|=pianyi1;
}
if(xi<8)
{
pianyi1=0x01<<(7-xi);
dispram[2*yi]|=pianyi1;
}
}
/*******************************************************
* *
* 控制方向函数 开始暂停 *
* *
*******************************************************/
uchar fangxiangkongzhi(void)
{
if(direction==0x01)//上
{
if(((xshu[changdu-1]+0)!=xshu[changdu-2])&&((yshu[changdu-1]-1)!=yshu[changdu-2]))
{
xfangxiang=0;
yfangxiang=-1;
direction=0;
return 1;
}
}
if(direction==0x02)//下
{
if(((xshu[changdu-1]+0)!=xshu[changdu-2])&&((yshu[changdu-1]+1)!=yshu[changdu-2]))
{
yfangxiang=1;
xfangxiang=0;
direction=0;
return 1;
} }
if(direction==0x03)//左
{
if(((xshu[changdu-1]+1)!=xshu[changdu-2])&&((yshu[changdu-1]+0)!=yshu[changdu-2]))
{
xfangxiang=1;
yfangxiang=0;
direction=0;
return 1;
}}
if(direction==0x04)//右
{
if(((xshu[changdu-1]-1)!=xshu[changdu-2])&&((yshu[changdu-1]+0)!=yshu[changdu-2]))
{
xfangxiang=-1;
yfangxiang=0;
direction=0;
return 1;
}
}
if(direction==0x05)//暂停
{
yanshi (100);
direction=0;
while(direction!=0x05)keydown();
direction=0;
}
else
return 0;
}
/*******************************************************
* *
* 前进函数 *
* *
*******************************************************/
void qianjin(void)
{
fangxiangkongzhi();
//fangxiangkongzhi();
mie(xshu[0],yshu[0]);
for(k=0;k<changdu-1;k++)
{
xshu[k]=xshu[k+1];
yshu[k]=yshu[k+1];
}
xshu[changdu-1]=xshu[changdu-2]+xfangxiang;
yshu[changdu-1]=yshu[changdu-2]+yfangxiang;
for(j=0;j<changdu;j++)
{
play(xshu[j],yshu[j]);
}
}
/*******************************************************
* *
* 判断死亡函数 *
* *
*******************************************************/
uchar ifdie()
{
for(i=0;i<changdu-1;i++)
if((xshu
==xshu[changdu-1])&&(yshu
==yshu[changdu-1]))
{return 0;} //判断是否撞到自己
if((xshu[changdu-1]>(PINGMUCHANGDU-1))||xshu[changdu-1]<0)
return 0;
if((yshu[changdu-1]>(PINGMUKUANDU-1))||yshu[changdu-1]<0)
return 0; //判断是否撞到边界
else
return 1;
}
/*******************************************************
* *
* 随机数生成函数 *
* *
*******************************************************/
void chanshengsuijishu()
{
suijix=TL0;
suijiy=TL0;
suijix=suijix%PINGMUKUANDU;
suijiy=suijiy%31%16;
for(i=1;i<changdu;i++)
if((xshu[i-1]==suijix)&&(yshu[i-1]==suijiy))
{
suijix=suijix%PINGMUKUANDU;
suijiy=suijiy%31%16;
i=0;
}
play(suijix,suijiy);
}
//程序结束
加载中...
pangjineng
2楼-- · 2020-01-23 20:53
哪里出错了?
加载中...
HeP028
3楼-- · 2020-01-23 21:46
收藏,有空研究研究
加载中...
TerrenceYu
4楼-- · 2020-01-24 02:40
有空看看
加载中...
一周热门
更多
>
相关问题
【东软载波ESF0654 PDS开发板活动】开箱
1 个回答
东软载波ESF0654 PDS开发板外部中断
1 个回答
东软载波ESF0654 PDS开发板高级控制定时器AD16C4T
1 个回答
用串口调试助手为什么只能在hex模式接收发送而在文本模式不行
9 个回答
触摸芯片SC02B/SC04B在地砖灯的设计方案
1 个回答
东软载波ESF0654 PDS开发板串口USART0代码分享
1 个回答
普通32位单片机使用linux的应用代码
5 个回答
东软载波ESF0654 PDS开发板AT24C04的调试
9 个回答
相关文章
51单片机与蓝牙模块连接
0个评论
51单片机的硬件结构
0个评论
基于51单片机的无线遥控器制作
0个评论
51单片机 AD转换
0个评论
51单片机数码管递增显示
0个评论
如何实现对单片机寄存器的访问
0个评论
基于51单片机的指纹密码锁
0个评论
×
关闭
采纳回答
向帮助了您的网友说句感谢的话吧!
非常感谢!
确 认
×
关闭
编辑标签
最多设置5个标签!
51单片机
保存
关闭
×
关闭
举报内容
检举类型
检举内容
检举用户
检举原因
广告推广
恶意灌水
回答内容与提问无关
抄袭答案
其他
检举说明(必填)
提交
关闭
×
关闭
您已邀请
15
人回答
查看邀请
擅长该话题的人
回答过该话题的人
我关注的人
#include <intrins.h>
#include "key.h"
#define uchar unsigned char
#define uint unsigned int
#define SNAKE 20 //最大长度
#define PINGMUCHANGDU 16 //屏幕长最大长度
#define PINGMUKUANDU 16 //屏幕宽最大长度
#define BLKN 2 //列锁存器数
#define ABCD138 P2
sbit SDATA_595=P3^0; //串行数据输入
sbit SCLK_595 =P3^1; //移位时钟脉冲
sbit RCK_595 =P3^2; //输出锁存器控制脉冲
sbit G_74138 =P3^4; //显示允许控制信号端口
uchar xshu[SNAKE],yshu[SNAKE];
uint speed=200;
uchar temp,pianyi;
uchar changdu;
uchar i,k,j;
uchar suijix,suijiy;
uchar data dispram[32]={0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,
0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF,0xFF}; //显示缓存
void delay(uint);
void yanshi(uint);
/*******************************************************
* *
* 显示函数 *
* *
*******************************************************/
void play(uchar xi,uchar yi)
{
uchar pianyi1;
if(xi>7)
{
pianyi1=0x01<<(15-xi);
pianyi=~pianyi1;
dispram[2*yi+1]&=pianyi;
}
if(xi<8)
{
pianyi1=0x01<<(7-xi);
pianyi=~pianyi1;
dispram[2*yi]&=pianyi;
}
}
/*******************************************************
* *
* 熄灭函数 *
* *
*******************************************************/
void mie(uchar xi,uchar yi)
{
uchar pianyi1;
if(xi>7)
{
pianyi1=0x01<<(15-xi);
dispram[2*yi+1]|=pianyi1;
}
if(xi<8)
{
pianyi1=0x01<<(7-xi);
dispram[2*yi]|=pianyi1;
}
}
/*******************************************************
* *
* 控制方向函数 开始暂停 *
* *
*******************************************************/
uchar fangxiangkongzhi(void)
{
if(direction==0x01)//上
{
if(((xshu[changdu-1]+0)!=xshu[changdu-2])&&((yshu[changdu-1]-1)!=yshu[changdu-2]))
{
xfangxiang=0;
yfangxiang=-1;
direction=0;
return 1;
}
}
if(direction==0x02)//下
{
if(((xshu[changdu-1]+0)!=xshu[changdu-2])&&((yshu[changdu-1]+1)!=yshu[changdu-2]))
{
yfangxiang=1;
xfangxiang=0;
direction=0;
return 1;
} }
if(direction==0x03)//左
{
if(((xshu[changdu-1]+1)!=xshu[changdu-2])&&((yshu[changdu-1]+0)!=yshu[changdu-2]))
{
xfangxiang=1;
yfangxiang=0;
direction=0;
return 1;
}}
if(direction==0x04)//右
{
if(((xshu[changdu-1]-1)!=xshu[changdu-2])&&((yshu[changdu-1]+0)!=yshu[changdu-2]))
{
xfangxiang=-1;
yfangxiang=0;
direction=0;
return 1;
}
}
if(direction==0x05)//暂停
{
yanshi (100);
direction=0;
while(direction!=0x05)keydown();
direction=0;
}
else
return 0;
}
/*******************************************************
* *
* 前进函数 *
* *
*******************************************************/
void qianjin(void)
{
fangxiangkongzhi();
//fangxiangkongzhi();
mie(xshu[0],yshu[0]);
for(k=0;k<changdu-1;k++)
{
xshu[k]=xshu[k+1];
yshu[k]=yshu[k+1];
}
xshu[changdu-1]=xshu[changdu-2]+xfangxiang;
yshu[changdu-1]=yshu[changdu-2]+yfangxiang;
for(j=0;j<changdu;j++)
{
play(xshu[j],yshu[j]);
}
}
/*******************************************************
* *
* 判断死亡函数 *
* *
*******************************************************/
uchar ifdie()
{
for(i=0;i<changdu-1;i++)
if((xshu==xshu[changdu-1])&&(yshu==yshu[changdu-1]))
{return 0;} //判断是否撞到自己
if((xshu[changdu-1]>(PINGMUCHANGDU-1))||xshu[changdu-1]<0)
return 0;
if((yshu[changdu-1]>(PINGMUKUANDU-1))||yshu[changdu-1]<0)
return 0; //判断是否撞到边界
else
return 1;
}
/*******************************************************
* *
* 随机数生成函数 *
* *
*******************************************************/
void chanshengsuijishu()
{
suijix=TL0;
suijiy=TL0;
suijix=suijix%PINGMUKUANDU;
suijiy=suijiy%31%16;
for(i=1;i<changdu;i++)
if((xshu[i-1]==suijix)&&(yshu[i-1]==suijiy))
{
suijix=suijix%PINGMUKUANDU;
suijiy=suijiy%31%16;
i=0;
}
play(suijix,suijiy);
}
//程序结束
一周热门 更多>