当前位置: 首页 > news >正文

嵌入式产品级-超小尺寸游戏机(从0到1 硬件-软件-外壳)

Ultra-small size gaming console。

超小尺寸游戏机-Pico

This embedded product is mainly based on miniaturization, followed by his game functions are also very complete, for all kinds of games can be played, and there will be relevant illustrations in the follow-up of the article.

This product is a very, very small game console, and he has all the functions inherent in the game console.

这款超小尺寸游戏机Pico,是一款结合了小型化设计和强大游戏功能的嵌入式设备。它的体积非常紧凑,适合携带,同时它依然保留了传统游戏机的各种功能。无论是经典的2D横版游戏、复古的街机游戏,还是一些现代的小游戏,Pico都能够顺利运行。

Pico的设计重点之一就是极致的便携性,尽管体积小,但依然能提供丰富的游戏体验。它通常具备类似按键、显示屏和扬声器的基本硬件配置,能够满足各种游戏操作的需求。此外,Pico内置了游戏模拟器和相关软件,使得用户能够体验不同平台上的游戏。

具体来说,这款游戏机可能搭载了流行的嵌入式开发平台,如Raspberry Pi Pico,支持多种编程语言和工具,甚至可以通过自定义代码和硬件扩展来进一步增强其功能。

  • 极致便携性:Pico的尺寸非常小巧,方便携带。无论是放口袋里还是随身携带,都不占太多空间,适合外出时随时随地享受游戏。

  • 强大兼容性:它支持多种游戏模拟器和格式,能够运行各类经典游戏,包括复古街机游戏、掌机游戏等,甚至可以自定义加载新游戏。

  • 高性价比:作为一款小型游戏机,Pico提供的功能远超其体积。你可以以较低的成本享受到多种游戏的娱乐体验,同时它还支持编程开发,适合开发者进行定制化应用。

  • 开源与可定制性:Pico基于流行的嵌入式平台(如Raspberry Pi Pico),具有开源特性,允许用户根据个人需求进行软件和硬件的修改和扩展,能够轻松实现个性化定制。

  • 简单易用:操作界面简洁,用户只需轻松连接显示设备和控制器,就可以迅速开始游戏。无论是初学者还是有经验的玩家都能很快上手。

  • 节能高效:由于体积小,功耗低,Pico非常节能,适合长时间游戏而不需要频繁充电。

  • 丰富的开发资源:由于其基于开放平台,Pico有着丰富的开发资源和社区支持,用户可以轻松找到教程、工具和讨论,快速进行功能扩展。

  • 多功能集成:除了作为游戏机,Pico还可以作为其他嵌入式项目的开发平台,具备了强大的开发潜力和应用灵活性。

下述为原理图以及PCB。

下述为相关游戏的部分案例代码。

