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

鸿蒙游戏 Store 设计(AI + 多端)

子玥酱掘金 / 知乎 / CSDN / 简书 同名大家好我是子玥酱一名长期深耕在一线的前端程序媛 ‍。曾就职于多家知名互联网大厂目前在某国企负责前端软件研发相关工作主要聚焦于业务型系统的工程化建设与长期维护。我持续输出和沉淀前端领域的实战经验日常关注并分享的技术方向包括前端工程化、小程序、React / RN、Flutter、跨端方案在复杂业务落地、组件抽象、性能优化以及多端协作方面积累了大量真实项目经验。技术方向前端 / 跨端 / 小程序 / 移动端工程化内容平台掘金、知乎、CSDN、简书创作特点实战导向、源码拆解、少空谈多落地文章状态长期稳定更新大量原创输出我的内容主要围绕前端技术实战、真实业务踩坑总结、框架与方案选型思考、行业趋势解读展开。文章不会停留在“API 怎么用”而是更关注为什么这么设计、在什么场景下容易踩坑、真实项目中如何取舍希望能帮你在实际工作中少走弯路。子玥酱 · 前端成长记录官 ✨ 如果你正在做前端或准备长期走前端这条路 关注我第一时间获取前端行业趋势与实践总结 可领取11 类前端进阶学习资源工程化 / 框架 / 跨端 / 面试 / 架构 一起把技术学“明白”也用“到位”持续写作持续进阶。愿我们都能在代码和生活里走得更稳一点 文章目录引言一、先说结论二、最小 Store先从简单开始错误写法正确基础写法三、第一步升级模块化 Store模块化结构对应 Store 更新四、第二步升级Action 机制引入 ActionReducer使用方式五、第三步升级支持 AI问题正确方式AI → Action执行六、第四步升级支持多端问题方案Store → 分布式同步同步逻辑其他设备接收七、第五步升级支持网络场景统一入口示例八、完整 Store 架构九、为什么这样设计1、可控性2、可扩展性3、可调试性十、常见错误1、直接改 state2、UI 调用多个逻辑3、不同设备不同逻辑4、AI 绕过 Store总结引言如果你已经写过几天鸿蒙游戏大概率会遇到一个问题一开始一切正常后面越写越乱。具体表现状态到处都是多端同步很难搞AI 加进来之后彻底失控最后你会发现问题不在功能而在 Store 设计。在 HarmonyOS 中Store不只是“状态管理”而是整个系统的“中枢”。一、先说结论一个“正确”的 Store必须满足 3 个能力1 单一状态源Single Source of Truth 2 可扩展数据结构 3 可控的数据流谁能改状态如果缺任何一个小项目还能跑大项目一定崩二、最小 Store先从简单开始错误写法exportclassGameStore{score0playerX0}问题状态分散无法扩展无法统一更新正确基础写法exportinterfaceGameState{player:{x:number;y:number}score:number}exportclassGameStore{state:GameState{player:{x:0,y:0},score:0}update(partial:PartialGameState){this.state{...this.state,...partial}}}exportconstgameStorenewGameStore()核心所有状态必须集中在一个对象里三、第一步升级模块化 Store当游戏变大你不能再用一个“平铺 state”。模块化结构exportinterfaceGameState{player:PlayerState ui:UIState task:TaskState}exportinterfacePlayerState{x:numbery:numberhp:number}exportinterfaceUIState{dialog:string[]}exportinterfaceTaskState{current:string}好处分层清晰易扩展易维护对应 Store 更新updatePlayer(partial:PartialPlayerState){this.state.player{...this.state.player,...partial}}不再直接操作顶层。四、第二步升级Action 机制问题来了谁都可以update()会发生什么答案状态失控引入 ActiontypeAction|{type:MOVE;payload:{x:number}}|{type:ADD_SCORE;payload:number}Reducerdispatch(action:Action){switch(action.type){caseMOVE:this.state.player.xaction.payload.xbreakcaseADD_SCORE:this.state.scoreaction.payloadbreak}}核心所有状态修改必须通过 dispatch使用方式gameStore.dispatch({type:ADD_SCORE,payload:10})好处所有变更可追踪Debug 简单AI / 多端更安全五、第三步升级支持 AIAI 会成为“状态输入源”。问题如果 AI 直接改状态gameStore.state.score999完全失控。正确方式AI → ActionclassNPCAgent{decide(state){if(state.player.x100){return{type:ADD_SCORE,payload:5}}returnnull}}执行constactionagent.decide(gameStore.state)if(action){gameStore.dispatch(action)}本质AI 也是一个“合法的数据输入源”六、第四步升级支持多端问题多设备手机 TV 平板状态如何同步方案Store → 分布式同步dispatch(action:Action){this.reduce(action)this.sync(action)}同步逻辑sync(action:Action){distributedSync.send(action)}其他设备接收onReceive(action:Action){this.reduce(action)}核心同步 Action而不是同步 State好处更轻量可回放可调试七、第五步升级支持网络场景排行榜 / 多人游戏。统一入口dispatch(action:Action){this.reduce(action)this.syncToDevices(action)this.syncToServer(action)}示例syncToServer(action:Action){fetch(/api/action,{method:POST,body:JSON.stringify(action)})}本质所有数据变化统一出口八、完整 Store 架构InputUI / AI / 网络 / 多端 ↓ Action ↓ Store.dispatch ↓ Reducer ↓ State ↓ UI扩展dispatch ↓ 本地更新 ↓ 多端同步 ↓ 服务端同步九、为什么这样设计1、可控性所有状态变化都有入口2、可扩展性轻松支持AI多端网络3、可调试性console.log(action)可回放。十、常见错误1、直接改 statestate.score2、UI 调用多个逻辑数据流混乱。3、不同设备不同逻辑状态不一致。4、AI 绕过 Store失控。总结一个支持AI 多端 网络的鸿蒙游戏 Store本质是State数据 Action变化 Reducer规则核心原则所有变化必须走 Action 所有数据集中在 Store在 HarmonyOS 中这种 Store 设计带来的不是“代码优化”而是从“写逻辑”升级为“设计系统”。你的游戏能走多远取决于你的 Store 能撑多复杂。

