一. 前言
最近在弄一个桌面小摆件的DIY,在里面弄了一个贪吃蛇的小游戏,在stm32f103平台上实现,通过tft模块进行显示。不加显示部分的话,贪吃蛇游戏与平台无关,可以轻松添加到自己其他平台项目的代码中,也是便于学习,其中蛇数据的存储使用到了链表结构,下面来让我其做一个简单的介绍吧。
C代码可以关注微信公众号 FPGA之旅 回复 stm32贪吃蛇获取(不是工程文件,需要自己根据贪吃蛇的数据进行绘制显示)
链接:
演示视频
后面等整个DIY项目完成后,会开源出整个项目,欢迎关注公众号获取最新动态
二. 游戏整体介绍
先来看看下图,如果蛇移动的速度为1s的话,就每隔1s调用一下这个函数即可(先要初始化一下蛇的长度和食物的位置以及移动方向),非常方便。
JudgeCrossDeal : 通过方向来移动蛇的移动
EatFoodOrNot : 判断是否吃到食物
Eated : 吃到食物更新蛇的长度
GenerateFood: 产生食物
Lcd***** and Draw***: 绘制函数,结和具体的显示器件来学习。
整体过程是 : 先对蛇进行移动,然后判断是否吃到食物,如果吃到了的话,就更新蛇的长度和更新食物。
三. 核心函数介绍
1. 初始化SnakeInit()函数
该函数对蛇链表进行了初始化,链表长度为3,也就是蛇的初试长度为3,然后生成食物,也就是食物的位置,以及移动的方向。其他的一些可用可无。
2. 移动判断JudgeCrossDeal()和Move(uint16 headX , uint16 headY)函数
JudgeCrossDeal()函数主要是对蛇穿墙的判断,如果蛇头要穿墙的话,就设置对应的坐标,不是的话,就蛇头的坐标就对应的加或减一,然后调用Move函数,将上一节蛇身的坐标赋值给下一节蛇身的位置,这样就可以达到蛇移动的目标了。
3. 销毁SnakeDestory()函数
使用链表还要注意一个问题哦,在退出游戏之后,需要对分配的内存进行收回,这一点不要忘记(虽然不销毁的话也没啥,但是在一个项目里面最好还是要的)。
核心函数就介绍这么多喽,需要的可以下载文件学习。
四. 完结
通过两个定时器最终完成贪吃蛇游戏,一个用来检测按键输入,控制蛇的方向,另外一个用来产生1s的时间,移动蛇(我这里使用的TIM3和TIM4)。
公众号:FPGA之旅