【3D技术宅公社】XR数字艺术论坛  XR技术讨论 XR互动电影 定格动画

 找回密码
 立即注册

QQ登录

只需一步,快速开始

调查问卷
论坛即将给大家带来全新的技术服务,面向三围图形学、游戏、动画的全新服务论坛升级为UTF8版本后,中文用户名和用户密码中有中文的都无法登陆,请发邮件到324007255(at)QQ.com联系手动修改密码

3D技术论坛将以计算机图形学为核心,面向教育 推出国内的三维教育引擎该项目在持续研发当中,感谢大家的关注。

查看: 1887|回复: 0

解析HTML5技术的不足及其游戏开发前景

[复制链接]
发表于 2012-11-20 15:01:05 | 显示全部楼层 |阅读模式

作者:Mike Arcuri

HTML5对于广大游戏开发者的吸引力越发明显了。让我们从用户覆盖面,访问与控制三大过程来看。

1.用户覆盖面

运行于主要的现代游戏平台(包括Anroid,iOS,Facebook,PC和Mac)的游戏具有空前广阔的用户覆盖率。这些游戏的潜在玩家已经多达20亿了(这是截止至5月份对于Flash用户数的估计,这一数量整整是第七代游戏主机销量的10倍)。

2.玩家访问

这些游戏都具有较短的游戏过程,玩家不管是使用公司的电脑还是家用电脑,亦或是便携的触屏智能手机和平板电脑都能够轻松地玩游戏,这种体验将改变游戏产业并能够吸引更多新玩家的加入。

3.控制

基于手机,平板电脑以及PC上所运行的相同的游戏代码,即时的游戏更新,简单的数据追踪,以及网络技术中固有的数据驱动优化,开发者能够面向更广泛的用户轻松地传达最佳游戏体验。更棒的是网络应用的设置权限也更加自由,即当你能够吸引一名用户时,你便能够随时进行更新,按照自己的想法去设置支付方式,并做出对自己有利的合作关系和技术选择。

如果HTML5是帮助开发者覆盖用户,访问以及控制这三大目标的最佳方法,那它就理应受到媒体和权威人士的肯定(在其问世一年多时间以来),但是为何我的老板上周会在网络上说“HTML5游戏只是炒作?”

为何EA创意总监Richard Hilleman在上周有关HTML5的新游戏大会上一直着重强调这一平台所存在的问题?Zynga和EA都未公开表示对于HTML5的支持?Facebook,谷歌,苹果以及微软是否决定为游戏制定新的标准?是否存在吸引人的WebGL样本?Adobe不是已公开承认Flash输掉了浏览器游戏之战,他们将转而支持HTML5并面向手机设备去推动原生应用的发展了吗?关于HTML5这一游戏开发技术的理想与现实是否存在着巨大的差别?

如果是这样,那是否还存在其它可行的跨平台游戏开发选择,还是我们注定只能待在可预见未来的孤立的游戏市场和跨平台移植项目中?

html5(from itsabacus.com)


调查第一步:找到一款优秀的HTML5游戏

已经有一些人阐述了Facebook上的一些HTML5手机游戏不如Flash游戏,所以我便决定寻找其它正面的例子。《贪婪之手》是面向iOS平台而发行的一次性HTML游戏,但是它却只是对于原生应用体验的一种模拟;不只遗漏了粒子效果等外观元素,同时其它功能,包括声音,倒数计时器,动画以及屏幕转换也都未能有效地呈现出来。甚至连触屏反应和碰撞检测也具有各种缺陷。

我同样也检测了Chrome Web Store中一些最优秀的游戏,但是却发现这些游戏大多都属于Flash游戏(游戏邦注:《愤怒的小鸟》和《植物大战僵尸》便都是Flash游戏)。最后我便不得不询问身边的人是否知道哪些与iPhone或Android游戏一样受欢迎的HTML5游戏。经他人推荐,我找到一款非常出色的游戏,在其中投入了30分钟,并感觉整个过程就像在做梦一样。所以接下来我将尝试着在火狐7.0.1版本浏览器上加载游戏。但是这时候却不再那般顺畅了。呈现在我眼前的只是一个黑色矩形游戏区域。甚至在IE 9中,当我第一次加载游戏时浏览器立马出现崩溃现象,而当我第二次加载游戏时,画布元素则不会再出现了。在iOS或Anroid上也未出现好结果。

