游戏开发论坛

 找回密码
 立即注册
搜索
查看: 2520|回复: 0

开发者谈互动角色行为设计的12条原则

[复制链接]

5万

主题

5万

帖子

8万

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
86234
发表于 2022-3-11 09:51:53 | 显示全部楼层 |阅读模式
(本文的两位作者以及Sophie Peseux共同创建了Virtual creatures,这是一家专注于行为设计的初创公司,致力于创造出具有深度互动性的NPC。)

简介

在科幻电影《她》中有个十分有趣的片段:主人公Theodore在玩一个AR游戏,突然,一个NPC朝他辱骂了起来。原本平淡无奇的路人角色突然展现出了真实的个性,这种意外的展开促使Theodore笑了出来,也引发了他的思考。他意识到这种行为是个谜题。于是他也骂了回去,最终Theodore解决了谜题,游戏冒险继续。

微信图片_20220311094053.gif

八年后,最先进的互动角色仍然无法提供类似于这样的体验。专业人士和玩家都一致认为,在2005年《极度恐慌》发行之后,角色AI一直没有实现质的突破。更糟糕的是,最近出版的游戏AI教科书明确指出角色AI的创新基本上是停滞不前了。如今,人们更感兴趣的领域是AI驱动的艺术创作、系统层面的AI应用等等。

现今大多数热门游戏都有某种类型的NPC。因此我们认为,角色AI创新的匮乏会成为未来游戏的创意瓶颈,但对于那些愿意尝试新方法的人来说,它或许会成为一个巨大的机会。因此,把这篇文章当作是互动角色探讨系列的开端,我们认为是比较合理的。如果说人们创造NPC这样的影响因素(agent)是为了让他们以特定的方式行动从而让玩家沉浸到游戏中,那么我们首先就要问自己影响因素的行为(agent behavior)具体是什么(这里的影响因素可以指动物也可以指人类)?

心理学和人工行为 (artificial behavior,AB)是我们学术研究的根基所在。在AB引擎上投入了这么多年的时间,我们总结出了行为的12种特性。我们可以把它们称作是“原则”——算是对迪士尼著名的“动画十二原则”的致敬吧。

有些是显而易见的,有些不太容易能够想到。重要的是,结合这12条原则,你能够将那些似是而非的东西排除掉。更重要的是,如果你想要创建一个AB引擎,让互动角色变得更“鲜活”一些,你就得确保引擎能够支持这12条原则。

原则1:行为是可目击的

微信图片_20220311094109.gif

首先,你可能会想到的是行为与用到的肌肉有关。就比如说你坐在一家高档餐厅里,等待着你的约会对象。你的手指在不断敲击桌面,你的心脏(这也是肌肉)在狂跳。

这意味着你在同时做两件事吗?并不算是。人的身体里有很多复杂的东西在做复杂的事情,但大部分都是外界无法感知的。就我们的目的而言,行为仅包括无需特殊仪器(如核磁共振扫描仪)就能观察到的事件。所以,如果你的心跳快到让你神经紧绷,最后不慎打翻了一杯橙汁,把自己的衣服弄脏了,这就是可以观察到的,也正是我们所说的行为。

对AB引擎来说, 这一原则带来了一种非常乐见的简化——我们不需要试图再造生命体,只需要再现它的外观。迪士尼称之为“生命的幻象”,而我们更进一步地称之为“互动生命的幻象”——在后续的系列文章中会详细展开。

原则2:行为是连续的

微信图片_20220311094110.gif

生命体从出生一直到死亡都有行为。人类的语言为我们提供了大量的术语,可以用来形容没有任何动作或发出任何可听见的声音的人。例如,我们可以说这个人在睡觉、坐着不动、屏住呼吸、装死,等等。

但这难道不与原则1冲突吗?并没有。因为即使一个影响因素什么都不做,我们也能从中观察到一些东西,比如Stephen Colbert坐在气球雨中的画面,你可以很容易地看出他保持坐定是一种熟练(而且可能是排练过)的行为表现。单纯的坐直动作需要协调使用几十块肌肉。从更笼统的意义上来讲,我们可以说影响因素产生了连续的行为流。因此,AB的问题在于如何在个体行为中生成这样的流,而且它要能起到承上启下的作用。

原则3:行为是交互式的

微信图片_20220311094111.gif

现实生活中并不存在没有互动的行为。比如说,与朋友玩耍需要回应他们的行为,攀岩需要调整手势。即使是最独立的行为也会涉及到情景,需要跟它互动。以呼吸为例,呼吸速率取决于大气中的氧气密度。如果我们把情景(氧气)剔除,行为(呼吸)就不再有意义了。

影响因素通过行为与世界建立联系,这就是为什么所有的行为都要是可以交互的。这也意味着互动行为、适应性行为或响应性行为之间是没有区别——这些词本质上都是在说“行为必须是有情景的”。对于AB引擎来说,这意味着所有行为需要程序生成——不幸的是如今大多数游戏都在做完全相反的事,这些游戏开发者倾向于从预先配置的行为包中组装行为流,如站立-循环、行走-循环、跳跃等等,它们之间的过渡很生硬。

原则4:行为是受到约束的

微信图片_20220311094112.gif

情景对行为施加了许多约束,以各种条件的形式塑造行为。目前来看,最重要的一种就是世界的物理构成——它给行动主体制造的阻力、它允许的声音传播的方式等等。

约束本身可以是主动的也可以是被动的,由此可以动态地引导影响因素的行为,往意想不到的方向发展。因此,AB必须超越单纯的程序选择行为,并为程序动画提供全面的支持,允许行为流动态地适应约束。

原则5:行为是有序的

微信图片_20220311094113.gif

