青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Fork me on GitHub
隨筆 - 215  文章 - 13  trackbacks - 0
<2015年11月>
25262728293031
1234567
891011121314
15161718192021
22232425262728
293012345


專注即時通訊及網(wǎng)游服務(wù)端編程
------------------------------------
Openresty 官方模塊
Openresty 標(biāo)準(zhǔn)模塊(Opm)
Openresty 三方模塊
------------------------------------
本博收藏大部分文章為轉(zhuǎn)載,并在文章開頭給出了原文出處,如有再轉(zhuǎn),敬請保留相關(guān)信息,這是大家對原創(chuàng)作者勞動成果的自覺尊重!!如為您帶來不便,請于本博下留言,謝謝配合。

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

相冊

Awesome

Blog

Book

GitHub

Link

搜索

  •  

積分與排名

  • 積分 - 221316
  • 排名 - 117

最新評論

閱讀排行榜

http://www.gameres.com/335685.html
1. 客戶端地圖格子的相關(guān)知識

  在2.5D的MMO游戲里,角色是通過3D的方式渲染,2D的地圖是通過2D的方式顯示,所以在客戶端一般會有三個坐標(biāo)系:


a) 3D坐標(biāo)系:所有需要3D渲染的角色和光效,都以3D坐標(biāo)系中定位。

b) 2D坐標(biāo)系:用來定位和繪制固定的2D地圖元素,比如草皮、馬路等。

c) 3D坐標(biāo)里的格子坐標(biāo)系:用來實現(xiàn)打掩碼、自動尋路和進行一些坐標(biāo)配置(比如NPC和怪物初始的位置)。使用格子坐標(biāo),一是為了方便打掩碼和進行自動尋路的計算(經(jīng)典的A*尋路),二是為了更方便查找坐標(biāo)的具體位置。


  端游使用的格子大小一般為(64, 32),手游的精確度要求低一些,可以用(100, 50),即3D坐標(biāo)系里長為100寬為50的矩形,即是格子坐標(biāo)系里的一個坐標(biāo)。示例圖如下:


一款已上市MMO手游地圖同步方案總結(jié)

 


2. 服務(wù)器同步大格子:9宮格

  MMO游戲里,玩家要能看到地圖上所有角色的行為,這就需要將其它玩家的動作都通過網(wǎng)絡(luò)數(shù)據(jù)同步過來。同步一般使用9宮格來確定,哪些玩家的數(shù)據(jù)要同步過來,然后自己的行為要同步給哪些玩家。


  服務(wù)器大格子的大小,以3*3的格子要總比客戶端顯示范圍要大一點為原則。比客戶端大一點,是為了預(yù)留資源加載的時間。


  如下圖所示,綠色表示手機客戶端的顯示區(qū)域,當(dāng)角色A在格子6中時,他可以看到1,2,3,5,6,7,9,10,11這9個格子里的內(nèi)容,那么當(dāng)他的狀態(tài)發(fā)生變化時,就需要同步給在這9個格子里的所有玩家;同樣,當(dāng)這9個格子里的有玩家或者怪物的狀態(tài)改變時,也需要都同步給角色A。


一款已上市MMO手游地圖同步方案總結(jié)

 


  當(dāng)角色A移動到角色B所在的格子(7),則他將不再看到1,5,9這三個格子里的內(nèi)容(玩家和怪物),同時他將新看到4,8,12這三個格子里的地圖內(nèi)容。所以這個過程中,服務(wù)器要下發(fā)消息,刪除角色A所在的客戶端里的1,5,9這三個格子里的地圖內(nèi)容,同時下發(fā)消息新增4,8,12這三個格子里的地圖內(nèi)容(類型一)。


  推薦大格子具體的大小,按客戶端iPhone4S的960*640分辨來制定,取屏幕長寬的1/2大一些,可以定為640*360。


3. 角色的移動同步

  地圖上角色的同步可以分為位移的同步和行為(比如放技能)的同步。這里主要討論位移的同步方式。


  位移同步的目的是為了將自己的位置變化發(fā)給服務(wù)器,然后由服務(wù)器通過9宮格的方式轉(zhuǎn)發(fā)給周圍的其他玩家。


  有的端游是以客戶端格子的基本單位進行同步,當(dāng)玩家從一個格子移動到了另一個格子時,就發(fā)消息通知給服務(wù)器。這種方式的缺點就是:


一、同步的延遲。玩家從一個格子開始移動,移動到另一個格子后,才發(fā)消息給服務(wù)器,服務(wù)器再轉(zhuǎn)發(fā)給其它客戶端,那其它客戶端的玩家位置,總會有一點延后。