很明显,Chrome能够最有效地支持HTML5,但是我找到的第一款真正优秀的HTML5游戏却不能有效地运行于台式机或手机浏览器上。如此它便难以帮助开发者实现用户覆盖面和玩家访问的目标。

调查第二步:驾驭HTML5不同于原生应用的性能

虽然Hilleman(游戏邦注:EA首席创意总监)和Bakaus(Zynga德国工作室CTO)都指出了HTML5的性能和声音支持所存在的问题,但是我希望找到一些更具体的数据。从Chrome的硬件加速以及WebGL支持来看,我认为这是运行HTML5的最佳环境,并且我也开始着手追踪(相对于Chrome上的HTML5)原生应用的渲染和计算性能测试结果。

3周前谷歌在Chrome Web Store上发布了“Flocking Geese”的样本,即“能够同时基于JavaScript和C++(使用Native Client——谷歌在浏览器领域所推出的一个开源技术)而运行一个经典的群集算法,并衡量每一秒的模拟运转数。”谷歌补充道:“这种执行方法非常简单,并且基于两种语言而获得的结果是相同的,”并能够提供两种执行性能比较标准。

在我的机器上所进行的1分钟测试中,样本的源代码版本的运行总是快于HTML5(基于JavaScript),倍数也总是在4.0至9.2之间波动着。

我们当然知道手机设备的运行速度远远快于摩尔定律(揭示了信息技术进步的速度),但是当这类游戏比起基于原生代码而编写的游戏速度慢了9倍时,游戏设计师是否还能指望在手机设备或PC浏览器上吸引用户注意力?

调查第三步:采访那些致力于创造HTML5游戏的人(尽管出现了种种问题)。

尽管出现了种种问题,一些大公司如EA和Zynga也都开始投资于HTML5游戏开发,而对于那些没有钱去使用多种技术的小工作室来说难道就只能眼睁睁地看着别人获胜?我访问了两家初创游戏工作室,以及位于西雅图一家致力于使用技术将想法呈现于平台和其它替代选择上的互动体验机构。

Pixel Lab的Kevin Moore

HTML5游戏案例:面向于微软的IE 9而创造的《Agent 008 Ball》。

Agent 008 Ball(from develop-online)


为何选择HTML5?“我们正致力于为用户创造最美好的互动体验,其中便包括一些样本游戏。我最欣赏HTML5的一点便是我们可以通过编写代码去降低游戏在其它浏览器的运行性能。但是如果我们所创造的是消费者游戏,我们便不会愿意忍受游戏性能的降低。”

从性能和音频方面来看:“最新的手机设备,如iPad 2和iPhone 4s的性能都越来越出色了。目前来看谷歌的音频API尤为出色,其它浏览器的性能则还有一定改进空间。”

Massively Fun Flagship的Grant Goodale

HTML5游戏案例:世界上第一款大型多人模式填字游戏《Word2》。

Word2(from develop-online)


如何创造这款游戏?“我们是基于JavaScript,并使用WebSockets和DOM去创造这款游戏。同时我们也一直在寻找合适的Canvas端口。”

游戏是否已经进入了手机平台?“还没有,最初我们是致力于原生iOS和Android应用的端口进行开发,而现在我们开始着眼于添加PhoneGap而独立进行HTML5游戏的开发,并想办法解决手机上的Safari浏览器所存在的局限性和安全问题。”

基于HTML5的游戏:“我们是否已经拥有了一款极其成功的应用了?还没有。那么我们是否应该合理使用技术基础而创造出属于自己的成功应用?当然了。”

Hyperbotic Labs的Steve Cellini

制作过程中的HTML5游戏:《CrowdGame Trivially v2》(开发中)

如何创造这款游戏:“第一版本的《Trivially》要求主机玩家必须在iPad上安装Trivia主机应用,而其他玩家则需要在自己的iPhone上安装Trivially Remote应用。而在新版本中我们将只添加一种原生应用,即Trivially Console,并且任何玩家都可以使用自己的手机网络浏览器连接到它所支持的网络服务器上。在我们的测试中,WebSockets能够确保远程遥控与主机间的即时通信。”

