• <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>

            兔子的技術博客

            兔子

               :: 首頁 :: 聯系 :: 聚合  :: 管理
              202 Posts :: 0 Stories :: 43 Comments :: 0 Trackbacks

            留言簿(10)

            最新評論

            閱讀排行榜

            評論排行榜

            大多數實時網絡游戲,將 server 的時間和 client 的時間校對一致是可以帶來許多其他系統設計上的便利的。這里說的對時,并非去調整 client 的 os 中的時鐘,而是把 game client 內部的邏輯時間調整跟 server 一致即可。

            一個粗略的對時方案可以是這樣的,client 發一個數據包給 server,里面記錄下發送時刻。server 收到后,立刻給這個數據包添加一個server 當前時刻信息,并發還給 client 。因為大部分情況下,game server 不會立刻處理這個包,所以,可以在處理時再加一個時刻。兩者相減,client 可以算得包在 server 內部耽擱時間。

            client 收到 server 發還的對時包時,因為他可以取出當初發送時自己附加的時刻信息,并知道當前時刻,也就可以算出這個數據包來回的行程時間。這里,我們假定數據包來回時間相同,那么把 server 通知的時間,加上行程時間的一半,則可以將 client 時間和 server 時間校對一致。

            這個過程用 udp 協議做比用 tcp 協議來的好。因為 tcp 協議可能因為丟包重發引起教大誤差,而 udp 則是自己控制,這個誤差要小的多。只是,現在網絡游戲用 tcp 協議實現要比 udp 有優勢的多,我們也不必為對時另起一套協議走 udp 。

            一般的解決方法用多次校對就可以了。因為,如果雙方時鐘快慢一致的情況下,對時包在網絡上行程時間越短,就一定表明誤差越小。這個誤差是不會超過包來回時間的一半的。我們一旦在對時過程中得到一個很小的行程時間,并在我們游戲邏輯的時間誤差允許范圍內,就不需要再校對了。

            或者校對多次,發現網絡比較穩定(雖然網速很慢),也可以認為校對準確。這種情況下,潛在的時間誤差可能比較大。好在,一般,我們在時間敏感的包上都會攜帶時間戳。當雙方時間校對誤差很小的時候,client 發過來的時間戳是不應該早于 server 真實時刻的。(當時間校對準確后,server 收到的包上的時間戳加上數據包單行時間,應該等于 server 當前時刻)

            一旦 server 發現 client 的包“提前”收到了,只有一種解釋:當初校對時間時糟糕的網絡狀態帶來了很多的時間誤差,而現在的網絡狀態要明顯優于那個時候。這時,server 應該勒令 client 重新對時。同理,client 發現 server 的數據包“提前”到達,也可以主動向 server 重新對時。

            一個良好的對時協議的設定,在協議上避免 client 時間作弊(比如加速器,或者減速器)是可行的。這里不討論也不分析更高級的利用游戲邏輯去時間作弊的方式,我們給數據包打上時間戳的主要目的也非防止時間作弊。

            校對時間的一般用途是用來實現更流暢的戰斗系統和位置同步。因為不依賴網絡傳輸的統一時間參照標準可以使游戲看起來更為實時。

            首先談談位置同步。

            好的位置同步一定要考慮網絡延遲的影響,所以,簡單把 entity 的坐標廣播到 clients 不是一個好的方案。我們應該同步的是一個運動矢量以及時間信息。既,無論是 client 還是 server ,發出和收到的信息都應該是每個 entity 在某個時刻的位置和運動方向。這樣,接收方可以根據收到的時刻,估算出 entity 的真實位置。對于 server 一方的處理,只要要求 client 按一個頻率(一般來說戰斗時 10Hz 即可,而非戰斗狀態或 player 不改變運動狀態時可以更低) 給它發送位置信息。server 可以在網絡狀態不好的情況下依據最近收到的包估算出現在 player 位置。而 client 發出的每次 player 位置信息,都應該被 server 信任,用來去修正上次的估算值。而 server 要做的只是抽查,或交給另一個模塊去校驗數據包的合法性(防止作弊)。

            在 server 端,每個 entity 的位置按 10Hz 的頻率做離散運動即可。

            client 因為涉及顯示問題,玩家希望看到的是 entity 的連續運動,所以處理起來麻煩一點。server 發過來的位置同步信息也可能因為網絡延遲晚收到。client 同樣根據最近收到的包做估算,但是再收到的包和之前已經收到的信息估算結果不同的時候,應該做的是運動方向和速度的修正,盡可能的讓下次的估算更準確。

            關于戰斗指令同步,我希望是給所有戰斗指令都加上冷卻時間和引導時間,這正是 wow 的設計。這樣,信任 client 的時間戳,就可以得到 client 準確的指令下達時間。引導時間(或者是公共冷卻時間)可以充當網絡延遲時間的緩沖。當然我們現在的設計會更復雜一些,這里不再列出。對于距離敏感的技能,例如遠程攻擊和范圍魔法,我們的設計是有一個模糊的 miss 判定公式,解決距離邊界的判定問題。

            這里, server 對攻擊目標的位置做估算的時候,可以不按上次發出包的運動方向去做位置估計,而選擇用最有利于被攻擊者的運動方向來做。這樣,可以減少網絡狀況差的玩家的劣勢。

            對于 PVE 的戰斗,甚至可以做更多的取舍,達到游戲流暢的效果。比如一個網絡狀態差的玩家去打 npc,他攻擊 npc 的時刻,npc 是處于攻擊范圍之內的。但是由于網絡延遲,數據包被 server 收到的時候,npc 已經離開。這個時候 server 可以以 client 的邏輯來將 npc 拉會原來的坐標。

            雖然,這樣做,可能會引起其他玩家(旁觀者) client 上表現的不同。但是,網絡游戲很多情況下是不需要嚴格同步的。在不影響主要游戲邏輯的情況下,player 的手感更為重要。

            轉自:http://blog.codingnow.com/2006/04/sync.html#comments
            posted on 2013-04-12 12:20 會飛的兔子 閱讀(478) 評論(0)  編輯 收藏 引用 所屬分類: 框架/圖像/算法
            亚洲伊人久久精品影院| 久久精品国产99久久香蕉| 漂亮人妻被中出中文字幕久久| 久久无码一区二区三区少妇| 午夜精品久久久久| 国产精品久久久久久久久免费| 精品久久久无码中文字幕天天| 久久精品综合网| 久久er国产精品免费观看2| 亚洲伊人久久成综合人影院 | 亚洲精品tv久久久久久久久久| 中文国产成人精品久久亚洲精品AⅤ无码精品 | 久久久久99精品成人片三人毛片| 亚洲中文字幕伊人久久无码| 国产精品9999久久久久| 一级a性色生活片久久无| 久久久国产精品网站| 99久久99久久精品国产片果冻| 91精品婷婷国产综合久久| 伊人久久综合无码成人网| 久久国产美女免费观看精品| 色综合久久无码中文字幕| 久久国产香蕉视频| 一本久久a久久精品综合夜夜| 性做久久久久久久| 免费精品国产日韩热久久| 久久久受www免费人成| 99久久国产主播综合精品| 国产精品一区二区久久| 漂亮人妻被黑人久久精品| 伊人久久大香线蕉亚洲五月天| 久久九九免费高清视频| 91久久九九无码成人网站| 久久精品人人做人人爽97| 久久人妻少妇嫩草AV无码专区 | 欧美亚洲国产精品久久久久| 久久99精品国产麻豆不卡| 亚洲天堂久久精品| 91精品国产高清久久久久久国产嫩草 | 精品无码久久久久久午夜| 无码人妻久久一区二区三区免费 |