相关文章:

鸿蒙游戏 Store 设计(AI + 多端)

子玥酱 (掘金 / 知乎 / CSDN / 简书 同名) 大家好,我是 子玥酱,一名长期深耕在一线的前端程序媛 👩‍💻。曾就职于多家知名互联网大厂,目前在某国企负责前端软件研发相关工作,主要聚…...

数学建模小白必看:从优化到预测,这四大类模型到底该怎么选?(附实战场景推荐)

数学建模实战指南:四大类模型的选择逻辑与场景适配 当你第一次面对数学建模竞赛题目时,是否曾被琳琅满目的模型选项弄得手足无措?优化、分类、评价、预测四大类模型下又细分数十种方法,每种都有其数学原理和应用前提。本文将从实际…...

TMSpeech:5分钟配置Windows本地实时语音转文字终极指南

TMSpeech:5分钟配置Windows本地实时语音转文字终极指南 【免费下载链接】TMSpeech 腾讯会议摸鱼工具 项目地址: https://gitcode.com/gh_mirrors/tm/TMSpeech 想要一个完全免费、无需联网的实时语音转文字工具吗?TMSpeech正是你需要的解决方案。这…...

2025网盘下载终极指南:八大平台直链解析工具LinkSwift深度评测

2025网盘下载终极指南:八大平台直链解析工具LinkSwift深度评测 【免费下载链接】Online-disk-direct-link-download-assistant 一个基于 JavaScript 的网盘文件下载地址获取工具。基于【网盘直链下载助手】修改 ,支持 百度网盘 / 阿里云盘 / 中国移动云盘…...

2026年硕士论文AI率要求15%以下怎么达到?亲测这2款最靠谱

导师组会上明确说了:硕士论文知网AIGC检测AI率必须15%以下,不然不给答辩资格。我当时论文初稿AI率42%,当场就有点懵。 后来试了几款工具,最稳定的是嘎嘎降AI(www.aigcleaner.com),一次处理完AI…...

中兴光猫配置解密工具完整技术指南:深度解析与实战应用

中兴光猫配置解密工具完整技术指南:深度解析与实战应用 【免费下载链接】ZET-Optical-Network-Terminal-Decoder 项目地址: https://gitcode.com/gh_mirrors/ze/ZET-Optical-Network-Terminal-Decoder 中兴光猫配置解密工具是一款基于Qt框架开发的专业级网络…...

从One-Hot到Target Encoding:category_encoders编码方法演进史

从One-Hot到Target Encoding:category_encoders编码方法演进史 【免费下载链接】category_encoders A library of sklearn compatible categorical variable encoders 项目地址: https://gitcode.com/gh_mirrors/ca/category_encoders category_encoders是一…...

交换机安全隔离技术实战:MUX VLAN与端口隔离的协同部署方案

