当前位置:首页 > 工业控制 > 电路设计项目集锦
[导读]这是一个运行在Arduino平台上的简单的吃豆人游戏,使用OLED显示屏来显示游戏界面。游戏的目标是控制吃豆人在迷宫中移动,吃掉所有的豆子,同时避免撞到墙壁。

OLED显示屏上导航吃豆人,吃豆子并避开迷宫中的墙壁。

这是一个运行在Arduino平台上的简单的吃豆人游戏,使用OLED显示屏来显示游戏界面。游戏的目标是控制吃豆人在迷宫中移动,吃掉所有的豆子,同时避免撞到墙壁。

初始化和设置:

•定义OLED显示屏的宽度和高度,以及用于重置OLED的宏OLED_RESET。

•创建Adafruit_SSD1306对象显示器来控制OLED显示器。

•定义了吃豆人PACMAN_SIZE的大小,以及吃豆人和豆子、pacmanX、pacmanY、beanX、beanY的初始位置。

•定义一个二维数组网格来表示迷宫的布局,其中1代表墙壁,0代表可以吃豆子的路径。

•初始化吃豆人方向和分数的方向。

设置()函数:

•初始化串行通信。

•启动OLED显示屏,显示游戏标题,然后清空显示屏。

•设置用于控制吃豆人移动的插脚输入上拉模式。

resetBean()函数:

•随机生成bean的位置,确保它不是在墙上生成的。

readButton()函数:

•读取按钮状态并返回吃豆人的新方向。

循环()函数:

•这是Arduino的主循环,其中游戏逻辑被持续执行。

•读取按钮输入并更新吃豆人的方向。

•根据新方向更新吃豆人的位置,但前提是新位置不是墙。

•如果吃豆人遇到豆子,就会增加分数并重新生成豆子的位置。

•清除OLED显示屏并重新绘制迷宫、吃豆人和豆子。

•显示当前分数。

•在每个循环之后都有一个短暂的延迟来控制游戏的速度。

图逻辑:

•使用display.drawRect()绘制墙壁。

•使用display.fillRect()绘制吃豆人。

•使用display.fillCircle()绘制bean。

•显示比分。

游戏循环:

•游戏将继续循环,直到用户停止程序或Arduino设备断电。

图表

吃豆人游戏

这是一个运行在Arduino平台上的简单的吃豆人游戏,使用OLED显示屏来显示游戏界面。游戏的目标是控制吃豆人在迷宫中移动,吃掉所有的豆子,同时避免撞到墙壁。

代码

Arduino吃豆人游戏:吃豆子,避开墙壁

这是一个运行在Arduino平台上的简单的吃豆人游戏,使用OLED显示屏来显示游戏界面。游戏的目标是控制吃豆人在迷宫中移动,吃掉所有的豆子,同时避免撞到墙壁。

#include

#include

#include

#include

#define SCREEN_WIDTH 128

#define SCREEN_HEIGHT 64

#define OLED_RESET -1

Adafruit_SSD1306 display(SCREEN_WIDTH, SCREEN_HEIGHT, &Wire, OLED_RESET);

#define PACMAN_SIZE 6

int pacmanX = 2;

int pacmanY = 2;

int beanX;

int beanY;

const int gridWidth = 16;

const int gridHeight = 8;

const int grid[gridHeight][gridWidth] = {

{1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1},

{1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1},

{1, 0, 1, 1, 0, 1, 1, 1, 1, 1, 0, 1, 1, 1, 0, 1},

{1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1},

{1, 0, 1, 1, 1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 0, 1},

{1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1, 0, 1},

{1, 0, 1, 1, 1, 1, 0, 1, 1, 0, 1, 1, 1, 1, 0, 1},

{1, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 0, 1}

};

int direction = 0; // 0: Stay, 1: Up, 2: Down, 3: Left, 4: Right

int score = 0;

void setup() {

Serial.begin(9600);

if (!display.begin(SSD1306_SWITCHCAPVCC, 0x3C)) {

Serial.println(F("SSD1306 allocation failed"));

for (;;);

}

display.clearDisplay();

display.setTextSize(1);

display.setTextColor(SSD1306_WHITE);

display.setCursor(0, 0);

display.println(F("Pacman Game"));

display.display();

delay(2000);

display.clearDisplay();

pinMode(2, INPUT_PULLUP); // Up

pinMode(3, INPUT_PULLUP); // Down

pinMode(4, INPUT_PULLUP); // Left

pinMode(5, INPUT_PULLUP); // Right

resetBean();

}

void resetBean() {

do {

beanX = random(1, gridWidth - 1);

beanY = random(1, gridHeight - 1);

} while (grid[beanY][beanX] == 1); // 确保豆子不会生成在墙上

}

