»
首页
|
手机数码
|
汽车资讯
|
游戏硬件
|
评测专题
|
手机壁纸
|
海淘值得买
|
度假
|
求职招聘
|
广告联系
» 您尚未登录:请
登录
|
注册
|
标签
|
帮助
|
小黑屋
|
TGFC Lifestyle
»
游戏业界综合讨论区
» 小型开发者的利器——内容的程序自动生成
发新话题
发布投票
发布商品
发布悬赏
发布活动
发布辩论
发布视频
公司招聘信息
打印
小型开发者的利器——内容的程序自动生成
xat
小黑屋
帖子
1798
精华
13
积分
17469
激骚
33 度
爱车
主机
相机
手机
注册时间
2003-6-28
发短消息
加为好友
当前离线
1
#
大
中
小
发表于 2007-7-10 03:34
显示全部帖子
原文载于
Behind Another World 游戏设计研究室
转载请注明出处,并保留原文链接
译自
Introversion Software《Procedural Content Generation》
简介
内容。
是。
折磨人的。
这是一条任何独立开发者都需要牢记的简单却非常重要的规则。在IntroversionSoftware的最新游戏《核战危机》(《DEFCON》)里,真正由我们创作的内容只有音效。游戏中几乎所有的其他内容都是来自于公之于众的信息——城市的位置,多变的海岸线的经纬度,国家的边境线等全都可以在互联网上免费获取。《核站危机》开发了一年。Introversion的《Darwinia》的内容有“手工”创造,约有10个小时的gameplay,却开发了三年之久。在《Darwinia》中的场景是有几行代码自动生成的——如果这其中的每一样都要手工来做的话,不知道要花费多少时间。
随着每一代的新主机的降临,创造游戏的成本,不论是时间还是资金,都飞速地增长。而小型开发组无力应付这样的增长。“内容的自动生成”于是便有了用武之地。自动生成的内容是由计算机算法创造出来的,而不是由美工精心雕琢而出的。这样的内容完全是动态生成,或者可以在一些(比如由用户或文本文件的)外部输入的基础上来生成。
假设,作为一个独立开发者,你想要制作一款像《GTA3》一样的游戏。你可以为了一个城市花上几个月的时间,为它增加建筑,为游戏世界铺上材质。或者你可以花费几个星期的时间,来研究一个自动生成这些城市的方法。这样做的成果是有几乎无限数量的城市供你游玩,而开发时间却被大大减少了。
你也许会不服气,认为这样创造出来的城市远没有手工制作地那样精细,但这全看你在这些动态内容上投入多少精力。你的动态建筑可以是简单的方块,加上窗户和门的贴图,或者这些逼真的窗子可以是基于建筑本身的设计和大小生成出来的,窗户的贴图甚至可以依据放置在边上的邻居的房子来改变。
这些截图来自于由Chris Delay为IntroversionSoftware现正在开发的游戏《Subversion》所写的城市自动生成程序。这是一个快速自动生成内容的很好的例子——经过了一个星期的努力,我们现在有了一种动态生成令人信服的城市布局以及建筑的方法。这些建筑的大小会根据城市里那个区域的人口密度来改变。正如你所见的,同样的算法可以用来生成一系列风格迥异的城市,只要很简单地改变输入到生成程序的数值就可以了。
这便是这系统的灵活性所在。只要有一些细微的改变,同样的算法可以用来创造完全不同的对象。在《Subversion》这个例子里,生成城市里每幢建筑的布局都是用的同一个函数。
显然,手工设计这样规模的城市里的每一栋建筑会是一项可笑的壮举。这可能会花上击败,甚至很可能是几千个“人月”。而由一个人写出来的算法却能够在几秒钟内完成,而且可以被改良用于你可能需要的其他任何目的。比如《Darwania》中的树就是用相似的原理生成的——线条由种子点向外“生长”,树枝以成倍的数量向同一方向伸展。
广度
作为一个只有有限数量员工,并且没有3D模型师的公司,这显然是一个比花费数月手工制作成堆的模型更可取得方案。
自动生成内容还能让你大大增加游戏的广度(scope)。就用前一个例子,在一个手工建造的城市和十万个可比较的自动生成的城市间选择,答案是显而易见的。WillWright的《孢子》(《Spore》)就将这个概念发挥到了极致——整个星系,大到星系系统,小到这些星系里行星上的微生物,都由每个开始游戏的玩家动态生成的。
自动生成内容并非是一个新鲜事物——事实上,多数早期的电子游戏都将自动生成作为将大量数据装进那个时期仅有的相对较小的媒体中的唯一手段。《精英》(《Elite》)及其续作《边境》(《Frontier》)就是典型的例子——动态生成的星系系统,动态生成的关卡,以及一整套其他的特色内容全都是程序生成的——一个本质上无穷尽的宇宙就这样被装进了一张软盘里。
当然,你能够用程序生成的不仅是静态的模型和形状。贴图,音效,甚至动画都可以由算法在运行(runtime)时被创造出来。在回到先前的例子,《Spore》的一大特色就是能动态生成玩家创造的生物的动画和贴图。动画是根据给定生物的骨骼解剖架构动态创造出来的,这包括行走,奔跑,进食,甚至舞蹈。这个生物的贴图和它的身形完全匹配,而它的身形是由头部,胃部,背部和身体上其他部位的位置决定的。
另一个更加极端的例子是一个叫做《.kkrieger》的演示作品。这个作品是由一个叫做.theprodukkt的团队制作的。《.kkrieger》是一款第一人称射击游戏,其中的任何东西都完全有程序自动生成。关卡(只有一个关卡,这毕竟只是一个演示作品),贴图,模型,动画,音效——全都是由游戏在运行时动态创造的。更加令人叫绝的是,这样华丽的图像(考虑到所有因素而言),整个游戏只有96kb——你下载这篇文章里都包含不止96kb的信息量!如果所有的数据都是预先制作好,并且以传统的方式来存储的话,它很有可能占几百兆的空间。
当然,自动生成内容也有些许不足。对于初学者来说,如果你的整个游戏都是由程序自动生成出来的,就很难有外观别致的场景——很容易得到尽管布局不同,却十分雷同的关卡。这意味着一定程度的人为介入是让游戏变得光鲜所必需的。
《Darwinia》就是一个很好的例子——《Darwinia》的布景是接受简单字符串输入后由程序自动生成的,但游戏里所有的建筑都是手工摆放的,设计者还写了一部分由脚本控制的事件序列。尽管团队尝试过完全随机动态地生成关卡,但发现要产生玩起来有趣的场景,这样做是极其困难的。
另一个致命的不足是动态生成内容所要花费的时间。比如,也许生成城市里的一栋建筑只需要花费不足一秒钟的时间,而一旦你要生成整个城市里的几百栋建筑,以及道路系统,这就会累积成一段明显的停顿时间。这个问题在前面提到的《.kkrieger》中尤为明显——游戏开始前会有一段冗长的“读盘”时间[译注:loadingtime,原指将光盘媒体中的游戏内容读取到内存所花费的时间,在这里是指CPU计算出整个关卡的时间。将游戏本身——生成内容的程序读入内存对这个游戏来说只花极少的时间。],其间关卡中的所有内容正在生成。这也意味着运行这样的游戏要比预制预存的游戏更需要一台强劲的电脑。
尽管如此,程序自动生成内容对小型开发团队来说是一个关键的工具。而且有些人可能还会持有这样的观点——这将是业界的未来。随着开发成本铺卷开来,难以控制,发行商们变得越来越不敢冒险,尝试投资新生作品,情愿守着那些已经尝试过和考验过的方法,也不愿发掘原创作品。使用程序自动生成的方法可以降低成本,开发者们可以获得更多的自由来测试新的想法,而且确实,如果没有程序自动生成,像Introversion这样的小公司甚至可能都将不存在。
本帖最近评分记录
voodoo
发贴积分
+30
精品文章
2007-7-10 09:46
UID
12707
帖子
1798
精华
13
积分
17469
交易积分
0
阅读权限
1
在线时间
2318 小时
注册时间
2003-6-28
最后登录
2019-11-19
查看详细资料
TOP
xat
小黑屋
帖子
1798
精华
13
积分
17469
激骚
33 度
爱车
主机
相机
手机
注册时间
2003-6-28
发短消息
加为好友
当前离线
2
#
大
中
小
发表于 2007-7-10 16:39
显示全部帖子
完全交给程序自然是不可能的,但如果在项目中很好结合的话,会有非常不错的结果。
一个很简单的例子,比如你需要256个npc。但你未必需要245个npc的模型,你只需要4种头,4种身体,4种手,4种脚。
那么就可以让程序来完成排列组合。
这并非是什么尖端技术,也非是什么创新理念,常人皆能想到。
让我惊叹的是,Introversion竟然能在如此重依赖于自动生成的情况下将实际的游戏制作出来。
UID
12707
帖子
1798
精华
13
积分
17469
交易积分
0
阅读权限
1
在线时间
2318 小时
注册时间
2003-6-28
最后登录
2019-11-19
查看详细资料
TOP
控制面板首页
密码修改
积分交易
积分记录
公众用户组
基本概况
版块排行
主题排行
发帖排行
积分排行
交易排行
在线时间
管理团队
管理统计