MOBA 游戏技能系统设计 2.0
随着游戏开发的完整度提升,技能系统的设计复杂性也越来越高,导致了用模板方式的配置方法和处理方法会导致以下几个问题:
- 代码冗余
- 排错困难
- 配置项冗余
- 熟悉业务流程时间长
- 扩展性低
经过我思考决定重写之。分析以下几个观点,由于早期设计上的局限,和实际开发预期的不符,技能系统也必然会成为策划脑洞大开的一个点,并且也会成为MOBA游戏体验的深度核心项之一。于是一个成熟的MOBA技能系统应该包含一下几点:
- 代码流程清晰
- 错误定位精确
- 配置项定位精确
- 熟悉业务流程时间短
- 扩展性强
应该还有一些我没有想到或者没有记录到的点,在此就说明以上几个。
有一些程序在设计一些高扩展性同时又是核心要素的系统时,不出意外的也会遇到以上的几个问题。
这里的核心关键就是:
在设计之初对未来的需求是未知且不可预测的。
那么我是怎么解决以上的几个问题的呢?
因为我一直在使用 Unity 做前端开发。深知Unity的ECS (实体组件系统) 架构体系带来的便利。
于是我打算根据ECS的架构方式的模子去设计,但不完全根据ECS的架构来,保持对具体项目需求的贴切。
于是我设计了如下三个层:
- 流程控制层
- 原子函数层(技能)
- 逻辑层(技能)
有时候我认为这个设计很像行为树。好吧确实有点像,但又不是那么像。这里不深究,留疑。核心还是留在解决需求上。
流程控制层具备以下几个组件:
- CtrlBase -> 作为所有流程控制的基类
- CtrlBreak -> 用于中断所有流程控制组件
- CtrlCondition -> 用于流程控制中的分支操作
- CtrlDelayTime -> 用于流程控制中的延时执行操作
- CtrlDuration -> 用于在一段时间内执行一段动作
- CtrlSequence -> 用于序列执行一组动作
- CtrlTimeLine 组件 -> 用于创建一个时间轴,让所有流程组件在这个时间轴上执行
原子函数层(技能)具备以下几个组件:
- SkillCondition -> 提供技能条件的判定
- SkillEntity -> 提供技能实体的操作
- SkillFightObjMap -> 提供战斗对象查询获取等操作
- SkillInOutValueToPlayer -> 提供对战斗对象角色的数值输入输出
- SkillPlayuerCtrl -> 提供对角色的控制操作
- SkillTarget -> 提供技能对象的具体信息
逻辑层(技能):
- SkillBase -> 所有逻辑层的基类 定义所有的技能逻辑层数据
- Hero1/skill_1 -> 英雄1的技能1逻辑对象
- Hero2/skill_2 -> 英雄2的技能2逻辑对象
- ...类推
从以上的结构中可以直接看出目前的冗余层在逻辑层,而逻辑层的支撑在控制层和原子函数层,随着开发深度的越来越高,控制层和原子函数层的操作组件会越来越多或功能性越来越强。则为逻辑层提供的操作/组合方式更为丰富,则可实现的动作会更为强大。
并且从排错来说只要控制层和原子层确保无误(实际也必须无误),基本错误定位能直接找到对应技能的逻辑层,且逻辑层没有多余代码,每一句都和技能的具体逻辑有所关联,线性排错。难度低。如若错误出在原子或控制层则是一批技能同时出现问题,也好定位。
所以这里已经做到代码流程清晰,错误定位精确。
同时因为每个技能有独立逻辑层则配置的定义也可以独立,这里也做到了配置项定位精确。
基于以上几点精确定位的特性导致熟悉业务的时间就因此变短了。
又因为原子函数层/控制层的支持性可扩展,具体技能的业务逻辑可定制,所以扩展性强了。
给予这种设计模式,带来的好处可见是非常大的,但是同时也导致了必须要让程序长期来维护或定制具体的技能模块。所以我一直认为策划是可以具备一些脚本功底的,只要我们保证原子函数层和控制层提供的是安全接口。则可以对策划放开脚本编写,甚至可以用弱类型解析类脚本语言来提供具体的技能逻辑定制。
还有一种方案是开发一款能够生成逻辑层的流程编辑器,将原子函数层和控制层反射导入。生成逻辑层代码。不过这个成本太高而且规则不好定制。有可能还没程序直接编程性价比更高。所以我没有选择开发流程编辑器的方式。
这个架构在我实际运用中,感觉还是非常好的,因为大多的技能其实相似性还是蛮高的,如果技能难度不高,原子函数不需要迭代添加,则进行逻辑组合的时候实际效率很高。我刚刚开发完这套系统,重构现有的技能(10个左右)也就花了3个小时左右吧。相比之下模板类的效率我认为要高的多,而且对开发者的友好度更高。
所有的设计都应该建立在更贴切实际开发需求上,我认为所有的系统设计都应该建立在需求的不可预知和灵活性扩展上,同时也需要衡量它的性价比,不做过度设计,不墨守成规。
MOBA 游戏技能系统设计 2.0的更多相关文章
- ARPG游戏技能系统设计
ARPG游戏的技能的前端表现, 主要指的是人物动作和特效表现, 从普遍意义上讲,大致可以分为三个阶段:起手.飞行.碰撞(爆炸). [特效可见性判断] 1.[attacker & victim] ...
- 在moba游戏里面模拟实现绝地求生毒雾圈功能
---恢复内容开始--- 已经有很长一段时间没做项目了上半年大多数时间都荒废在王者荣耀,哈哈,S8赛季也上了王者,美滋滋 转回正题,公司需要开个新项目,需要把原有的moba游戏,改成类似绝地求生那玩法 ...
- MOBA游戏学会这些知识,你才算真的入门了!
<英魂之刃口袋版>是一个标准的MOBA游戏,MOBA指的是多人在线战术竞技游戏,游戏模式始于1998年<星际争霸>中的一张自定义地图,经过近20年的优化和调整逐渐演变成了我们现 ...
- 王亮:游戏AI探索之旅——从alphago到moba游戏
欢迎大家前往腾讯云+社区,获取更多腾讯海量技术实践干货哦~ 本文由云加社区技术沙龙 发表于云+社区专栏 演讲嘉宾:王亮,腾讯AI高级研究员.2013年加入腾讯,从事大数据预测以及游戏AI研发工作.目前 ...
- 知道创宇研发技能表v3.0
知道创宇研发技能表v3.0 2015/8/21 发布 by @知道创宇(www.knownsec.com) @余弦 & 404团队 后续动态请关注微信公众号:Lazy-Thought 说明 关 ...
- Unite 2017 | 从《闹闹天宫》看MOBA游戏里的网络同步技术
http://mp.weixin.qq.com/s/0v0EU79Q6rFafrh8ptlmhw 在Unite 2017 Shanghai案例分享专场,来自蓝港互动<闹闹天宫>项目组的主程 ...
- MOBA游戏的网络同步技术
转自:http://www.gameres.com/750888.html 在5月13日Unite 2017 案例分享专场上,蓝港互动<闹闹天宫>项目组的主程序陈实分享了MOBA游戏的网络 ...
- Scut游戏服务器引擎6.0.5.0发布-支持C#脚本
1. 增加C#脚本支持2. 增加Pay和Sns中间件对Mysql数据库支持3. 精简布署步骤,取消Redis写入程序,将其移到游戏底层运行4. 修正Mysql对中文可能会出现乱码的BUG 点击下载:S ...
- AI-Info-Micron-Insight:将您的游戏技能变成一份工作
ylbtech-AI-Info-Micron-Insight:将您的游戏技能变成一份工作 1.返回顶部 1. 将您的游戏技能变成一份工作 听起来不现实? 一位来自著名商学院的教授不这么认为.他认为,金 ...
随机推荐
- MYSQL数据库增量备份
MySQL数据库增量备份,在这之前修改我们的数据库配置文件/etc/my.cnf开启bin-log日志功能即可.接下来是我参考了下网上的一些方法,自己写的,主要还是要能学到他的一些思路和方法. #fu ...
- ceph-deploy出错UnableToResolveError Unable to resolve host
背景 ps:在本文中,假设我系统的hostname为node1. 使用ceph-deploy命令搭建Ceph集群,执行ceph new node1时,出现如下错误: [node1][INFO ] Ru ...
- CMD命令操作MySql数据库详解
第一:mysql服务的启动和停止 1. net stop mysql 2. net start mysql 第二:登录 mysql –u用户名 [–h主机名或者IP地址] –p密码 例如:mysq ...
- 算法-java代码实现快速排序
快速排序 对于一个int数组,请编写一个快速排序算法,对数组元素排序. 给定一个int数组A及数组的大小n,请返回排序后的数组. 测试样例: [1,2,3,5,2,3],6 [1,2,2,3,3,5] ...
- Web前端性能优化——如何提高页面加载速度
前言: 在同样的网络环境下,两个同样能满足你的需求的网站,一个"Duang"的一下就加载出来了,一个纠结了半天才出来,你会选择哪个?研究表明:用户最满意的打开网页时间是2-5秒, ...
- 使用vue框架运行npm run dev 时报错解决
使用使用vue框架运行npm run dev 时报错 如下: 原因: localhost:8080 有可能其他软件占用了,导致其他问题的出现 我们可以动态修改地址 解决: 进入项目文件的config文 ...
- tp5 url 线上访问 在nginx 上 出现404错误,解决办法(1.80nginx 配置 pathInfo)
对于ThinkPHP的URL访问路劲如:http://域名/index.php/Index/BlogTest/read,原先的Nginx的是不支持的pathinfo路劲的,导致你在thinkPHP ...
- Linux中rpm命令用法听语音
rpm 是红帽(RedHat)软件包管理工具,实现类似于 Windows 中的添加/删除程序功能.下面,就来向大家介绍 rpm 命令的用法. 工具/原料 CentOS 一.rpm常用参数 1 rpm ...
- 邓_Excal
--------------------------------------------------------------------- 快速输入固定文字 有一些固定的词组,输入 1 个.2 个,貌 ...
- ajax和跨域
一.简介 ajax是什么? AJAX(Asynchronous JavaScript and XML) 是一种在无需重新加载整个网页的情况下,能够更新部分网页的技术. AJAX, (异步的JavaSc ...