游戏开发论坛

 找回密码
 立即注册
搜索
查看: 19169|回复: 10

[分享] 一个数值框架,让效率提升10倍!

  [复制链接]

1万

主题

1万

帖子

3万

积分

论坛元老

Rank: 8Rank: 8

积分
36572
发表于 2016-8-31 13:33:50 | 显示全部楼层 |阅读模式
文/张小勇

  刚入行的时候,我调整一版完整的数值需要将近一周的时间,几个EXCEL之间来回切换查看再汇总统计让我十分忙乱,按照新的规划重新计算大量的数值让我非常疲惫,填写几十份的配置表让我无比痛苦。后来我不断地优化自己的数值框架,把一些EXCEL和VBA能处理的问题全部在框架中一次性解决,现在我只需要用半天就能调整一版完整的数值,效率提升了10倍。我的数值框架将我从“高级填表员”的工作中解救出来,让我能够将更多的时间和精力放在数值体验上,我的工作效率和质量都提高了一个档次。

  本文将分享一套以战斗为主的数值框架,讲述一下做数值框架的思路和方法,希望能对大家有所帮助。

  前期工作

  一般而言,我做数值框架会从确定属性种类和战斗公式开始。

  属性种类

  很多游戏喜欢将属性分为一级属性和二级属性,这样做最大的好处是方便做出“加点”的玩法,但一般需要辅助以比较多的属性说明,否则玩家会比较难理解,你能直接看懂下面这张图中的几个一级属性代表什么意思么?

1.jpg

  因为我做的游戏都没有加点这个概念,所以我都是直接用生命、攻击、防御、暴击这些属性种类,自己做着方便,玩家也容易理解。

  几乎所有游戏中的属性类型都由血攻防这样的基础属性和暴击格挡穿透之类的高级属性组成,个人建议再规划一个“超级属性”。“超级属性”指的是对PVP有决定性影响且十分难升满的属性,超级属性可以承载大R玩家的追求和消费,比如《拳皇98OL》在传统卡牌的基础上将“先手值”独立出来作为“超级属性”,其中很多的大R玩家为了追求“先手值”这一项属性消费了几万甚至十几万。

  战斗公式

  战斗公式不是本文的重点,相关的文章也很多,不再细述,简单说几点自己的体会:

  1.没有最好的,只有最合适的:刚入行的时候觉得像《WOW》、《暗黑》之类的战斗公式才叫牛逼,第一次看到damage=atk^2/(atk+def)的时候虽然看不懂,但是感觉简直屌爆了。当时最鄙视的就是减法公式,damage=atk-def,尼玛小学生都会算,一点都不高端。后来发现《放开那三国》用的是减法、《传奇》用的是减法、畅销榜恶霸《梦幻西游》用的也是减法,自己用了一次之后才深深地体会到了减法公式易做反馈、适合做小差距、适合做小数值的特点,拿来做MMORPG十分好用。但如果是做MOBA,需要计算大量的平衡关系,就最好选用damage=atk*(c/(def+c))这种公式,因为这种公式下确定一个英雄的强弱只需要这个英雄自身的属性就可以。

  2.关键在于怎么用: 同样是减法公式,《传奇》和《传奇xxx私服》的体验完全不同。合适的公式确实会让之后的工作舒爽一些,但最终的体验如何还是要看如何使用。

  3.多动手: 网上有很多战斗公式相关的文章,一般都是写一下公式,找个例子算一下,再做几个函数图,最后总结一下。我自己就看了很多这样的文章,收获不小,不过还是有很多疑惑没有解开。其实很多时候遇到公式上的疑惑,自己算一算,对比对比,在相关游戏中跑一跑,会获得更深入更透彻的理解。

  数值框架中要明确地列出都有哪些属性和这些属性的详细说明,也要将详细的伤害判定流程和伤害计算公式写出来。这样既能防止自己不小心遗忘,也能方便以后的交接。下面这张图是个简单的展示:

2.jpg

  职业设定

  职业设定一般而言有三个基本的目的:

  1.职业之间相对平衡(或是循环克制)

  2.职业差异化:不同职业的作用和体验不同

  3.整体战斗体验好:战斗节奏好,战斗时长能够接受

  在数值框架中职业设定主要包含两大模块:属性模型,技能设定。