1. 企业网络隔离需求与挑战 现代企业网络环境中,不同部门、不同身份的用户往往需要差异化的访问权限。财务部门的数据需要严格保密,市场部门的素材需要内部共享,而外来访客则只能访问有限的资源。传统方案是通过划分多个VLAN来实现隔离&#…...

Phi-4-mini-reasoning代码生成案例:用自然语言描述生成可调试算法代码

Phi-4-mini-reasoning代码生成案例:用自然语言描述生成可调试算法代码 1. 模型简介 Phi-4-mini-reasoning是微软推出的3.8B参数轻量级开源模型,专为数学推理、逻辑推导和多步解题等强逻辑任务设计。这个模型主打"小参数、强推理、长上下文、低延迟…...

Epusdt多钱包轮询技术揭秘:提升支付并发率的终极方案

Epusdt多钱包轮询技术揭秘:提升支付并发率的终极方案 【免费下载链接】epusdt 开源优雅的跨平台usdt收付中间件 Easy Payment USDT——epsdt 项目地址: https://gitcode.com/gh_mirrors/ep/epusdt Epusdt作为一款开源的跨平台USDT收付中间件,其核…...

YOLO12保姆级部署指南:开箱即用Web界面+Gradio+Ultralytics全流程

YOLO12保姆级部署指南:开箱即用Web界面GradioUltralytics全流程 1. 引言:为什么选择YOLO12? 如果你正在寻找一个既快速又准确的目标检测模型,YOLO12绝对值得你关注。作为2025年最新发布的目标检测模型,YOLO12在保持实…...

C# ModbusRtu与TCP协议上位机源码:包含存储、数据到SQL SERVER、趋势曲线...

C# ModbusRtu或者TCP协议上位机源码,包括存储,数据到SQL SERVER数据库,趋势曲线图,数据报表,实时和历史报警界面,有详细注释,需要哪个协议版本ModbusRTU 上位机工程:功能全景与技术实…...

开源中国“模力方舟“:国产AI数据集托管的战略高地

在人工智能技术迅猛发展的当下,数据集作为AI模型的"生命之源",其托管平台的选择直接影响着研发效率与创新成果。开源中国旗下的"模力方舟"MoArk平台凭借其完整的生态闭环、国家级项目背书和对国产化环境的深度适配,正成为…...

别只盯着那几根线了:深入聊聊JTAG的TAP控制器和边界扫描到底能干嘛

别只盯着那几根线了:深入聊聊JTAG的TAP控制器和边界扫描到底能干嘛 当工程师第一次接触JTAG接口时,注意力往往被那几根物理引脚吸引——TCK、TMS、TDI、TDO,最多再加上TRST。但就像外科医生不能只认识手术刀一样,真正发挥JTAG威力…...

高通QCM8550传感器驱动移植与调试实战指南

1. 高通QCM8550传感器驱动移植概述 第一次接触高通QCM8550平台的传感器驱动移植时,我被它独特的SEE(Sensors Execution Environment)架构搞得一头雾水。这个平台把传感器数据处理从Android系统剥离出来,放在独立的ADSP&#xff08…...

Halcon图像处理避坑:为什么你的rotate_image效果不理想?仿射变换的正确打开方式

Halcon图像旋转实战:从rotate_image陷阱到仿射变换精控 在工业视觉检测项目中,图像旋转是最基础却又最容易出问题的操作之一。许多开发者习惯性地使用Halcon的rotate_image算子,却在复杂场景中频频遇到图像裁剪、坐标偏移、精度丢失等"坑…...

如何实现抗体高效表达与纯化?

一、抗体表达与纯化为何是生物医药生产的核心环节?抗体表达与纯化是生物制药工艺流程中不可或缺的关键环节,直接决定了抗体药物的质量、产量和生产成本。高效表达系统能够确保抗体分子正确折叠并具备完整生物活性,而精细纯化过程则是去除杂质…...

2026届必备的六大AI科研工具解析与推荐

Ai论文网站排名(开题报告、文献综述、降aigc率、降重综合对比) TOP1. 千笔AI TOP2. aipasspaper TOP3. 清北论文 TOP4. 豆包 TOP5. kimi TOP6. deepseek 作为人工智能语言模型的DeepSeek,于学术论文写作里呈现出显著的辅助价值&#xf…...

ExtractorSharp终极指南:3步成为游戏资源编辑专家 [特殊字符]

ExtractorSharp终极指南:3步成为游戏资源编辑专家 🎮 【免费下载链接】ExtractorSharp Game Resources Editor 项目地址: https://gitcode.com/gh_mirrors/ex/ExtractorSharp ExtractorSharp是一款专业的游戏资源编辑器,专为Windows游…...