HTML5的潜能与问题

大大小小的游戏工作室都都因为HTML5的潜能兴奋不已,并开始投身于HTML5游戏的制作中,尽管如此,Facebook和PC网络上的手机和Flash游戏仍然占据着排行榜单的有利位置,并仍然是众多投资者的最佳投资对象。基于特定的目标平台(游戏邦注:如PC和Mac上的Facebook)以及当前的浏览器版本,我们认为Flash是那些对技术要求不高的游戏的最佳选择。

然而,API的不足,充满安全隐患,带有性能局限性等仍然是阻碍大多数游戏开发者去追求用户覆盖面,访问和控制目标的大问题。所以在HTML5真正能够兑现其承诺前,创造者必须想办法完善浏览器,升级硬件并添加API等。我们很难估算所有内容的发布时间,以及真正渗透到整个市场的时间,但是根据我15年的软件创造经验,我们应该以年为单位进行估算而非月。若不提及替代选择,那么这篇文章就不能算是完整的,以下我将列出3个能够帮助开发者更好地获得用户和访问目标的替代选择:

1.移植

是的,这是一种相对昂贵的方法,这也不是多让人兴奋的开发工作,这让我们很难去利用某一特定平台上突然迸发的人气。尽管如此,完整的游戏移植却是现今游戏开发者最常使用且最容易获得成功的方法,能够帮助他们在保留最初游戏体验的前提下更好地向新平台扩展。

你必须掌握的关键:首先选择在1至2个平台上发行游戏,如果取得了不错的成绩你便可以快速将其移植到其它设备上。这一方法已经帮助许多热门游戏成功地扩展到各大平台上了。遗憾的是这些平台的排行榜上还未出现多少HTML5游戏能够用于进行对照。

2.浏览器上的本地客户端

你必须信任Chrome团队——从对于HTML5的支持以及其它最优的可选择方法,即惊人的浏览器内部设置来:本地客户端来看,Chrome远远领先于其它主要的浏览器。本地客户端允许你使用任何语言进行游戏编写,并且也不会造成多大的性能退化,但是尽管这是一种开源项目,到目前为止它也只能运行于Chrome浏览器上。广大游戏开发者希望可以在所有主要的PC和手机设备浏览器上使用本地客户端去实现获得用户和访问目标,而无需在编程语言,工具或游戏体验上做出让步。

3.中间件和多设备开发平台

这一类别中还存在着多种选择,包括使用Flash去生成原生iOS应用,使用Unity3D,基于Lua脚本(Moai,Corona)或网络技术(PhoneGap,Titanium)使用Frameworks。一些中间件解决方法和开发平台便是针对于游戏而设计的,而其它的则是针对于缺少图像的密集型应用进行设定。有些解决方法只面向手机设备,而有些则能扩展到手机应用,PC和网络上。有些工具属于开源项目,有些则是私人专属内容。我一直致力于Moai中间件,并极力向其它开发者推荐这一方法——因为它属于开放源,能够有效地进行游戏优化,同时支持前后端游戏开发,并适用于6种不同的平台上。

比起HTML5,所有的多设备开发平台都能够用于创造具有良好性能的原生应用,并帮助你覆盖到你想到达的范围而无需在游戏玩法或硬件设备功能上做出较大的让步。

我所期待的多设备游戏的未来——当提到技术,我最拥护的还是稳定的替代选择和开放性市场竞争。我希望HTML5能够在今后两年内兑现它的承诺。我也希望看到本地客户端能够在同一时间段内被应用在更广泛的浏览器上。

除此之外我希望中间件和平台执行能够越来越完善,从而让游戏开发者能够使用它们去创造名列各大设备平台排行榜前列的游戏。如果能够成就这样的未来,我们便可以说针对单一平台移植游戏已经是过去式了,它们只是促成该产业不断成熟的一个过程。

游戏邦注:原文发表于2011年12月22日,所涉事件及数据均以当时为准。


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

本版积分规则

手机版|小黑屋|3D数字艺术论坛 ( 沪ICP备14023054号 )

GMT+8, 2025-5-6 23:38

Powered by Discuz! X3.4

Copyright © 2001-2020, Tencent Cloud.

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