不支持Flash
新浪首页 > 游戏世界 > 新闻动态 > 手机游戏 > >  正文
浅谈即时战略游戏在 J2ME 上的实现
http://games.sina.com.cn 2004-09-16 11:19 杨勇

    《星际》、《魔兽》、《文明》……这些都是PC游戏玩家们耳熟能详的名字,可以说以这些游戏为代表的战略游戏是PC游戏的典型代表,战略游戏的玩家也是众多PC游戏类型里忠诚度最高的玩家。战略游戏分为回合制和即时战略两类,两种战略游戏都有数量众多玩家,而后者更因为紧张激烈的游戏性逐渐压倒了回合制战略游戏,近几年来,一直在战略游戏中占统治地位。

    在“J2ME平台上开发网络即时战略游戏”,这个话题在现今大多数J2ME 开发者听来无异于天方夜谭。即时战略游戏名字的“即时”两个字决定了复杂的运算和数据交互、稳定快速的网络连接要求、庞大的资源和绘制任务,我们都知道J2ME设备的资源和性能都极为有限,现有GPRS网络业不尽如人意……这些似乎都成为了在J2ME上开发网络即时战略游戏不可逾越困难。

    困难实实在在的挡在我们面前,但中国三亿手机用户中蕴藏的庞大的潜在即时战略玩家促使我们去克服这些困难,只要还有一点可能,我们也要去寻找一条跨过这些障碍的道路。怎么样才能在手机上实现网络即时战略游戏呢?

    从性能和用户量考虑,我们选择诺基亚的60系列作为初期的开发平台。

    上面提到的困难中最大的瓶颈是网络,看下面一组数据:

    HTTP数据传送时间

  连接 1 2 3 4 5 6 7 8 9 平均
7650 7.812 2.79 2.641 2.5 2.63 3.922 2.438 2.672 2.219 2.594 2.712
6600 3.937 1.984 2.172 1.641 1.5 1.531 2.125 1.906 1.843 2.156 1.873

    SOCKET数据传送时间

  连接 1 2 3 4 5 6 7 8 9 平均
7650 1.719 1.312 1.609 3.359 3.36 1.375 1.781 3.313 1.25 1.329 2.075
6600 3.188 1.281 1.406 1.266 1.83 1.688 1.719 1.688 1.625 1.703 1.579

    (数据引自http://www.javaresearch.org/article/showarticle.jsp?column=3&thread=15337,特向原文作者致谢)

    我们不考虑采用HTTP协议,虽然它是J2ME设备中普遍采用的协议,但其相对SOCKET的低效性和本身是无连接协议决定了它不适合即时战略这种游戏形式。从上表可以看出建立连接的时间要高出连接后的数据传送时间许多,HTTP协议需要花费许多额外开销在建立连接上;HTTP平均的数据传送时间也要比SOCKET高许多。我们测试了大部分的60机型(7650, 3650, 3660, 6600, N-GAGE, N-GAGE QD),所有测试的机型均支持socket。

    从上表可以看出,socket连接数据往返一次的平均时间在1 ~ 2秒间,这对回合制的战略游戏或许足够,但对即时战略游戏来说还是太长了。有什么办法能大幅压缩数据传送的时间呢?

    我们可以从server和数据包协议考虑。

    以上测试的服务器是用Serverlet写的,而serverlet是构建在Web server上的,那么这个数据里包含的服务器反应和处理的时间就不容忽略了,为了获得更快的响应和处理速度,我们必须重新设计和构建游戏的专用Server。传送的数据包大小也是影响速度的一个关键。平时大家开发J2ME的网络应用,习惯于用文本流来传送数据,因为大多数应用Server端都是基于Web Server,而且采用文本表示信息非常直观,也便于Server处理,但对于J2ME平台和gprs网络来说,没有经过压缩的文本还是浪费了一些。

    简单考虑一下游戏服务器:一台主机应该能支撑一百到两百名玩家同时在线;为了便于配置,Server应用应该是跨平台的,而客户端也是J2ME的,因此Server的开发环境java当是首选;采用Java 1.4后新增的Java 异步通信功能,性能上也能达到我们的要求。

    因为Server必须我们自己写,所以没有必要使用文本编码协议,代之以字节流编码。简单估算一下,表示相同的信息,采用文本和字节编码方式数据大小的比例大于4:1,而且数据本来以数字为主,省去了文本转换的一大笔开销。更小的数据相应的也带来了更快的速度,另外,也为用户节省了大笔昂贵的GPRS流量开支。

    采取以上的措施后,我们再次测试了数据传送的响应时间,平均小于1秒!也许在很多人看来,这个时间还是太长,达不到实时的要求,但应该知道,绝对的实时是不可能实现的,只要在策划和开发中采用一些合理的策略,这小于1秒的延迟完全可以很好的掩盖。

    典型的PC即时战略游戏如《星际》,在局域网对战时实际上并不需要服务器的,对战中的一台或多台客户机充当了服务器的角色,即使是上战网,战网服务器完成的也只是社区管理的工作。在手机上实现不能采取这种结构:首先,通过GPRS网络,两部手机无法直接连接(不排除蓝牙或红外的互连,这不在我们的讨论范围内),只能通过服务器中转;另外,手机的运算能力有限,为了游戏能良好的运行,必须把很多的运算转移到资源相对更丰富的Server端,这和一般的CS结构中,尽量让Client分担Server的工作以使得Server能支撑更多的Client的做法背道而驰,也体现了J2ME网络应用的特殊性吧:)

    再简单说一下整个系统的架构:


  

    服务器按功能分为连接服务器、大厅服务器、游戏逻辑服务器、用户管理服务器和日志服务器五种。视用户的数量,如果数量很小,所有的服务器都可以置于一台主机中;随着用户量增多,各服务器可以移动到不同的主机中,通过调整各服务器主机的数量达到均衡负载。

    以上是我的一家之言,很多地方可能不尽合理,欢迎大家指正。另外,敬请关注招商迪辰天空数码即将推出的国内首款手机网络即时战略游戏:《英雄――决战天下》。欢迎到天空数码论坛进行关于此类游戏的讨论!

点击此处查询全部手机游戏新闻
评论】【推荐】【打印】【关闭

 相关专题:
 相关报道
大型联网即时战略游戏《英雄—决战天下》即将面市 (2004-09-09 09:59)
数字鱼精品速递 K墙特工演绎英雄救美 (2004-08-11 14:03)
天空数码携手深圳联通共同打造手机流媒体业务 (2004-07-26 12:06)
我玩网精彩游戏兔子也疯狂——疯狂兔 (2004-09-09 14:37)
“极品恐龙”的一次手机游戏“脱贫”经历 (2004-09-09 12:21)
59k的《暗黑破坏神》手机游戏的极限魅力 (2004-09-09 11:54)
掌中米格游戏巨献《忍者龙剑传》评测报告 (2004-09-09 11:23)
调查称美国手机游戏用户2009年将达7860万 (2004-09-09 10:53)

 发表评论:  匿名发表  笔名:   密码:


新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 会员注册 | 产品答疑

Copyright © 1996 - 2007 SINA Corporation, All Rights Reserved

新浪公司 版权所有
北京市通信公司提供网络带宽