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

Godot(2D)主要架构:交互解释与游戏实际实现3:全局存档系统

前言本篇文章是 针对Godot(2D)游戏架构的研究 的主要架构中对全局存档系统的解释文章将会对Godot中通用物品栏的实现方式进行详细的讲解本文章的存档系统使用JSON进行存储并且文章中所使用的Godot中的函数以及使用的数据交互方式(单例)均在主要文章中的细化文章中解释过主要文章地址针对Godot(2D)游戏架构的研究-CSDN博客1. 实现概述1. 全局存档系统存档系统的本质就是存储内存数据游戏运行时所有数据玩家属性、物品、位置、状态都在内存里存档 把内存里的临时数据写到硬盘变成持久文件读档 把硬盘文件读回来还原回内存数据全局存档系统是将存档系统作为游戏运行时始终存在的单例存档系统存档系统主要的作用是存储玩家在游戏过程中玩家本身的属性以及部分环境的属性使玩家再次进入游戏时能够继续未完成的游戏。而作为全局存在的意义是能够让存档在切换场景的时候仍然可以发挥作用同时可以统一给不同场景与存档有关的脚本发送一致的存档信息防止出现存档乱套2. JSON文件JSON同时代指JSON文件与JSON格式。JSON本质是一种数据格式,.JSON作为后缀的文件是纯文本文件JSON是一种轻量级的数据交换格式JSON格式类似字典因为JSON格式的数据结构清晰使用简单而且方便人类直接读取所以作为本全局存档系统使用的演示存档文件。需要注意的是.JSON等纯文本文件类型实现的存档在存档数据量大的情况下读取较慢JSON编写的存档示例如下:{ Player: { allCoolTime_Magn: 1.0, attackDamageMag: 1.0, defense_Mag: 1.0, dexterity_Mag: 1.0, experience: 0.0, global_position: Vector2(0, 100), intelligence_Mag: 1.0, level: 1, magic_Attack_Mag: 1.0, magic_Point: 200.0, magic_defense_Mag: 1.0, now_Arm_select: 1, real_hp: 200.0, strength_Mag: 1.0, vitality_Mag: 1.0 } }2. 存档实现这里我将会使用具体操作来演示全局存档的实现下面所有传进去的存档字典为其中Player.instance为玩家单例var player_dict: Dictionary { Player: { global_position: var_to_str(Player.instance.global_position), level: Player.instance.level, experience: Player.instance.experience, real_hp: Player.instance.real_hp, now_Arm_select: Player.instance.now_Arm_select, magic_Point: Player.instance.magic_Point, attackDamageMag: Player.instance.attackDamageMag, defense_Mag: Player.instance.defense_Mag, magic_Attack_Mag: Player.instance.magic_Attack_Mag, magic_defense_Mag: Player.instance.magic_defense_Mag, dexterity_Mag: Player.instance.dexterity_Mag, strength_Mag: Player.instance.strength_Mag, intelligence_Mag: Player.instance.intelligence_Mag, vitality_Mag: Player.instance.vitality_Mag, allCoolTime_Magn: Player.instance.allCoolTime_Mag } }构建全局存档单例1. 构建单例建立全局存档系统首先构建全局单例这里我构建手动全局单例使用左下角新建脚本本全局存档系统不需要使用自己单独的场景然后构建全局存档系统单例# 这里脚本继承的是Node也是作为节点的形式加入场景 extends Node # 这里定义全局存档系统的类名用于访问 class_name SaveDataSystem # 这个是保存系统单例 static var instance: SaveDataSystem ## 在节点被创建的时候执行 ## 注意这里是一创建节点就执行 ## Godot中ready()是节点全部加载完后执行 func _init() - void: _instance_initialize() func _instance_initialize() - void: #创建单例 if instance null: instance self #销毁多余单例 else: queue_free()再通过编辑器设置加入全局自动加载进入游戏的时候存档系统就能被自动加载(在主文章中已解释)2. 建立存档函数与JSON操作函数首先在代码中加入存档地址与存档信号extends Node class_name SaveDataSystem static var instance: SaveDataSystem ## 新加入的三个存档地址 ## 使用user://是为了防止执行删除存档时误删游戏源文件 ## Godot中的user://的地址在Windows中为 ## C:\Users\你的用户名\AppData\Roaming\Godot\app_userdata\项目名字 static var savePathFirst: String user://Save01.json static var savePathSecond: String user://Save02.json static var savePathThird: String user://Save03.json #这里是存档改变的时候需要向外发射的信号 signal saveChange() func _init() - void: _instance_initialize() func _instance_initialize() - void: if instance null: instance self else: queue_free()1. 存入函数存入函数提供了一个存储存档信息并保存为JSON存档的功能提供存储地址得到当前存档信息存入函数的操作为:1. 获得游戏需要存储的数据为一个字典类型。2. 将字典格式转化为JSON格式3. 将转换完的数据保存为JSON文件具体实现如下(这里的函数是在上面单例代码的下面直接复制放入即可下文同理)(注意Godot中Vector2作为传入存档的变量需要使用var_to_str()转变后存入不然存入的Vector2变量会变成数组)# 保存存档数据(使用json保存) func set_information(filePath: String) - void: # 这里是存档信息一个字典类型的数据 var player_dict: Dictionary ## 将字典格式的数据转化为JSON格式的数据 ## 其中 JSON.stringify() 是Godot中自带的转化函数 ## JSON.stringify(player_dict, ) 中第一个参数是要转换的数据 ## 第二个是转化后的JSON格式中每一行开头的字符用 是方便人眼读取 var json_str JSON.stringify(player_dict, ) #打开一个文件没有就自动创建一个 var file FileAccess.open(filePath, FileAccess.WRITE) #文件如果存在 if file: #存入JSON格式的数据 file.store_string(json_str) file.close() #发射存档改变的信号 SaveDataSystem.instance.saveChange.emit()这里运行一次该函数后可以在对应位置得到保存的JSON文件:内容为:这样就实现了存档的保存2. 读入函数读入函数就是将刚刚的存档读入并保存为字典方便后面使用函数更改游戏数据读入函数的操作流程为1. 打开给定地址的文档2. 读入文档并转化为字典3. 传值为字典类型以下为演示示例:#获得存档信息(字典返回值) func get_information(filePath: String) - Dictionary: #如果文件不存在就直接返回空字典 if !FileAccess.file_exists(filePath): return {} #打开文件 var file FileAccess.open(filePath, FileAccess.READ) #将文件内的数据以字符串的形式读入注意不是直接读入字典 var tempText file.get_as_text() #关闭文件 file.close() var json JSON.new() ##这里parse()函数负责解析String解析完后的数据在json中 ##这里解析完后, json.data 就是字典 json.parse(tempText) SaveDataSystem.instance.saveChange.emit() #返回解析后得到的字典 return json.data as Dictionary这里返回我们先前存进去的字典。3. 使用函数使用函数将得到的字典作为游戏存档传回游戏需要得到读入函数传来的字典然后根据字典依次更改游戏数值比如玩家存档等级血条。这里演示的代码为单纯的传值操作:#传入字典(就是刚刚读入函数返回的字典) func UseSave(saveDict: Dictionary, filePath: String) - void: #判断字典是否为空 if (saveDict.is_empty()): set_information(filePath) return var saveDic: Dictionary saveDict.get(Player, {}) #注意Godot中Vector2变量作为存进去的变量读取后需要使用str_to_var转回Vector2类型 Player.instance.global_position str_to_var(saveDic.get(global_position, Vector2(0, 0))) Player.instance.level saveDic.get(level, 1) Player.instance.experience saveDic.get(experience, 0) Player.instance.real_hp saveDic.get(real_hp, Player.instance.max_hp) Player.instance.now_Arm_select saveDic.get(now_Arm_select, 0) Player.instance.magic_Point saveDic.get(magic_Point, Player.instance.max_Magic_Point) Player.instance.attackDamageMag saveDic.get(attackDamageMag, 1) Player.instance.defense_Mag saveDic.get(defense_Mag, 1) Player.instance.magic_Attack_Mag saveDic.get(magic_Attack_Mag, 1) Player.instance.magic_defense_Mag saveDic.get(magic_defense_Mag, 1) Player.instance.dexterity_Mag saveDic.get(dexterity_Mag, 1) Player.instance.strength_Mag saveDic.get(strength_Mag, 1) Player.instance.intelligence_Mag saveDic.get(intelligence_Mag, 1) Player.instance.vitality_Mag saveDic.get(vitality_Mag, 1) Player.instance.allCoolTime_Mag saveDic.get(allCoolTime_Mag, 1)3. 补充以上三个函数便提供了一个最基础的存档功能而且作为全局存档系统可以统一提供开放的API方便需要使用存档系统的地方调用同时可以使用其中定义的改变信号通知与存档有关的系统改变获得的存档状态这样做的原因是存档系统不建议始终运行在每一帧上为了优化建议改变一次存档全局与存档有关的位置也只发生一次改变而不是全局持续检测3. 结束语与返回本篇文章是 针对Godot(2D)游戏架构的研究_CSDN博客 的第三篇针对主架构实现的文章主要解释了全局存档系统的实现方式这里返回主要架构针对Godot(2D)游戏架构的研究_CSDN博客

