随着游戏开发的完整度提升,技能系统的设计复杂性也越来越高,导致了用模板方式的配置方法和处理方法会导致以下几个问题:

  1. 代码冗余
  2. 排错困难
  3. 配置项冗余
  4. 熟悉业务流程时间长
  5. 扩展性低

经过我思考决定重写之。分析以下几个观点,由于早期设计上的局限,和实际开发预期的不符,技能系统也必然会成为策划脑洞大开的一个点,并且也会成为MOBA游戏体验的深度核心项之一。于是一个成熟的MOBA技能系统应该包含一下几点:

  1. 代码流程清晰
  2. 错误定位精确
  3. 配置项定位精确
  4. 熟悉业务流程时间短
  5. 扩展性强

  应该还有一些我没有想到或者没有记录到的点,在此就说明以上几个。

 有一些程序在设计一些高扩展性同时又是核心要素的系统时,不出意外的也会遇到以上的几个问题。

  这里的核心关键就是:

  在设计之初对未来的需求是未知且不可预测的。

  那么我是怎么解决以上的几个问题的呢?

  因为我一直在使用 Unity 做前端开发。深知Unity的ECS (实体组件系统) 架构体系带来的便利。

  于是我打算根据ECS的架构方式的模子去设计,但不完全根据ECS的架构来,保持对具体项目需求的贴切。

  于是我设计了如下三个层:

  1. 流程控制层
  2. 原子函数层(技能)
  3. 逻辑层(技能)

  有时候我认为这个设计很像行为树。好吧确实有点像,但又不是那么像。这里不深究,留疑。核心还是留在解决需求上。

  流程控制层具备以下几个组件:

  1. CtrlBase -> 作为所有流程控制的基类
  2. CtrlBreak -> 用于中断所有流程控制组件
  3. CtrlCondition -> 用于流程控制中的分支操作
  4. CtrlDelayTime -> 用于流程控制中的延时执行操作
  5. CtrlDuration -> 用于在一段时间内执行一段动作
  6. CtrlSequence -> 用于序列执行一组动作
  7. CtrlTimeLine 组件 -> 用于创建一个时间轴,让所有流程组件在这个时间轴上执行

  原子函数层(技能)具备以下几个组件:

  1. SkillCondition -> 提供技能条件的判定
  2. SkillEntity -> 提供技能实体的操作
  3. SkillFightObjMap -> 提供战斗对象查询获取等操作
  4. SkillInOutValueToPlayer -> 提供对战斗对象角色的数值输入输出
  5. SkillPlayuerCtrl -> 提供对角色的控制操作
  6. SkillTarget -> 提供技能对象的具体信息

  逻辑层(技能):

  1. SkillBase -> 所有逻辑层的基类 定义所有的技能逻辑层数据
  2. Hero1/skill_1 -> 英雄1的技能1逻辑对象
  3. Hero2/skill_2 -> 英雄2的技能2逻辑对象
  4. ...类推

  从以上的结构中可以直接看出目前的冗余层在逻辑层,而逻辑层的支撑在控制层和原子函数层,随着开发深度的越来越高,控制层和原子函数层的操作组件会越来越多或功能性越来越强。则为逻辑层提供的操作/组合方式更为丰富,则可实现的动作会更为强大。

  并且从排错来说只要控制层和原子层确保无误(实际也必须无误),基本错误定位能直接找到对应技能的逻辑层,且逻辑层没有多余代码,每一句都和技能的具体逻辑有所关联,线性排错。难度低。如若错误出在原子或控制层则是一批技能同时出现问题,也好定位。

  所以这里已经做到代码流程清晰,错误定位精确。

  同时因为每个技能有独立逻辑层则配置的定义也可以独立,这里也做到了配置项定位精确。

  基于以上几点精确定位的特性导致熟悉业务的时间就因此变短了。

  又因为原子函数层/控制层的支持性可扩展,具体技能的业务逻辑可定制,所以扩展性强了。

  给予这种设计模式,带来的好处可见是非常大的,但是同时也导致了必须要让程序长期来维护或定制具体的技能模块。所以我一直认为策划是可以具备一些脚本功底的,只要我们保证原子函数层和控制层提供的是安全接口。则可以对策划放开脚本编写,甚至可以用弱类型解析类脚本语言来提供具体的技能逻辑定制。

  还有一种方案是开发一款能够生成逻辑层的流程编辑器,将原子函数层和控制层反射导入。生成逻辑层代码。不过这个成本太高而且规则不好定制。有可能还没程序直接编程性价比更高。所以我没有选择开发流程编辑器的方式。

  这个架构在我实际运用中,感觉还是非常好的,因为大多的技能其实相似性还是蛮高的,如果技能难度不高,原子函数不需要迭代添加,则进行逻辑组合的时候实际效率很高。我刚刚开发完这套系统,重构现有的技能(10个左右)也就花了3个小时左右吧。相比之下模板类的效率我认为要高的多,而且对开发者的友好度更高。

  所有的设计都应该建立在更贴切实际开发需求上,我认为所有的系统设计都应该建立在需求的不可预知和灵活性扩展上,同时也需要衡量它的性价比,不做过度设计,不墨守成规。