int readButton() {

if (digitalRead(2) == LOW) return 1; // Up

if (digitalRead(3) == LOW) return 2; // Down

if (digitalRead(4) == LOW) return 3; // Left

if (digitalRead(5) == LOW) return 4; // Right

return 0; // Stay

}

void loop() {

int newDirection = readButton();

if (newDirection != 0) {

direction = newDirection;

int newX = pacmanX;

int newY = pacmanY;

switch (direction) {

case 1: newY--; break; // Up

case 2: newY++; break; // Down

case 3: newX--; break; // Left

case 4: newX++; break; // Right

}

if (grid[newY][newX] == 0) {

pacmanX = newX;

pacmanY = newY;

}

if (pacmanX == beanX && pacmanY == beanY) {

score += 10;

resetBean();

}

}

display.clearDisplay();

for (int i = 0; i < gridHeight; i++) {

for (int j = 0; j < gridWidth; j++) {

if (grid[i][j] == 1) {

int drawX = j * PACMAN_SIZE;

int drawY = (gridHeight - 1 - i) * PACMAN_SIZE; // 反转Y坐标

display.drawRect(drawX, drawY, PACMAN_SIZE, PACMAN_SIZE, SSD1306_WHITE);

}

}

}

// 绘制吃豆人

int pacmanDrawX = pacmanX * PACMAN_SIZE;

int pacmanDrawY = (gridHeight - 1 - pacmanY) * PACMAN_SIZE; // 反转Y坐标

display.fillRect(pacmanDrawX, pacmanDrawY, PACMAN_SIZE, PACMAN_SIZE, SSD1306_WHITE);

// 绘制豆子

int beanDrawX = beanX * PACMAN_SIZE + PACMAN_SIZE / 2;

int beanDrawY = (gridHeight - 1 - beanY) * PACMAN_SIZE + PACMAN_SIZE / 2; // 反转Y坐标

display.fillCircle(beanDrawX, beanDrawY, PACMAN_SIZE / 2, SSD1306_WHITE);

display.setCursor(0, SCREEN_HEIGHT - 8);

display.print(F("Score: "));

display.print(score);

display.display();

delay(100);

}

本文编译自hackster.io

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

LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: 驱动电源

在工业自动化蓬勃发展的当下,工业电机作为核心动力设备,其驱动电源的性能直接关系到整个系统的稳定性和可靠性。其中,反电动势抑制与过流保护是驱动电源设计中至关重要的两个环节,集成化方案的设计成为提升电机驱动性能的关键。

关键字: 工业电机 驱动电源

LED 驱动电源作为 LED 照明系统的 “心脏”,其稳定性直接决定了整个照明设备的使用寿命。然而,在实际应用中,LED 驱动电源易损坏的问题却十分常见,不仅增加了维护成本,还影响了用户体验。要解决这一问题,需从设计、生...

关键字: 驱动电源 照明系统 散热

根据LED驱动电源的公式,电感内电流波动大小和电感值成反比,输出纹波和输出电容值成反比。所以加大电感值和输出电容值可以减小纹波。

关键字: LED 设计 驱动电源

电动汽车(EV)作为新能源汽车的重要代表,正逐渐成为全球汽车产业的重要发展方向。电动汽车的核心技术之一是电机驱动控制系统,而绝缘栅双极型晶体管(IGBT)作为电机驱动系统中的关键元件,其性能直接影响到电动汽车的动力性能和...

关键字: 电动汽车 新能源 驱动电源

在现代城市建设中,街道及停车场照明作为基础设施的重要组成部分,其质量和效率直接关系到城市的公共安全、居民生活质量和能源利用效率。随着科技的进步,高亮度白光发光二极管(LED)因其独特的优势逐渐取代传统光源,成为大功率区域...

关键字: 发光二极管 驱动电源 LED

LED通用照明设计工程师会遇到许多挑战,如功率密度、功率因数校正(PFC)、空间受限和可靠性等。

关键字: LED 驱动电源 功率因数校正

在LED照明技术日益普及的今天,LED驱动电源的电磁干扰(EMI)问题成为了一个不可忽视的挑战。电磁干扰不仅会影响LED灯具的正常工作,还可能对周围电子设备造成不利影响,甚至引发系统故障。因此,采取有效的硬件措施来解决L...

关键字: LED照明技术 电磁干扰 驱动电源

开关电源具有效率高的特性,而且开关电源的变压器体积比串联稳压型电源的要小得多,电源电路比较整洁,整机重量也有所下降,所以,现在的LED驱动电源

关键字: LED 驱动电源 开关电源

LED驱动电源是把电源供应转换为特定的电压电流以驱动LED发光的电压转换器,通常情况下:LED驱动电源的输入包括高压工频交流(即市电)、低压直流、高压直流、低压高频交流(如电子变压器的输出)等。

关键字: LED 隧道灯 驱动电源
关闭