CocosCreator动作系统
废话没有,直接上代码,有注释可以看的,
cc.Class({
extends: cc.Component,
properties: {
//
player:{
default:null,
type:cc.Node,
tooltip:"this is a tips"//属性检查器内的自定义提示信息
}
},
onLoad:function(){
//////////使用动作系统///////////////////////////////////
//var action1=this.player.moveTo(2,100,100); cc.
//this.node.runAction(action1); error
//action 1 简单移动动作
//var action1=cc.moveTo(2,100,100);
//this.player.runAction(action1);
// 2 顺序执行的动作
//var seq0=cc.sequence(cc.moveBy(2,200,0),cc.moveBy(2,-200,0)) ;
//this.player.runAction(seq0);
// 3 同步动作 让节点在向上移动的同时缩放
//var spawn = cc.spawn(cc.moveBy(0.5, 0, 50), cc.scaleTo(0.5, 0.8, 1.4));
//this.player.runAction(spawn);
// 4 重复动作 cc.repeat 重复动作用来多次重复一个动作
/*
var seq=cc.repeat(
cc.sequence(
cc.moveBy(2,200,0),
cc.moveBy(2,-200,0)),5 );
this.player.runAction(seq); */
//5 永远重复 循环
/*
var seq0=cc.repeatForever(cc.sequence(cc.moveBy(2,200,0),cc.moveBy(2,-200,0))) ;
this.player.runAction(seq0); */
//6 速度动作
/*
var seq1=cc.speed(
cc.spawn(
cc.moveBy(2,200,0),
cc.scaleTo(2, 0.8, 1.4)
),0.5 );
this.player.runAction(seq1); */
// 一个复杂的跳跃动画
var JumpAction = cc.sequence(
cc.spawn(
cc.scaleTo(0.1, 0.8, 1.2),
cc.moveTo(0.1, , )
),
cc.spawn(
cc.scaleTo(0.2, , ),
cc.moveTo(0.2, , )
),
cc.delayTime(0.5),
cc.spawn(
cc.scaleTo(0.1, 1.2, 0.8),
cc.moveTo(0.1, , -)
),
cc.spawn(
cc.scaleTo(0.2, , ),
cc.moveTo(0.2, , )
)
// 以1/2的速度慢放动画,并重复5次
).speed().repeat();
this.player.runAction(JumpAction);
},
start :function() {
//获取组件所在的节点,只要在组件方法里访问 this.node 变量:
var node=this.node;
console.log(node.name+":0000000000000000000000000");
//获取其他组件,获得同一个节点上的其它组件,这就要用到 getComponent 这个 API
var canvas=this.getComponent(cc.Canvas);//canvas 为object
var text=canvas.name+":11111111111111111111111111";
console.log(text);
//也可以为 getComponent 传入一个类名
var label = this.getComponent("cc.Canvas");
console.log(label.name+":222222222222222222");//输出结果同上
//对用户定义的组件而言,类名就是脚本的文件名,且区分大小写。
//在节点上也有一个 getComponent 方法,它们的作用是一样的:
cc.log( this.node.getComponent(cc.Label) === this.getComponent(cc.Label) ); // true
/*如果在节点上找不到你要的组件,getComponent 将返回 null,如果你尝试访问 null 的值,
将会在运行时抛出 "TypeError" 这个错误。因此如果你不确定组件是否存在,记得判断一下:*/
if(this.node.getComponent(cc.label)){
console.log("this node had label component");
}
else{
console.log("this node don't have this component");
}
////////////////////////////////////////////////////////////////////////
//获得其它节点及其组件
// 最直接的方式就是在 属性检查器 中设置需要的对象。只需要在脚本中声明对应属性即可:1
//接着就可以将层级管理器上的任意一个节点拖到这个 player 控件,即可,之后可以直接在脚本里访问 player:this.player.xxxx
///////////////////////查找子节点/////////////////////////////////////////////////////////////
//游戏场景中有很多个相同类型的对象,像炮塔、敌人和特效通常都有一个全局的脚本来统一管理。此时不适合使用属性检查器一个个关联到脚本。为了更好地统一管理这些对象,可以统一的父物体下,然后通过父物体来获得所有的子物体:
var cannnos=this.node.children;
for(var i=;i<cannnos.length;i++)
{
console.log(cannnos[i].name);//不包括自身
}
//还可以使用 getChildByName:this.node.getChildByName("Cannon 01");
// console.log(this.node.getChildByName("richtext").name);
//全局名字查找 当 cc.find 只传入第一个参数时,将从场景根节点开始逐级查找:
//this.backNode = cc.find("Canvas/Menu/Back",this.node);
////////////////////////访问已有变量里的值//////////////////////////////////////////////////////////////
//1,通过全局变量访问
/*你应当很谨慎地使用全局变量,当你要用全局变量时,应该很清楚自己在做什么,我们并不推荐滥用全局变量,即使要用也最好保证全局变量只读。
让我们试着定义一个全局对象 window.Global,这个对象里面包含了 backNode 和 backLabel 两个属性。
// Globals.js, this file can have any name
window.Global = {
backNode: null,
backLabel: null,
};
由于所有脚本都强制声明为 "use strict",因此定义全局变量时的 window. 不可省略。
接着你可以在合适的地方直接访问并初始化 Global:
// Back.js
cc.Class({
extends: cc.Component,
onLoad: function () {
Global.backNode = this.node;
Global.backLabel = this.getComponent(cc.Label);
}
});
初始化后,你就能在任何地方访问到 Global 里的值:
// AnyScript.js
cc.Class({
extends: cc.Component,
// start 会在 onLoad 之后执行,所以这时 Global 已经初始化过了
start: function () {
var text = 'Back';
Global.backLabel.string = text;
}
});
访问全局变量时,如果变量未定义将会抛出异常。
添加全局变量时,请小心不要和系统已有的全局变量重名。
你需要小心确保全局变量使用之前都已初始化和赋值。 */
//2,通过模块访问
/*通过模块访问
如果你不想用全局变量,你可以使用 require 来实现脚本的跨文件操作,让我们看个示例:
// Global.js, now the filename matters
module.exports = {
backNode: null,
backLabel: null,
};
每个脚本都能用 require + 文件名(不含路径) 来获取到对方 exports 的对象。
// Back.js
// this feels more safe since you know where the object comes from
var Global = require("Global");
cc.Class({
extends: cc.Component,
onLoad: function () {
Global.backNode = this.node;
Global.backLabel = this.getComponent(cc.Label);
}
});
// AnyScript.js
// this feels more safe since you know where the object comes from
var Global = require("Global");
cc.Class({
extends: cc.Component,
// start 会在 onLoad 之后执行,所以这时 Global 已经初始化过了
start: function () {
var text = "Back";
Global.backLabel.string = text;
}
});*/
},
});
CocosCreator动作系统的更多相关文章
- Cocos Creator 中的动作系统那些事儿
动作系统就是可以在一定的时间内实现位移.旋转.缩放.跳动等各种动作. 需要注意的是,动作系统跟 Cocos Creator 编译器的动画系统不同,动作系统是面向程序员的API接口,而动画系统是通过编译 ...
- Unity Animation System(动画系统)
动画系统: 支持:动画融合,混合,叠加动画,行走循环的时间同步,动画层,控制动画的各个方面(时间,速度,融合权重) 带有每顶点1.2或4骨骼的蒙皮网格,以及支持基于物理的布娃娃系统和程序动画. ...
- cocos2d-x 详解之 CCAction(动作)
关于动作部分,总的来说使用起来比较简单,创建一个动作,然后让可渲染节点如精灵去执行这个动作即可.cocos2dx提供了很多类型的动作,使用起来也很方便.本节重点介绍动作CCAction的子类之一时间动 ...
- cocos2d动作讲解
从本章开始,我们开始讲解cocos2d-x库的动作(Action).游戏的世界是一个动态的世界:无论是主角精灵还是NPC精灵都处于不断的运动当中,甚至是背景中漂流的树叶,随风而动的小草.这些明显的或者 ...
- Simple2D-25 精灵动作
精灵动画作用在精灵上,使精灵表现出动画效果.本文将详细说明如何创建一个简单的动作系统,暂时只有 4 中基本的动作——平移.旋转.缩放和 Alpha 变化,并且这些动作能够自由组合,组成串行动作或并行动 ...
- FlappyBird
学习CocosCreator有段时间了,现在花了两天时间写了个像素鸟的小游戏,这个游戏之前又看到过,但是不知道怎么又下架了,之前还是蛮火的游戏,想起来后去网上看了看,原来是因为侵犯了 超级玛丽 的游戏 ...
- Andorid视觉新冲击-Material design语言
[写在前面] google在2014年 I/O大会上推出了一种新的设计设计语言—Material design,这种设计语言语言旨在为手机.平板电脑.台式机和“其他平台”提供更一致.更广泛的“外观和感 ...
- Cocos2d-JS游戏导演
什么是游戏的导演 具体来说,Cocos2d-JS中的导演是一个对象,它负责设置游戏的运行环境,控制游戏的住循环并且管理场景和场景的切换. 导演的任务 Cocos2d-JS中导演对象名为:cc.dire ...
- Intent的七大属性
1.Action Action属性代表系统要执行的动作 系统提供如下常用的Action属性 *ACTION_MAIN:应用程序入口点 *ACTION_VIEW:显示指定数据 *ACTION_EDIT: ...
随机推荐
- 【转】使用SevenZipSharp压缩、解压文件
引用 下载之后引用“SevenZipSharp.dll”至项目中,然后将“7z.dll”放到bin目录下,或者这样引用:SevenZipCompressor.SetLibraryPath(" ...
- 分布式调用技术 RPC VS REST
一 分布式调用大体上就分为两类,RPC式的,REST式的,两者的区别主要是就是: 1. RPC是面向动作的(方法调用) 2. REST是面向资源的(URL表示资源,HTTP动词表示动作) 从变现形式来 ...
- PYTHON-组合 封装 多态 property装饰器
# 组合'''软件重用的重要方式除了继承之外还有另外一种方式,即:组合组合指的是,在一个类中以另外一个类的对象作为数据属性,称为类的组合 1. 什么是组合 一个对象的属性是来自于另外一个类的对象,称之 ...
- python接口自动化测试十二:对返回的json的简单操作
# 1.requests里面自带解析器转字典 print(r.json()) print(type(r.json())) # 取出json中的'result_sk_temp'字段 # {"r ...
- DFMZ-开发过程中遇到的错误-01
未能加载文件或程序集“H2F, Version=1.0.0.0, Culture=neutral, PublicKeyToken=null”或它的某一个依赖项.试图加载格式不正确的程序. 原因分析:由 ...
- JavaScript常见的假值
值 说明 var a=false; 值等于false(假) var a =0; 值等于0 var a=''; 空的字符串 var a=10/'abc' NaN var a; 未赋值变量
- IntentService用法
IntentService 用完即走 IntentService,可以看做是Service和HandlerThread的结合体,在完成了使命之后会自动停止,适合需要在工作线程处理UI无关任务的 ...
- Spring的控制反转和依赖注入
Spring的官网:https://spring.io/ Struts与Hibernate可以做什么事? Struts, Mvc中控制层解决方案 可以进行请求数据自动封装.类型转换.文件上传.效验… ...
- php 发送超大数据处理
set_time_limit(0);//设置永不超时 ignore_user_abort(); //设置客户端断开,继续处理 //总数 $allusercount= $this->gamedb_ ...
- jQuery源码中的“new jQuery.fn.init()”什么意思?
所有文章搬运自我的个人主页:sheilasun.me 引子 最近打算试试看看jQuery的源码,刚开个头就卡住了.无论如何都理解不了jQuery源码入口部分中的 return new jQuery.f ...