2015-12-24 00:54:00 +08:00
|
|
|
// Custom Sprite
|
|
|
|
var MySprite = cc.Sprite.extend({
|
2016-01-18 14:28:02 +08:00
|
|
|
ctor: function (path) {
|
|
|
|
this._super(path);
|
|
|
|
},
|
|
|
|
something: function (x, y) {
|
|
|
|
this.setPosition(x,y);
|
|
|
|
}
|
2015-12-24 00:54:00 +08:00
|
|
|
});
|
|
|
|
|
|
|
|
//
|
|
|
|
// Scene Test 1
|
|
|
|
//
|
|
|
|
function runScene1(sender) {
|
|
|
|
var scene = new cc.Scene();
|
|
|
|
|
|
|
|
for (i = 0; i < 5; i++) {
|
|
|
|
var sprite = new MySprite("res/Images/grossini_dance_01.png");
|
|
|
|
sprite.something(50 + 50*i,200);
|
|
|
|
scene.addChild(sprite);
|
|
|
|
}
|
|
|
|
|
2016-01-24 19:37:20 +08:00
|
|
|
return scene;
|
2015-12-24 00:54:00 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// Scene Test 2
|
|
|
|
//
|
|
|
|
function runScene2(sender) {
|
|
|
|
|
|
|
|
var scene = new cc.Scene();
|
|
|
|
|
|
|
|
for (i = 0; i < 5; i++) {
|
|
|
|
var sprite = new cc.Sprite("res/Images/grossini_dance_08.png");
|
|
|
|
sprite.setPosition(50 + 50*i,200);
|
|
|
|
scene.addChild(sprite);
|
|
|
|
}
|
|
|
|
|
2016-01-24 19:37:20 +08:00
|
|
|
return scene;
|
2015-12-24 00:54:00 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
//
|
|
|
|
// Scene Test 3
|
|
|
|
//
|
|
|
|
function runScene3(sender) {
|
|
|
|
|
|
|
|
var scene = new cc.Scene();
|
|
|
|
|
|
|
|
var fontDef = new cc.FontDefinition();
|
|
|
|
fontDef.fontName = "Arial";
|
|
|
|
fontDef.fontSize = 32;
|
|
|
|
this.label = new cc.LabelTTF("See console!", fontDef);
|
|
|
|
this.label.setPosition(300,300);
|
|
|
|
scene.addChild(this.label);
|
2016-01-24 19:37:20 +08:00
|
|
|
|
|
|
|
var touchListener = null;
|
|
|
|
var mouseListener = null;
|
2015-12-24 00:54:00 +08:00
|
|
|
|
|
|
|
// 'browser' can use touches or mouse.
|
|
|
|
// The benefit of using 'touches' in a browser, is that it works both with mouse events or touches events
|
|
|
|
if ('touches' in cc.sys.capabilities) {
|
2016-01-24 19:37:20 +08:00
|
|
|
touchListener = cc.eventManager.addListener({
|
2015-12-24 00:54:00 +08:00
|
|
|
event: cc.EventListener.TOUCH_ALL_AT_ONCE,
|
2016-01-24 19:37:20 +08:00
|
|
|
onTouchesMoved: function (touches, event) {
|
|
|
|
var delta = touches[0].getDelta();
|
|
|
|
cc.log("onTouchesMoved:" + delta);
|
|
|
|
return true;
|
|
|
|
}
|
2015-12-24 00:54:00 +08:00
|
|
|
},
|
|
|
|
10);
|
|
|
|
} else if ('mouse' in cc.sys.capabilities) {
|
2016-01-24 19:37:20 +08:00
|
|
|
mouseListener = cc.eventManager.addListener({
|
2015-12-24 00:54:00 +08:00
|
|
|
event: cc.EventListener.MOUSE,
|
2016-01-24 19:37:20 +08:00
|
|
|
onMouseMove: function (event) {
|
|
|
|
if(event.getButton() == cc.EventMouse.BUTTON_LEFT)
|
|
|
|
cc.log("onMouseMove" + event.getDelta());
|
|
|
|
},
|
|
|
|
onMouseScroll: function (event) {
|
|
|
|
var delta = cc.sys.isNative ? event.getScrollY() * 6 : -event.getScrollY();
|
|
|
|
cc.log("onMouseScroll:" + delta);
|
|
|
|
return true;
|
|
|
|
}
|
2015-12-24 00:54:00 +08:00
|
|
|
},
|
|
|
|
10);
|
|
|
|
}
|
|
|
|
|
2016-01-24 19:37:20 +08:00
|
|
|
this.label.onExit = function () {
|
|
|
|
if (touchListener) {
|
|
|
|
cc.eventManager.removeListener(touchListener);
|
|
|
|
}
|
|
|
|
if (mouseListener) {
|
|
|
|
cc.eventManager.removeListener(mouseListener);
|
|
|
|
}
|
|
|
|
cc.LabelTTF.prototype.onExit.call(this);
|
|
|
|
};
|
|
|
|
|
|
|
|
return scene;
|
2015-12-24 00:54:00 +08:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function runScene4(sender) {
|
|
|
|
|
2016-01-18 14:28:02 +08:00
|
|
|
var scene = new cc.Scene();
|
2015-12-24 00:54:00 +08:00
|
|
|
|
2016-01-18 14:28:02 +08:00
|
|
|
var actionTo = cc.jumpTo(2, cc.p(300, 300), 50, 4);
|
|
|
|
var actionBy = cc.jumpBy(2, cc.p(300, 0), 50, 4);
|
|
|
|
var actionUp = cc.jumpBy(2, cc.p(0, 0), 80, 4);
|
|
|
|
var actionByBack = actionBy.reverse();
|
2015-12-24 00:54:00 +08:00
|
|
|
|
2016-01-18 14:28:02 +08:00
|
|
|
var delay = cc.delayTime(0.25);
|
2015-12-24 00:54:00 +08:00
|
|
|
|
2016-01-18 14:28:02 +08:00
|
|
|
var sprite1 = new cc.Sprite("res/Images/grossini_dance_08.png");
|
|
|
|
sprite1.setPosition(10,10);
|
|
|
|
var sprite2 = new cc.Sprite("res/Images/grossini_dance_01.png");
|
|
|
|
sprite2.setPosition(200,10);
|
|
|
|
var sprite3 = new cc.Sprite("res/Images/grossini_dance_04.png");
|
|
|
|
sprite3.setPosition(400,10);
|
2015-12-24 00:54:00 +08:00
|
|
|
|
2016-01-18 14:28:02 +08:00
|
|
|
scene.addChild(sprite1);
|
|
|
|
scene.addChild(sprite2);
|
|
|
|
scene.addChild(sprite3);
|
2015-12-24 00:54:00 +08:00
|
|
|
|
2016-01-18 14:28:02 +08:00
|
|
|
sprite1.runAction(actionTo);
|
|
|
|
sprite2.runAction(cc.sequence(actionBy, delay, actionByBack));
|
2015-12-24 00:54:00 +08:00
|
|
|
|
2016-01-18 14:28:02 +08:00
|
|
|
var action = cc.sequence(actionUp, delay.clone()).repeatForever();
|
|
|
|
sprite3.runAction(action);
|
2015-12-24 00:54:00 +08:00
|
|
|
|
2016-01-24 19:37:20 +08:00
|
|
|
return scene;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
function runScene5(sender) {
|
|
|
|
var scene = new cc.Scene();
|
|
|
|
|
|
|
|
var TREE_TAG = 888;
|
|
|
|
var tree = createTree(5, cc.rect(0, 0, cc.winSize.width, cc.winSize.height));
|
|
|
|
scene.addChild(tree, 0, TREE_TAG);
|
|
|
|
|
|
|
|
var fontDef = new cc.FontDefinition();
|
|
|
|
fontDef.fontName = "Arial";
|
|
|
|
fontDef.fontSize = 20;
|
|
|
|
fontDef.boundingWidth = cc.winSize.width * 0.8;
|
|
|
|
var label = new cc.LabelTTF("Click 'Replace Tree' to create a new tree and the current tree should be garbage collected", fontDef);
|
|
|
|
label.setPosition(cc.winSize.width / 2, cc.winSize.height / 2);
|
|
|
|
scene.addChild(label, 10);
|
2015-12-24 00:54:00 +08:00
|
|
|
|
2016-01-18 14:28:02 +08:00
|
|
|
// menu
|
2016-01-24 19:37:20 +08:00
|
|
|
var menu = new cc.Menu();
|
|
|
|
var button = new cc.MenuItemFont("Replace Tree", function () {
|
|
|
|
var levels = 4 + Math.floor( Math.random() * 4 );
|
|
|
|
var newTree = createTree(levels, cc.rect(0, 0, cc.winSize.width, cc.winSize.height));
|
|
|
|
label.string = "Now click 'Run GC', you should see a list of finalize message, the number should match the number of old tree nodes";
|
|
|
|
cc.log("Now click 'Run GC', you should see a list of finalize message, the number should match the number of old tree nodes");
|
|
|
|
var oldTree = scene.getChildByTag(TREE_TAG);
|
|
|
|
oldTree.removeFromParent(true);
|
|
|
|
scene.addChild(newTree, 0, TREE_TAG);
|
|
|
|
});
|
2016-01-18 14:28:02 +08:00
|
|
|
button.fontSize = 20;
|
|
|
|
button.fontName = "Arial";
|
|
|
|
menu.addChild(button);
|
2016-01-24 19:37:20 +08:00
|
|
|
menu.setPosition(cc.winSize.width / 4, cc.winSize.height - 40);
|
2016-01-18 14:28:02 +08:00
|
|
|
scene.addChild(menu);
|
2015-12-24 00:54:00 +08:00
|
|
|
|
2016-01-24 19:37:20 +08:00
|
|
|
return scene;
|
2016-01-18 14:28:02 +08:00
|
|
|
}
|
|
|
|
|
2016-01-24 19:37:20 +08:00
|
|
|
function runScene6 () {
|
|
|
|
var scene = new cc.Scene();
|
2016-01-18 14:28:02 +08:00
|
|
|
|
2016-01-24 19:37:20 +08:00
|
|
|
var callback = function () {
|
|
|
|
cc.log('A callback which do nothing');
|
|
|
|
};
|
|
|
|
|
|
|
|
var sprite = new cc.Sprite("res/Images/grossini_dance_01.png");
|
|
|
|
sprite.x = cc.winSize.width/2;
|
|
|
|
sprite.y = cc.winSize.height/2;
|
|
|
|
sprite.action = cc.callFunc(callback, sprite);
|
|
|
|
|
|
|
|
var SPRITE_TAG = 999;
|
|
|
|
scene.addChild(sprite, 0, SPRITE_TAG);
|
|
|
|
|
|
|
|
var fontDef = new cc.FontDefinition();
|
|
|
|
fontDef.fontName = "Arial";
|
|
|
|
fontDef.fontSize = 20;
|
|
|
|
fontDef.boundingWidth = cc.winSize.width * 0.8;
|
|
|
|
var label = new cc.LabelTTF("Click screen to remove sprite and it should be garbage collected", fontDef);
|
|
|
|
label.setPosition(cc.winSize.width / 2, cc.winSize.height / 2 + 100);
|
|
|
|
scene.addChild(label);
|
|
|
|
|
|
|
|
var touchListener = cc.eventManager.addListener({
|
|
|
|
event: cc.EventListener.TOUCH_ALL_AT_ONCE,
|
|
|
|
onTouchesEnded: function (touches, event) {
|
|
|
|
cc.sys.garbageCollect();
|
|
|
|
cc.sys.garbageCollect();
|
|
|
|
cc.log('You should see immidiately two release messages in Console (Sprite and Action)');
|
|
|
|
label.setString('You should see immidiately two release messages in Console (Sprite and Action)');
|
|
|
|
var target = event.getCurrentTarget();
|
|
|
|
target.removeChildByTag(SPRITE_TAG);
|
|
|
|
cc.sys.garbageCollect();
|
|
|
|
cc.eventManager.removeListener(touchListener);
|
|
|
|
}
|
|
|
|
}, scene);
|
|
|
|
|
|
|
|
return scene;
|
|
|
|
}
|
|
|
|
|
|
|
|
function runScene7 () {
|
|
|
|
var scene = new cc.Scene();
|
|
|
|
|
|
|
|
var fontDef = new cc.FontDefinition();
|
|
|
|
fontDef.fontName = "Arial";
|
|
|
|
fontDef.fontSize = 20;
|
|
|
|
fontDef.boundingWidth = cc.winSize.width * 0.8;
|
|
|
|
var label = new cc.LabelTTF("Click screen to remove button and it should be garbage collected", fontDef);
|
|
|
|
label.setPosition(cc.winSize.width / 2, cc.winSize.height / 2 + 100);
|
|
|
|
scene.addChild(label);
|
2016-01-18 14:28:02 +08:00
|
|
|
|
|
|
|
var menu = new cc.Menu();
|
2016-01-24 19:37:20 +08:00
|
|
|
var button = new cc.MenuItemFont("Remove myself", function () {
|
|
|
|
cc.sys.garbageCollect();
|
|
|
|
cc.sys.garbageCollect();
|
|
|
|
label.string = "Now click 'Run GC', you should see finalize message of button";
|
|
|
|
cc.log("Now click 'Run GC', you should see finalize message of button");
|
|
|
|
menu.removeAllChildren(true);
|
|
|
|
}, menu);
|
2016-01-18 14:28:02 +08:00
|
|
|
menu.addChild(button);
|
2016-01-24 19:37:20 +08:00
|
|
|
menu.setPosition(cc.winSize.width / 2, cc.winSize.height / 2);
|
2016-01-18 14:28:02 +08:00
|
|
|
scene.addChild(menu);
|
|
|
|
|
2016-01-24 19:37:20 +08:00
|
|
|
return scene;
|
2015-12-24 00:54:00 +08:00
|
|
|
}
|
|
|
|
|
2016-01-24 19:37:20 +08:00
|
|
|
var tests = [
|
|
|
|
runScene1,
|
|
|
|
runScene2,
|
|
|
|
runScene3,
|
|
|
|
runScene4,
|
|
|
|
runScene5,
|
|
|
|
runScene6,
|
|
|
|
runScene7
|
|
|
|
];
|
|
|
|
|
|
|
|
var replaceScene = (function () {
|
|
|
|
var curr = tests.length-1;
|
|
|
|
|
|
|
|
return function () {
|
|
|
|
if (curr < tests.length-1) {
|
|
|
|
curr++;
|
|
|
|
}
|
|
|
|
else {
|
|
|
|
curr = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
var scene = tests[curr]();
|
|
|
|
|
|
|
|
// menu
|
|
|
|
var menu = new cc.Menu();
|
|
|
|
var button = new cc.MenuItemFont("Next Scene", replaceScene);
|
|
|
|
button.fontSize = 20;
|
|
|
|
button.fontName = "Arial";
|
|
|
|
menu.addChild(button);
|
|
|
|
button = new cc.MenuItemFont("Run GC", cc.sys.garbageCollect);
|
|
|
|
button.fontSize = 20;
|
|
|
|
button.fontName = "Arial";
|
|
|
|
button.x = cc.winSize.width/4;
|
|
|
|
button.y = cc.winSize.height - 60;
|
|
|
|
menu.addChild(button);
|
|
|
|
menu.setPosition(cc.winSize.width/2, 20);
|
|
|
|
scene.addChild(menu);
|
|
|
|
|
|
|
|
cc.director.replaceScene(scene);
|
|
|
|
|
|
|
|
cc.sys.garbageCollect();
|
|
|
|
};
|
|
|
|
})();
|
|
|
|
|
2015-12-24 00:54:00 +08:00
|
|
|
//
|
|
|
|
// Main Entry point
|
|
|
|
//
|
|
|
|
function runMain() {
|
|
|
|
|
|
|
|
var scene = new cc.Scene();
|
|
|
|
|
|
|
|
// menu
|
2016-01-24 19:37:20 +08:00
|
|
|
var button = new cc.MenuItemFont("Start Test", replaceScene);
|
2015-12-24 00:54:00 +08:00
|
|
|
button.fontSize = 20;
|
|
|
|
button.fontName = "Arial";
|
|
|
|
var menu = new cc.Menu();
|
|
|
|
menu.addChild(button);
|
|
|
|
menu.setPosition(300,300);
|
|
|
|
|
|
|
|
scene.addChild(menu);
|
|
|
|
cc.director.runScene(scene);
|
|
|
|
}
|