如何在CocosCreator中利用常驻节点做图层管理
网络编程 2021-07-04 14:07www.168986.cn编程入门
这篇文章主要介绍了如何在CocosCreator中利用常驻节点做图层管理,这些技巧非常实用,希望同学们看完,回去可以试一下
CocosCreator版本2.3.4
一般游戏都有图层管理,比如
- sceneLayer 场景层
- panelLayer 弹框层
- tipLayer 提示框层
cocos里的场景不是持久化的,每次切换都会自动destroy,如果在场景上放这些图层,那么每个scene都要放一遍?然后再获取,这样很麻烦。
加载场景使用的是.director.loadScene,scene的容器node貌似是director上的一个nodeActivator
现在如果不考虑scene的容器或者cocos的顶层容器。我想一想两种图层管理的方法。
一、只有一个scene
整个游戏一个scene,就是游戏入口的scene,在这个scene上放sceneLayer等图层的node,这个入口scene相当于egret和laya的stage。
然后所有场景scene和弹框模块,都做成预制件prefab,每次显示都addChild到入口scene的相应图层上就行了。
二、使用常驻节点
比如我在场景1,放置sceneLayer等图层。为了方便显示,我每个图层加了个单色。
常驻节点必须在根节点下,也就是和canvas同级。把3个图层设置为常驻节点。
onLoad(){ .game.addPersistRootNode(.find("sceneLayer")); .game.addPersistRootNode(.find("panelLayer")); .game.addPersistRootNode(.find("tipLayer")); }
然后切换场景,在新场景中,仍然可以显示并获取到sceneLayer等图层。
onLoad(){ console.log(.find("sceneLayer")); //输出sceneLayer的.Node }
利用常驻节点,我们可以在入口场景中放置sceneLayer等图层。用图层管理类保存引用。
三、最佳实践
图层管理类,单例
export default class LayerManager extends .Component { private static instance:LayerManager; public static ins():LayerManager{ if(this.instance == null){ this.instance = new LayerManager(); } return this.instance; } public panelLayer:.Node; public tipLayer:.Node; }
在入口场景中设置常驻节点layer, 用图层管理类保存引用。以备之后使用。
@class export default class Helloworld extends .Component { onLoad(){ .game.addPersistRootNode(.find("sceneLayer")); .game.addPersistRootNode(.find("panelLayer")); .game.addPersistRootNode(.find("tipLayer")); LayerManager.ins().panelLayer = .find("panelLayer"); LayerManager.ins().tipLayer = .find("tipLayer"); } }
以上就是如何在CocosCreator中利用常驻节点做图层管理的详细内容,更多关于CocosCreator常驻节点做图层管理的资料请关注狼蚁SEO其它相关文章!
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程