基于触发机制的脚本系统

转载 2015年07月08日 21:41:04


#一直对一些诸如新手指引、剧情对话之类的系统无语,因为跟游戏的很多个系统之间的耦合太大,代码写起来很是麻烦,之前想过一些比较取巧的实现方式,但面对各种需求时改的面目全非,看到下面这篇文章,深有启发,在此先记下。#


1.问题

  绝大多数游戏项目都会开发新手引导,剧情之类的功能。这类功能有两个最大的特点:一是跳跃大,二是特殊化。一个完整的功能(如一段教学指引)需要在多个逻辑系统中跳转,并且具体形为的触发条件千差万别,需要很多特殊处理。这类功能实现对程序结构的挑战巨大,如果没有统一规划,很容易掉入Hard-Code的深渊。


  2.脚本系统


  解决这类问题的一个较好方法是抽象功能形为与触发事件,形成离散的形为(Action)集与事件(Event)集,然后通过脚本的形式组织成一个个完整的功能。为了以最干净的方式实现上述目的,我们只需要抽象两个概念,即上面提到的:行为(Action)与事件(Event)。一个行为只需要配置两个事件表达式:开始事件与结束事件即可明确指示其行为的执行时机。

基于触发机制的脚本系统


  开始事件表达式必须存在,否则行为无法开始执行;结束事件表达式可为空,取决于当前行为是否有“自结束”方式。另外,为了实现行为动作的组织,系统需要实现一个非常重要的事件:

  EventActionEnd:ID[ 额外参数列表]

  该事件在指定ID的行为结束后发出,这样就可以利用此事件统一的组织触发脚本,一个触发脚本本质上就是由上述表格中若干具有逻辑相关性的行组成的集合。

  到此,我们就可以完整描述一个具体的行为动作的执行过程:

基于触发机制的脚本系统


  3.应用

  上述对Action的实现方式采用常用的“三段式”:Begin(), Update(), End()。这样做的好处是Action的实现者可以实现三种形为方式:

  1) 实现单帧的“瞬时行为”;

  如瞬间给一个玩家加血可实现为一个瞬时行为。

  2) 实现跨帧的“持续行为”;

  如将怪物从A点移动到B点可实现为一个持续行为。

  3) 实现接受用户操作的“交互形为”。

  如剧情中要求用于作出选择可实现为一个交互形为。

  这些形为方式特别适合新手引导或者剧情之类的功能需求。

  另外事件的检查不局限于单一事件,而是事件表达式,这样方便组织逻辑结构。下面抽象一些常用的执行流程形式,再给出运用此脚本系统的表达方式:

  1) 顺序执行

基于触发机制的脚本系统


基于触发机制的脚本系统


  2) 分支执行

基于触发机制的脚本系统


基于触发机制的脚本系统


  上述分支很容易扩展成多分支,实现类似switch-case的执行结构。

  3) 循环执行

基于触发机制的脚本系统


基于触发机制的脚本系统


  4) 逻辑判断

基于触发机制的脚本系统


基于触发机制的脚本系统


基于触发机制的脚本系统


  如何应用到新手引导与剧情

  可以理解为每段新手引导或剧情都是一个脚本,一个脚本就是上述表格的若干行。一个脚本在游戏系统中需要给定一个唯一标识,通过外围游戏逻辑规则按需加载指定脚本处于WAITING-RUNNING状态。这样一段引导逻辑就进入游戏中,但它需要一定的事件去触发。我们可以实现任意有意义的事件在游戏中的任何地方,如打开一个界面时抛出一个事件,关闭一个界面时抛出事件,点击一个按钮时抛出一个事件,抛出事件是随心所欲的,只要有需要就可以。

  典型地,抛出一个事件只需要在任意地方添加一行代码,如:

  noxssSystem.Instance.Trigger(EventClickUI, “uiName”);

  这样事件被异步的发送出去,抛出事件的执行代价可忽略不计。如果玩家在当前游戏进程中没有加载任何脚本,这个事件很快被丢弃;如果有脚本加载,此事件会尝试去触发脚本中行为的执行。这样可以做到新手引导对系统的最小化开销。

  4.小结

  通过统一的触发脚本系统,可以完成任意的逻辑脚本开发,包括新手引导,剧情,甚至客户端AI等;同时减少某些“跳跃大,特殊化”功能需求对程序结构的破坏,避免HardCode的产生;脚本形式统一简单,可以通过excel形式编写,也利于开发可视化编辑器。


原文地址

相关文章推荐

第十一章 BIRT数据绑定与脚本,事件机制详解 .

11.1 事件机制详解 前面通过脚本获取数据源,以及在报表中利用单元格或者数据项的onRender方法添加脚本来增加交互性,或者直接在脚本编辑器中书写少量代码,或多或少的都利用到了BIRT的脚本和事...

浅析Lua脚本:MySQL Proxy工作机制

MySQL Proxy处于客户端应用程序和MySQL服务器之间,通过截断、改变并转发客户端和后端数据库之间的通信来实现其功能,这和WinGate之类的网络代理服务器的基本思想是一样的。代理服务器是和T...

第十一章 BIRT数据绑定与脚本,事件机制详解(续) .

下面以一个例子来介绍怎么在BIRT设计器中添加JAVA事件处理。在 Eclipse 中创建一个单一工程,引入样例报表,使用 Java 语言实现报表事件响应处理程序。引导读者在短时间内对百灵报表(BIR...

脚本语言和JAVA语言运行机制的区别

脚本语言和JAVA语言运行机制的区别脚本语言 脚本语言一般都有相应的脚本引擎来解释执行,需要解释器才能运行。脚本语言有很多种,解释器也有很多种,所以不同的脚本需要不同的解释器,只有脚本与解释器对...
  • YS0813
  • YS0813
  • 2017年03月20日 23:45
  • 518

Lua游戏脚本热更新机制

Lua游戏脚本热更新机制 ¶ 设计要点¶ 能够在服务器运行期间更新程序逻辑代码以实现修正程序Bug、修改游戏数据的目的。游戏框架代码的热更新暂不考虑。例如: 某个业务处理函数逻辑有Bug,服务...

不同脚本操作cookie的机制探究

一直在思考一个问题,js是运行在客户端的脚本,当然可以通过浏览器建立和读取本地cookie;但php是运行在服务器的脚本,它是如何操作cookie的呢,毕竟cookie是用户的本地文件,却被运行在服务...

中国银联对圈存脚本及冲正机制的建议

圈存脚本执行失败,是否一定要冲正?要分是什么情况。先来看看脚本的格式:...

[php-fpm自动拉起]从nginx的502错误出发谈锁机制在服务器自动监控脚本中的应用

由于负载能力无法满足需求,纸飞机服务器从去年7月开始迁移到nginx服务器,不过PHP 5.2上安装了eAccelerator扩展后服务器经常发生500错误,无奈升级到了PHP 5.3系列,虽然说50...

浅淡Win32 系统级异常处理机制

  • 2016年09月24日 00:50
  • 125KB
  • 下载

linux系统监控机制分析与实现

  • 2014年04月15日 12:01
  • 108KB
  • 下载
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:基于触发机制的脚本系统
举报原因:
原因补充:

(最多只允许输入30个字)