import PICOplaygame 
import time 
import random 
import gc from machine 
import freq
freq(125_000_000)
gc.enable() # This line helps make sure we don't run out of memory
# Sensitive game parameters
XVel = 0.05 YVel = 0 Distance = 0 YPos = 0 Gravity = 0.15 MaxFPS = 60 Points = 0 GameRunning = True CactusPos = random.randint(72, 300) CloudPos = random.randint(60, 200) JumpSoundTimer = 0
# Sprite data
PlayerSpr = bytearray([0x04 ^ 0xFF, 0x08 ^ 0xFF, 0xC8 ^ 0xFF, 0xBC ^ 0xFF, 0x1C ^ 0xFF, 0x0E ^ 0xFF, 0x1A ^ 0xFF, 0x2C ^ 0xFF]) PlayerRunFrame1 = bytearray([0xFF, 0xFF, 0xFF, 0xFD, 0xF9, 0xBB, 0xBB, 0xD3, 0xE1, 0xF1, 0xC1, 0xB3, 0x61, 0xD5, 0xF3, 0xFF]) PlayerRunFrame2 = bytearray([0xFF, 0xFF, 0xF7, 0xFB, 0xFB, 0xFB, 0x3B, 0x93, 0xE3, 0x71, 0x03, 0xE7, 0xC3, 0xAB, 0xE7, 0xFF]) CactusSpr1 = bytearray([0x00 ^ 0xFF, 0xFC ^ 0xFF, 0x86 ^ 0xFF, 0x92 ^ 0xFF, 0xC2 ^ 0xFF, 0xFC ^ 0xFF, 0x00 ^ 0xFF, 0x00 ^ 0xFF]) CactusSpr2 = bytearray([0x00 ^ 0xFF, 0x1E ^ 0xFF, 0x10 ^ 0xFF, 0xFE ^ 0xFF, 0xE4 ^ 0xFF, 0x20 ^ 0xFF, 0x78 ^ 0xFF, 0x00 ^ 0xFF]) CloudSpr = bytearray([0x9F, 0x4F, 0x63, 0x59, 0xBD, 0x73, 0x73, 0x65, 0x5C, 0x7E, 0x7E, 0x51, 0x57, 0x4F, 0x1F, 0xBF])
CactusSpr = CactusSpr1
PICOplaygame.display.fill(0) PICOplaygame.display.drawText("Tinysaur", 12, 0, 1) PICOplaygame.display.drawText("  Run", 15, 9, 1) PICOplaygame.display.update()
PICOplaygame.display.setFPS(60)
PICOplaygame.saveData.setName("SaurRun")
while(PICOplaygame.buttonA.pressed() == True or PICOplaygame.buttonB.pressed() == True): if(time.ticks_ms() % 1000 < 500): PICOplaygame.display.drawFilledRectangle(0, 32, 72, 8, 0)PICOplaygame.display.drawText("Press A/B", 9, 32, 1) else: PICOplaygame.display.drawFilledRectangle(0, 32, 72, 8, 1)PICOplaygame.display.drawText("Press A/B", 9, 32, 0) PICOplaygame.display.update()pass while(PICOplaygame.buttonA.pressed() == False and PICOplaygame.buttonB.pressed() == False): if(time.ticks_ms() % 1000 < 500): PICOplaygame.display.drawFilledRectangle(0, 32, 72, 8, 0)PICOplaygame.display.drawText("Press A/B", 9, 32, 1) else: PICOplaygame.display.drawFilledRectangle(0, 32, 72, 8, 1)PICOplaygame.display.drawText("Press A/B", 9, 32, 0) PICOplaygame.display.update()pass while(PICOplaygame.buttonA.pressed() == True or PICOplaygame.buttonB.pressed() == True): if(time.ticks_ms() % 1000 < 500): PICOplaygame.display.drawFilledRectangle(0, 32, 72, 8, 0)PICOplaygame.display.drawText("Press A/B", 9, 32, 1) else: PICOplaygame.display.drawFilledRectangle(0, 32, 72, 8, 1)PICOplaygame.display.drawText("Press A/B", 9, 32, 0) PICOplaygame.display.update()pass
while(GameRunning): t0 = time.ticks_us() # Check the time# Is the player on the ground and trying to jump?if(JumpSoundTimer < 0): JumpSoundTimer = 0 if((PICOplaygame.buttonA.pressed() == True or PICOplaygame.buttonB.pressed() == True) and YPos == 0.0): # Jump!JumpSoundTimer = 200YVel = -2.5# Handle "dynamics"YPos += YVelYVel += GravityDistance += XVelJumpSoundTimer -= 15if(JumpSoundTimer > 0): PICOplaygame.audio.set(500-JumpSoundTimer) else: PICOplaygame.audio.stop()# Accelerate the player just a little bitXVel += 0.000025# Make sure we haven't fallen below the groundWif(YPos > 0): YPos = 0.0YVel = 0.0# Has the player hit a cactus?if(CactusPos < 8 and CactusPos > -8 and YPos > -8): # Stop the game and give a promptGameRunning = FalsePICOplaygame.display.fill(1)PICOplaygame.audio.stop()PICOplaygame.display.drawText("Oh no!", 18, 1, 0)PICOplaygame.display.drawText(str(int(Distance))+"m", 26, 9, 0) high = -1if(PICOplaygame.saveData.hasItem("highscore")): high = int(PICOplaygame.saveData.getItem("highscore"))PICOplaygame.display.drawText("High: " + str(high)+"m", 8, 17, 0) if(Distance > high): PICOplaygame.saveData.setItem("highscore", Distance)PICOplaygame.saveData.save() PICOplaygame.display.drawText("Again?", 19, 25, 0)PICOplaygame.display.drawText("A:N B:Y", 16, 33, 0)PICOplaygame.display.update()PICOplaygame.audio.playBlocking(300, 250)PICOplaygame.audio.play(260, 250)while(PICOplaygame.inputPressed() == False): pass # Wait for the user to give us somethingwhile(GameRunning == False): if(PICOplaygame.buttonB.pressed() == True == 1): # Restart the gameXVel = 0.05YVel = 0Distance = 0YPos = 0Points = 0GameRunning = TrueCactusPos = random.randint(72, 300)CloudPos = random.randint(60, 200)elif(PICOplaygame.buttonA.pressed() == True): # QuitPICOplaygame.reset() # Exit game to main menu# Is the cactus out of view?if(CactusPos < -24): # "spawn" another one (Set its position some distance ahead and change the sprite) Points += 10PICOplaygame.audio.play(440, 300)CactusPos = random.randint(72, 500)if(random.randint(0, 1) == 0): CactusSpr = CactusSpr1 else: CactusSpr = CactusSpr2# Is the cloud out of view?if(CloudPos < -32): # "spawn" another oneCloudPos = random.randint(40, 200)# More dynaaaaaaaaaaaamicsCactusPos -= XVel * 16CloudPos -= XVel * 2# Draw game statePICOplaygame.display.fill(1)PICOplaygame.display.blit(CactusSpr, int(16 + CactusPos), 24, 8, 8, 1, 0, 0) PICOplaygame.display.blit(CloudSpr, int(16 + CloudPos), 8, 16, 8, 1, 0, 0)if(t0 % 250000 < 125000 or YPos != 0.0): # Player is in first frame of run animationPICOplaygame.display.blit(PlayerRunFrame1, 8, int(23 + YPos), 16, 8, 1, 0, 0) else: # Player is in second frame of run animationPICOplaygame.display.blit(PlayerRunFrame2, 8, int(24 + YPos), 16, 8, 1, 0, 0)PICOplaygame.display.drawFilledRectangle(0, 31, PICOplaygame.display.width, 9, 0) # Ground PICOplaygame.display.drawText(str(int(Points)), 0, 0, 0) # Current points PICOplaygame.display.drawText("pts", len(str(int(Points))) * 8, 0, 0) PICOplaygame.display.drawText(str(int(Distance)), 0, 32, 1) # Current distance PICOplaygame.display.drawText("m", len(str(int(Distance))) * 8, 32, 1) PICOplaygame.display.update()# Spin wheels until we've used up one frame's worth of timewhile(time.ticks_us() - t0 < 1000000.0 / MaxFPS): pass 