3.jpg

  属性模型主要是为了方便调整平衡、战斗时长和职业差异化,其本质就是各职业属性的比例关系,个人的习惯是将属性模型中加入【技能输出系数】和【技能生存系数】两个数值,分别代表算上技能之后输出会变为几倍和生存能力会变为几倍,然后在技能设定中根据这两个系数去调整具体的技能数值。

  技能设定时,需要运算多种技能的实际数值影响。其中倍数伤害、属性类buff、眩晕等类型的技能是可以直接转换成有效输出的,相对比较好算,如果不会的话找个数值策划群问一下就可以。而类似于加速、位移、陷阱之类的技能难以量化,需要不断地实测调整。各种技能的具体处理方式不再展开描述。

  一些游戏将不同职业的属性比例做的完全相同,然后通过技能设定达到平衡和差异化的目的,十分简单粗暴,各位可以尝试用一下。

  属性分配

  个人习惯用最大模型和系统分配比例来做不同系统间的属性分配,再在各个系统内细调,这样做的好处是大的改动比较快,细节体验也能调。

  系统间分配

  为了方便说明,我们假设不同职业的属性比例现在完全相同,这样我们只需要做一套最大模型。将最大属性模型中的每一项属性与对应的各个比例相乘即可得到每个系统应分配的具体属性。大致结构如同下表:

4.jpg

  说是“最大”属性模型,但往往扩展系统时会发现属性不够大,因此到后期属性比例中一些属性的比例总和会超过100%。

  最大属性模型一般都是通过将职业直接放大得到,但要注意一些公式将各职业属性等比放大后会破坏平衡,比如damage=atk*(c/(def+c))。


  系统内分配

  某个系统的的属性分配主要包含4个模块:

  1.可分配属性:对应系统间分配出来的属性、

  2.分配思路:文字描述,记录自己在这个养成系统是用怎样的思路分配每级的属性的,否则到后面自己都会忘记为何这样分配,如果有特殊的计算公式的话我也会记录在这里。

  3.分配参数:即使是几百上千级的成长,也可根据几个参数和公式来调控。

5.png

  4.最终属性表:通过上面三个模块计算得出的最终结果,如下图

6.png

  经济关联

  做经济系统时,我会将每天把消费产出全部拿完的玩家定为标准玩家,然后可以通过产出和消耗预算出标准玩家的成长情况。因为没有办法确定玩家具体会进行什么样的操作,所以这里的一切计算都是估算,比如玩家可能优先把材料全用来升武器,也可能材料全都放背包里不用,没有办法确定,所以我就按照玩家将所有材料平均分配到每一件装备上培养来估算玩家的装备培养等级。

  所有系统的经济做完后,我们可以得到一张表,里面有玩家在每个等级时各个养成系统的等级和玩家的总属性,类似下图:

7.jpg

  怪物属性

  有了通过经济关联算出的玩家属性,我们可以很轻松地得出各个等级对应的每种怪物属性。为了调整方便,我用怪物被玩家打时的生存时间和怪物打死玩家要用的时间来做参数。最终会得到一个类似于下图的表:

8.jpg

  如果没有特殊需求的话,所有怪物都可以从这个表中直接取值。

  做怪物数值时需要注意的点:

  1.上图中的表格没有技能,实际使用时需要注意技能的计算

  2.没有特殊需求的话,就将所有种类怪物的防御统一为一个值,比如玩家攻击的80%或是直接用0。

  3.表中是以“格斗家”为标准做的怪物数值,在一些职业特性比较强的游戏中需要注意各个职业的战斗体验,否则可能出现治疗职业半分钟杀一个小怪之类的问题

  配置导出

9.jpg

  将计算结果按照配置的形式关联到另一张表,然后通过VBA导出配置表,并不是很难,一会提供代码,先简单说下使用我的导出需要注意的地方:

  1.要在b1单元格填入导出后的表名

  2.需要导出的工作表的命名中需要有“-3”

