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

AISystem:鸿蒙游戏中的 AI 行为驱动

子玥酱(掘金 / 知乎 / CSDN / 简书 同名)

大家好,我是子玥酱,一名长期深耕在一线的前端程序媛 👩‍💻。曾就职于多家知名互联网大厂,目前在某国企负责前端软件研发相关工作,主要聚焦于业务型系统的工程化建设与长期维护。

我持续输出和沉淀前端领域的实战经验,日常关注并分享的技术方向包括前端工程化、小程序、React / RN、Flutter、跨端方案
在复杂业务落地、组件抽象、性能优化以及多端协作方面积累了大量真实项目经验。

技术方向:前端 / 跨端 / 小程序 / 移动端工程化
内容平台:
掘金、知乎、CSDN、简书
创作特点:
实战导向、源码拆解、少空谈多落地
文章状态:
长期稳定更新,大量原创输出

我的内容主要围绕前端技术实战、真实业务踩坑总结、框架与方案选型思考、行业趋势解读展开。文章不会停留在“API 怎么用”,而是更关注为什么这么设计、在什么场景下容易踩坑、真实项目中如何取舍,希望能帮你在实际工作中少走弯路。

子玥酱 · 前端成长记录官 ✨
👋 如果你正在做前端,或准备长期走前端这条路
📚 关注我,第一时间获取前端行业趋势与实践总结
🎁 可领取11 类前端进阶学习资源(工程化 / 框架 / 跨端 / 面试 / 架构)
💡 一起把技术学“明白”,也用“到位”

持续写作,持续进阶。
愿我们都能在代码和生活里,走得更稳一点 🌱

文章目录

    • 引言
    • 一、为什么不能把 AI 写进 BattleSystem?
    • 二、一个关键拆分:规则 vs 决策
      • System
      • AISystem
    • 三、AISystem 的核心职责
    • 四、AISystem 的最小模型
    • 五、从 if-else 到“行为模型”
      • 1、行为枚举
      • 2、行为选择器
      • 3、行为执行器
    • 六、AISystem 的三种进阶模式
      • 1、规则驱动
      • 2、权重驱动
      • 3、模型驱动
    • 七、AISystem 与 System 的协作关系
    • 八、引入“行为调度层”
    • 九、避免 AI 失控的关键机制
      • 1、约束
      • 2、校验
      • 3、优先级
    • 十、AISystem 在多端中的作用
    • 十一、一个关键认知升级
    • 十二、最终架构
    • 总结

引言

当你把鸿蒙游戏拆成:

Store(状态) System(规则) Engine(调度) UI(展示)

你会发现一件事:

玩家行为很好处理 点击 → System → 状态变化

但一旦你开始做这些内容:

NPC 行为 敌人决策 自动战斗 动态难度

问题就来了:

“AI 到底应该写在哪?”

很多人第一反应是:

写在 BattleSystem 里 写在 UI 里 甚至直接写 if-else

结果就是:

逻辑越来越乱 行为越来越不可控 难以扩展

所以需要我们要建立一个关键能力:

AISystem:让 AI 成为“行为驱动层”,而不是“逻辑补丁”

一、为什么不能把 AI 写进 BattleSystem?

看一个典型错误:

classBattleSystem{update(store:GameStore){// 玩家逻辑this.handlePlayer(store)// AI 逻辑if(store.enemyHp<30){this.escape()}else{this.attack()}}}

问题:

规则 + 决策 混在一起 AI 无法复用 行为不可扩展

本质上:

你把“怎么做”和“做什么”写在了一起

二、一个关键拆分:规则 vs 决策

你必须把这两件事分开:

System

攻击怎么计算? 伤害怎么算? 冷却怎么处理?

AISystem

什么时候攻击? 什么时候逃跑? 选择哪个技能?

一句话总结:

System 决定“能做什么”,AISystem 决定“现在做什么”

三、AISystem 的核心职责

AISystem 不做三件事:

不直接改 Store 不写具体规则 不控制流程

它只做一件事:

输出“行为决策”

四、AISystem 的最小模型

exportclassAISystem{decide(store:GameStore):Action{if(store.enemyHp<30){return{type:"ESCAPE"}}return{type:"ATTACK"}}}

然后由 System 执行:

constaction=ai.decide(store)battleSystem.execute(store,action)

五、从 if-else 到“行为模型”

初级写法:

if(hp<30)run()elseattack()

进阶之后你应该写成:

1、行为枚举

enumActionType{ATTACK,DEFEND,ESCAPE}

2、行为选择器

decide(store):ActionType{// 决策逻辑}

3、行为执行器

execute(store,action){switch(action){caseATTACK:...caseESCAPE:...}}

好处:

结构清晰 可扩展 可测试

六、AISystem 的三种进阶模式

1、规则驱动

if(hp<30)escape

特点:

简单 可控 适合基础 AI

2、权重驱动

score_attack=0.7score_escape=0.9

选择最高:

ESCAPE

示例:

decide(store){returnmaxBy([{type:ATTACK,score:calcAttack(store)},{type:ESCAPE,score:calcEscape(store)}])}

3、模型驱动

constdecision=awaitmodel.decide(context)

特点:

灵活 智能 但不可预测

七、AISystem 与 System 的协作关系

正确结构:

AISystem → 决策 System → 执行

错误结构:

AISystem → 直接改 Store 错误

正确示例:

constaction=ai.decide(store)engine.dispatch(action)

八、引入“行为调度层”

当 AI 变复杂后,你不能直接:

ai.decide()

你需要一个:

AI Engine

classAIEngine{aiSystems:AISystem[]=[]run(store){returnthis.aiSystems.map(ai=>ai.decide(store))}}

作用:

统一 AI 执行 支持多 AI 可组合

九、避免 AI 失控的关键机制

AI 一旦复杂,很容易失控。你必须加三层保护:

1、约束

if(store.stunned)returnNO_ACTION

2、校验

if(!isValid(action))fallback()

3、优先级

ESCAPE>ATTACK

十、AISystem 在多端中的作用

在多设备场景下:

AISystem 只能在“主节点”执行

否则:

每个设备各算一套 AI → 状态漂移

正确方式:

Host 运行 AI 其他设备同步结果

十一、一个关键认知升级

初学者会觉得:

AI = 一段逻辑

但进阶之后你会理解:

AI 是一个“行为生成系统”

系统运行变成:

状态(Store) ↓ AISystem(决策) ↓ System(执行) ↓ 状态变化

十二、最终架构

┌──────────────┐ │ Store │ └──────┬───────┘ │ ┌───────▼────────┐ │ AISystem │ └───────┬────────┘ │ Action ┌───────▼────────┐ │ System │ └───────┬────────┘ │ Engine │ UI

总结

在鸿蒙游戏中:

System:定义规则 AISystem:决定行为

两者缺一不可。如果用一句话总结:

System 决定“世界能做什么”,AISystem 决定“角色此刻做什么”。

而当你真正用好 AISystem,你的游戏就会从:

“写死逻辑”

进化为:

“行为驱动的动态世界”

http://www.jsqmd.com/news/728862/

相关文章:

  • Android开发与ARM Cortex-A8核心深度适配及优化实践
  • 穿透宿主机内核:QNAP Virtualization Station 硬件直通解析
  • 2026年材料科学论文降AI工具推荐:材料工程研究答辩前亲测3款对比方案
  • 终极指南:5步搭建免费开源Sunshine游戏串流服务器
  • LLM智能体在时间序列预测中的创新应用
  • 南京奢侈品回收选品推荐:南京,徐州名车典当,名车抵押,和田玉回收,房产抵押,翡翠回收,铂金回收,优选指南! - 优质品牌商家
  • 如果你正在做采购管理,这篇文章建议你认真看完(关于CPPM)
  • 桥梁拉索索力异常识别【附代码】
  • CubeMX配置STM32串口DMA后,为什么连续调用HAL_UART_Transmit_DMA会失败?一个调试案例复盘
  • 【Writeup】pwnable.kr--blackjack
  • 企业微信会话存档 API 开发实战:合规存档与数据检索全流程
  • 数据流加速器基准测试:Graphcore IPU、Cerebras CS-2与SambaNova SN30对比
  • 在Windows上直接安装安卓应用:APK Installer的五大高效解决方案
  • 【Laravel 12+ AI工程化落地指南】:从零集成LangChain、LlamaIndex与OpenAI,3小时构建生产级智能客服系统
  • 【云藏山鹰代数信息系统】浅析气质砥砺学研究范式
  • 0 代码自动化测试:RF 框架实现企业级 UI 自动化测试
  • 阿里云OSS Java SDK安全升级指南:从硬编码AK到环境变量,我这样管理敏感配置
  • Dify 2026边缘节点部署倒计时:2026年Q3起,未通过Dify Edge Compliance Check的节点将自动退出联邦推理网络
  • 【独家首发】Dify 2026文档解析精度优化内参:基于217万真实业务PDF的误差热力图+12个高危Layout Pattern规避指南
  • TV Bro电视浏览器:智能电视上网的终极解决方案
  • HarmonyOS 6 Progress 组件 - 设置线性进度条和胶囊进度条属性
  • Swoole协程+LLM流式响应落地实践(企业级高并发长连接架构白皮书)
  • 从曼德拉的菜园到你的代码:如何用‘园艺思维’管理你的技术项目(附GitHub实战)
  • Tidyverse 2.0升级后report生成失败?3大隐性兼容性陷阱+5步回滚验证流程全公开
  • 如何用开源AIOps平台Keep终结告警风暴,实现智能运维自动化
  • 新版小学初中课标:义务教育课程方案和各科课程标准(2025年修订版)
  • 从追剧到做视频:硬字幕、软字幕、外挂字幕,选对能让你的作品传播力翻倍
  • 流形优化在LLM训练中的创新应用与Mano优化器解析
  • HarmonyOS 6 QRCode 组件使用文档
  • 岩土力学微观探索:蓝光3D扫描在断面粗糙度分析中的应用