AI教科书经常会区分“脚本化”和“无脚本化”的行为,暗示后者更好、更自然。在我看来是有点没道理的,因为实际中影响因素的行为多数是二者的结合。

人类大脑有专门的回路(游戏邦注:尤其是小脑)来存储参数化运动序列的巨大数据库。这些序列促使大脑更容易配置行为的标准形式。同时,这种序列对具体环境和动态情景的适应性很强。这就构成了一个强大的组合。它可以使用模板,在运行时只需要填入几个参数,而不是每次都要重新决定要移动哪些肌肉,何时以及要移动多少,来制作……比如说一个探戈。除了降低复杂性外,这种方法还促进了个体之间的行为同步,这也能够在一定程度上解释为什么真实的行为有时感觉像是脚本化的。像Rascal这样的AB引擎是从神经科学汲取了灵感,并将参数化、自适应的序列融入到架构中。

原则6:行为是可中断的

微信图片_20220311094115.gif

即使是计划最完善的行为,也不一定能在第一次与现实接触时就顺利执行。影响因素会一直改变他们的想法,他们的行为也得随之改变。我们在现实世界中观察到的这种细枝末节对AB来说却是一个艰巨的挑战,主要是因为原则2。中断不能是直接打断行为流,然后再开始一个全新的行为流。

对连续性和可瞬间打断的两种要求就像是拔河的双方,会造成一种紧绷的局势。此外,这种缺乏控制的感觉可能正是引擎使用者想要达到的效果(例如喜剧效果),这就是AB引擎还面临的另一种挑战。我们的引擎Rascal是通过一种层级控制结构来实现的——这个设计是从机器人领域获得的启发,我们或许会在之后的文章中详细说说。

原则7:行为的变化是模式化的

微信图片_20220311094116.gif

你不能两次踏入同一条河流,同样的行为你也不能展现两次。给一些变化——无论多小,但是总是会有,这就是让行为变得更自然的有效方法之一。

重要的是,这些“相同”行为的不同表现方式往往是随机、结构化的。就比如说,《哈利·波特》系列中韦斯莱家的双胞胎在同步说“什么”的时候,他们抬头、张嘴的方式可能会有点不同,但他们不会在……比如说在需要张开嘴的时候闭上嘴,反之亦然。演化生物学家称这种现象为模式化变化(patterned variation)。无论是哪个场景,你都可以看出这些变化是基于已经设置好的生成原则或规则——例如,控制发声器如何产生单词“什么”的规则。这并不意味着(比如说)AB引擎需要模拟整个发声装置来产生更自然的变化。在实践中,潜在变化的维数通常是有限的,可以用更浅显的方法来实现近似。

原则8:行为是有层级的

微信图片_20220311094117.gif

当一个影响因素在展现行为时,如果你仔细观察就会发现有很多事情通常是同时发生的。这个原则,还有后续的几条能够帮助你建立秩序。

行为几乎都是有层级结构的,让我们先从运动学角度入手。握手这个动作就很好地说明了这点。尽管它是“握手”,但这个小小的仪式涉及到许多身体部位的协调——它们都处于层级关系中,从属部位会受到上级部位的影响。

所有的动作都是从躯干开始的,这使得手臂(从属于躯干)在摇晃时向前倾。同时,头部(也依附于躯干上)朝向对方,眼睛(依附于头部)最初需要向下看从而调整最初的抓力。然后抬头,跟对方做出回应。

当我们开始在行为中寻找层级关系时,我们就会发现它是无处不在的,更棘手的是,它们会随着时间的推移而迅速变化(回想一下原则5)。

原则9:行为是平行的

微信图片_20220311094118.gif

你看到《广告狂人》(Mad Men)里的Peggy Olson在一边步行一边吸烟,同时做几件事是极为常见的。这些东西甚至不需要有等级关系(你可以不走路就抽烟,反之亦然)。尽管如此,原则8和原则9对AB的影响是相同的。它们要求行为流必须由多个具有层级关系的子行为组成。这些子行为可以控制身体不同或重叠的运动部位(眼睛、嘴巴、四肢……),让AB的复杂性又提升了一个层次。举个不同部位的例子:上面提到的Peggy Olson,她的吸烟行为完全不影响她走路。至于重叠,你可以想象一下Peggy一边行走一边因恐惧而颤抖——这两种行为会对相同的身体部位产生影响,但方式不同且可能很复杂。

原则10——12:行为是由认知引起的、可被观察的、可解读的

最后三点我们可以放在一起讨论,因为我们要讲认知和行为之间的关系。

影响因素拥有控制其行为的中枢神经系统。他们看到其它影响因素的行为会自动解读。在进化过程中,我们已经习惯于从可观察的行为中硬解读出某种(不可观察的)认知原因,并赋予其目的性和意义。

微信图片_20220311094119.gif

因此,在上面的动图中,你看到的不仅仅是一个女主持人举起然后放下她的手臂——你看到的是她一开始试图与同事击掌,但没有引起对方的注意,最终为自己的失败感到丢脸。大量的心理学研究表明,这种归因是自发的,是不可抑制的。对于AB来说,这意味着我们不可能将人工创造的行为与它所引发的意义剥离。行为总是在表达某种意思,不管你的本意是否如此。因此,AB引擎的开发不仅是一个工程上的挑战,也是一个心理上的挑战。这是关于如何说服玩家相信生成行为的(人造)意义,我们计划在未来的几篇文章中继续讨论这个话题。

文/游戏邦编译
原译文https://www.gamedeveloper.com/design/the-future-of-interactive-characters-part-1-4-twelve-basic-principles-of-behavior

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

GMT+8, 2024-12-24 00:25

Powered by Discuz! X3.4

Copyright © 2001-2021, Tencent Cloud.

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