成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Java 多玩家 libgdx 教程

開發 后端
這篇文章中我們看到如何用AppWarp開發多人游戲。 我們在一個現成的libgdx超級跳躍例子基礎上用 AppWarp Cloud 特性進行拓展。

StartScreen java multiplayer libgdx tutorial

我們如何去做?

  • 在 libgdx的主頁修改libgdx樣本“superjumper".

  • 使用 AppWarp Cloud將它轉化為2個玩家的實時游戲.

  • 本游戲將匹配玩家并且用戶需要到達城堡來贏得游戲的勝利.

  •  用戶將獲得其他用戶成績的實時反饋以增加了游戲的刺激性。 

Eclipse 項目設置

 接下來,您需要從這個git repository下載libgdx游戲樣本(superjumper項目。.

在Eclipse中打開下載的superjumper解決方案。你將看到項目如下:

SetUp java multiplayer libgdx tutorial

為了創建多玩家,我使用了 AppWarp Java SDK (1.5 as of now)

關于libgdx的依賴
 

正如 libgdx的官網上提到的,這個示例依賴于libgbx。如果你試圖運行libgbx網站上的superjumper示例程序,你會得到關于gdx,gdx-backend-lwjgl, gdx-jnigen, gdx-openal的錯誤。你需要將這些工程設置為你的應用(superjumper)的依賴庫工程來解決這些錯誤。

但我已經將這些庫包含在了superjumper git倉庫中的libs文件夾下。觀看這個視頻或閱讀這個教程來了解更多關于libgdx工程的安裝設置。

取得你的AppWarp application keys

如果你要與AppWarp云服務集成,你需要從ShepHertz開發者面板AppHq取得你的application keys.這些key能夠在ShepHertz云服務中識別的你應用空間,而且AppWarp云需要用它們隔離不同應用間的消息。

AppWarp網站上按步驟注冊(免費)并取得你的application keys.

現在打開superjumper示例工程中的 WarpController.java 文件并在其中添加這些值。例如:

  1. public static String AppKey = "14a611b4b3075972be364a7270d9b69a5d2b24898ac483e32d4dc72b2df039ef";  
  2. public static String SecretKey = "55216a9a165b08d93f9390435c9be4739888d971a17170591979e5837f618059"

運行多用戶sample
 

既然你已經準備好了, 我們可以實際運行并觀察這個游戲了。因為這個游戲有單人或多人游戲的選項,為了玩多人游戲你需要在2個模擬器/設備上同時運行它。

當你按了multiplayer按扭, 這個游戲會連接AppWarp并加入一個游戲房間。一旦進入這個游戲房間, 這個客戶端在游戲開始前會一直等待第二個玩家加入該房間。

[[113667]]

現在你需要在第二個模擬器/設備上做同樣的操作,AppWarp的匹配API會將第二個玩家連接到相同的游戲房間,然后游戲開始。玩家需要到達城堡來完成這個游戲。同時用戶會發現他們的對手在實時地運動。這個游戲內實時通信正是AppWarp的強大之處。

[[113668]]

游戲會在這三個條件下完成

  1. 用戶離開:當一個玩家離開游戲時,另一個玩家被判定為勝利者。因為他的對手已經離開的游戲。

  2. 闖關成功:到達城堡的玩家成為勝利者

  3. 游戲結束:如果玩家碰到了松鼠或者玩家掉了下來那另一個玩家會成為勝利者。

GameOver java multiplayer libgdx tutorial 

#p#

怎樣與AppWarp集成
 

開始游戲

首先你需要用你的應用密鑰初始化Warpclient單例(WarpController.java).

  1. WarpClient.initialize(apiKey, secretKey); 

接下你需要連接到AppWarp云端并且加入一個游戲房間(WarpController.java)

注意: AppWarp SDK 提供通過異步API提供它的功能。這意味著你只需簡單的將請求監聽器添加到WarpClient實例中區接受響應和通知即可。

這個文件 (WarpController.java) 有我們這步所需的所有代碼。它創建連接請求,房間請求,區域請求(如果有必要創建一個房間)。因此我們添加相關監聽器到OnStart()方法中。

  1. public WarpController()  
  2. {  
  3.     initAppwarp();  
  4.     warpClient.addConnectionRequestListener(new ConnectionListener(this));  
  5.     warpClient.addChatRequestListener(new ChatListener(this));  
  6.     warpClient.addZoneRequestListener(new ZoneListener(this));  
  7.     warpClient.addRoomRequestListener(new RoomListener(this));  
  8.     warpClient.addNotificationListener(new NotificationListener(this));  
  9. }  
  1. private void initAppwarp(){  
  2.     try {  
  3.         WarpClient.initialize(apiKey, secretKey);  
  4.         warpClient = WarpClient.getInstance();  
  5.     } catch (Exception e) {  
  6.         e.printStackTrace();  
  7.     }  
  8. }  

設置好listener后我們可以繼續創建連接。用戶需要傳入一個惟一用戶名(username)以連接到AppWarp云。在示例中我只是使用了一個隨機字符串(你也可以從用戶或像facebook的第三方服務處取得來惟一標識用戶)。隨機字符串是在MainMenuScreen.java文件中生成的。

  1. WarpClient.connectWithUserName(userName); 

連接的結果會交給以下回調函數。

  1. public void onConnectDone(ConnectEvent e) {  
  2.     if(e.getResult()==WarpResponseResultCode.SUCCESS){  
  3.         callBack.onConnectDone(true);  
  4.     }else{  
  5.         callBack.onConnectDone(false);  
  6.     }  
  7. }  
  1. public void onConnectDone(boolean status){  
  2.     if(status){  
  3.         warpClient.initUDP();  
  4.         warpClient.joinRoomInRange(11false);  
  5.     }else{  
  6.         isConnected = false;  
  7.         handleError();  
  8.     }  

如果連接成功,我們會試著加入一個房間。我們也可以選擇初始化UDP(稍后的游戲玩家會用到)。為了加入房間,我們使用JoinRoomInRange方法并傳入參數(1,1),它會請求服務器將客戶端加入只有一個用戶的房間。如果失敗我們會新建并加入一個容納兩個玩家的房間。

  1. public void onJoinRoomDone(RoomEvent event){  
  2.     if(event.getResult()==WarpResponseResultCode.SUCCESS){// success case  
  3.         this.roomId = event.getData().getId();  
  4.         warpClient.subscribeRoom(roomId);  
  5.     }else if(event.getResult()==WarpResponseResultCode.RESOURCE_NOT_FOUND){// no such room found  
  6.         HashMap<string, object=""> data = new HashMap<string, object="">();  
  7.         data.put("result""");  
  8.         warpClient.createRoom("superjumper""shephertz"2, data);  
  9.     }else{  
  10.         warpClient.disconnect();  
  11.         handleError();  
  12.     }  
  13. }  

一旦加入某個房間(不管是現在還是創建新房間之后),客戶端需要訂閱這個房間來接收房間的通知(這在游戲中是必須的)。這里詳細解釋了這些概念。訂閱之后我們要調用getLiveRoomInfo來檢查房間是否有兩個玩家了,如果是我們就開始游戲,否則就等待其他玩家加入這個房間。

  1. WarpClient.getLiveRoomInfo(roomId); 
  1. public void onGetLiveRoomInfo(String[] liveUsers){  
  2.     if(liveUsers!=null){  
  3.         if(liveUsers.length==2){  
  4.             startGame();      
  5.         }else{  
  6.             waitForOtherUser();  
  7.         }  
  8.         }else{  
  9.             warpClient.disconnect();  
  10.             handleError();  
  11.     }  
  12. }  

開始游戲

進行游戲的代碼在MultiplayerGameScreen.java文件中。如果用戶進入了這個界面,那就意味著有兩個用戶在這個房間中且游戲開始了。玩家玩這個游戲,并且他也要更新其他玩家的狀態。其他玩家在你的界面上顯示成綠色小怪物。

隨著玩家在界面上移動以完成游戲關卡,需要繪制它的移動軌跡,也要將位置更新發送給遠程玩家。參見WorldRenderer.java(multiplayer)

  1. private void renderBob () {  
  2. {  
  3. ...  
  4. ...  
  5.     if (side < 0){  
  6.         batch.draw(keyFrame, world.local_bob.position.x + 0.5f, world.local_bob.position.y - 0.5f, side * 11);  
  7.         sendLocation(world.local_bob.position.x + 0.5f, world.local_bob.position.y - 0.5f, side * 11);  
  8.     }else{  
  9.         batch.draw(keyFrame, world.local_bob.position.x - 0.5f, world.local_bob.position.y - 0.5f, side * 11);  
  10.         sendLocation(world.local_bob.position.x - 0.5f, world.local_bob.position.y - 0.5f, side * 11);  
  11.     }  
  12. }  

消息通過我們在這個示例中所寫的工具方法來發送。WarpClient允許客戶端將字節數組廣播給它所在的房間??梢允褂肨CP(默認)或UDP來發送。記住我們已經在成功連接到云服務后的***個界面中初始化了UDP。

  1. private void sendLocation(float x, float y, float width, float height){  
  2.   try {  
  3.     JSONObject data = new JSONObject();  
  4.     data.put("x", x);  
  5.     data.put("y", y);  
  6.     data.put("width", width);  
  7.     data.put("height", height);  
  8.     WarpController.getInstance().sendGameUpdate(data.toString());  
  9.     } catch (Exception e) {  
  10.         // exception in sendLocation  
  11.     }  
  12.   }  

發送給房間的消息是通過onUpdatePeersReceived的回調方法提供的。在這個回調中我們要解析這個消息并識別發送者,消息類型和與此消息綁定的數據。我們根據這些消息做相應的處理。

  1. public void onUpdatePeersReceived(UpdateEvent event) {  
  2.     callBack.onGameUpdateReceived(new String(event.getUpdate()));  
  3. }  
  1. try {  
  2.     JSONObject data = new JSONObject(message);  
  3.     float x = (float)data.getDouble("x");  
  4.     float y = (float)data.getDouble("y");  
  5.     float width = (float)data.getDouble("width");  
  6.     float height = (float)data.getDouble("height");  
  7.     renderer.updateEnemyLocation(x, y, width, height);  
  8. catch (Exception e) {  
  9.     // exception   
  10. }  

#p#

游戲結束

當游戲結束后我們只需要更新房間的屬性。其他玩家收到通知后需要根據此消息更新他們的UI。

  1. public void updateResult(int code, String msg){  
  2.     if(isConnected){  
  3.         STATE = COMPLETED;  
  4.         HashMap<string, object=""> properties = new HashMap<string, object="">();  
  5.         properties.put("result", code);  
  6.         warpClient.lockProperties(properties);  
  7.     }  
  8. }  

lockProperties

當兩個遠程玩家同玩游戲時,他們有可能會同時結束游戲,而這會引起資源競爭。這種情況***交由服務器解決,所以我們使用了lockProperties API。所以當游戲結束時用戶向服務器發送一個lockProperties請求將結果屬性鎖定。一旦這個結果被某個用戶鎖定,服務器會放棄處理后續對同一個屬性的lockProperties請求。點擊此處以了解更多此AppWarp仲裁方式。

隨著游戲的結束,其他用戶得到通知,StartMultiplayerScreen.java根據以下代碼將游戲結束的原因顯示到界面上。

  1. public void onGameFinished (int code) {  
  2.     if(code==WarpController.GAME_WIN){  
  3.         this.msg = game_loose;  
  4.     }else if(code==WarpController.GAME_LOOSE){  
  5.         this.msg = game_win;  
  6.     }else if(code==WarpController.ENEMY_LEFT){  
  7.         this.msg = enemy_left;  
  8.     }  
  9.     update();  
  10.     game.setScreen(this);  
  11. }  

我們也要離開并取消訂閱此房間,并且取消監聽器;如果游戲不在運行狀態我們也要刪除房間。由于在這個游戲中我們使用的是AppWarp 動態房間,在使用完后***立即刪除(盡管空動態房間在60分鐘后都會被自動刪除)。

  1. public void handleLeave(){  
  2.     if(isConnected){  
  3.         warpClient.unsubscribeRoom(roomId);  
  4.         warpClient.leaveRoom(roomId);  
  5.         if(STATE!=STARTED){  
  6.             warpClient.deleteRoom(roomId);  
  7.         }  
  8.         warpClient.disconnect();  
  9.     }  
  10. }  
  1. private void disconnect(){  
  2.     warpClient.removeConnectionRequestListener(new ConnectionListener(this));  
  3.     warpClient.removeChatRequestListener(new ChatListener(this));  
  4.     warpClient.removeZoneRequestListener(new ZoneListener(this));  
  5.     warpClient.removeRoomRequestListener(new RoomListener(this));  
  6.     warpClient.removeNotificationListener(new NotificationListener(this));  
  7.     warpClient.disconnect();  
  8. }  

用戶可以在這里點擊并返回MainMenuScreen,然后我們可以重新進行這個過程。但這次我們只需要找到一個房間就可以開始了(因為我們已經連接到了服務器)。

總結

這篇文章中我們看到如何用AppWarp開發多人游戲。 我們在一個現成的libgdx超級跳躍例子基礎上用 AppWarp Cloud 特性進行拓展。我們同樣看到客戶端怎樣連接到AppWarp上,怎樣加入游戲房間。繼承概念不受libgdx的影響,并且可以應有與其他任何Java程序中。

使用Robovm發布到iOS

你可以使用 Robovm 來將超級跳躍游戲發布到iOS上. 下面是幾步是任何其它項目中都需要做的。另外你需要做如下改變。

1. 將這些屬性添加到 robovm.xml  

  1. <forcelinkclasses>  
  2.   <pattern>org.apache.harmony.xnet.provider.jsse.OpenSSLProvider</pattern>  
  3.   <pattern>org.apache.harmony.security.provider.cert.DRLCertFactory</pattern>  
  4.   <pattern>com.android.org.bouncycastle.jce.provider.BouncyCastleProvider</pattern>  
  5.   <pattern>org.apache.harmony.security.provider.crypto.CryptoProvider</pattern>  
  6.   <pattern>org.apache.harmony.xnet.provider.jsse.JSSEProvider</pattern>  
  7.   <pattern>com.android.org.bouncycastle.jce.provider.JCEMac$SHA1</pattern>  
  8. </forcelinkclasses>  

2. 使用如下代碼從背景中改變屏幕。

  1. Gdx.app.postRunnable(new Runnable() {  
  2.   @Override 
  3.   public void run () {  
  4.       game.setScreen(new MultiplayerGameScreen(game, StartMultiplayerScreen.this));  
  5.   }  
  6. });  

這里另有要求, 我們得到如下錯誤,因為AppWarp的回調不在UI線程中。

    Exception in thread "MessageDispatchThread" java.lang.IllegalArgumentException:     Error compiling shader

3. 超級跳躍中聲音不可用了,這是因為iOS中的聲音是使用RoboVm。

英文原文: Java Multiplayer libgdx Tutorial

譯文鏈接:http://www.oschina.net/translate/java-multiplayer-libgdx-tutorial

責任編輯:林師授 來源: 開源中國社區 編譯
相關推薦

2013-11-06 11:31:28

Android游戲

2013-12-04 13:30:45

Android游戲引擎libgdx教程

2013-12-06 10:22:42

Android游戲引擎libgdx教程

2013-12-06 10:31:14

Android游戲引擎libgdx教程

2013-12-04 17:27:10

Android游戲引擎libgdx教程

2013-12-06 10:12:49

Android游戲引擎libgdx教程

2013-12-06 09:59:53

Android游戲引擎libgdx教程

2022-01-07 13:34:25

Java時間格式化

2021-01-19 11:07:34

內存條標簽硬件

2023-05-18 07:15:35

SSDHDD游戲

2013-12-04 16:21:02

Android游戲引擎libgdx教程

2013-12-04 17:14:57

Android游戲引擎libgdx教程

2013-12-04 16:07:27

Android游戲引擎libgdx教程

2013-12-06 10:35:28

Android游戲引擎libgdx教程

2013-12-04 16:28:29

Android游戲引擎libgdx教程

2011-12-24 21:59:02

iPhone

2021-08-26 21:55:38

DPU架構數據

2009-03-23 13:50:40

Nehalem服務器高性能

2020-04-06 11:56:04

黑客網絡威脅網絡攻擊

2009-05-26 08:23:04

魔獸集體移民臺灣玩家
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲免费一区二区 | 精品一区二区三区视频在线观看 | 一级毛片免费 | 午夜视频在线免费观看 | 色在线视频网站 | 国产一区二区中文字幕 | 国产2区 | 日韩精品在线一区 | 日本精品久久 | 色站综合 | 亚洲欧美视频在线观看 | 97久久精品午夜一区二区 | 国产欧美日韩 | 最新国产视频 | 亚洲性在线 | 男人的天堂久久 | 亚洲精品一区二区 | 91se在线| 一级毛片播放 | 亚洲国产一区二区三区四区 | 99精品视频在线观看 | 国产精品一区二区久久精品爱微奶 | caoporn视频| 九九成人| 日韩av手机在线观看 | 成人av一区 | 国产精品区二区三区日本 | 国产精品视频一区二区三区 | 青青草在线视频免费观看 | 成在线人视频免费视频 | 久久亚 | 亚洲 自拍 另类 欧美 丝袜 | 欧美日韩国产一区二区 | 一区二区三区在线播放 | 国产精品精品 | 午夜久久久 | 欧美日韩成人在线 | 成人av一区 | 91精品福利 | 超碰在线国产 | 欧美日韩精品影院 |