如何设计一个易扩展的游戏技能系统?

简介:

如何设计一个易扩展的游戏技能系统?


技能没什么框架,只是有很多字段罢了,比如cd、施法距离、释放动画、飞行动画等等。。。其实游戏技能不是一直不是什么难点,毕竟根据每个属性实现逻辑就好了。

技能真正麻烦一点是其实是 所谓的“效果”。因为从很久以前,游戏设计的时候就把效果这个概念添加进来了。对于 游戏战斗对象主体,我们暂时叫做BattleAgent简称BA。影响BA的数据有很多,比如移动速度、攻击力、基础属性等等,影响的入口也有很多:

  • 技能
  •  buff/被动技能
  • 装备
  • 强化
  • 宝石

等等,而这些实际上从影响结果没什么区别。

首先我们先谈区别,对于这些数值影响,其实区别只有入口或者说是作用的方式,技能是BA(castor)对BA(target)释放造成的瞬间数值影响。

buff是castor对BA(target)安装后造成的持续数值影响,分为按时触发瞬发和持续修改数值。

装备是特定容器对BA持续修改数值。

所以这里游戏开发者们抽象出了 效果这个概念。

对与效果而言,只存在2个行为:

对BA产生数值影响

对BA撤销数值影响

所以效果最终定义为:


 
 
  1. interface Effect { 
  2.  
  3.     void cast(BattleAgent target); 
  4.  
  5.     default void reverse(){ 
  6.  
  7.     } 
  8.  

而对于其他功能实体来说,就可以简化为效果的容器:


 
 
  1. interface EffectContainer extends Effect{ 
  2.  
  3.     List getEffects(); 
  4.  

这样我们就只要定义不同效果容器就可以了,

比如技能:


 
 
  1. class abstract  Skill implements EffectContainer{ 
  2.  
  3.     public void spellTo(BattleAgent target){ 
  4.  
  5.         foreach(Effect effect in getEffects()){ 
  6.  
  7.             effect.cast(target); 
  8.  
  9.         } 
  10.  
  11.     } 
  12.  

对于buff:


 
 
  1. class abstract Buff implements EffectContainer{ 
  2.  
  3.     public void update(){ 
  4.  
  5.         foreach(Effect effect in getEffects()){ 
  6.  
  7.            effect.cast(target); 
  8.  
  9.         } 
  10.  
  11.     } 
  12.  

对于被动技能(其实也是buff):


 
 
  1. class abstract  BuffSkill extends Buff { 
  2.  
  3.     public void install(){ 
  4.  
  5.         foreach(Effect effect in getEffects()){ 
  6.  
  7.             effect.cast(target); 
  8.  
  9.     } 
  10.  
  11.  
  12.     public void unstall(){ 
  13.  
  14.         foreach(Effect effect in getEffects()){ 
  15.  
  16.             effect.reverse(target); 
  17.  
  18.         } 
  19.  
  20.     } 
  21.  

装备同理被动技能,是不是很清晰?而对于复杂的技能效果,因为我们已经抽象出了Effect。

所以怎么实现也就很容易了!


 
 
  1. class DamageEffect implements Effect{ 
  2.  
  3.     private int damage = 100
  4.  
  5.     public void cast(BattleAgent target){ 
  6.  
  7.         target.hp -= damage; 
  8.  
  9.     } 
  10.  

看起来是不是很简单,我们来写个变羊。

这个技能包括 2 个效果 外形修改和属性。

1、外形变羊


 
 
  1. class ChangSheepEffect implements Effect{ 
  2.  
  3.     public void cast(BattleAgent target){ 
  4.  
  5.         target.gameObject = GameManager.getAnimeObject("sheep"); 
  6.  
  7.     } 
  8.  

2、攻击力和防御力变0 速度变慢


 
 
  1. class PropChangeEffect implements Effect{ 
  2.  
  3.     public void cast(BattleAgent target){ 
  4.  
  5.         target.atk = 0
  6.  
  7.         target.def = 0
  8.  
  9.         target.speed = 50
  10.  
  11.     } 
  12.  

就是这么简单,同学你明白了吗?

如果要深入一点的话,就是变羊是持续型的,到了时间会变回来。

所以我们要一个可以触发buff的效果:


 
 
  1. class TriggerBuffEffect implements Effect{ 
  2.  
  3.     BuffSkill buff = new BuffSkill (){ 
  4.  
  5.         public List<>getEffects(){ 
  6.  
  7.             return new List().add(new ChangSheepEffect()).add(new PropChangeEffect()); 
  8.  
  9.         } 
  10.  
  11.     } 
  12.  
  13.     public void cast(BattleAgent target){ 
  14.  
  15.         int time = 3000;//3秒 
  16.  
  17.         target.addBuff(buff,time); 
  18.  
  19.     } 
  20.  

然后把这个TriggerBuffEffect加到技能能上就ok了,就完成了一个可以变羊3秒的技能。


作者:suiling

来源:51CTO

相关文章
|
开发者
AppsFlyer 研究(十六)广告平台配置及代理商授权总结
AppsFlyer 研究(十六)广告平台配置及代理商授权总结
1174 0
|
25天前
|
人工智能 JavaScript API
解锁AI协同干活!OpenClaw阿里云/本地零基础部署接入免费API+集成Agent Teams配置及常见问题
2026年,AI Agent的进化方向从“单点执行”转向“团队协作”——OpenClaw(曾用名Clawdbot)借鉴Claude Code的Agent Teams核心逻辑,推出专属“多智能体协同框架”,支持创建由多个AI代理组成的“虚拟团队”,分工协作完成复杂任务。不同于传统单代理模式,Agent Teams让AI代理具备“自我协调、并行工作、互相通信”能力,可同时处理研究、开发、审查等多维度任务,效率提升3-5倍。
1328 7
|
机器学习/深度学习 缓存 人工智能
大语言模型中常用的旋转位置编码RoPE详解:为什么它比绝对或相对位置编码更好?
Transformer的基石自2017年后历经变革,2022年RoPE引领NLP新方向,现已被顶级模型如Llama、Llama2等采纳。RoPE融合绝对与相对位置编码优点,解决传统方法的序列长度限制和相对位置表示问题。它通过旋转矩阵对词向量应用角度与位置成正比的旋转,保持向量稳定,保留相对位置信息,适用于长序列处理,提升了模型效率和性能。RoPE的引入开启了Transformer的新篇章,推动了NLP的进展。[[1](https://avoid.overfit.cn/post/9e0d8e7687a94d1ead9aeea65bb2a129)]
2620 0
|
分布式计算 大数据 数据处理
浅谈几个经典大数据处理框架
【6月更文挑战第15天】本文介绍企业如何在数据洪流中保持竞争力需借助可扩展平台和数据策略。数据管道整合多元数据源,便于分析和流转。Kappa架构专注于实时处理(如通过Kafka、Spark Streaming),适合实时响应场景;Lambda架构结合批处理与实时处理(如Spark、Hadoop与Flink),平衡实时性和批处理,易于开发和维护。Apache Beam提供统一模型,适用于流处理和批处理,提升代码复用和效率。这两种架构满足现代应用对数据一致、性能和灵活性的需求。
1425 3
浅谈几个经典大数据处理框架
|
消息中间件 Java 编译器
面试官:说说Lambda表达式底层原理?
面试官:说说Lambda表达式底层原理?
246 3
面试官:说说Lambda表达式底层原理?
|
Python
游戏开发丨基于Pygame的贪吃蛇小游戏
游戏开发丨基于Pygame的贪吃蛇小游戏
585 2
|
JavaScript
Node.js的安装
这篇文章提供了Node.js的安装指南,包括从官网下载、安装步骤、验证安装是否成功,以及如何安装淘宝镜像加速器cnpm或使用淘宝npm镜像来加速npm包的安装过程。
Node.js的安装
|
传感器 物联网 Android开发
【Android App】物联网中查看手机支持的传感器及实现摇一摇功能-加速度传感器(附源码和演示 超详细)
【Android App】物联网中查看手机支持的传感器及实现摇一摇功能-加速度传感器(附源码和演示 超详细)
689 1
|
存储 Linux 数据中心
容器跨主机通信:Flannel网络实现机制分析(一)
容器跨主机通信:Flannel网络实现机制分析(一)
992 0