OpenVSP:为什么说它是航空航天工程师的“参数化设计瑞士军刀“?

OpenVSP:为什么说它是航空航天工程师的"参数化设计瑞士军刀"? 【免费下载链接】OpenVSP A parametric aircraft geometry tool 项目地址: https://gitcode.com/gh_mirrors/ope/OpenVSP 在航空航天领域,每个设计决策都关乎着…...

Electron程序控制台打不开?3种常见原因及快速检测方法(附代码)

Electron控制台无法打开的深度诊断与实战解决方案 刚接手一个遗留的Electron项目时,最让人抓狂的莫过于按下F12却看不到开发者工具窗口。上周我就遇到了这样的场景——一个打包后的应用在生产环境突然无法调出控制台,而团队里没人记得当初的配置细节。这…...

深入解析ioremap:从内存映射到页表属性

1. ioremap基础概念与使用场景 第一次接触ioremap是在调试一块PCIe采集卡的时候。当时需要在Linux驱动中访问设备的寄存器空间,直接使用物理地址会引发段错误。同事轻描淡写地说:"用ioremap映射一下就行"。这个看似简单的接口背后,…...

uniapp实战:滚动监听与锚点联动,打造沉浸式导航菜单

1. 滚动监听与锚点联动的核心价值 长页面浏览时最头疼的问题是什么?就是当你滚动到页面底部,突然想跳转到某个章节,却要手动滚回去找导航菜单。我在开发电商App的商品详情页时,产品经理拿着手机怼到我面前:"这体验…...

HAL库新手必看:为什么你的stm32f1xx_hal_gpio.h会报HAL_StatusTypeDef错误?

HAL库报错解析:HAL_StatusTypeDef未定义的深层原因与解决方案 刚接触STM32 HAL库的开发者经常会遇到一个令人困惑的报错:error: #20: identifier "HAL_StatusTypeDef" is undefined,而这个错误偏偏出现在HAL库自己的头文件里。这就…...

HPE服务器固件升级后网络适配器端口配置重置问题解析与解决方案

1. 问题现象与影响范围 最近在给HPE ProLiant服务器升级固件时,不少工程师都遇到了一个让人头疼的问题:升级完成后,网络适配器的端口配置莫名其妙被重置了。这个问题特别容易出现在使用HPE Broadcom 33x系列网卡的服务器上,比如常…...

Yi-Coder-1.5B智能合约:Solidity开发实战

Yi-Coder-1.5B智能合约:Solidity开发实战 1. 引言 智能合约开发一直是区块链领域的核心技能,但对于很多开发者来说,编写安全可靠的Solidity代码并非易事。传统的开发过程中,开发者需要深入理解Solidity的语法特性、安全漏洞模式…...

ExtractorSharp游戏资源编辑工具:从零开始掌握NPK与IMG文件编辑的完整指南

ExtractorSharp游戏资源编辑工具:从零开始掌握NPK与IMG文件编辑的完整指南 【免费下载链接】ExtractorSharp Game Resources Editor 项目地址: https://gitcode.com/gh_mirrors/ex/ExtractorSharp 你是否曾想过自定义游戏中的角色外观、武器特效或界面元素&a…...

城通网盘解析器:3步解决下载慢、广告多的终极方案

城通网盘解析器:3步解决下载慢、广告多的终极方案 【免费下载链接】ctfileGet 获取城通网盘一次性直连地址 项目地址: https://gitcode.com/gh_mirrors/ct/ctfileGet 还在为城通网盘下载速度慢如蜗牛而烦恼吗?还在被层层广告弹窗折磨得耐心全无吗…...

The Ultimate Guide to Ruby Timeouts:Web服务器和Rack中间件超时配置

The Ultimate Guide to Ruby Timeouts:Web服务器和Rack中间件超时配置 【免费下载链接】the-ultimate-guide-to-ruby-timeouts Timeouts for popular Ruby gems 项目地址: https://gitcode.com/gh_mirrors/th/the-ultimate-guide-to-ruby-timeouts 在Ruby应用…...

D3KeyHelper:解放双手的暗黑破坏神3智能战斗助手终极指南

D3KeyHelper:解放双手的暗黑破坏神3智能战斗助手终极指南 【免费下载链接】D3keyHelper D3KeyHelper是一个有图形界面,可自定义配置的暗黑3鼠标宏工具。 项目地址: https://gitcode.com/gh_mirrors/d3/D3keyHelper 你是否厌倦了在暗黑破坏神3中长…...