MOBA 游戏技能系统设计 2.0的更多相关文章

  1. ARPG游戏技能系统设计

    ARPG游戏的技能的前端表现, 主要指的是人物动作和特效表现, 从普遍意义上讲,大致可以分为三个阶段:起手.飞行.碰撞(爆炸). [特效可见性判断] 1.[attacker & victim] ...

  2. 在moba游戏里面模拟实现绝地求生毒雾圈功能

    ---恢复内容开始--- 已经有很长一段时间没做项目了上半年大多数时间都荒废在王者荣耀,哈哈,S8赛季也上了王者,美滋滋 转回正题,公司需要开个新项目,需要把原有的moba游戏,改成类似绝地求生那玩法 ...

  3. MOBA游戏学会这些知识,你才算真的入门了!

    <英魂之刃口袋版>是一个标准的MOBA游戏,MOBA指的是多人在线战术竞技游戏,游戏模式始于1998年<星际争霸>中的一张自定义地图,经过近20年的优化和调整逐渐演变成了我们现 ...

  4. 王亮:游戏AI探索之旅——从alphago到moba游戏

    欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由云加社区技术沙龙 发表于云+社区专栏 演讲嘉宾:王亮,腾讯AI高级研究员.2013年加入腾讯,从事大数据预测以及游戏AI研发工作.目前 ...

  5. 知道创宇研发技能表v3.0

    知道创宇研发技能表v3.0 2015/8/21 发布 by @知道创宇(www.knownsec.com) @余弦 & 404团队 后续动态请关注微信公众号:Lazy-Thought 说明 关 ...

  6. Unite 2017 | 从《闹闹天宫》看MOBA游戏里的网络同步技术

    http://mp.weixin.qq.com/s/0v0EU79Q6rFafrh8ptlmhw 在Unite 2017 Shanghai案例分享专场,来自蓝港互动<闹闹天宫>项目组的主程 ...

  7. MOBA游戏的网络同步技术

    转自:http://www.gameres.com/750888.html 在5月13日Unite 2017 案例分享专场上,蓝港互动<闹闹天宫>项目组的主程序陈实分享了MOBA游戏的网络 ...

  8. Scut游戏服务器引擎6.0.5.0发布-支持C#脚本

    1. 增加C#脚本支持2. 增加Pay和Sns中间件对Mysql数据库支持3. 精简布署步骤,取消Redis写入程序,将其移到游戏底层运行4. 修正Mysql对中文可能会出现乱码的BUG 点击下载:S ...

  9. AI-Info-Micron-Insight:将您的游戏技能变成一份工作

    ylbtech-AI-Info-Micron-Insight:将您的游戏技能变成一份工作 1.返回顶部 1. 将您的游戏技能变成一份工作 听起来不现实? 一位来自著名商学院的教授不这么认为.他认为,金 ...

随机推荐

  1. android仿微信红包动画、Kotlin综合应用、Xposed模块、炫酷下拉视觉、UC浏览器滑动动画等源码

    Android精选源码 仿微信打开红包旋转动画 使用Kotlin编写的Android应用,内容你想象不到 Android手机上的免Root Android系统日志Viewer 一个能让微信 Mater ...

  2. solr服务的搭建(以solr4.1实现)

    1.准备工作:一个干净的Tomcat,solr-4.10.3. 2.新建一个文件夹我这里命名为solr,将Tomcat和solr-4.10.3放进去.新建一个solrhome的文件夹,里面放的是sol ...

  3. [国嵌笔记][029][ARM处理器启动流程分析v2]

    2440启动流程 启动方式:nor flash启动.nand flash启动 地址布局: 选择nor flash启动时,SROM(nor flash)地址为0x00000000 选择nand flas ...

  4. light oj 1184 Marriage Media

    题目: You run a marriage media. You take some profiles for men and women, and your task is to arrange ...

  5. SQL语句order by两个字段同时排序。

    ORDER BY  后可加2个字段,用英文逗号隔开.理解:对两个字段都排序,并不是之排序其中的一个字段: f1用升序, f2降序,sql该这样写 ORDERBY  f1, f2  DESC 也可以这样 ...

  6. Uva10129 - Play on Words 欧拉通路 DFS

    题目链接: http://uva.onlinejudge.org/index.php?option=com_onlinejudge&Itemid=8&category=105& ...

  7. [转]另一种遍历Map的方式: Map.Entry 和 Map.entrySet()

    转自: http://blog.csdn.net/mageshuai/article/details/3523116 今天看Think in java 的GUI这一章的时候,里面的TextArea这个 ...

  8. Spring 数据库连接(Connection)绑定线程(Thread)的实现

    最近在看spring事务的时候在想一个问题:spring中的很多bean都是单例的,是非状态的,而数据库连接是一种有状态的对象,所以spring一定在创建出connection之后在threadloc ...

  9. Hystrix-request collapsing(请求合并)

    介绍: Hystrix的请求合并就是把重复的请求批量的用一个HystrixCommand命令去执行,以减少通信消耗和线程数的占用.Hystrix的请求合并用到了HystrixCollapser这个抽象 ...

  10. Spring简单的REST例子

    控制器处理 HTTP 的4个主要方法 GET,POST,PUT,DELETE 使用@PathVariable注解获取URL中的参数 import javax.inject.Inject; import ...