CocosCreator MVCアーキテクチャの詳細な説明

CocosCreator MVCアーキテクチャの詳細な説明

概要

この記事では、ゲームクライアントでよく使用される MVC アーキテクチャについて紹介します。ゲームの MVC は次のように分割されます。

M: 1) すべてのゲーム モジュール データがエントリされる単一のグローバル データ センター ワールド、2) 各モジュール独自のデータ構造。

V: 1) クリエイターが作成したUIインターフェースとシーンのプレハブ、2) 各インターフェースの表示ロジックのViewCtrl

C: 1) グローバル MainCtrl、2) 各モジュールのビジネスロジッククラス ModuleCtrl

特定のモジュール

まずはMの部分を紹介しましょう。 1 つのモジュールのデータは、フレンド モジュールなどの他のモジュールでもアクセスする必要があるため、チャット中やランキング リストでもアクセスする必要があります。データにはシングルトンのグローバル データ センター クラス World が必要であり、すべてのゲーム モジュールのデータ クラスには World のエントリがあります。これらのデータは、プレイヤーがログインした後にサーバーから取得して設定できます。

エクスポートクラス World {
    プライベート静的インスタンス: World = null;
 
    プライベート _test: TestData = null;
 
    /**
     * シングルトンモード */
    プライベートコンストラクタ() {
 
    }
 
    /**
     * インスタンスを取得 */
    パブリックスタティックgetinst(): World {
        if (!World.instance) {
            World.instance = 新しいWorld();
        }
 
        World.instance を返します。
    }
 
    // テスト用
    パブリックセットテスト(val: TestData) {
        this._test = val;
    }
 
    パブリックテスト()を取得:テストデータ{
        this._test を返します。
    }
}

このように、モジュールは独自のデータ構造を独立して設計し、メッセージを送信して対応するモジュールの ModuleCtrl に変更を要求し、World を通じてそれを読み取ることができます。

エクスポートクラスTestData {
    プライベート_text: 文字列 = null;
 
    パブリックコンストラクタ() {
 
    }
 
    公開テキストを設定します(値: 文字列) {
        this._text = val;
    }
 
    パブリックテキスト取得(): 文字列 {
        this._text を返します。
    }
}

データが更新されるとメッセージが送信され、インターフェースは更新のためにメッセージをリッスンできます。

以下に、インターフェースとスクリプト コードの関連について説明します。前の章で紹介したように、Cocos Creator はコンポーネント モデルに基づいています。各 UI インターフェースをプレハブにし、各プレハブにスクリプト コンポーネントを追加して、このインターフェースの表示ロジックを制御できるようにしました。

ポップアップ ウィンドウの管理では、cc.Component を継承する ViewCtrl というクラスを設計したと述べました。すべてのインターフェイス表示ロジック クラスは ViewCtrl を継承し、対応するインターフェイス プレハブに追加されます。前述のように、データが更新されるとメッセージが送信されます。ViewCtrl はデータ更新メッセージをリッスンし、関連するインターフェイスを更新します。

const {ccclass、プロパティ} = cc._decorator;
 
@ccクラス
エクスポートデフォルトクラスTestViewCtrlはViewCtrlを拡張します{
}

ViewCtrl はインターフェイスの表示ロジックのみを処理し、データ ビジネス ロジックは処理しません。モジュールのデータ ビジネス ロジックは、モジュールの ModuleCtrl によって処理されます。 ViewCtrl はユーザー操作に応答してメッセージを送信し、ModuleCtrl はメッセージをリッスンして処理します。ほとんどのモジュールの ModuleCtrl は、主にネットワーク通信と、このモジュールのキャッシュされたデータの変更に使用されます。