二、當(dāng)網(wǎng)絡(luò)不穩(wěn)定的時候,很容易看到其它玩家不是均速的移動,比如玩家位置沒動,然后一下子瞬移到了下一個格子。


  我們采用的方式,是同步狀態(tài)的變化,然后由客戶端來觸發(fā)服務(wù)器對大格子跨越的判斷:


d) 當(dāng)玩家點擊地圖上某個地方,或者改變了搖桿方向,玩家的運行狀態(tài)就變化了,即向某個坐標(biāo)點移動。狀態(tài)變化的時候,客戶端就立即給服務(wù)器發(fā)消息,然后服務(wù)器進行轉(zhuǎn)發(fā)。這樣如果忽略了網(wǎng)絡(luò)的延遲,那這個角色在所有客戶端上,幾乎是同時開始移動。


  如果移動過程中沒有其它變化,則整個移動過程中只有一次消息同步。這里需要處理一個問題,就是服務(wù)器需要知道這個角色什么時候跨越了服務(wù)器的同步大格子,當(dāng)角色跨越了同步大格子時,服務(wù)器就需要進行第二節(jié)里(類型一)的操作。


e) 如何判斷角色的移動過程中跨越了同步大格子,有的游戲里采用服務(wù)器判斷的方式,即根據(jù)角色的移動速度和方向,計算出跨越的時刻,然后使用一個Timer來觸發(fā)。同時如果服務(wù)器要取這個角色的當(dāng)前位置,則需要通過運動公式來進行計算。這個方案相對精確一些,但比較復(fù)雜,服務(wù)器也需要為每一個移動的角色設(shè)定一個Timer,對服務(wù)器的性能有所影響。


  我們采用的方式,是由客戶端判斷角色每移動一小段距離,然后發(fā)消息通知服務(wù)器,服務(wù)器不對這個消息進行轉(zhuǎn)發(fā),而只是判斷是否跨越了大格子,同時記錄下這個坐標(biāo),作為角色的當(dāng)前位置。這一小段距離可以取100左右,值取得越大時,消息發(fā)送頻率越小,但服務(wù)器的同步大格子跨越判斷和角色當(dāng)前位置就越不精確。


  因為是直接同步的運行狀態(tài),所以客戶端發(fā)給服務(wù)器的坐標(biāo)單位是3D坐標(biāo)系里單位,而不是3D坐標(biāo)系格子的坐標(biāo)單位。這樣就更加精確,一點點距離的移動,都能準(zhǔn)確同步。


f) 同步運動狀態(tài)的一個問題是,如果玩家操作很頻繁,比如快死了逃跑時,瘋狂地點地圖,這時運動狀態(tài)變化的非常快,如果每個狀態(tài)的變化都同步給服務(wù)器,再加上廣播,那消息量是很大的。


  所以需要設(shè)置一個狀態(tài)同步的最短時間,當(dāng)運動狀態(tài)變化很快時,則將狀態(tài)變化的消息緩存在客戶端,同時加一個Timer跟蹤。當(dāng)馬上有新的狀態(tài)變化消息出來時,則進行替換,同時更新Timer。當(dāng)沒有狀態(tài)變化的消息出來時,Timer到時間了就會觸發(fā),將緩存的狀態(tài)變化的消息,發(fā)給服務(wù)器。


  這樣通過消息緩存加上Timer的處理,既實現(xiàn)了運行狀態(tài)同步的最短時間限制,也保證了最后有效的運行狀態(tài)會稍晚一點點發(fā)送給服務(wù)器。


4. 怪物的同步

  怪物的同步在傳統(tǒng)的端游里,是完全由服務(wù)器的怪物AI系統(tǒng)觸發(fā),客戶端只是純粹的接受服務(wù)器下發(fā)的怪物狀態(tài)數(shù)據(jù)。對于手機游戲里,由于手機上很難出現(xiàn)像PC里那樣的外掛,所以怪物的AI可以考慮放在客戶端觸發(fā),同時減少怪物的狀態(tài)同步。詳細(xì)說明如下:


a) 怪物的隨機移動不同步


  在地圖上,怪物都會有一個固定的位置。怪物沒有進入戰(zhàn)斗狀態(tài)時,就會在這個固定位置的周圍走來走去,隨機的移動。這個隨機的移動由每個客戶端自己控制,這樣怪物的隨機移動,就不用消息廣播進行同步了。


  由于客戶端自己控制怪物的隨機走動,所以會出現(xiàn)不同客戶端里,怪物位置不一樣的問題。但由于怪物隨機移動的范圍較小,所以這個問題不是很明顯,在手機上是可以接受的。角色打怪時,是扇形的傷害范圍,所以即使怪物坐標(biāo)在不同的客戶端有點不一致,打怪的效果也是可以接受的。


