用 AI 做鸿蒙游戏 NPC,是一种什么体验?

张开发
2026/4/3 20:37:31 15 分钟阅读
用 AI 做鸿蒙游戏 NPC,是一种什么体验?
子玥酱掘金 / 知乎 / CSDN / 简书 同名大家好我是子玥酱一名长期深耕在一线的前端程序媛 ‍。曾就职于多家知名互联网大厂目前在某国企负责前端软件研发相关工作主要聚焦于业务型系统的工程化建设与长期维护。我持续输出和沉淀前端领域的实战经验日常关注并分享的技术方向包括前端工程化、小程序、React / RN、Flutter、跨端方案在复杂业务落地、组件抽象、性能优化以及多端协作方面积累了大量真实项目经验。技术方向前端 / 跨端 / 小程序 / 移动端工程化内容平台掘金、知乎、CSDN、简书创作特点实战导向、源码拆解、少空谈多落地文章状态长期稳定更新大量原创输出我的内容主要围绕前端技术实战、真实业务踩坑总结、框架与方案选型思考、行业趋势解读展开。文章不会停留在“API 怎么用”而是更关注为什么这么设计、在什么场景下容易踩坑、真实项目中如何取舍希望能帮你在实际工作中少走弯路。子玥酱 · 前端成长记录官 ✨ 如果你正在做前端或准备长期走前端这条路 关注我第一时间获取前端行业趋势与实践总结 可领取11 类前端进阶学习资源工程化 / 框架 / 跨端 / 面试 / 架构 一起把技术学“明白”也用“到位”持续写作持续进阶。愿我们都能在代码和生活里走得更稳一点 文章目录引言一、从“脚本 NPC”到“智能 NPC”传统 NPCAI NPC二、第一感受NPC“活”了传统 NPCAI NPC三、第二感受你开始“调性格”而不是“写逻辑”示例四、第三感受调试方式完全变了示例五、第四感受不确定性好处坏处示例六、鸿蒙上的独特体验1、端侧 AI2、多设备感知示例3、分布式协同七、一个完整 AI NPC 示例1、NPC Agent2、接入页面3、执行行为八、进阶接入大模型示例九、开发建议1、不要一开始就用大模型2、加“安全边界”3、记录行为日志4、限制决策频率十、最大的变化总结1、逻辑变了2、开发方式变了3、调试方式变了4、体验变了引言如果你做过游戏开发一定写过 NPC。而且大概率是这样写的if(playerNear){attack()}else{patrol()}简单、直接、可控。但也有一个明显问题NPC 永远是“写死的”而当你把 AI 引入到 HarmonyOS 游戏里事情会发生变化constactionnpcAgent.decide(state)这时候你会发现你不再是在“写 NPC”而是在“创造一个角色”一、从“脚本 NPC”到“智能 NPC”先看最核心的变化。传统 NPCif(hp30){runAway()}else{attack()}特点可预测可控制可调试AI NPCconstactionagent.decide({hp,enemyDistance,history})特点不完全可预测有“行为风格”会“变化”本质变化NPC 从“规则集合”变成“决策系统”二、第一感受NPC“活”了这是最直观的体验。传统 NPC玩家靠近 → 攻击 玩家远离 → 停止AI NPC可能会先观察你选择绕后假装撤退再反击开发者的第一反应通常是“这行为我没写过啊”没错——这正是 AI 的价值三、第二感受你开始“调性格”而不是“写逻辑”传统开发if(...)doSomething()AI 开发prompt你是一个谨慎的敌人 优先保命其次攻击你在做的事情变成设计行为风格Personality示例npcAgent.setProfile({style:aggressive,riskTolerance:0.8})本质变化代码 → 行为设计四、第三感受调试方式完全变了传统调试打断点看变量查逻辑AI 调试看输入看输出调 prompt示例console.log(state:,state)console.log(action:,action)你会发现Bug 不再是“代码错了”而是“AI 理解错了”五、第四感受不确定性AI NPC 最大的特点不可完全预测好处更真实更有趣更耐玩坏处难调试难复现可能“失控”示例// 有时候 NPC 突然不攻击你会想“是 bug 吗”其实可能是AI 决策的结果六、鸿蒙上的独特体验在 HarmonyOS 上AI NPC 还有一些独特优势。1、端侧 AIconstactionlocalModel.infer(state)优点实时决策无网络依赖2、多设备感知AI 可以感知手机输入 TV 状态 传感器数据示例agent.decide({playerInput,deviceContext,environment})NPC 变成“全场景感知角色”3、分布式协同多个 NPC 可以协作teamAgent.decide(teamState)形成AI 队伍七、一个完整 AI NPC 示例我们做一个简单 Demo1、NPC AgentclassNPCAgent{asyncdecide(state){if(state.hp20){returnescape}if(state.enemyDistance50){returnattack}returnpatrol}}这是“规则 AI”的过渡版本。2、接入页面constactionnpcAgent.decide({hp:this.hp,enemyDistance:this.distance})this.execute(action)3、执行行为execute(action:string){switch(action){caseattack:this.attack()breakcaseescape:this.runAway()break}}这就是最小 AI NPC 架构State → Agent → Action → Execute八、进阶接入大模型如果你接入大模型LLMNPC 会更“人性化”。示例asyncdecide(state){constprompt当前血量${state.hp}敌人距离${state.enemyDistance}你会怎么做returnawaitllm.generate(prompt)}效果会说话会表达情绪会“演戏”九、开发建议1、不要一开始就用大模型先用规则 → 简单 AI → LLM2、加“安全边界”if(!validAction(action)){actionidle}3、记录行为日志log.push({state,action})4、限制决策频率setInterval((){agent.decide()},500)十、最大的变化传统 NPC 你写“它做什么”AI NPC你定义“它是什么样的人”总结在 HarmonyOS 上用 AI 做 NPC本质是一次角色设计方式的升级。可以总结为四个变化1、逻辑变了if/else → AI 决策2、开发方式变了写代码 → 设计行为3、调试方式变了查 bug → 调 AI4、体验变了NPC → 角色最后给你一个很有意思的结论当 NPC 不再是“写出来的”而是“表现出来的”游戏世界就开始变得真实。而这可能才是 AI 游戏真正的开始。

更多文章