当前位置:首页 > 单片机 > 单片机
[导读]  该项目设计硬件平台选择了简单易用的AT89C51单片机,显示屏选择的是AMPIRE128X64液晶屏幕显示器,按照一定顺序连接后,如下图:    软件方面采用了C51编写代码,代码编写模块如下图:  除去网上已有的图形

  该项目设计硬件平台选择了简单易用的AT89C51单片机,显示屏选择的是AMPIRE128X64液晶屏幕显示器,按照一定顺序连接后,如下图:

  

  软件方面采用了C51编写代码,代码编写模块如下图:

  除去网上已有的图形驱动代码外,其核心代码主要为游戏处理、信息处理和按键处理。

  编写游戏的功能代码,先定义游戏的数据结构和常量。

#define uchar unsigned char

#define uint unsigned int


sbit P00 = P0 ^ 0; // 右

sbit P01 = P0 ^ 1; // 左

sbit P02 = P0 ^ 2; // 上

sbit P03 = P0 ^ 3; // 下

sbit P04 = P0 ^ 4; // 开始/暂停


#define RIGHT 1

#define LEFT 2

#define UP 3

#define DOWN 4


#define ERASE 0

#define REWRITTEN 1


#define NO 0

#define YES 1


#define FALSE 0

#define TRUE 1


bit ESC = TRUE; // 开始 暂停标志位


uchar gameSpeed = 20; // 游戏速度调节

uchar level = 1; // 难度

uchar s1[] = "1"; // 保存显示难度的汉子


// uchar = unsigned char

// 食物的结构体

struct Food

{

uchar x; // 食物的横坐标

uchar y; // 食物的纵坐标

}food;


// 贪吃蛇主体的结构体

struct Snake

{

uchar x[39];

uchar y[39];

uchar node; // 蛇的节数

uchar direction; // 蛇移动方向

}snake;


  其中食物的数据结构采用结构体定义,两个unsigned char变量分别定义为食物的横纵坐标;蛇的身体定义为长度最大值为39的数组,游戏中贪吃蛇长度达到39,游戏通关结束。

  游戏处理模块为贪吃蛇在游玩过程中遇到的需要被处理的情况,主要实现的功能包括以下四个方面,即移动、食物、死亡和更新。

移动

  流程与运行仿真如上图,按下“开始”键后,游戏开始启动,初始化完毕后,屏幕会显示“贪吃蛇”、“食物”和游戏的边界框,“贪吃蛇”在固定的周期内会向前移动一格,此时“贪吃蛇”身体从尾巴至头部每一个后序节点会向前序节点移动,后序节点移动完毕后,头部会根据此时按键的方向对相应的横纵坐标进行加减。

食物

  “贪吃蛇”向前移动后,此时要判断蛇头是否与“食物”的横纵坐标一一对应,如果不是则退出该模块,进入下一模块;如果是,则“贪吃蛇”的节数增加一。节数增加后判断蛇的节数是否为10的倍数,如果是则提升“贪吃蛇”的等级,并对游戏增加难度,加快贪吃蛇移动的速度。退出了游戏升级的模块后将进入创建新的“食物”模块,为了避免“食物”与“贪吃蛇”的节点坐标重复,“食物”在创建后要与“贪吃蛇”的每个节点的坐标一一比较,如果重合则重新创建“食物”的坐标,直到创建成功为止。

结束

  “贪吃蛇”在向前移动后,有可能撞到墙壁或自己的身体,也有可能吃到食物,或者只是向前移动一格,移动完毕后如果吃到了食物,如果“贪吃蛇”的node(节数)达到了最大值(39),那么玩家将会通关游戏,并且游戏退出,此时需要判断游戏是否结束,一共有三种判别,前两种为失败结局,即撞到了墙壁或自己的身体,最后一种为通关结局,将在屏幕上打印“Congratulations”祝贺玩家成功通关游戏。

更新

  游戏在判断结束后,如果没有结束,那么更新屏幕上的“贪吃蛇”的状态。

  四个模块的核心代码如下:

// 运行游戏的具体实现

void gamePlay(void)