相关文章:

Godot(2D)主要架构:交互解释与游戏实际实现3:全局存档系统

前言:本篇文章是 针对Godot(2D)游戏架构的研究 的主要架构中对全局存档系统的解释文章,将会对Godot中通用物品栏的实现方式进行详细的讲解 本文章的存档系统使用JSON进行存储,并且文章中所使用的Godot中的函数,以及使用的数据交互…...

从仿真到上板:手把手教你用自定义控制器验证FPGA DDR3设计(附Vivado工程)

从仿真到上板:FPGA DDR3设计全流程实战指南 在FPGA开发中,DDR3存储器的集成与调试一直是工程师面临的关键挑战之一。许多开发者能够顺利完成仿真验证,却在将设计部署到实际硬件时遇到各种棘手问题。本文将深入探讨从仿真环境平滑过渡到硬件实…...

你的高速串行链路测试做对了吗?深入聊聊PRBS码型在PCIe/USB测试中的实战选型与常见误区

高速串行链路测试中的PRBS码型实战指南:从PCIe到USB的深度解析 在实验室里盯着示波器上跳动的眼图,你是否曾疑惑过为什么PCIe 5.0标准推荐使用PRBS31而不是更简单的PRBS7?当USB4的误码率测试结果出现异常时,是否考虑过可能是PRBS种…...