10.jpg

  3.代码的本质是将第六行以下所有有内容的单元格复制到另一个EXCEL中,并将该EXCEL重命名存在与数值框架相同路径下的output文件夹中

  4.用这种方式导出的表需要另建一个文档写相关的配置说明

  5.需要注意一些美术资源的配置

  6.要养成在数值框架中改表导出的习惯

  这个导表VBA并不是很强大,使用不熟练时很容易出错,但一旦用顺手之后效率会提升很多倍。

  VBA代码如下:
  1. Sub 单表导出()

  2.     If Dir(ThisWorkbook.Path & "\output", vbDirectory) = "" Then

  3.         MkDir (ThisWorkbook.Path & "\output")

  4.     End If

  5.    

  6.     If ActiveSheet.Name Like "*-3*" Then

  7.         With ActiveSheet

  8.             a = .Range("a65535").End(3).Row

  9.             b = .Range("IV6").End(1).Column

  10.             arr1 = .Range(.Cells(6, 1), .Cells(a, b))

  11.             

  12.             Filename = .Range("b1")

  13.         End With

  14.         If Filename = "" Then

  15.             MsgBox (Sheets(i).Name & "中的表名为空")

  16.             i = Sheets.Count

  17.         End If

  18.         

  19.         For Each xls In Workbooks

  20.             If xls.Name = Filename & ".xlsx" Then

  21.                 xls.Close

  22.             End If

  23.             

  24.         Next

  25.                

  26.                 Dim wb As Workbook

  27.         Set wb = Workbooks.Add

  28.         wb.ActiveSheet.Range(Cells(1, 1), Cells(a - 5, b)) = arr1

  29.         

  30.         Application.DisplayAlerts = False

  31.         wb.SaveAs ThisWorkbook.Path & "\output" & Filename & ".xlsx"

  32.         Application.DisplayAlerts = True

  33.    

  34.         wb.Close

  35.     End If

  36. End Sub

  37.   

  38. Sub 导出()

  39.     If Dir(ThisWorkbook.Path & "\output", vbDirectory) = "" Then

  40.         MkDir (ThisWorkbook.Path & "\output")

  41.     End If

  42.    

  43.     For i = 1 To Sheets.Count

  44.         If Sheets(i).Name Like "*-3*" Then

  45.             With Sheets(i)

  46.                 a = .Range("a65535").End(3).Row

  47.                 b = .Range("IV6").End(1).Column

  48.                 Filename = .Range("b1")

  49.                 arr1 = .Range(.Cells(6, 1), .Cells(a, b))

  50.             End With

  51.             If Filename = "" Then

  52.                 MsgBox (Sheets(i).Name & "中的表名为空")

  53.                 i = Sheets.Count

  54.             End If

  55.             

  56.             For Each xls In Workbooks

  57.                 If xls.Name = Filename & ".xlsx" Then

  58.                     xls.Close

  59.                 End If

  60.                

  61.             Next

  62.                     

  63.             

  64.             Dim wb As Workbook

  65.             Set wb = Workbooks.Add

  66.             wb.ActiveSheet.Range(Cells(1, 1), Cells(a - 5, b)) = arr1

  67.             

  68.             Application.DisplayAlerts = False

  69.             wb.SaveAs ThisWorkbook.Path & "\output" & Filename & ".xlsx"

  70.             Application.DisplayAlerts = True

  71.         

  72.             wb.Close

  73.         End If

  74.     Next i

  75.    

  76. End Sub
复制代码


  其他

  1.数值框架中包含游戏中所有的数值,后期框架中将有很多个工作表,建议做一个目录

  2.根据自己的需求去设计框架结构,少做无用功。我曾经为了结果准确,做了个很复杂的战斗模拟器,做完时程序的战斗模块已经做完了,之后我再全都是配到游戏中直接体验,再也没有用过这个模拟器。

  3.用颜色区分一下内容的类型,但不要用太多的颜色。

  4.实际应用时记得在框架中体现出不同层次玩家的数据,这样可以帮助你猜想各类玩家的体验

  结语

  文章中的截图是我临时做的一个简化框架,其中只做了“格斗家”一个职业的详细数值,但功能基本是完整的。仅供各位参考,欢迎各种交流~

  相关阅读游戏战斗数值框架搭建入门

