CocosCreator でレイヤー管理に常駐ノードを使用する方法

CocosCreator でレイヤー管理に常駐ノードを使用する方法

CocosCreator バージョン: 2.3.4

ほとんどのゲームにはレイヤー管理機能があり、例えば

  • sceneLayer シーンレイヤー
  • panelLayer ポップアップレイヤー
  • tipLayer ヒントボックスレイヤー

Cocos のシーンは永続的ではなく、切り替えるたびに自動的に破棄されます。これらのレイヤーをシーンに配置する場合、シーンごとに 1 回配置する必要がありますか?そしてまたそれを手に入れるのですが、これは非常に面倒です。

シーンは cc.director.loadScene を使用してロードされます。シーンのコンテナ ノードは、ディレクターの nodeActivator であるようです。

ここで、シーン コンテナーや Cocos のトップレベル コンテナーについては考慮しません。レイヤー管理には 2 つのアプローチが考えられます。

1. シーンは1つだけ

ゲーム全体では 1 つのシーンがあり、それがゲームの入り口のシーンです。このシーンには、sceneLayer などのレイヤーのノードが配置されます。この入り口のシーンは、エグレットとラヤのステージに相当します。

次に、すべてのシーンとポップアップ モジュールをプレハブ化し、表示されるたびに、エントリ シーンの対応するレイヤーに addChild を追加するだけです。

2. 常駐ノードを使用する

例えば、シーン1にsceneLayerなどのレイヤーを配置します。表示をわかりやすくするために、各レイヤーに単一の色を追加しました。

常駐ノードはルート ノードの下、つまりキャンバスと同じレベルにある必要があります。 3 つのレイヤーを永続ノードとして設定します。

オンロード(){
    cc.game.addPersistRootNode(cc.find("sceneLayer"));
    cc.game.addPersistRootNode(cc.find("panelLayer"));
    cc.game.addPersistRootNode(cc.find("tipLayer"));
}

次にシーンを切り替えます。新しいシーンでも、sceneLayer などのレイヤーを表示したり取得したりすることができます。

オンロード(){
    console.log(cc.find("sceneLayer")); //sceneLayerのcc.Nodeを出力
}

常駐ノードを使用すると、入口シーンに sceneLayer などのレイヤーを配置できます。参照を保存するには、レイヤー管理クラスを使用します。

III. ベストプラクティス

レイヤー管理クラス、シングルトン

デフォルトクラスLayerManagerをエクスポートし、cc.Componentを拡張します。

    プライベート静的インスタンス:LayerManager;
    パブリック静的ins():LayerManager{
        if (this.instance == null) {
            this.instance = 新しい LayerManager();
        }
        this.instance を返します。
    }

    パブリック パネル レイヤー:cc.Node;
    パブリック tipLayer:cc.Node;
    
}

エントリシーンに常駐ノードレイヤーを設定し、レイヤー管理クラスを使用して参照を保存します。後で使用するため。

@ccクラス
デフォルトクラスHelloworldをエクスポートし、cc.Componentを拡張します。

    オンロード(){
        cc.game.addPersistRootNode(cc.find("sceneLayer"));
        cc.game.addPersistRootNode(cc.find("panelLayer"));
        cc.game.addPersistRootNode(cc.find("tipLayer"));

        LayerManager.ins().panelLayer = cc.find("panelLayer");
        LayerManager.ins().tipLayer = cc.find("tipLayer");
    }
}

以上が、CocosCreator のレイヤー管理用常駐ノードの使用方法の詳細です。CocosCreator のレイヤー管理用常駐ノードの詳細については、123WORDPRESS.COM の他の関連記事をご覧ください。

以下もご興味があるかもしれません:
  • CocosCreator 入門チュートリアル: ネットワーク通信
  • CocosCreatorでWeChatゲームを作成する方法
  • CocosCreator システムイベントがどのように生成され、トリガーされるかについての詳細な説明
  • CocosCreatorでゲームコントローラーを使用する方法
  • CocosCreator Huarongdaoデジタルパズルの詳しい説明
  • CocosCreatorゲームにおける魚群アルゴリズムの詳細な説明
  • CocosCreator最適化DrawCallの詳細な説明
  • CocosCreatorがスキル冷却効果を実装
  • cocoscreatorプレハブの詳しい説明
  • CocosCreatorメッセージ配信メカニズムの詳細な説明

<<:  新しい Linux ファイル権限設定における umask の詳細な理解

>>:  Dockerコンテナとローカルマシン間でファイルを転送する方法

推薦する

Typescript の as、疑問符、感嘆符の詳細な説明

1. asキーワードはアサーションを示すTypescript では、アサーションを表現する方法が 2...

子ども向けウェブサイトの視覚構造レイアウト設計手法の分析

1. 温かくて優しい関連アドレス: http://www.web-designers.cn/post...

Nginx サービス クイック スタート チュートリアル

目次1. Nginx の紹介1. Nginx とは何ですか? 2. Nginx を使用する理由3. ...

Docker で FastDFS をデプロイする方法

Dockerにfastdfsをインストールするディレクトリをマウント-v /e/fdfs/トラッカー...

spanタグのスタイルに幅属性を設定する方法

span タグのスタイルに width 属性を直接設定すると、効果がないことがわかります。 disp...

過去2年間のユーザーエクスペリエンス

<br />国内のウェブサイトが本格的に普及し、ユーザーエクスペリエンスに重点が置かれる...

Windows での MySQL 5.7.10 のインストールと設定のチュートリアル

MySQL は、ユーザーごとに 2 つの異なるバージョンを提供します。 MySQL コミュニティ サ...

CentOS7環境にMySQL5.5データベースをインストールする

目次1. 現在のシステムにMySQLがインストールされているかどうかを確認する2. インストールされ...

Centos7 でスーパーバイザ デーモンをインストールして設定する方法

初心者は自分で録音しましょう1. スーパーバイザーをインストールします。 Supervisor は ...

HTML テーブル境界制御実装コード

一般的に、テーブルを使用する場合は、常に <table border="1"...

よく理解しましたかタグ 定義方法 使用方法

序文:今日、「<!DOCTYPE> タグを注意深く理解しましたか?」と尋ねられました。私...

Vue は小数点付きの星評価を実装します

この記事では、小数点付きの星評価を実装するためのVueの具体的なコードを参考までに共有します。具体的...

MYSQL8.0.13 無料インストール版 設定チュートリアル例 詳細説明

1. ダウンロード、例として8.0を取り上げますダウンロードアドレス: https://dev.my...

docker compose デプロイメントにおけるマスタースレーブレプリケーションの実装

目次構成解析サービス構築ディレクトリ構造ファイルを作成インスタンス構成サービスを開始するテストRed...

JavaScript に関する 6 つの奇妙で便利な点

目次1. 解体のヒント2. デジタルセパレーター3. try...catch...finally が...