现在不优化Swoole-LLM长连接,下季度账单将暴涨210%?3个实时告警阈值+1套动态缩容机制

更多请点击: https://intelliparadigm.com 第一章:Swoole-LLM长连接成本失控的严峻现实 当 Swoole 与大语言模型(LLM)服务深度耦合,长连接不再只是性能优化手段,而成为资源吞噬黑洞。每个 WebSocket 连接在…...

MCP-SuperAssistant:AI插件开发调试与运维一体化工具链实践

1. 项目概述:一个面向MCP生态的超级助手最近在折腾AI应用开发,特别是围绕Model Context Protocol(MCP)生态的工具链时,发现了一个挺有意思的项目:srbhptl39/MCP-SuperAssistant。乍一看这个仓库名&#xff…...

如何用WinUtil一键优化Windows系统:终极配置指南

如何用WinUtil一键优化Windows系统:终极配置指南 【免费下载链接】winutil Chris Titus Techs Windows Utility - Install Programs, Tweaks, Fixes, and Updates 项目地址: https://gitcode.com/GitHub_Trending/wi/winutil 还在为Windows系统管理而烦恼吗&…...

ComfyUI-Impact-Pack V8终极指南:解锁AI图像增强的专业级工具包

ComfyUI-Impact-Pack V8终极指南:解锁AI图像增强的专业级工具包 【免费下载链接】ComfyUI-Impact-Pack Custom nodes pack for ComfyUI This custom node helps to conveniently enhance images through Detector, Detailer, Upscaler, Pipe, and more. 项目地址:…...

快速上手使用 curl 命令直连 Taotoken 进行大模型对话测试

快速上手使用 curl 命令直连 Taotoken 进行大模型对话测试 1. 准备工作 在开始之前,请确保您已具备以下条件: 有效的 Taotoken API Key(可在控制台创建)目标模型 ID(可在模型广场查看)支持 curl 命令的终…...

AI编程智能体框架解析:从感知-思考-行动循环到实战部署