b) 怪物的行為同步


  當(dāng)有角色攻擊被動怪物,或者進入主動怪物的視野范圍內(nèi)時,怪物的AI就被這個角色所在的客戶端鎖定了,同時怪物進入攻擊狀態(tài)。攻擊的判斷完全由鎖定怪物AI的客戶端進行處理,同時這個客戶端會將這個怪物的行為上發(fā)到服務(wù)器,由服務(wù)器廣播給周圍的其他玩家。


  怪物的AI鎖定,使用搶占式,即誰最先發(fā)消息給服務(wù)器申請怪物的AI鎖定,誰就獲得了怪物的控制權(quán),直到怪物死亡或脫離戰(zhàn)斗狀態(tài)。


  怪物可以每進行一次攻擊,客戶端就發(fā)一個消息給服務(wù)器。這樣做,消息還是有點多,特別是一群怪圍著幾個角色進行攻擊時,消息廣播還是有點多。所以可以將狀態(tài)的概念向上擴大,只同步怪物在攻擊哪個玩家,而不同步每一次的攻擊,然后由每個客戶端根據(jù)怪物固定的攻擊速度各自去表現(xiàn)。這樣一個怪去攻擊一個玩家,就會只有一次消息廣播了。


c) 精英怪和BOSS怪的AI


  精英怪和BOSS怪由于數(shù)量較少,而且比較重要,所以不能由客戶端來申請AI控制權(quán),而是服務(wù)器根據(jù)某種策略來控制。所使用的策略可以考慮角色的傷害值、防御值、角色與BOSS的距離遠(yuǎn)近等,根據(jù)這些因素,服務(wù)器計算出BOSS怪當(dāng)前最適合攻擊的對象(比如血量最少的玩家,最脆弱的法師等),然后將AI控制權(quán)發(fā)給那個客戶端,由那個客戶端控制攻擊行為,同時通過消息讓服務(wù)器同步給其他玩家。


  總結(jié):怪物的同步方式的選擇,就是要盡量減少消息的廣播,同時讓游戲效果在可接受的范圍內(nèi)。怪物AI的這個處理方式,實際上是同時省去了游戲服務(wù)器的怪物AI模塊(端游一般是專門用的一個進程或者另外一臺物理服務(wù)器來進行怪物AI的計算),從而簡化了MMO游戲的開發(fā)難度,同時保證了較好的游戲體驗。

