cocos-creator 脚本逻辑-1
1.节点
编辑组件的脚本文件时。可以通过以下语句获得节点
this 就是当前组件
this.node
拿到组件依附的节点
This.node.parent
拿到组件依附的节点 的父节点
This.node.children
拿到组件依附的节点 的子节点
this.node.getChildByName(‘’)
通过名称取得特定名的直系子节点
cc.removeSelf()
从节点树删除该节点 留在内存,但已经不在节点中 如果 args = true 则消失
跨直系引用节点
在properties 中声明 node 对象再在编辑器中拖拽绑定
就可以在组建内部直接引用
两个属性
默认组件名样式 name:节点<组件>
isValid 组件是否还在活动
2.动作
所有的动作 api 是由节点提供的,所以我们要先拿到节点
如 node.runAction()
1)动作运行:
runAction('action') 开始一个动作
stopAction(‘action’) 停止一个动作
stopAllAction() 停止该节点下的所有动作
2) 设置tag
action.setTag('tag_name')
node.getActionByTag('tag_name')
3)移动
cc.moveTo(1,20,20) 用 1s 以父节点锚点为坐标中心移动到(20,20)的位置
可以移动到一个点的相对位置,比如可以换成 cc.v2(100,100) 以c2为坐标的(100,100)
cc.rotateTo(1,50) 1s 第二个参数是角度
cc.moveBy() 相对移动
cc.scaleTo(1,2,2) 1s 放大到 2,2 scale
cc.fadeOut(1) 1s 消失
4)动作包装
包装为一个动作
cc.sequence(
动作1,
动作2
)
5)容器动作
顺序动作:cc.sequence
可执行来回往复运动,如:
var seq = cc.sequence(cc.moveBy(0.5, 200, 0), cc.moveBy(0.5, -200, 0));
node.runAction(seq);//左右来回移动
同步动作:cc.spawn
可执行叠加系列动作,如:
var spawn = cc.spawn(cc.moveBy(0.5, 0, 50), cc.scaleTo(0.5, 0.8, 1.4));
node.runAction(spawn);//向上同时缩放
重复动作:cc.repeat
可执行重复一个动作,如:
var seq = cc.repeat(
cc.sequence(
cc.moveBy(2, 200, 0),
cc.moveBy(2, -200, 0)
), 5);
node.runAction(seq);//左右移动,重复5次永远重复动作:cc.repeatForever可执行一直重复动作,如:
var seq = cc.repeatForever(
cc.sequence(
cc.moveBy(2, 200, 0),
cc.moveBy(2, -200, 0)
));//一直重复左右移动改变速度:cc.speed可执行改变速率,如:
var action = cc.speed(
cc.spawn(
cc.moveBy(2, 0, 50),
cc.scaleTo(2, 0.8, 1.4)
), 0.5);
node.runAction(action);//速度加快一倍,2秒变1秒
3.回调函数 callFunc
cc.callFunc(this.callBack, this, {'args':args}) 函数,对象,参数
callBack :function(targetNode, args){}
4.事件/交互内容
添加 Label 内置组件来添加名称,方便于判断
在操作过程中记得返回编辑器拖拽补充引用。
emit 和 on 配套 发射和监听
This.node.emit(”事件“,{参数}); 发生“事件” 同时给出参数
this.node.on(”事件“,this.event1, this.node1) 发生了“事件”后 执行 event1 执行对象是这个 node
this.node.on(”事件“,this.event2,this.node2)
限制:(参数必须和 on 一致 )
this.node.once() 只监听听一次
this.node.off() 不再监听 on
实例:
这里的 this 指的是 node1
- event1: function(e){
- console.log(e.detail),
- this.runAction(cc.moveTo(1,200,0))
- },
5 触摸事件 鼠标事件 键盘事件
This.node.on(‘touchStart’,this.onTouchStart, this) 开始触摸
this.node.on(‘touchmove’,this.onTouchMove,this); 触摸移动,持续触发
this.node.on(‘touchEnd’,this.onTouchEnd, this) 触摸停止
this.node.on(‘touchCancel’, this.onTouchCancel, this) 触摸取消,(节点外释放)
This.node.on(‘mouseup’,this.onMouseUp,this) 鼠标脱离
mouseDown onMouseDown 鼠标按下
mouseMove onMouseMove 鼠标移动(不一定要点击)
mouseEnter onMouseEnter 鼠标进入节点区域
mouserLeave onMouseLeave 鼠标离开节点区域
mouseWheel onMouseWheel 鼠标滚轮
获取点击
getButton() 返回 0 1 2 对应 左中右
2)键盘事件
cc.systemEvent.on(type,callback,target)
返回一个 keycode
可选的 type 类型有:
- cc.SystemEvent.EventType.KEY_DOWN (键盘按下)
- cc.SystemEvent.EventType.KEY_UP (键盘释放)
- cc.SystemEvent.EventType.DEVICEMOTION (设备重力传感)
例如
cc.systemEvent.off(cc.SystemEvent.EventType.KEY_DOWN, this.onKeyDown, this);
If e.keyCode == cc.KEY.w 当 keycode 是 w 时
cc.KEY.(按键)
3)获取坐标
getLocation() 获取全局坐标下的圆心
例子:
onTouchStart: function(e){
E.getLocation()
}
坐标转换:从全局坐标系转到本地坐标系
let locationOfThisNode = this.node.convertToNodeSpaceAR(e.getLocation()) AR 忽略锚点 this.node目标坐标系对应节点
让某个节点的坐标更新
this.node.position = locationOfThisNode
cocos-creator 脚本逻辑-1的更多相关文章
- Cocos Creator 脚本模板
1.由于新建Cocos Creator脚本带有很多注释,并且有时候需要增加定制的默认注释,所以需要修改脚本生成模板. 2.在CocosCreator\resources\static\template ...
- <5>Cocos Creator 脚本简介
1.创建脚本 在资源管理器窗口中点击鼠标右键,显示菜单中点击新建,选择新建的脚本类型,这里举例就选择菜单中的JavaScript,或者如下图点击创建按钮也可. 新建后就会在资源管理器中出现一个NewS ...
- Cocos Creator脚本开发事例
HelloWorld.js window.Global = { gint: 168, }; cc.Class({ extends: cc.Component, properties: { label: ...
- Cocos Creator学习目录
目录 安装和启动 文件结构 编辑器基础 基本概念 (场景树 节点 坐标 组件 ) Cocos Creator 脚本简介 Cocos Creator调试 节点 cc.Node 组件开发cc.Compon ...
- <7>Cocos Creator 节点 cc.Node
1.简介 节点(cc.Node)是渲染的必要组成部分.所有需要在游戏场景中显示的内容都必须是节点或者依附于节点之上.节点负责控制显示内容的位置.大小.旋转.缩放.颜色等信息. 2.节点属性 1: na ...
- 关于Cocos Creator用js脚本代码播放骨骼动画的步骤和注意事项
步骤: 1.用cc.find()方法找到相应的骨骼动画节点,并把这个对象赋值给一个var出来的新对象. 具体代码:var spineboy_anim = cc.find("UI_Root/a ...
- [经验] Cocos Creator使用笔记 --- 调用不同脚本下的函数
因为 JavaScript 不同于 Java, 想要调用不同文件的函数的话不能直接 ClassName object = new ClassName(); object.function(param) ...
- Cocos Creator—最佳构建部署实践
这篇文章主要是我们团队在使用Cocos Creator过程中的一些关于部署方面的实践总结,标题党了一回,严格来说,应该是<快看漫画游戏研发团队使用Cocos Creator构建部署最佳实践> ...
- cocos creator主程入门教程(七)—— MVC架构
五邑隐侠,本名关健昌,10年游戏生涯,现隐居五邑.本系列文章以TypeScript为介绍语言. 这一篇将介绍在游戏客户端常用的架构MVC架构.一个游戏的MVC如下划分: M:1)单例全局的数据中心Wo ...
- cocos creator入门
前面的话 Cocos Creator 是一个完整的游戏开发解决方案,包括了 cocos2d-x 引擎的 JavaScript 实现,以及快速开发游戏所需要的各种图形界面工具.Cocos Creator ...
随机推荐
- easyui页面上显示和PL/SQL编码问题
在页面上,只需要显示人们看的懂的文字就行,但是在数据库里面就不一定了,一般情况下,在数据库里面存字母,数字等除了汉字以外的字符,存汉字有个问题,就是有时候不同oracle数据库的客户端会出现乱码问题: ...
- Flink学习笔记:Operators之CoGroup及Join操作
本文为<Flink大数据项目实战>学习笔记,想通过视频系统学习Flink这个最火爆的大数据计算框架的同学,推荐学习课程: Flink大数据项目实战:http://t.cn/EJtKhaz ...
- python在一堆目录中寻找json文件
在一个目录下,有好几层目录,里面零零散散存放着几个json文件,我要做的是用python脚本把它们都找出来,一开始就一层一层地找,用os.listdir加上for循环,根据目录树的深度确定for循环的 ...
- [原创]VMware Workstation 14.1.3 Pro安装CentOS_7.6.1810
前言 Linux作为最主流的服务器操作系统,在市场上的使用占比保持着领先对位.其中CentOS作为基于Red Hat Linux 提供的可自由使用源代码的企业级Linux发行版本,在企业的服务器中,也 ...
- odoo 二次开发的方法
介绍 二开时模型创建完毕并配好视图后对于基本的CRUD操作不需要再在代码中实现,框架会自动提供这些功能,但如果我们的开发需求不仅仅是对当前对象的CRUD时,就需要在框架原来方法的基础上扩展出一些自己所 ...
- thinkphp5.0升级
之前一些项目是thinkphp5.0的版本.这个版本是有严重漏洞的.根据官方建议会把Request.php下面的 method方法做一个替换.但是实际上为了安全最好是做一个升级.首先必须要先做一个备份 ...
- android面试注意点
Java 基础知识 面向对象的基本思想 Object类相关:Object类的几个关键函数.String涉及到的常量池概念,序列化 & 反序列化. 重要关键字:final.static. 内部类 ...
- ORACLE MERGE INTO UPDATE DELETE 用法
ORACLE MERGE INTO UPDATE DELETE 用法 使用该MERGE语句从一个或多个源中选择行以进行更新或插入表或视图.您可以指定条件以确定是更新还是插入目标表或视图. 此语句是组合 ...
- (转)Python random模块
原文:https://my.oschina.net/cuffica/blog/33336 https://www.cnblogs.com/renpingsheng/p/7105296.html ran ...
- 等待页面元素(webdriverwait)
前言 在脚本中加入太多的 sleep 后会影响脚本的执行速度,虽然 implicitly_wait ()这种方法隐式等待方法一定程度上节省了很多时间.但是一旦页面上某些 js 无法加载出来(其实界面元 ...