下述内容就是功能演示了。

相关文章:

嵌入式产品级-超小尺寸游戏机(从0到1 硬件-软件-外壳)

Ultra-small size gaming console。 超小尺寸游戏机-Pico This embedded product is mainly based on miniaturization, followed by his game functions are also very complete, for all kinds of games can be played, and there will be relevant illustrations in the fo…...

计算机毕业设计Python+Django+Vue3微博数据舆情分析平台 微博用户画像系统 微博舆情可视化(源码+ 文档+PPT+讲解)

温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 温馨提示&#xff1a;文末有 CSDN 平台官方提供的学长联系方式的名片&#xff01; 作者简介&#xff1a;Java领…...

前端开发10大框架深度解析

摘要 在现代前端开发中&#xff0c;框架的选择对项目的成功至关重要。本文旨在为开发者提供一份全面的前端框架指南&#xff0c;涵盖 React、Vue.js、Angular、Svelte、Ember.js、Preact、Backbone.js、Next.js、Nuxt.js 和 Gatsby。我们将从 简介、优缺点、适用场景 以及 实际…...

Mybatis 的关联映射(一对一,一对多,多对多)

前言 在前面我们已经了解了&#xff0c;mybatis 的基本用法&#xff0c;动态SQL&#xff0c;学会使用mybatis 来操作数据库。但这些主要操作还是针对 单表实现的。在实际的开发中&#xff0c;对数据库的操作&#xff0c;常常涉及多张表。 因此本篇博客的目标&#xff1a;通过my…...

