ネットワーク通信の概要オンライン ゲームを開発する場合、必然的にネットワーク通信に対処する必要があります。注意すべき問題がいくつかあります: 1. 迅速な開発のため、サーバーは初期段階では http 通信を使用し、後で websocket/socket に変更する場合があります。 2. httpとwebsocket/socket通信の両方が存在する 3. 通信データ形式はいつでも JSON またはプロトコル バッファに置き換える必要があり、追加のヘッダーを追加する必要が生じる場合があります。 4. 初心者ガイドのシミュレーションにはローカル データを使用するため、リクエストをバックエンドに送信する必要はありません。 5. 再接続後の簡単なデータ同期 具体的な実装1 番目と 2 番目の質問に関して、通信モジュールを設計する際には、通信を可能な限り統一された外部インターフェイスに抽象化し、ゲーム開始時に異なるドライバーを通じてインスタンスを作成することを検討します (通信方法が 1 つだけの場合は、単一のインスタンスを使用します)。 パブリックコンストラクタ(ドライバ: ConnectDriver) { this._driver = ドライバー; } まず、一般的なネットワーク通信データ構造を定義します。リクエストはデータと制御の 2 つのタイプに分かれており、ハートビート、ログイン、再接続を区別するために使用されます。 /** * リクエストタイプ */ エクスポート列挙型リクエストタイプ{ データ = 1、 Ctrl } /** * ネットワーク通信データ構造 */ エクスポートインターフェースNetData { seq?: number; // シリアル番号 mod: number; // モジュール cmd: number; // コマンド path?: string; // パス data?: any; // データ tmpData?: any; // データプロセッサの一時データ status?: number; // ステータスコード type?: RequestType; // リクエストタイプ} 次に共通の外部インターフェースを定義します パブリックオープン(url: 文字列、ポート: 数値、isBinary: ブール値、タイムアウト: 数値、再試行回数: 数値、パラメーター: 任意、cb: (succ: ブール値) => void): void {} パブリックclose(): 数値{} パブリック再オープン(cb: (succ: boolean) => void): void {} パブリック sendData(データ: NetData、パラメーター: HttpReq | any、succCb: (データ: NetData) => void、failedCb: (コード: 数値、理由: 文字列) => void): void {} パブリック resendNotRecv(): void {} resendNotRecv は、再接続後に応答を受信しなかったパケットを送信するために使用され、バックエンドはシーケンス番号に基づいてそれを処理するかどうかを決定します。 ここではプッシュ処理は行われません。実際には、プッシュはサーバーのデータを受信した後にリスナーにブロードキャストを呼び出すことです。以下はリスナーの定義です /** * ネットワーク接続イベント監視インターフェース */ エクスポートインターフェースConnectEventListener { onOpen(ドライバ: ConnectDriver); onClosed(ドライバー: ConnectDriver); onError(ドライバー: ConnectDriver、メッセージ: 文字列); onSendStart(ドライバー: ConnectDriver); onRecvEnd(ドライバー: ConnectDriver); } /** * ネットワークイベント監視インターフェース */ エクスポートインターフェース NetEventListener は ConnectEventListener を拡張します { onPush(ドライバー: ConnectDriver、データ: NetData): void; } 外部関係者に登録および削除インターフェースを提供する パブリックaddEventListener(リスナー: NetEventListener): void {} パブリックremoveEventListener(リスナー: NetEventListener): void {} 3 番目の問題については、データを送信する前とデータを受信した後に傍受と前処理を実行するためのプリプロセッサをいくつか定義する必要があります。 /** * ネットワーク通信データプロセッサインターフェース */ エクスポートインターフェースNetDataProcessor { プロセス要求データ(データ: 任意): 任意; プロセス応答データ(データ: 任意): 任意; } 外部への追加および削除インターフェースを提供し、通信データ形式を柔軟に定義できるようにします。 パブリックaddDataProcessor(プロセッサ: NetDataProcessor): void {} パブリックremoveDataProcessor(プロセッサ: NetDataProcessor): void {} 4 番目の問題に関しては、リクエストが送信される前にそれを処理する特別なインターセプターも追加します。インターセプターがそれを処理できる場合、リクエストはバックエンドに送信されなくなります。 /** * サーバーインターフェースをシミュレートする */ エクスポートインターフェースSimServer{ handleRequest(データ: NetData): NetData; } 外部設定インターフェースを提供する パブリック setSimServer(サーバー: SimServer): void {} 5 番目の質問については、すべてのデータ要求にシリアル番号が付けられ、要求が記録され、応答のない要求パケットはキューに配置されます。再接続後、これらのパケットは処理のためにバックエンドに再送信されます。 パブリック resendNotRecv(): void {} 以上がCocosCreator入門チュートリアルにおけるネットワーク通信の詳しい内容です。CocosCreatorネットワーク通信の詳細については、123WORDPRESS.COMの他の関連記事に注目してください。 以下もご興味があるかもしれません:
|
<<: CMD で MySQL データベースを操作するときに中国語の文字化けが発生する問題の解決方法
>>: Linuxのsortコマンドの複数のパラメータを理解するための1つの質問
最近VScodeのリモート開発機能をいじっています。Dockerのコンテナに接続できるほか、WSLに...
この記事では、例を使用して MySQL コマンドライン スクリプトの実行について説明します。ご参考ま...
私の環境: 3 centos7.5 1804マスター 192.168.100.140ノード1 192...
NULL が頻繁に使用されるのはなぜですか? (1)Javaのnull Java の NullPoi...
1. ファイアウォールの状態を確認するファイアウォールのステータスを確認する systemctl s...
Q1: データベースにはどのようなインデックスがありますか?メリットとデメリットは何ですか? 1. ...
エラーメッセージ:エラー 2002: ソケット '/tmp/mysql.sock' ...
Zabbix サーバー環境プラットフォームバージョン: ZABBIX バージョン 4.4システム:...
この記事では、具体的な例を使用して、CentOS 7 から CentOS 8 にアップグレードする方...
質問最近、以下に示すように、テキストストローク効果を実現するという要件に遭遇しました。 解決策1まず...
Web ページでは、あるページに情報を入力すると、別のページにジャンプし、入力した情報が別のページ...
目次1. 特徴2. 例3. オプション4. 基本的な文法5. ライフサイクル6. ルーティング管理 ...
目次1.mysqlダンプ実行プロセス:特徴2. CSVファイルをエクスポートする(最も柔軟性が高い)...
まずデータ テーブルを作成しましょう。 使用テスト; テーブル「従業員」を作成します( emp_no...
写真といえば、まず背景画像が思い浮かびます。私たちの装飾の多くは背景画像を使用して実現されているから...