cocos creator基础-cc.Node(一)场景树

场景树

1: creator是由一个一个的游戏场景组成,通过代码逻辑来控制场景跳转;

2: creator场景是一个树形结构;

3: 父节点, 孩子节点;

4: cc.Node就是场景树中的节点对象。

5: 每个节点只要在场景里面,所以任何一个节点都是一个cc.Node;

cc.Node属性

1: name: 获取节点的名字

2: active: 设置节点的可见性;

3: position: 相对坐标,参照物是父亲节点;

4: rotation: 旋转,顺时针为正, 数学逆时针为正;

5: scale: 缩放;

6: anchor: 锚点, 左下角(0, 0), 右上角(1, 1) 可以超过这个范围可以

7: Size: 大小

8: Color: 环境颜色;

9: Opacity: 透明度,

10: Skew: 扭曲;

11: Group: 分组; 进行碰撞检测

12: parent: 父亲节点的cc.Node;

13: children/childrenCount: 孩子节点的数组;

14: tag : 节点标签;

cc.Component

1:所有的组件都扩展自cc.Component(类, 构造函数);

2:每个cc.Component组件实例都有个成员node,指向它关联节点的cc.Node;

3: name: 每一个cc.Component组件通过name属性可以获得节点的名字;

4: 组件实例入口函数:

onLoad: 在组件加载的时候调用;

start: 组件第一次激活前, 调用在第一次update之前;

update(dt): 每次游戏刷新的时候调用,

lateUpdate(dt): 在update之后调用;

enabled:组件是否被启动;

onEnable: 组件被允许的时候调用;

onDisable: 组件不被允许的时候调用;

代码组件

1:每个代码组件实例都继承自cc.Component(构造函数),所以有一个node数据成员指向cc.Node;

2: cc.Class({...}) 定义导出了一个新的类的构造函数,它继承自cc.Component;

3: 当为每个节点添加组件的时候,会实例化(new)这个组件类,生成一个组件实例;(js语法new)

4: 当组件加载运行的时候,代码函数里面的this指向这个组件的实例;

5: 代码组件在挂载的时候扩展自cc.Component, 里面有个成员node会指向节点(cc.Node);

所以在代码组件里面,可以使用this.node来访问这个组件实例说挂载的节点对象;

6: 代码里访问cc.Node总要属性;

cc.Node场景树相关方法

1: 代码中创建一个节点new cc.Node();

1: addChild; 加一个子节点

2: removeFromParent/ removeAllChildren; 从父节点删除单个 / 删除所有孩子

3: setLocalZOrder/ 绘制顺序, 在下面(值越大)的会绘制在屏幕的上面;

4: 遍历节点的子节点;

5: setPosition/getPosition,

6: getChildByName/getChildByTag, getChildByIndex, 局部查找

7: cc.find(): 方便,不通用, 消耗 全局查找

cc.Class({

extends: cc.Component,

properties: {

// foo: {

// default: null, // The default value will be used only when the component attaching

// to a node for the first time

// url: cc.Texture2D, // optional, default is typeof default

// serializable: true, // optional, default is true

// visible: true, // optional, default is true

// displayName: 'Foo', // optional

// readonly: false, // optional, default is false

// },

// ...

},

// use this for initialization

// 组件实例在加载的时候运行

// 组件实例.onLoad(), 组件实例.start;

onLoad: function () {

// this, --> 当前组件实例

console.log(this);

console.log("this.onLoad");

// 代码里面怎么找到节点?

// 指向这个组件实例所挂载的节点

console.log("=======================");

console.log(this.node);

console.log(this.node.name);

console.log(this.node.active);

console.log(this.node.x, this.node.y, this.node.position);

console.log(this.node.group, this.node.groupIndex);

if (this.node.parent) {

console.log(this.node.parent.name);

console.log("go if @@@@@");

}

else {

// console.log(this.node.parent);

console.log("go else @@@@@");

}

console.log("========================");

// end

// 孩子

var children = this.node.children; // [cc.Node, cc.Node, cc.Node]

for(var i = 0; i < children.length; i ++) {

console.log(children[i].name);

}

// end

console.log("yes we have:", this.node.childrenCount,"chilren");

// 添加

/*var new_node = new cc.Node();

this.node.addChild(new_node);

new_node.removeFromParent();

this.node.removeAllChildren();*/

// end

// 查找,局部查找

var item = this.node.getChildByName("item1");

console.log("^^^^^^^", item.name);

// end

// 全局, 时间消耗,对于编写通过用的模块

item = cc.find("Canvas/parent/item1");

console.log("#######", item.name);

// end

var pos = item.getPosition(); // 相对位置

console.log("pos = ", pos);

pos = cc.p(100, 100); // cc.Vec,

item.setPosition(pos);

var item2 = this.node.getChildByName("item2");

item2.setLocalZOrder(100);

item2.active = false; //

},

// 组件实例

start: function() {

},

// called every frame, uncomment this function to activate update callback

// 组件实例.update

update: function (dt) {

},

});

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容