注:本分享主要面向策划,重点介绍GAS框架的思想,以期拓展技能机制的设计思路,其中设计技术实现的部分,可参见:

在文中如果出现UE4中实现的注意事项,会用(UE_Note)标记。

 GasShooter演示项目的示例文档。

https://docs.unrealengine.com/zh-CN/InteractiveExperiences/GameplayAbilitySystem/index.html 官方GAS文档

当然最好的文档是源码: Plugins/Runtime/GameplayAbilities/

技能系统应该包括哪些功能?

逻辑:

技能的获得和施放。

各种触发效果、条件判断。

Buff系统

视听效果:

角色动画

特效

音效

数据:

属性系统

数据配置

 GAS框架的主要组成   :

  

  

GAS框架如何实现技能需求:

技能的所有者:AbilitySystemComponent。

技能的逻辑:GameplayAbility。

技能效果:GameplayEffect。

技能修改的属性:AttributeSet。

技能涉及的条件:GameplayTag。

技能视频音频:GameplayCue。

技能的异步行动:GameplayTask。

技能目标:GameplayTaskActor。

其中,GameplayTask和GameplayTag是UE4Gameplay框架原有的概念,但在GAS框架中被深度使用。

GAS框架的优缺点:

这张图摘自2020UOD的演讲PPT,列出了EpicGames大钊看来GAS框架的优势和劣势。

        GAS框架的一个主要优势,在于将一个技能的各个逻辑进行了适当的解耦设计,大幅降低了思考粒度,比如在设计一个技能的输入规则、选目标操作、何时触发效果时,不需要考虑效果的具体内容,甚至可以交给另一个完全不了解技能规则,但负责设计效果和数值的人来配置,而不用担心互相之间会产生影响。这点在实际使用时会带来相当大的便利,即时是一个人开发,同一时间也可以专心于一项任务,不用担心会影响之前或之后的工作。

          对虚幻使用的DS网络框架来说,GAS实现了较为完善的网络同步和预测机制,几乎所有会影响技能表现的逻辑都实现了客户端的预测及回滚功能。