深度解码!清华大学第六弹《AIGC发展研究3.0版》

在Grok3与GPT-4.5相继发布之际&#xff0c;《AIGC发展研究3.0版》的重磅报告——这份长达200页的行业圣经&#xff0c;不仅预测了2025年AI技术爆发点&#xff0c;更将「天人合一」的东方智慧融入AI伦理建构&#xff0c;堪称数字时代的《道德经》。 文档&#xff1a;清华大学第…...

/dev/console文件详解

/dev/console概览 /dev/console 是 Linux 系统中的一个特殊设备文件&#xff0c;通常用于与系统的控制台进行交互。它的作用和特点如下&#xff1a; 1. 作用 init 进程&#xff08;PID 1&#xff09;和某些系统服务在启动时会使用 /dev/console 进行日志输出&#xff0c;以确…...

ProfibusDP主站转ModbusTCP网关如何进行数据互换

ProfibusDP主站转ModbusTCP网关如何进行数据互换 在现代工业自动化领域&#xff0c;通信协议的多样性和复杂性不断增加。Profibus DP作为一种经典的现场总线标准&#xff0c;广泛应用于工业控制网络中&#xff1b;而Modbus TCP作为基于以太网的通信协议&#xff0c;因其简单易…...

springboot3 WebClient

1 介绍 在 Spring 5 之前&#xff0c;如果我们想要调用其他系统提供的 HTTP 服务&#xff0c;通常可以使用 Spring 提供的 RestTemplate 来访问&#xff0c;不过由于 RestTemplate 是 Spring 3 中引入的同步阻塞式 HTTP 客户端&#xff0c;因此存在一定性能瓶颈。根据 Spring 官…...

牛客周赛 Round 83

A.和猫猫一起起舞&#xff01; 思路&#xff1a;遇到‘U’和‘D’&#xff0c;输出‘R’或者‘L’&#xff1b;遇到‘R’和‘L’&#xff0c;输出‘U’或者‘D’.(这题比较简单) AC代码&#xff1a; void solve() {int n, m, k;char ch;cin >> ch;if (ch U || ch D)…...

硬通货用Deekseek做一个Vue.js组件开发的教程

安装 Node.js 与 Vue CLI‌ npm install -g vue/cli vue create my-vue-project cd my-vue-project npm run serve 通过 Vue CLI 可快速生成项目骨架&#xff0c;默认配置适合新手快速上手 目录结构‌ src/ ├── components/ # 存放组件文件 │ └── …...

Windows权限维持之利用安全描述符隐藏服务后门进行权限维持(八)

我们先打开cs的服务端 然后我们打开客户端 我们点击连接 然后弹出这个界面 然后我们新建一个监听器 然后我们生成一个beacon 然后把这个复制到目标主机 然后我们双击 运行 然后cs这边就上线了 然后我们把进程结束掉 然后我们再把他删除掉 然后我们创建服务 将后门程序注册…...

Ubuntu20.04双系统安装及软件安装(七):Anaconda3

Ubuntu20.04双系统安装及软件安装&#xff08;七&#xff09;&#xff1a;Anaconda3 打开Anaconda官网&#xff0c;在右侧处填写邮箱&#xff08;要真实有效&#xff01;&#xff09;&#xff0c;然后Submit。会出现如图示的Success界面。 进入填写的邮箱&#xff0c;有一封Ana…...