{

bit hero = FALSE; // 完成游戏

while(1) {

EA = 1;

if (ESC == FALSE) {

gameSpeed = 20;

level = 1;

s1[0] = '1';

start();

}


while(ESC == FALSE) {

EA = 1;


move(); // 贪吃蛇向前移动


if(snake.x[0] == food.x && snake.y[0] == food.y) { // 判断蛇头吃到食物以后

RectArea(food.x, food.y, food.x + 2, food.y + 2, ERASE); // 把画面上的食物去掉

snake.node++; // 蛇的身体长一节


if (increaseLevel()) { // 根据难度变化判断是否要重新开始

restart();

continue;

}


while (!createNewFood()) { // 如果创建失败则继续创建,直到成功

;

}

RectArea(food.x, food.y, food.x + 2, food.y + 2, REWRITTEN); // 在画面上显示食物

}

if (isOver()) { // 判断游戏是否结束

if(snake.node == 39)

hero = TRUE;

}

ESC = TRUE;

hero = gameOver(hero);

break;

}

// 打印贪吃蛇

updataSnakeHead(); // 更新头部

delay(gameSpeed); // 速度设置

eraseSnakeTail(); // 删除尾巴

} // 退出循环(!ESC)

}

}

  其余的函数代码编写如下:

// 随机数产生

int rand(void)

{

int i;

i = ((TH0 << 8) " TL0) & 0x7fff;

return(i);

}


// 延时

void delay(uchar ms) // 10毫秒

{

uchar i, j, k;

while(ms--) {

for(i = 5; i > 0; i--) {

for(j = 4; j > 0; j--) {

for(k = 248; k > 0; k--)

;

}

本站声明: 本文章由作者或相关机构授权发布,目的在于传递更多信息,并不代表本站赞同其观点,本站亦不保证或承诺内容真实性等。需要转载请联系该专栏作者,如若文章内容侵犯您的权益,请及时联系本站删除。
换一批
延伸阅读

9月2日消息,不造车的华为或将催生出更大的独角兽公司,随着阿维塔和赛力斯的入局,华为引望愈发显得引人瞩目。

关键字: 阿维塔 塞力斯 华为

加利福尼亚州圣克拉拉县2024年8月30日 /美通社/ -- 数字化转型技术解决方案公司Trianz今天宣布,该公司与Amazon Web Services (AWS)签订了...

关键字: AWS AN BSP 数字化

伦敦2024年8月29日 /美通社/ -- 英国汽车技术公司SODA.Auto推出其旗舰产品SODA V,这是全球首款涵盖汽车工程师从创意到认证的所有需求的工具,可用于创建软件定义汽车。 SODA V工具的开发耗时1.5...

关键字: 汽车 人工智能 智能驱动 BSP

北京2024年8月28日 /美通社/ -- 越来越多用户希望企业业务能7×24不间断运行,同时企业却面临越来越多业务中断的风险,如企业系统复杂性的增加,频繁的功能更新和发布等。如何确保业务连续性,提升韧性,成...

关键字: 亚马逊 解密 控制平面 BSP

8月30日消息,据媒体报道,腾讯和网易近期正在缩减他们对日本游戏市场的投资。

关键字: 腾讯 编码器 CPU

8月28日消息,今天上午,2024中国国际大数据产业博览会开幕式在贵阳举行,华为董事、质量流程IT总裁陶景文发表了演讲。

关键字: 华为 12nm EDA 半导体

8月28日消息,在2024中国国际大数据产业博览会上,华为常务董事、华为云CEO张平安发表演讲称,数字世界的话语权最终是由生态的繁荣决定的。

关键字: 华为 12nm 手机 卫星通信

要点: 有效应对环境变化,经营业绩稳中有升 落实提质增效举措,毛利润率延续升势 战略布局成效显著,战新业务引领增长 以科技创新为引领,提升企业核心竞争力 坚持高质量发展策略,塑强核心竞争优势...

关键字: 通信 BSP 电信运营商 数字经济

北京2024年8月27日 /美通社/ -- 8月21日,由中央广播电视总台与中国电影电视技术学会联合牵头组建的NVI技术创新联盟在BIRTV2024超高清全产业链发展研讨会上宣布正式成立。 活动现场 NVI技术创新联...

关键字: VI 传输协议 音频 BSP

北京2024年8月27日 /美通社/ -- 在8月23日举办的2024年长三角生态绿色一体化发展示范区联合招商会上,软通动力信息技术(集团)股份有限公司(以下简称"软通动力")与长三角投资(上海)有限...

关键字: BSP 信息技术
关闭
关闭