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コンテナとローカルマシン間でファイルを転送する方法

推薦する

JavaScript キャンバスで動的な点と線の効果を実現

この記事では、動的な点と線の効果を実現するためのJavaScriptキャンバスの具体的なコードを参考...

少なくとも7日間連続して注文を行ったユーザーに対するSQLクエリ

テーブルを作成するテーブル order(id varchar(10),date datetime,o...

Vueにおける仮想DOMの理解のまとめ

これは本質的に、ビュー インターフェース構造を記述するために使用される共通の js オブジェクトです...

mysql は sql ファイルを実行し、エラーを報告します エラー: 不明なストレージ エンジン 'InnoDB' ソリューション

問題を見つける最近、仕事で問題が発生しました。InnoDB タイプの SQL ファイルを実行すると、...

WeChat アプレットのカスタム スクロール ビューのサンプル コード

ミニプログラムカスタムスクロールビュースクロールバーさっそくレンダリングを見てみましょうレンダリング...

Linux で大きなファイルの内容を消去または削除する 5 つの方法

Linux ターミナルでファイルを操作しているときに、Linux コマンドライン エディターでファイ...

CentOS で MySQL 5.1 を 5.5.36 にアップグレードする

CentOS 6.4 環境で MySQL 5.1 を 5.5.36 にアップグレードする手順を記録し...

ZFS とは何か? ZFS を使用する理由とその機能

ZFSの歴史Z ファイル システム (ZFS) は、2001 年に Matthew Ahrens と...

仮想スクロールを簡単に実装するためのVueサンプルコード

目次序文ローリング原理成し遂げるソースコード参照する序文モバイル Web ページの日常的な開発では、...

新しいカーネルをLinuxシステムに移植する手順

1. ubuntu16.04 イメージと対応する ubuntu16.04 カーネル バージョンのソー...

Dockerイメージの階層化の原理の詳細な説明

ベースイメージベースイメージには 2 つの意味があります。他のイメージに依存せず、ゼロから構築します...

Mac OS に MySQL 5.7.20 をインストールするための詳細なグラフィックとテキストの説明

Mac OS X で TAR.GZ から MySQL 5.7 をインストールする MySQL 5.6...

MySQL 5.7.19 のインストールと設定方法のグラフィック チュートリアル (win10)

以下に記録されているように、WIN10システムにMYSQLをダウンロードしてインストールするための詳...

実用的な基本的な Linux sed コマンドのサンプルコード

Linux ストリーム エディターは、データ センターでスクリプトを実行するのに便利な方法です。これ...

Flexレイアウトを使用してdiv内のサブ要素を垂直方向に中央揃えする例

1. Flex は Flexible Box の略で、「柔軟なレイアウト」を意味し、ボックス モデル...