MMORPG网络游戏如何实现玩家同步

在很多开发者的眼里,网络游戏是如何实现玩家同步,这点一直很神秘,特别是没有做过大型网络游戏项目的小伙伴,今天我们一起来分享一下网络游戏是如何来实现多玩家同步的。网络游戏同步,从技术方向来说有两个,一个是状态同步,一个是帧同步

这里有个游戏开发学习交流小组点击可以加入,一起学习交流

状态同步是如何实现的呢?其实很简单,就是服务器上跑游戏逻辑,服务器通过网络接收玩家的输入,在服务器计算游戏逻辑,推进游戏进度向前发展,如果有状态改变和产生了重要的事件,把状态同步给感兴趣的客户端,客户端播放动画即可。这里需要重点解决的一些技术问题,接下来我们总结并分析下如何实现。

1: 服务器基于帧率来迭代游戏逻辑

服务端游戏逻辑和客户端一样,也是基于帧频来迭代计算的,这个帧率的设置目前有两大方向,一个是固定的帧率(比如1秒20次迭代计算),有一种是动态的改变帧率。很多游戏都采用简单一点的固定帧率来做。帧率没有必要像客户端一样,60FPS,客户端维持60FPS是为了维持动画的流畅,而服务器上完全没有必要维持这么高的帧率,帧率越低,意味着计算量越少,同时为了游戏手感,一般服务器的以帧率15FPS--->20FPS来触发。如果有一些迭代进度比较高的可以采用FixedUpdate机制,拿20FPS为例, 那么帧的时间间隔就是50ms, 如果有一些高精度的迭代,要求60FPS,也就是16ms就要迭代一次,这个怎么办呢?那么采用fixedUpdate, 将50ms 分成几次迭代,每次迭代的时间间隔为16ms这个就是FixedUpdate机制。如物理引擎,为了防止穿透,如果你迭代的次数少,时间间隔长,那么迭代计算后,可能容易穿透,那FixedUpdate来迭代物理引擎,增加迭代次数,这样能让物理计算更精准。基于帧频,我们编写游戏逻辑就像客户端一样了,但是只是不用管UI,和动画这些表现而已。听上去很蛮烦,其实写起来也简单。基于帧率的模式设计完成后,再实现一些基于帧率的常用的模块,比如游戏中的定时器等。

2: 服务器上跑游戏地图

服务器上帧频的机制确立好以后,接下来就是要部署一个地图在服务器上,服务器的地图如何做呢?其实很简单,如果是2D地图,我们把地图看作是一个xoy平面,把地图分成一些小块,并在平面上标记出来哪些区域块是障碍物,哪些可以行走。这个数据可以在客户端的地图编辑器编辑好,并把这个数据导出来给服务器用。如果是3D游戏,俯瞰游戏3D地图,将地图看作一个平面,和2D一样标记区域,哪些是障碍物,哪些是路径,如果你的3D游戏地图中,没有上坡和下坡,那么就和普通的2D游戏没有区别,如果有上坡下坡,就让客户端把地图的高度图导出来,你给定一个(x, z), 可以得到一个y的高度值。 地图数据确立好后,接下来就要编写服务器上的寻路算法与导航,能控制服务器上的玩家对象在地图上移动,当然这些都是数据,没有图像。

服务器上跑地图,要结合客户端做一个地图编辑器,地图编辑器导出地图数据给服务器。

3:玩家行走时,服务器如何同步?

服务器上的地图数据,寻路导航模块做好以后,就可以独立的让游戏角色在地图上移动了。那么有一个很经典的问题就出现了,这也是很多小伙伴搞不懂的一个点,服务器上游戏角色每次移动的时候,是否要把位置同步给客户端呢?答案肯定是不用,也没有必要。那么什么时候同步位置,客户端有如何处理呢?我们一起来分析详细的过程。

先考虑一个客户端,当玩家A在客户端的地图上点了一下鼠标以后,它会把地图的目标点发送给服务器,服务器检查这个目标点,玩家A是否可以行走,(点是否为障碍物,点是否距离玩家A太远,疑似外挂等)如果玩家A不可以行走,什么都不处理或返回一个状态码给客户端,表示不可行走。如果玩家A可以走到目标点,那么服务器会通知所有能看见玩家A的客户端(包含玩家A),告诉它们,玩家A要走向那个目的地,这些客户端收到消息后,本地寻路导航移动播放动画,在这个过程中,不用同步任何服务器上的数据,服务器跑服务器的,客户端跑客户端的。直到服务器上玩家A走到目的地,然后服务器又给能看见玩家A的所有客户端(包含玩家A)同步一下服务器中玩家A的位置,这样这些客户端玩家A的位置就同步到服务器上对应的点了。这里其实就是征询一个原则,行走的时候,如果状态变化,那么先同步位置等状态,再基于同步后的状态处理下一件事情。服务器玩家A开始行走,到达后状态变化,由行走变为待机,这样就要同步位置。

如果在行走中遇到了一个敌人,发起攻击怎么办呢?还是遵循这个原则,只要状态变化了,先同步玩家的最新状态(位置,方向等)。再做后面的动作。这样会不会有作弊呢?不会,因为服务器上跑的是真实的数据,所有结果都是服务器算出来后通知客户端的。

4: AOI技术: 如何查找感兴趣的其他玩家。

AOI算法主要由两个方向,九宫格与十字链表。今天来给大家分享九宫格算法。九宫格算法其实非常简单,如图:

我们对整个地图,用一个个视野块来划分(蓝色线框为一个块,和地图块是不一样的), 以玩家所在的区域为中心,周围一圈就是这个玩家的AOI区域形状, 先确定把地图分成几x几的视野块, 以多大的视野块来地图合适呢?确定视野大小, 可以根据摄象机来的视野来预估。摄像机的视野多宽,我们大概预估一下计算出来视野块大小。 九宫格算法还有一个优势, 对"我"敢兴趣的玩家在九宫格里面, 我感兴趣的玩家也在九宫格里面。每个格子负责维护它里面的玩家,这样我们就可以快速的找出来"我"感兴趣的玩家,和对"我"感兴趣的玩家。

当玩家移动的时候,如果我们会发生了AOI区域的变化,如图: 新的AOI为红色框。

a: 不在原来的AOI区域, 在新的AOI区域内新加的块,那我们就要把这些新加的块里的玩家先同步到你这个客户端,你所在的客户端把新进入视野的玩家创建出来,同时你要把你自己的最新状态,同步给新进来的玩家客户端,新进玩家的客户端,也会把你这个角色创建出来,你看到别人的同时,也要让别人看到你。

b: 既在原AOI区域又在新AOI区域, AOI区域没有变化的块,我们不用做任何处理;

c: 在原来的AOI区域内,但是不在新的AOI区域内: 你就要告诉这些玩家,你离开了,这些玩家的客户端,就把你删掉,它们就看不见你了,同时还要把这些玩家发给你,表示说这些玩家你看不见了,你把这些角色删除就可以了。

好, 今天MMORPG 状态同步要解决的主要的核心问题,就写到这里,

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,457评论 5 459
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,837评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,696评论 0 319
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,183评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,057评论 4 355
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,105评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,520评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,211评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,482评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,574评论 2 309
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,353评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,213评论 3 312
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,576评论 3 298
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,897评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,174评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,489评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,683评论 2 335

推荐阅读更多精彩内容