via:GAD

1

主题

92

帖子

1577

积分

金牌会员

Rank: 6Rank: 6

积分
1577
发表于 2016-8-31 13:43:25 | 显示全部楼层
好文章~~谢谢楼主分享

17

主题

191

帖子

2556

积分

金牌会员

Rank: 6Rank: 6

积分
2556
QQ
发表于 2016-8-31 15:59:57 | 显示全部楼层
入门级的精品文章,也算是干货。

0

主题

114

帖子

753

积分

高级会员

Rank: 4

积分
753
发表于 2016-8-31 22:26:23 | 显示全部楼层
实用的文章。所谓的数值框架其实核心就是体验可控。
战斗数值就是标准回合,以及如何维持这个标准回合的稳定。
经济数值就是产出消耗,以及如何把控产出消耗的比例。

0

主题

302

帖子

1148

积分

金牌会员

Rank: 6Rank: 6

积分
1148
发表于 2016-8-31 22:56:38 | 显示全部楼层
不错不错~支持楼主

0

主题

2

帖子

30

积分

注册会员

Rank: 2

积分
30
发表于 2016-9-1 11:45:09 | 显示全部楼层
关于技能方面还可以详细点么

1

主题

47

帖子

188

积分

注册会员

Rank: 2

积分
188
发表于 2016-9-1 14:51:51 | 显示全部楼层
楼主的数值设计思路跟我个人的常规做法惊人一致,相似率达到95%以上。。。
所以看这个文章基本上是在看我自己的设计思路。。
不过楼主也提醒了我一点:可以把自己的思路写下来,在求职的时候会更容易让人了解你的想法和能力。
至于楼上说的技能,我狗尾续貂的补充一个思路:
1.首先,确定你的技能(以单个技能为例)在一场战斗中的输出占比D;
2.计算普通攻击对标准敌人所能造成的伤害值A;
3.设定以下值:普通攻击频率X,和技能冷却时间Y(即技能攻击频率),,技能攻击敌人所能造成的伤害值为B,一场战斗时间为T;
则:D=技能全局伤害/(普攻全局伤害+技能全局伤害)=(TB/Y)/(TA/X-TA/Y+TB/Y)=(B/Y)/(A/X-A/Y+B/Y),最后算出B=DA(Y-X)/X(1-DA)
设D=0.5,Y=4X        则:B=A(Y/X-1)/(1-d)        推出B=6A        
也就是说,当你的技能(以单个技能为例)在一场战斗中的输出占比50%,且技能冷却时间Y=4X(X是普通攻击频率)的时候,技能攻击伤害值B=6A(A是普攻)

当然,技能还分单攻群攻,在做数值的时候还分与自身攻击关联加成,还分各种复合、奇葩技能,那就只能逐一细化了

0

主题

33

帖子

229

积分

中级会员

Rank: 3Rank: 3

积分
229
发表于 2016-9-3 15:09:46 | 显示全部楼层
入门级干货,给楼主提个小小的建议,既然你都已经在用VBA了,那么不妨在做怪物属性的时候,可以做个战斗模拟器,因为往往随着属性的变多,战斗公式本身也会变得复杂,你很难通过一个战斗计算公式控制平衡,此时最好的做法就是做个战斗模拟器,模拟他个1W场次,看胜率,看累计战斗结束血量差值。

我说的这些东西,玄学策划肯定都看不懂。

0

主题

20

帖子

159

积分

注册会员

Rank: 2

积分
159
发表于 2016-9-4 08:21:52 | 显示全部楼层
职业设定的三个基本目的中“3.整体战斗体验好:战斗节奏好,战斗时长能够接受”不是很明白。为什么有职业就战斗节奏好了?以及对战斗时长的影响。

2

主题

6

帖子

40

积分

注册会员

Rank: 2

积分
40
发表于 2016-9-7 09:49:05 | 显示全部楼层
不错,值得学习一番
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

作品发布|文章投稿|广告合作|关于本站|游戏开发论坛 ( 闽ICP备17032699号-3 )

GMT+8, 2025-4-29 16:24

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

快速回复 返回顶部 返回列表