posted on 2015-11-30 12:00 思月行云 閱讀(912) 評論(0)  編輯 收藏 引用 所屬分類: MMO
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲一区综合| 久久成人免费| 亚洲欧洲精品成人久久奇米网 | 国内外成人免费激情在线视频| 亚洲欧美变态国产另类| 亚洲丶国产丶欧美一区二区三区| 中文一区二区| 一区二区欧美激情| 美女网站久久| 另类综合日韩欧美亚洲| 国产精品中文字幕在线观看| 亚洲精品一区在线观看| 亚洲国产精品福利| 久久久久久尹人网香蕉| 久久天堂av综合合色| 国产欧美婷婷中文| 亚洲综合久久久久| 亚洲午夜精品福利| 欧美日韩三区四区| 亚洲精品乱码久久久久久久久 | 好吊一区二区三区| 一区二区欧美日韩| 欧美福利一区| 久久精品国语| 国产亚洲成年网址在线观看| 亚洲五月六月| 久久精品国产精品| 国产麻豆视频精品| 午夜精品在线视频| 久久天堂av综合合色| 在线日韩中文字幕| 噜噜噜91成人网| 亚洲成色999久久网站| 亚洲日本激情| 欧美日韩国产一区精品一区| 一区二区免费在线观看| 99在线|亚洲一区二区| 欧美日韩在线亚洲一区蜜芽 | 久久在线免费观看视频| 亚洲影院免费观看| 亚洲欧洲日本国产| 亚洲精品国精品久久99热| 久久亚洲二区| 亚洲日本视频| 亚洲欧美日韩精品综合在线观看| 国产精品久久久久久久电影| 午夜精品久久久久久99热软件| 久久久久免费| 亚洲精品人人| 欧美午夜寂寞影院| 欧美在线播放一区| 亚洲国产精品久久人人爱蜜臀| 亚洲天堂久久| 久久久国产精品一区二区三区| 久久国产精品亚洲va麻豆| 欧美黑人多人双交| 亚洲综合欧美日韩| 在线精品视频一区二区三四| 欧美国产日韩一区二区三区| 午夜精品久久久久| 亚洲国产欧美另类丝袜| 午夜影院日韩| 在线观看欧美亚洲| 国产精品久久久久三级| 卡一卡二国产精品| 亚洲一区三区在线观看| 亚洲电影免费观看高清| 校园春色综合网| 日韩视频精品在线观看| 国产午夜精品一区二区三区视频| 欧美成人dvd在线视频| 一本久久综合| 欧美国产日韩在线| 欧美中文在线视频| 亚洲特级毛片| 91久久国产综合久久91精品网站| 国产精品亚洲产品| 欧美久久综合| 免费成人在线观看视频| 欧美一区二区在线播放| 在线视频欧美精品| 亚洲七七久久综合桃花剧情介绍| 久久精品亚洲一区| 亚洲欧美综合精品久久成人| 亚洲精品一区二区三区樱花| 极品av少妇一区二区| 国产精品成人国产乱一区| 欧美99久久| 久久在线播放| 亚洲视频网站在线观看| 久久精品在这里| 午夜精品一区二区在线观看 | 欧美成va人片在线观看| 欧美一区日韩一区| 亚洲免费婷婷| 日韩亚洲欧美精品| 亚洲精品一区二区三区四区高清| 在线播放中文字幕一区| 国产在线精品二区| 久久久久一区二区三区| 麻豆av福利av久久av| 亚洲欧美日韩综合国产aⅴ| 在线中文字幕日韩| 一区二区三区精密机械公司| 91久久夜色精品国产九色| 激情亚洲网站| 亚洲国产精品123| 影院欧美亚洲| 亚洲第一偷拍| 一区二区三区欧美在线| 久久视频在线视频| 国产无一区二区| 国产亚洲午夜高清国产拍精品| 国产嫩草影院久久久久| 国产一区二区三区的电影 | 国产一区在线视频| 韩国精品久久久999| 精品成人在线| 亚洲日本中文字幕区 | 1000部精品久久久久久久久| 极品尤物av久久免费看| 亚洲高清资源| 日韩一区二区免费高清| 99综合精品| 亚洲欧美视频在线观看| 久久精品夜夜夜夜久久| 你懂的国产精品| 亚洲国产精品激情在线观看| 亚洲激情中文1区| 一区二区国产日产| 欧美亚洲一区二区在线| 久久视频国产精品免费视频在线| 欧美大片免费观看在线观看网站推荐| 欧美精品日韩www.p站| 国产精品护士白丝一区av| 国产亚洲午夜| 日韩午夜中文字幕| 亚洲嫩草精品久久| 久久久水蜜桃| 亚洲美女免费视频| 欧美伊人久久久久久午夜久久久久 | 免费久久99精品国产自| 亚洲高清色综合| 亚洲在线一区| 狼狼综合久久久久综合网| 欧美视频日韩视频| 精品白丝av| 亚洲一区二区三区激情| 久久最新视频| 日韩视频在线免费观看| 久久精品免费| 欧美网站在线| 亚洲国产精品久久久久婷婷884| 亚洲一区二区三区777| 美女主播一区| 亚洲一区国产精品| 欧美肥婆在线| 国产伊人精品| 亚洲在线免费观看| 亚洲电影在线播放| 欧美一区二区三区精品电影| 欧美日韩成人在线视频| 在线观看亚洲一区| 亚洲欧美国产精品va在线观看| 欧美黄色一区二区| 亚洲一区二区在线免费观看视频| 欧美va亚洲va香蕉在线| 红桃视频一区| 久久福利电影| 中文在线一区| 欧美日韩精品免费| 亚洲日本黄色| 欧美激情亚洲视频| 久久噜噜亚洲综合| 国产九九精品| 亚洲一区成人| 久久激情视频免费观看| 欧美午夜精品久久久| 日韩一级裸体免费视频| 中文日韩电影网站| 久久精品国亚洲| 在线免费观看一区二区三区| 亚洲视频一区在线| 亚洲精品国久久99热| 蜜桃精品一区二区三区| 在线激情影院一区| 欧美风情在线观看| 噜噜噜久久亚洲精品国产品小说| 国产欧美日韩视频| 久久国产精品亚洲77777| 亚洲综合色丁香婷婷六月图片| 欧美色中文字幕| 亚洲一区二区三区在线看| 99热这里只有成人精品国产| 欧美日韩在线视频首页| 中文有码久久| 亚洲自拍偷拍麻豆| 国产亚洲欧美激情| 久久亚洲影院| 免费成人黄色|