エクスポートクラスTestCtrl {
 
    パブリックコンストラクタ() {
 
    }
 
    パブリック init(): void {}
 
    パブリック開始(): void {
        NotificationCenter.addListener(MSG_TEST_HTTP、(ソース: 任意、データ: 任意) => {
            このテストHttp();
        }、 これ);
    }
 
    パブリックtestHttp(): void {
        データ = {
            mod: 1, // モジュール cmd: 1, // コマンド}
 
        パラメータ: HttpReq = {
            パス: ""、
            メソッド: HTTP_METHOD_GET
        }
 
        MainCtrl.inst.http.sendData(データ、パラメータ、(データ: NetData) => {
            World.inst.test = 新しい TestData();
            テキスト = "123";
        }, (コード: 数値、理由: 文字列) => {});
    }
}

前述したように、C レイヤーにはグローバル シングルトン MainCtrl もあります。このクラスは主に、モジュールの登録、グローバル操作インターフェース(インターフェース/シーンの表示や非表示など)の提供、ネットワーク通信処理を担当します。

上記は、CocosCreator MVC アーキテクチャの詳細な説明です。CocosCreator MVC アーキテクチャの詳細については、123WORDPRESS.COM の他の関連記事に注目してください。

以下もご興味があるかもしれません:
  • Unity は物理エンジンを使用してマルチロータードローンの飛行をシミュレートします
  • Android 向け 2D 物理エンジン Box2d を使用する簡単な例
  • CocosCreator ソースコードの解釈: エンジンの起動とメインループ
  • CocosCreator 一般的なフレームワーク設計リソース管理
  • CocosCreatorでリストを作成する方法
  • CocosCreator の新しいリソース管理システムの分析
  • CocosCreator スケルトンアニメーション ドラゴンボーン
  • CocosCreatorでシューティングゲームを作る詳しい解説
  • CocosCreatorでクールなレーダーチャートを描く方法
  • CocosCreator で物理エンジン ジョイントを使用する方法

<<:  Centos7 サーバーで jar パッケージ プロジェクトを開始する最良の方法

>>:  MySQL の一般的なツール例の概要 (推奨)

推薦する

要素フォーム検証で検証プロンプトをクリアする方法

目次問題のシナリオ:解決: 1. フィールドを個別にチェックする2. フォームフィールドの下のフィー...

cmd と python での MySQL の一般的な操作についての簡単な説明

環境設定1: MySQLをインストールし、MySQLのbinディレクトリを環境変数に追加する環境設定...

jsは古典的なマインスイーパゲームを実装します

この記事の例では、古典的なマインスイーパゲームを実装するためのjsの具体的なコードを参考までに共有し...

JavaScript でシンプルなクリスマス ゲームを実装する

目次序文成果を達成するコードCSSコードJSコードHTMLコードデモンストレーションのプロセス序文ク...

Centos7.5 構成 Java 環境のインストール Tomcat の説明

Tomcat は Java 言語をベースにした Web サーバー ソフトウェアです。この記事では主に...

Vue がコンポーネント通信を実装する 8 つの例

目次1. Props 親コンポーネント ---> 子コンポーネント通信2. $emit 子コン...

WeChatアプレットトラック再生の実装と遭遇した落とし穴の詳細な説明

WeChat アプレットの軌跡再生では、主に線描画操作にポリラインを使用し、車の移動操作にマーカーを...

バックエンドデータを取得するためのVue Elementフロントエンドアプリケーション開発

目次概要1. バックエンドデータの取得と処理2. インターフェース表示処理概要前回のエッセイ「ステッ...

MySQL ストレージエンジン InnoDB の設定と使用方法の説明

MyISAM と InnoDB は、MySQL で最も一般的なストレージ エンジンです。前回の記事で...

HTML ハイパーリンクの詳細な説明

ハイパーリンクハイパーリンクは、Web サイト上のすべてのページがハイパーリンクで接続され、ページ間...

LinuxカーネルマクロContainer_Ofの詳細な説明

目次1. 構造体はメモリにどのように保存されますか? 2. container_ofマクロ3. 型4...

MySQL 5.7 のインストールと設定のチュートリアル

この記事では、参考までにMySQLのインストールと設定のチュートリアルを紹介します。具体的な内容は次...

MySQLインデックスの失敗の典型的なケース

目次典型的なケース付録: 一般的なインデックス障害の状況典型的なケース次の構造を持つ 2 つのテーブ...

詳細なLinuxインストールチュートリアル

(Win7 システム) VMware 仮想マシンのインストール チュートリアルVMware は仮想マ...

画像ボタンをフォームのリセットボタンとして使用する方法

フォームを作成するときに、送信ボタンとリセットボタンを配置することがよくあります。ページの外観を考慮...