本文主要从一个程序员的角度阐述一下mmorpg服务器技能系统的程序框架设计,最近在做这个,就当做一个总结吧,其中某些概念可能没有解释清楚,欢迎大家拍砖讨论~

技能其实是战斗系统的一个组成部分,战斗基本上都可以由技能触发,技能系统实际上就是一套完整的逻辑,我们用表格来设计,将技能的逻辑用属性字段抽象出来,然后依据属性字段来控制逻辑,策划人员可以通过更改属性字段来配置出不同的逻辑属性。

1. 表格属性字段的设计

为了减少冗余,我们将技能属性字段设计在4个不同的表中:

Skill表:技能表的入口表,包括cast表,buffer表,op表,技能的释放需求,伤害

Cast表: 技能的释放过程表,包括技能吟唱时间,技能命中距离等等

Buffer表:各种人物状态,静态和动态的光环,效果等等

Status表:角色状态表,角色在状态下能使用或被使用的技能或者buffer

op表: 技能的伤害计算公式

skill表字段设计:

 
【转】MMORPG游戏服务器技能系统设计:表格字段与技能程序框架-LMLPHP

名称:技能名称,如火球术

技能id:技能id值

技能名称id:技能系,id一样表示一个系技能

技能类型:加血、物理攻击、魔法攻击、buffer、地图技能

公共CD时间:多个技能可以共cd,比如所有吃药技能

CD时间:cd时间

CD保存类型:cd时间在人物下线后是否保存数据库

需要角色等级:角色等级需求

 
【转】MMORPG游戏服务器技能系统设计:表格字段与技能程序框架-LMLPHP

角色状态限制:使用技能的角色状态限制,这个字段需要斟酌以后重新设计成一个表格

需要武器:技能释放需要的武器类型,如弓,刀,剑等等

消耗类型:需要消耗,如hp,mp,xp等等

消耗数量:hp,mp,xp的消耗数量

是否有益:是否是有益技能

技能属于:生活技能、装备技能、职业技能等等

升级技能:改技能的升级技能

调用cast表:调用cast表的id号

 
【转】MMORPG游戏服务器技能系统设计:表格字段与技能程序框架-LMLPHP

调用describe表:调用技能描述表id号

影响形状:范围技能的影响范围,直线、圆、扇形

影响个数:范围技能影响的npc个数

Buffer1:技能触发的buffer1

概率1:技能触发buffer1的概率

Buffer2:技能触发的buffer2

概率2:技能触发buffer2的概率

 
【转】MMORPG游戏服务器技能系统设计:表格字段与技能程序框架-LMLPHP

伤害效果:技能产生的伤害

调用op表计算效果:op表中数值计算的公式

是否产生伤害仇恨:是否产生仇恨值

携带仇恨:技能产生的仇恨值

cast表字段设计:

 
【转】MMORPG游戏服务器技能系统设计:表格字段与技能程序框架-LMLPHP

名称:cast表对应技能名称

是否对地释放:是否对地释放

是否对他人释放:是否可以对他人释放该技能

是否对自己释放:是否可以对自己释放该技能

是否前摇打断:前腰是否可以打断

前摇时间:动画前摇的时间

飞行时间:魔法的飞行时间

持续施法时间:技能的施法时间

 
【转】MMORPG游戏服务器技能系统设计:表格字段与技能程序框架-LMLPHP

吟唱时间:吟唱时间

释放距离:释放技能距离目标的距离

技能命中:技能命中率

命中最大距离:指向型技能当目标出了fire区域就不受攻击了

buffer表字段设计:

 
【转】MMORPG游戏服务器技能系统设计:表格字段与技能程序框架-LMLPHP

名称:对应skill表中的技能名称

Id:buffer id

效果nameID:表示一个系列的buffer

类型:静态、动态、状态buffer

是否有益:是否有益处

角色状态:加了buffer后角色处于的状态,如沉默,天神下凡,嗜血等等

伤害效果:buffer的伤害

调用op表:指向op表中的公式id

动态次数:对应动态buffer生效次数,对静态buffer无效

 
【转】MMORPG游戏服务器技能系统设计:表格字段与技能程序框架-LMLPHP

生效间隔:对应动态buffer每次生效的间隔时间,静态buffer无效

持续时间:对应静态buffer的持续时间,-1表示永久buffer

产生buffer:某些 buffer可以给队友或敌人加

影响范围:buffer影响的范围

是否可以移除:对应驱散技能

移除类型:对应驱散技能等级

是否可以覆盖:同类型buffer是否可以覆盖,还是效果叠加

 
【转】MMORPG游戏服务器技能系统设计:表格字段与技能程序框架-LMLPHP

覆盖类型:大的覆盖小的

是否需要from:计算效果时是否需要buffer来源。

status表字段设计:

 
【转】MMORPG游戏服务器技能系统设计:表格字段与技能程序框架-LMLPHP

状态名称:角色的状态名称,如沉默,死亡,天神下凡等等。

状态id:角色状态的id号

角色动作最大值:在该状态下可以使用或者被使用的技能的最大值,如无敌不能受伤害;

角色动作最小值:在该状态下可以使用或者被使用的技能的最小值,如无敌不能受伤害;

状态最大值:在该状态下,可以被使用buffer的最大值;

状态最小值:在该状态下,可以被使用buffer的最小值。

2.技能程序框架

技能的表格属性字段我们已经设计好了,可以满足策划短期需求了,接下来我们来设计一下技能程序的框架。

技能系统服务器和客户端是有交互的,具体流程看下图:

 
【转】MMORPG游戏服务器技能系统设计:表格字段与技能程序框架-LMLPHP

服务器要通知客户端是否能释放技能,吟唱时间,技能命中结果,伤害数字,服务器还要广播技能释放结果,让同区域的玩家可以看到别人在释放技能。

需要立即同步的。

1. hp,众所周知;

2,角色状态,角色的各种状态,比如天神下凡,沉默,死亡。

不需要同步的。

角色属性改变,如力量,敏捷等角色属性。

ps:服务器和客户端同一套代码,客户端进行预判,除了血量和角色状态服务器向客户端发同步消息,其他属性改变可以不发消息,这样可减少服务器和客户都的消息数量。

代码的结构设计

 
【转】MMORPG游戏服务器技能系统设计:表格字段与技能程序框架-LMLPHP

这里只画一个简单结构,将每个table抽象为一个table_data,然后在game_char中组合起来。

04-13 13:59