【极光 Orbit•STC8A-8H】02. STC8 单片机工程模板创建

【极光 Orbit•STC8A-8H】02. STC8 单片机工程模板创建 七绝单片机 小小芯片大乾坤&#xff0c; 集成世界在其中。 初学虽感千重难&#xff0c; 实践方知奥妙通。 今天的讲法和过去不同&#xff0c;直接来一个多文件模块化的工程模板创建&#xff0c;万事开头难&#xff0c;…...

Spring Boot WebFlux 中 WebSocket 生命周期解析

Spring Boot WebFlux 中的 WebSocket 提供了一种高效、异步的方式来处理客户端与服务器之间的双向通信。WebSocket 连接的生命周期包括连接建立、消息传输、连接关闭以及资源清理等过程。此外&#xff0c;为了确保 WebSocket 连接的稳定性和可靠性&#xff0c;我们可以加入重试…...

PostgreSQL中的事务隔离

1. 事务隔离的概念 在数据库管理系统中&#xff0c;事务隔离是一项重要的功能&#xff0c;它能确保在并发访问数据库时事务之间能够独立运行&#xff0c;不会相互干扰。数据库系统通常支持不同级别的事务隔离&#xff0c;用来满足不同应用程序之间的需求。 2. 事务隔离的种类…...

基于Rye的Django项目通过Pyinstaller用Github工作流简单打包

前言 Rye的介绍和安装 Ryehttps://rye.astral.sh/Rye 完整使用教程_安装rye-CSDN博客https://blog.csdn.net/zhenndbc/article/details/144544692 正文 项目建立 配置好环境后 新建文件夹 新建文件夹&#xff0c;进入项目 初始化 rye init下载依赖 rye syncpycharm 打…...

ubuntu 20.04 C++ 源码编译 cuda版本 opencv4.5.0

前提条件是安装好了cuda和cudnn 点击下载&#xff1a; opencv_contrib4.5.0 opencv 4.5.0 解压重命名后 进入opencv目录&#xff0c;创建build目录 “CUDA_ARCH_BIN ?” 这里要根据显卡查询一下,我的cuda是11&#xff0c;显卡1650&#xff0c;所以是7.5 查询链接&#xff1a;…...

【VUE】第一期——初使用、基本语法

目录 0 前言 1 准备工作 1.1 创建vue实例 1.2 vue开发者工具 2 插值表达式 2.1 基本用法 3 常用指令 3.1 内容渲染指令 3.1.1 v-text 3.1.2 v-html 3.2 条件渲染指令 3.2.1 v-show 3.2.2 v-if 3.2.3 v-else 和 v-else-if 3.3 事件绑定指令 3.3.1 内联语句 3.3…...

计算光学成像与光学计算概论

计算光学成像所涉及研究的内容非常广泛&#xff0c;虽然计算光学成像的研究内容是发散的&#xff0c;但目的都是一致的&#xff1a;如何让相机记录到客观实物更丰富的信息&#xff0c;延伸并扩展人眼的视觉感知。总的来说&#xff0c;计算光学成像现阶段已经取得了很多令人振奋…...

开启科创服务新篇章:八月瓜科技CRM数字化管理系统成功上线

近日&#xff0c;北京八月瓜科技有限公司&#xff08;以下简称 “八月瓜科技”&#xff09;与纷享销客达成深度战略合作&#xff0c;成功部署并上线CRM数字化管理系统。此次合作是八月瓜科技在数字化转型进程中的重要里程碑&#xff0c;标志着其在科技创新服务领域的数字化变革…...

接口测试中缓存处理策略

在接口测试中&#xff0c;缓存处理策略是一个关键环节&#xff0c;直接影响测试结果的准确性和可靠性。合理的缓存处理策略能够确保测试环境的一致性&#xff0c;避免因缓存数据导致的测试偏差。以下是接口测试中常见的缓存处理策略及其详细说明&#xff1a; 一、缓存处理的核…...