1. 项目概述:一个面向AI辅助编程的智能体框架最近在GitHub上闲逛,发现了一个挺有意思的项目,叫aihoc-copaw-agent。光看这个名字,可能有点摸不着头脑,但如果你对AI编程助手、自动化工作流或者智能体(Agent&…...

Laravel 12+ AI模块成本失控诊断工具包(含自动识别11类高危调用链的artisan命令)

更多请点击: https://intelliparadigm.com 第一章:Laravel 12 AI集成成本失控的根源与认知重构 当 Laravel 12 引入原生异步任务调度、内置模型级向量嵌入支持(via Illuminate\AI)及 php-v8js 可选绑定后,开发者常误…...

Vue3项目实战:用西瓜播放器搞定直播流(FLV/HLS)与点播(MP4)的完整封装方案

Vue3视频播放器深度封装:基于西瓜播放器的直播与点播全场景解决方案 在当今的Web应用中,视频播放功能已成为教育、娱乐、监控等领域的标配需求。不同于简单的播放器集成,真实业务场景往往需要同时处理直播流(如FLV、HLS&#xff0…...

用 TestSprite 给 AgentHansa 做一次后端测试

TestSprite 创建了名为 agenthansa 的测试任务,并在 Web Tests 中生成了一组 Backend 用例。列表页显示 9 条可见用例,其中 4 条通过、5 条失败,creation 状态仍为 In Progress。这个结果本身比单一结论更有参考价值:它能把基础功…...

手把手调试:用逻辑分析仪抓取并解析MIPI CSI-2 RAW8图像数据包(附实战波形分析)

实战指南:用逻辑分析仪捕获与解码MIPI CSI-2 RAW8图像数据的完整流程 调试摄像头模组时,最令人头疼的莫过于物理层信号异常却无法定位问题根源。上周在调试一款8MP车载摄像头时,我花了整整三天时间才揪出那个诡异的LSB/MSB顺序错位问题——这…...

QKeyMapper终极指南:Windows平台开源按键映射工具的完整技术解析

QKeyMapper终极指南:Windows平台开源按键映射工具的完整技术解析 【免费下载链接】QKeyMapper [按键映射工具] QKeyMapper,Qt开发Win10&Win11可用,不修改注册表、不需重新启动系统,可立即生效和停止。支持游戏手柄映射到键鼠&…...

Java程序员72小时Python实战手册

Java写了几年的人转Python,根本不需要从头学。核心语法一张表就能覆盖,然后直接案例练手。这篇给你一张对照表,再加一个实战:把一段Java的HttpClient调用,改成Python异步流式请求模块,直接对接大模型API。后…...

终极指南:Cursor Pro破解工具完整方案,5步实现AI编程助手永久免费使用

终极指南:Cursor Pro破解工具完整方案,5步实现AI编程助手永久免费使用 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功…...

对比直接使用厂商API通过Taotoken调用在延迟与稳定性上的主观感受

通过 Taotoken 调用大模型 API 的延迟与稳定性体验观察 1. 背景与使用场景 在多个大模型厂商 API 之间切换时,开发者常面临接口差异、密钥管理和计费分散等问题。我们团队在过去三个月里,将原本直接调用厂商 API 的工作流逐步迁移到 Taotoken 平台&…...

ChatGPT-Next-Web:一键部署你的跨平台AI助手,支持Claude、GPT4和Gemini Pro

ChatGPT-Next-Web:一键部署你的跨平台AI助手,支持Claude、GPT4和Gemini Pro 【免费下载链接】ChatGPT-Next-Web ✨ Light and Fast AI Assistant. Support: Web | iOS | MacOS | Android | Linux | Windows 项目地址: https://gitcode.com/GitHub_Tren…...

Ultimaker Cura:从切片小白到3D打印高手的5步进阶指南

Ultimaker Cura:从切片小白到3D打印高手的5步进阶指南 【免费下载链接】Cura 3D printer / slicing GUI built on top of the Uranium framework 项目地址: https://gitcode.com/gh_mirrors/cu/Cura 你是否曾面对复杂的3D打印参数感到无从下手?或…...

别再让YOLOv7在人群里‘抓瞎’:用CrowdHuman数据集搞定头部、全身、可见身体检测(附完整训练权重)

突破拥挤场景检测瓶颈:YOLOv7与CrowdHuman数据集的深度适配实战 拥挤人群中的目标检测一直是计算机视觉领域的棘手难题。当你在火车站、演唱会现场或是校园食堂尝试用通用目标检测模型统计人流量时,那些重叠交错的身体、部分遮挡的面孔,总能让…...

手把手教你用Python+OpenCV模拟‘找色’自瞄原理(仅供学习反作弊)

PythonOpenCV实战:屏幕颜色识别与自动化原理剖析 在游戏开发和反作弊技术领域,理解自动化工具的工作原理至关重要。本文将带领读者使用Python和OpenCV构建一个屏幕颜色识别系统,通过技术实验的方式揭示基础自动化原理。这个项目完全基于合法、…...

Unity游戏上架Google Play必看:AAB+PAD资源加载性能实测与内存优化方案

Unity游戏上架Google Play必看:AABPAD资源加载性能实测与内存优化方案 在移动游戏开发领域,资源加载效率直接影响着玩家的第一印象和留存率。当Unity开发者将游戏发布到Google Play商店时,采用AAB(Android App Bundle)…...

别再死记公式了!用PyTorch手写SENet和CBAM,5分钟搞懂通道与空间注意力

从零实现SENet与CBAM:用PyTorch代码拆解注意力机制的本质 在计算机视觉领域,注意力机制已经成为提升模型性能的关键组件。但很多初学者在理解通道注意力和空间注意力时,常常陷入公式推导的泥潭而忽略了其工程实现的本质。本文将带你用PyTorc…...

从零构建MCP 2026集成中枢:用1个OpenAPI 3.1 Schema驱动6大系统联动,附可运行Terraform IaC模板

更多请点击: https://intelliparadigm.com 第一章:MCP 2026集成中枢的核心定位与架构范式 MCP 2026集成中枢是面向多模态协同处理(Multi-Modal Coordination Platform)的新一代服务编排基础设施,其核心定位在于统一抽…...

Node.js fs模块实战:从回调地狱到Promise/Stream,手把手教你处理大文件读写

Node.js fs模块实战:从回调地狱到Promise/Stream,手把手教你处理大文件读写 在Node.js开发中,文件操作是每个开发者都无法绕开的课题。无论是处理用户上传的图片、解析日志文件,还是构建静态资源服务器,fs模块都是我们…...

使用 Taotoken 后 API 调用延迟与账单清晰度实际体验分享

使用 Taotoken 后 API 调用延迟与账单清晰度实际体验分享 1. 接入 Taotoken 的初始体验 作为长期使用多个大模型 API 的开发者,接入 Taotoken 的过程相当顺畅。通过平台提供的 OpenAI 兼容接口,我只需将原有代码中的 base_url 替换为 https://taotoken…...

别再被HDF文件搞懵了!手把手教你用MRT批量处理MODIS NDVI数据(附避坑指南)

从HDF到NDVI地图:MRT工具链实战全解析与避坑手册 当你第一次拿到MODIS的HDF文件时,那种面对未知数据格式的茫然感我深有体会。作为一名长期处理遥感数据的地学工作者,我至今记得初次接触MOD13A3数据时的手足无措——几十个HDF文件躺在文件夹里…...

Taotoken 提供的稳定性与低延迟在实时对话应用中的实际体感

Taotoken 提供的稳定性与低延迟在实时对话应用中的实际体感 1. 实时对话场景的技术需求 开发实时 AI 对话应用时,服务稳定性和响应速度直接影响用户体验。这类应用通常需要高频调用 API,且用户期望获得接近人类对话的流畅交互。延迟超过 1 秒的响应会显著…...

告别环境配置烦恼:用VSCode Remote SSH + DevEco Device Tool远程开发鸿蒙Hi3861(保姆级避坑指南)

远程开发新范式:VSCodeSSH高效构建鸿蒙Hi3861应用全流程 在Windows系统下进行嵌入式开发,尤其是涉及交叉编译和工具链管理的场景,传统方案往往需要在虚拟机、双系统或复杂的本地环境配置中反复切换。这种割裂的工作流不仅降低效率&#xff0…...

如何快速配置Mos:面向Mac外设用户的完整指南

如何快速配置Mos:面向Mac外设用户的完整指南 【免费下载链接】Mos 一个用于在 macOS 上平滑你的鼠标滚动效果或单独设置滚动方向的小工具, 让你的滚轮爽如触控板 | A lightweight tool used to smooth scrolling and set scroll direction independently for your m…...