Zustand 状态管理库:极简而强大的解决方案

Zustand 是一个轻量级、快速和可扩展的状态管理库&#xff0c;特别适合 React 应用。它以简洁的 API 和高效的性能解决了 Redux 等状态管理方案中的繁琐问题。 核心优势对比 基本使用指南 1. 创建 Store // store.js import create from zustandconst useStore create((set)…...

以下是对华为 HarmonyOS NETX 5属性动画(ArkTS)文档的结构化整理,通过层级标题、表格和代码块提升可读性:

一、属性动画概述NETX 作用&#xff1a;实现组件通用属性的渐变过渡效果&#xff0c;提升用户体验。支持属性&#xff1a;width、height、backgroundColor、opacity、scale、rotate、translate等。注意事项&#xff1a; 布局类属性&#xff08;如宽高&#xff09;变化时&#…...

FastAPI 教程:从入门到实践

FastAPI 是一个现代、快速&#xff08;高性能&#xff09;的 Web 框架&#xff0c;用于构建 API&#xff0c;支持 Python 3.6。它基于标准 Python 类型提示&#xff0c;易于学习且功能强大。以下是一个完整的 FastAPI 入门教程&#xff0c;涵盖从环境搭建到创建并运行一个简单的…...

蓝桥杯 2024 15届国赛 A组 儿童节快乐

P10576 [蓝桥杯 2024 国 A] 儿童节快乐 题目描述 五彩斑斓的气球在蓝天下悠然飘荡&#xff0c;轻快的音乐在耳边持续回荡&#xff0c;小朋友们手牵着手一同畅快欢笑。在这样一片安乐祥和的氛围下&#xff0c;六一来了。 今天是六一儿童节&#xff0c;小蓝老师为了让大家在节…...

什么是库存周转?如何用进销存系统提高库存周转率?

你可能听说过这样一句话&#xff1a; “利润不是赚出来的&#xff0c;是管出来的。” 尤其是在制造业、批发零售、电商这类“货堆成山”的行业&#xff0c;很多企业看着销售不错&#xff0c;账上却没钱、利润也不见了&#xff0c;一翻库存才发现&#xff1a; 一堆卖不动的旧货…...

Nuxt.js 中的路由配置详解

Nuxt.js 通过其内置的路由系统简化了应用的路由配置&#xff0c;使得开发者可以轻松地管理页面导航和 URL 结构。路由配置主要涉及页面组件的组织、动态路由的设置以及路由元信息的配置。 自动路由生成 Nuxt.js 会根据 pages 目录下的文件结构自动生成路由配置。每个文件都会对…...

零基础在实践中学习网络安全-皮卡丘靶场(第九期-Unsafe Fileupload模块)(yakit方式)

本期内容并不是很难&#xff0c;相信大家会学的很愉快&#xff0c;当然对于有后端基础的朋友来说&#xff0c;本期内容更加容易了解&#xff0c;当然没有基础的也别担心&#xff0c;本期内容会详细解释有关内容 本期用到的软件&#xff1a;yakit&#xff08;因为经过之前好多期…...

Pinocchio 库详解及其在足式机器人上的应用

Pinocchio 库详解及其在足式机器人上的应用 Pinocchio (Pinocchio is not only a nose) 是一个开源的 C 库&#xff0c;专门用于快速计算机器人模型的正向运动学、逆向运动学、雅可比矩阵、动力学和动力学导数。它主要关注效率和准确性&#xff0c;并提供了一个通用的框架&…...

springboot整合VUE之在线教育管理系统简介

可以学习到的技能 学会常用技术栈的使用 独立开发项目 学会前端的开发流程 学会后端的开发流程 学会数据库的设计 学会前后端接口调用方式 学会多模块之间的关联 学会数据的处理 适用人群 在校学生&#xff0c;小白用户&#xff0c;想学习知识的 有点基础&#xff0c;想要通过项…...