axmol/tests/js-tests/src/SpriteTest/SpriteTest.js

5500 lines
184 KiB
JavaScript
Raw Normal View History

2015-04-16 18:07:35 +08:00
/****************************************************************************
Copyright (c) 2008-2010 Ricardo Quesada
Copyright (c) 2011-2012 cocos2d-x.org
Copyright (c) 2013-2014 Chukong Technologies Inc.
http://www.cocos2d-x.org
Permission is hereby granted, free of charge, to any person obtaining a copy
of this software and associated documentation files (the "Software"), to deal
in the Software without restriction, including without limitation the rights
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
copies of the Software, and to permit persons to whom the Software is
furnished to do so, subject to the following conditions:
The above copyright notice and this permission notice shall be included in
all copies or substantial portions of the Software.
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
THE SOFTWARE.
****************************************************************************/
var TAG_TILE_MAP = 1;
var TAG_SPRITE_BATCH_NODE = 1;
var TAG_NODE = 2;
var TAG_ANIMATION1 = 1;
var TAG_SPRITE_LEFT = 2;
var TAG_SPRITE_RIGHT = 3;
var TAG_SPRITE1 = 0;
var TAG_SPRITE2 = 1;
var TAG_SPRITE3 = 2;
var TAG_SPRITE4 = 3;
var TAG_SPRITE5 = 4;
var TAG_SPRITE6 = 5;
var TAG_SPRITE7 = 6;
var TAG_SPRITE8 = 7;
var IDC_NEXT = 100;
var IDC_BACK = 101;
var IDC_RESTART = 102;
var spriteTestIdx = -1;
var spriteFrameCache = cc.spriteFrameCache;
//------------------------------------------------------------------
//
// SpriteTestDemo
//
//------------------------------------------------------------------
var SpriteTestDemo = BaseTestLayer.extend({
_title:"",
_subtitle:"",
ctor:function () {
if (arguments.length === 0) {
this._super(cc.color(0, 0, 0, 255), cc.color(98, 99, 117, 255));
} else {
this._super.apply(this, arguments);
}
},
onRestartCallback:function (sender) {
var s = new SpriteTestScene();
s.addChild(restartSpriteTest());
director.runScene(s);
},
onNextCallback:function (sender) {
var s = new SpriteTestScene();
s.addChild(nextSpriteTest());
director.runScene(s);
},
onBackCallback:function (sender) {
var s = new SpriteTestScene();
s.addChild(previousSpriteTest());
director.runScene(s);
},
// automation
numberOfPendingTests:function () {
return ( (arrayOfSpriteTest.length - 1) - spriteTestIdx );
},
getTestNumber:function () {
return spriteTestIdx;
}
});
//------------------------------------------------------------------
//
// Sprite1
//
//------------------------------------------------------------------
var Sprite1 = SpriteTestDemo.extend({
_title:"Non Batched Sprite ",
_subtitle:"Tap screen to add more sprites",
ctor:function () {
//----start0----ctor
this._super();
this.addNewSpriteWithCoords(cc.p(winSize.width / 2, winSize.height / 2));
if ('touches' in cc.sys.capabilities) {
cc.eventManager.addListener({
event: cc.EventListener.TOUCH_ALL_AT_ONCE,
onTouchesEnded: function(touches, event){
for (var it = 0; it < touches.length; it++) {
var touch = touches[it];
if (!touch)
break;
var location = touch.getLocation();
event.getCurrentTarget().addNewSpriteWithCoords(location);
}
}
}, this);
} else if ('mouse' in cc.sys.capabilities)
cc.eventManager.addListener({
event: cc.EventListener.MOUSE,
onMouseUp: function(event){
event.getCurrentTarget().addNewSpriteWithCoords(event.getLocation());
}
}, this);
//----end0----
},
addNewSpriteWithCoords:function (p) {
//----start0----addNewSpriteWithCoords
var idx = 0 | (Math.random() * 14);
var x = (idx % 5) * 85;
var y = (0 | (idx / 5)) * 121;
var sprite = new cc.Sprite(s_grossini_dance_atlas, cc.rect(x, y, 85, 121));
this.addChild(sprite);
sprite.x = p.x;
sprite.y = p.y;
var action;
var random = Math.random();
if (random < 0.20) {
action = cc.scaleBy(3, 2);
} else if (random < 0.40) {
action = cc.rotateBy(3, 360);
} else if (random < 0.60) {
action = cc.blink(1, 3);
} else if (random < 0.8) {
action = cc.tintBy(2, 0, -255, -255);
} else {
action = cc.fadeOut(2);
}
var action_back = action.reverse();
var seq = cc.sequence(action, action_back);
sprite.runAction(seq.repeatForever());
this.testSprite = sprite;
//----end0----
},
//
// Automation
//
testDuration:1,
pixel:{"0":51, "1":0, "2":51, "3":255},
testSprite:null,
setupAutomation:function () {
var fun = function () {
var sprite = new cc.Sprite(s_grossini_dance_atlas, cc.rect(0, 0, 85, 121));
this.addChild(sprite, 999);
sprite.x = winSize.width / 2;
sprite.y = winSize.height / 2;
};
this.scheduleOnce(fun, 0.5);
},
getExpectedResult:function () {
var ret = {"useBatch":false, "pixel":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
var ret = {"useBatch":this.testSprite.getBatchNode() != null, "pixel":this.containsPixel(ret1, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNode1
//
//------------------------------------------------------------------
var SpriteBatchNode1 = SpriteTestDemo.extend({
_title:"Batched Sprite ",
_subtitle:"Tap screen to add more sprites",
ctor:function () {
//----start1----ctor
this._super();
if ('touches' in cc.sys.capabilities) {
cc.eventManager.addListener({
event: cc.EventListener.TOUCH_ALL_AT_ONCE,
onTouchesEnded: function (touches, event) {
for (var it = 0; it < touches.length; it++) {
var touch = touches[it];
if (!touch)
break;
var location = touch.getLocation();
event.getCurrentTarget().addNewSpriteWithCoords(location);
}
}
}, this);
} else if ('mouse' in cc.sys.capabilities)
cc.eventManager.addListener({
event: cc.EventListener.MOUSE,
onMouseUp: function(event){
event.getCurrentTarget().addNewSpriteWithCoords(event.getLocation());
}
}, this);
var batchNode = new cc.SpriteBatchNode(s_grossini_dance_atlas, 50);
this.addChild(batchNode, 0, TAG_SPRITE_BATCH_NODE);
this.addNewSpriteWithCoords(cc.p(winSize.width / 2, winSize.height / 2));
//----end1----
},
addNewSpriteWithCoords:function (p) {
//----start1----addNewSpriteWithCoords
var batchNode = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
var idx = 0 | (Math.random() * 14);
var x = (idx % 5) * 85;
var y = (0 | (idx / 5)) * 121;
var sprite = new cc.Sprite(batchNode.texture, cc.rect(x, y, 85, 121));
batchNode.addChild(sprite);
sprite.x = p.x;
sprite.y = p.y;
var action;
var random = Math.random();
if (random < 0.20)
action = cc.scaleBy(3, 2);
else if (random < 0.40)
action = cc.rotateBy(3, 360);
else if (random < 0.60)
action = cc.blink(1, 3);
else if (random < 0.8)
action = cc.tintBy(2, 0, -255, -255);
else
action = cc.fadeOut(2);
var action_back = action.reverse();
var seq = cc.sequence(action, action_back);
sprite.runAction(seq.repeatForever());
this.testSprite = sprite;
//----end1----
},
//
// Automation
//
testDuration:1,
pixel:{"0":51, "1":0, "2":51, "3":255},
testSprite:null,
setupAutomation:function () {
var fun = function () {
var sprite = new cc.Sprite(s_grossini_dance_atlas, cc.rect(0, 0, 85, 121));
this.addChild(sprite, 999);
sprite.x = winSize.width / 2;
sprite.y = winSize.height / 2;
}
this.scheduleOnce(fun, 0.5);
},
getExpectedResult:function () {
var ret = {"useBatch":true, "pixel":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
var ret = {"useBatch":this.testSprite.getBatchNode() != null, "pixel":this.containsPixel(ret1, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteColorOpacity
//
//------------------------------------------------------------------
var SpriteColorOpacity = SpriteTestDemo.extend({
_title:"Sprite: Color & Opacity",
ctor:function () {
//----start11----ctor
this._super();
var sprite1 = new cc.Sprite(s_grossini_dance_atlas, cc.rect(0, 121, 85, 121));
var sprite2 = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85, 121, 85, 121));
var sprite3 = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85 * 2, 121, 85, 121));
var sprite4 = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85 * 3, 121, 85, 121));
var sprite5 = new cc.Sprite(s_grossini_dance_atlas, cc.rect(0, 121, 85, 121));
var sprite6 = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85, 121, 85, 121));
var sprite7 = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85 * 2, 121, 85, 121));
var sprite8 = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85 * 3, 121, 85, 121));
sprite1.x = (winSize.width / 5);
sprite1.y = (winSize.height / 3);
sprite2.x = (winSize.width / 5) * 2;
sprite2.y = (winSize.height / 3);
sprite3.x = (winSize.width / 5) * 3;
sprite3.y = (winSize.height / 3);
sprite4.x = (winSize.width / 5) * 4;
sprite4.y = (winSize.height / 3);
sprite5.x = (winSize.width / 5);
sprite5.y = (winSize.height / 3) * 2;
sprite6.x = (winSize.width / 5) * 2;
sprite6.y = (winSize.height / 3) * 2;
sprite7.x = (winSize.width / 5) * 3;
sprite7.y = (winSize.height / 3) * 2;
sprite8.x = (winSize.width / 5) * 4;
sprite8.y = (winSize.height / 3) * 2;
var delay = cc.delayTime(0.25);
var action = cc.fadeOut(2);
var action_back = action.reverse();
var fade = cc.sequence(action, delay.clone(), action_back).repeatForever();
var tintRed = cc.tintBy(2, 0, -255, -255);
var tintRedBack = tintRed.reverse();
var red = cc.sequence(tintRed, delay.clone(), tintRedBack).repeatForever();
var tintGreen = cc.tintBy(2, -255, 0, -255);
var tintGreenBack = tintGreen.reverse();
var green = cc.sequence(tintGreen, delay.clone(), tintGreenBack).repeatForever();
var tintBlue = cc.tintBy(2, -255, -255, 0);
var tintBlueBack = tintBlue.reverse();
var blue = cc.sequence(tintBlue, delay.clone(), tintBlueBack).repeatForever();
// late add: test dirtyColor and dirtyPosition
this.addChild(sprite1, 0, TAG_SPRITE1);
this.addChild(sprite2, 0, TAG_SPRITE2);
this.addChild(sprite3, 0, TAG_SPRITE3);
this.addChild(sprite4, 0, TAG_SPRITE4);
this.addChild(sprite5, 0, TAG_SPRITE5);
this.addChild(sprite6, 0, TAG_SPRITE6);
this.addChild(sprite7, 0, TAG_SPRITE7);
this.addChild(sprite8, 0, TAG_SPRITE8);
sprite5.runAction(red);
sprite6.runAction(green);
sprite7.runAction(blue);
sprite8.runAction(fade);
this.schedule(this.removeAndAddSprite, 2);
//----end11----
},
// this function test if remove and add works as expected:
// color array and vertex array should be reindexed
removeAndAddSprite:function (dt) {
//----start11----removeAndAddSprite
var sprite = this.getChildByTag(TAG_SPRITE5);
this.removeChild(sprite, false);
this.addChild(sprite, 0, TAG_SPRITE5);
//----end11----
},
//
// Automation
//
testDuration:2.1,
pixel1:{"0":255, "1":0, "2":0, "3":255},
pixel2:{"0":0, "1":204, "2":0, "3":255},
pixel3:{"0":0, "1":0, "2":153, "3":255},
pixel4:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes", "pixel4":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels((winSize.width / 5) * 1, (winSize.height / 3) * 2 + 40, 5, 5);
var ret2 = this.readPixels((winSize.width / 5) * 2, (winSize.height / 3) * 2 + 40, 5, 5);
var ret3 = this.readPixels((winSize.width / 5) * 3, (winSize.height / 3) * 2 + 40, 5, 5);
var ret4 = this.readPixels((winSize.width / 5) * 4, (winSize.height / 3) * 2 + 40, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel2) ? "yes" : "no",
"pixel3":this.containsPixel(ret3, this.pixel3) ? "yes" : "no",
"pixel4":this.containsPixel(ret4, this.pixel4) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeColorOpacity
//
//------------------------------------------------------------------
var SpriteBatchNodeColorOpacity = SpriteTestDemo.extend({
_title:"SpriteBatchNode: Color & Opacity",
ctor:function () {
//----start12----ctor
this._super();
// small capacity. Testing resizing.
// Don't use capacity=1 in your real game. It is expensive to resize the capacity
var batch = new cc.SpriteBatchNode(s_grossini_dance_atlas, 1);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
var sprite1 = new cc.Sprite(batch.texture, cc.rect(0, 121, 85, 121));
var sprite2 = new cc.Sprite(batch.texture, cc.rect(85, 121, 85, 121));
var sprite3 = new cc.Sprite(batch.texture, cc.rect(85 * 2, 121, 85, 121));
var sprite4 = new cc.Sprite(batch.texture, cc.rect(85 * 3, 121, 85, 121));
var sprite5 = new cc.Sprite(batch.texture, cc.rect(0, 121, 85, 121));
var sprite6 = new cc.Sprite(batch.texture, cc.rect(85, 121, 85, 121));
var sprite7 = new cc.Sprite(batch.texture, cc.rect(85 * 2, 121, 85, 121));
var sprite8 = new cc.Sprite(batch.texture, cc.rect(85 * 3, 121, 85, 121));
sprite1.x = (winSize.width / 5) * 1;
sprite1.y = (winSize.height / 3) * 1;
sprite2.x = (winSize.width / 5) * 2;
sprite2.y = (winSize.height / 3) * 1;
sprite3.x = (winSize.width / 5) * 3;
sprite3.y = (winSize.height / 3) * 1;
sprite4.x = (winSize.width / 5) * 4;
sprite4.y = (winSize.height / 3) * 1;
sprite5.x = (winSize.width / 5) * 1;
sprite5.y = (winSize.height / 3) * 2;
sprite6.x = (winSize.width / 5) * 2;
sprite6.y = (winSize.height / 3) * 2;
sprite7.x = (winSize.width / 5) * 3;
sprite7.y = (winSize.height / 3) * 2;
sprite8.x = (winSize.width / 5) * 4;
sprite8.y = (winSize.height / 3) * 2;
var delay = cc.delayTime(0.25);
var action = cc.fadeOut(2);
var action_back = action.reverse();
var fade = cc.sequence(action, delay.clone(), action_back).repeatForever();
var tintRed = cc.tintBy(2, 0, -255, -255);
var red = cc.sequence(tintRed, delay.clone(), tintRed.reverse()).repeatForever();
var tintGreen = cc.tintBy(2, -255, 0, -255);
var tintGreenBack = tintGreen.reverse();
var green = cc.sequence(tintGreen, delay.clone(), tintGreenBack).repeatForever();
var tintBlue = cc.tintBy(2, -255, -255, 0);
var tintBlueBack = tintBlue.reverse();
var blue = cc.sequence(tintBlue, delay.clone(), tintBlueBack).repeatForever();
// late add: test dirtyColor and dirtyPosition
batch.addChild(sprite1, 0, TAG_SPRITE1);
batch.addChild(sprite2, 0, TAG_SPRITE2);
batch.addChild(sprite3, 0, TAG_SPRITE3);
batch.addChild(sprite4, 0, TAG_SPRITE4);
batch.addChild(sprite5, 0, TAG_SPRITE5);
batch.addChild(sprite6, 0, TAG_SPRITE6);
batch.addChild(sprite7, 0, TAG_SPRITE7);
batch.addChild(sprite8, 0, TAG_SPRITE8);
sprite5.runAction(red);
sprite6.runAction(green);
sprite7.runAction(blue);
sprite8.runAction(fade);
this.schedule(this.removeAndAddSprite, 2);
//----end12----
},
// this function test if remove and add works as expected:
// color array and vertex array should be reindexed
removeAndAddSprite:function (dt) {
//----start12----removeAndAddSprite
var batch = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
var sprite = batch.getChildByTag(TAG_SPRITE5);
batch.removeChild(sprite, false);
batch.addChild(sprite, 0, TAG_SPRITE5);
//----end12----
},
//
// Automation
//
testDuration:2.1,
pixel1:{"0":255, "1":0, "2":0, "3":255},
pixel2:{"0":0, "1":204, "2":0, "3":255},
pixel3:{"0":0, "1":0, "2":153, "3":255},
pixel4:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes", "pixel4":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels((winSize.width / 5) * 1, (winSize.height / 3) * 2 + 40, 5, 5);
var ret2 = this.readPixels((winSize.width / 5) * 2, (winSize.height / 3) * 2 + 40, 5, 5);
var ret3 = this.readPixels((winSize.width / 5) * 3, (winSize.height / 3) * 2 + 40, 5, 5);
var ret4 = this.readPixels((winSize.width / 5) * 4, (winSize.height / 3) * 2 + 40, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel2) ? "yes" : "no",
"pixel3":this.containsPixel(ret3, this.pixel3) ? "yes" : "no",
"pixel4":this.containsPixel(ret4, this.pixel4) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteZOrder
//
//------------------------------------------------------------------
var SpriteZOrder = SpriteTestDemo.extend({
_dir:0,
_title:"Sprite: Z order",
ctor:function () {
//----start13----ctor
this._super();
this._dir = 1;
var sprite;
var step = winSize.width / 11;
for (var i = 0; i < 5; i++) {
sprite = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85 * 0, 121 * 1, 85, 121));
sprite.x = (i + 1) * step;
sprite.y = winSize.height / 2;
this.addChild(sprite, i);
}
for (i = 5; i < 10; i++) {
sprite = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85 * 1, 121 * 0, 85, 121));
sprite.x = (i + 1) * step;
sprite.y = winSize.height / 2;
this.addChild(sprite, 14 - i);
}
sprite = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85 * 3, 121 * 0, 85, 121));
this.addChild(sprite, -1, TAG_SPRITE1);
sprite.x = winSize.width / 2;
sprite.y = winSize.height / 2 - 20;
sprite.scaleX = 10;
sprite.color = cc.color.RED;
this.schedule(this.reorderSprite, 1);
//----end13----
},
reorderSprite:function (dt) {
//----start13----reorderSprite
var sprite = this.getChildByTag(TAG_SPRITE1);
var z = sprite.zIndex;
if (z < -1)
this._dir = 1;
if (z > 10)
this._dir = -1;
z += this._dir * 3;
this.reorderChild(sprite, z);
//----end13----
},
//
// Automation
//
testDuration:4.2,
pixel:{"0":255, "1":0, "2":0, "3":255},
getExpectedResult:function () {
var ret = {"pixel":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var step = winSize.width / 11;
var ret1 = this.readPixels((6 + 1) * step, winSize.height / 2 + 10, 5, 5);
var ret = {"pixel":this.containsPixel(ret1, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeZOrder
//
//------------------------------------------------------------------
var SpriteBatchNodeZOrder = SpriteTestDemo.extend({
_dir:0,
_title:"SpriteBatch: Z order",
ctor:function () {
//----start14----ctor
this._super();
this._dir = 1;
// small capacity. Testing resizing.
// Don't use capacity=1 in your real game. It is expensive to resize the capacity
var batch = new cc.SpriteBatchNode(s_grossini_dance_atlas, 1);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
var sprite;
var step = winSize.width / 11;
for (var i = 0; i < 5; i++) {
sprite = new cc.Sprite(batch.texture, cc.rect(85 * 0, 121 * 1, 85, 121));
sprite.x = (i + 1) * step;
sprite.y = winSize.height / 2;
batch.addChild(sprite, i);
}
for (i = 5; i < 10; i++) {
sprite = new cc.Sprite(batch.texture, cc.rect(85 * 1, 121 * 0, 85, 121));
sprite.x = (i + 1) * step;
sprite.y = winSize.height / 2;
batch.addChild(sprite, 14 - i);
}
sprite = new cc.Sprite(batch.texture, cc.rect(85 * 3, 121 * 0, 85, 121));
batch.addChild(sprite, -1, TAG_SPRITE1);
sprite.x = winSize.width / 2;
sprite.y = winSize.height / 2 - 20;
sprite.scaleX = 10;
sprite.color = cc.color.RED;
this.schedule(this.reorderSprite, 1);
//----end14----
},
reorderSprite:function (dt) {
//----start14----reorderSprite
var batch = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
var sprite = batch.getChildByTag(TAG_SPRITE1);
var z = sprite.zIndex;
if (z < -1)
this._dir = 1;
if (z > 10)
this._dir = -1;
z += this._dir * 3;
batch.reorderChild(sprite, z);
//----end14----
},
//
// Automation
//
testDuration:4.2,
pixel:{"0":255, "1":0, "2":0, "3":255},
getExpectedResult:function () {
var ret = {"pixel":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var step = winSize.width / 11;
var ret1 = this.readPixels((6 + 1) * step, winSize.height / 2 + 10, 5, 5);
var ret = {"pixel":this.containsPixel(ret1, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeReorder
//
//------------------------------------------------------------------
var SpriteBatchNodeReorder = SpriteTestDemo.extend({
_title:"SpriteBatchNode: reorder #1",
_subtitle:"Should not crash",
ctor:function () {
//----start15----ctor
this._super();
var a = [];
var asmtest = new cc.SpriteBatchNode(s_ghosts);
for (var i = 0; i < 10; i++) {
var s1 = new cc.Sprite(asmtest.texture, cc.rect(0, 0, 50, 50));
a.push(s1);
asmtest.addChild(s1, 10);
}
for (i = 0; i < 10; i++) {
if (i != 5)
asmtest.reorderChild(a[i], 9);
}
var prev = -1, currentIndex;
var children = asmtest.children;
var child;
for (i = 0; i < children.length; i++) {
child = children[i];
if (!child)
break;
//TODO need fixed
currentIndex = child.atlasIndex;
//cc.Assert(prev == currentIndex - 1, "Child order failed");
////----UXLog("children %x - atlasIndex:%d", child, currentIndex);
prev = currentIndex;
}
prev = -1;
var sChildren = asmtest.descendants;
for (i = 0; i < sChildren.length; i++) {
child = sChildren[i];
if (!child)
break;
currentIndex = child.atlasIndex;
//cc.Assert(prev == currentIndex - 1, "Child order failed");
////----UXLog("descendant %x - atlasIndex:%d", child, currentIndex);
prev = currentIndex;
}
//----end15----
},
//
// Automation
//
testDuration:1.2,
getExpectedResult:function () {
return JSON.stringify(true);
},
getCurrentResult:function () {
return JSON.stringify(true);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeReorderIssue744
//
//------------------------------------------------------------------
var SpriteBatchNodeReorderIssue744 = SpriteTestDemo.extend({
_title:"SpriteBatchNode: reorder issue #744",
_subtitle:"Should not crash",
ctor:function () {
//----start16----ctor
this._super();
// Testing issue #744
// http://code.google.com/p/cocos2d-iphone/issues/detail?id=744
var batch = new cc.SpriteBatchNode(s_grossini_dance_atlas, 15);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
var sprite = new cc.Sprite(batch.texture, cc.rect(0, 0, 85, 121));
sprite.x = winSize.width / 2;
sprite.y = winSize.height / 2;
batch.addChild(sprite, 3);
batch.reorderChild(sprite, 1);
//----end16----
},
//
// Automation
//
testDuration:1.2,
pixel:{"0":51, "1":0, "2":51, "3":255},
getExpectedResult:function () {
var ret = {"pixel":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
var ret = {"pixel":this.containsPixel(ret1, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeReorderIssue766
//
//------------------------------------------------------------------
var SpriteBatchNodeReorderIssue766 = SpriteTestDemo.extend({
_batchNode:null,
_sprite1:null,
_sprite2:null,
_sprite3:null,
_title:"SpriteBatchNode: reorder issue #766",
_subtitle:"In 2 seconds 1 sprite will be reordered",
ctor:function () {
//----start17----ctor
this._super();
this._batchNode = new cc.SpriteBatchNode(s_piece, 15);
this.addChild(this._batchNode, 1, 0);
this._sprite1 = this.makeSpriteZ(2);
this._sprite1.x = 200;
this._sprite1.y = 160;
this._sprite2 = this.makeSpriteZ(3);
this._sprite2.x = 264;
this._sprite2.y = 160;
this._sprite3 = this.makeSpriteZ(4);
this._sprite3.x = 328;
this._sprite3.y = 160;
this.schedule(this.reorderSprite, 2);
//----end17----
},
reorderSprite:function (dt) {
//----start17----reorderSprite
this.unschedule(this.reorderSprite);
this._batchNode.reorderChild(this._sprite1, 4);
//----end17----
},
makeSpriteZ:function (aZ) {
//----start17----makeSpriteZ
var sprite = new cc.Sprite(this._batchNode.texture, cc.rect(128, 0, 64, 64));
this._batchNode.addChild(sprite, aZ + 1, 0);
//children
var spriteShadow = new cc.Sprite(this._batchNode.texture, cc.rect(0, 0, 64, 64));
spriteShadow.opacity = 128;
sprite.addChild(spriteShadow, aZ, 3);
var spriteTop = new cc.Sprite(this._batchNode.texture, cc.rect(64, 0, 64, 64));
sprite.addChild(spriteTop, aZ + 2, 3);
return sprite;
//----end17----
},
//
// Automation
//
testDuration:2.2,
pixel1:{"0":0, "1":0, "2":0, "3":255},
pixel2:{"0":255, "1":255, "2":255, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(213, 159, 5, 5);
var ret2 = this.readPixels(211, 108, 5, 5);
var ret = {"pixel1":!this.containsPixel(ret1, this.pixel1) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel2) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeReorderIssue767
//
//------------------------------------------------------------------
var SpriteBatchNodeReorderIssue767 = SpriteTestDemo.extend({
_title:"SpriteBatchNode: reorder issue #767",
_subtitle:"Should not crash",
ctor:function () {
//----start18----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_ghostsPlist, s_ghosts);
//
// SpriteBatchNode: 3 levels of children
//
var aParent = new cc.SpriteBatchNode(s_ghosts);
this.addChild(aParent, 0, TAG_SPRITE1);
// parent
var l1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("father.gif"));
l1.x = winSize.width / 2;
l1.y = winSize.height / 2;
aParent.addChild(l1, 0, TAG_SPRITE2);
var l1W = l1.width, l1H = l1.height;
// child left
var l2a = new cc.Sprite(spriteFrameCache.getSpriteFrame("sister1.gif"));
l2a.x = -25 + l1W / 2;
l2a.y = 0 + l1H / 2;
l1.addChild(l2a, -1, TAG_SPRITE_LEFT);
var l2aW = l2a.width, l2aH = l2a.height;
// child right
var l2b = new cc.Sprite(spriteFrameCache.getSpriteFrame("sister2.gif"));
l2b.x = 25 + l1W / 2;
l2b.y = 0 + l1H / 2;
l1.addChild(l2b, 1, TAG_SPRITE_RIGHT);
var l2bW = l2b.width, l2bH = l2b.height;
// child left bottom
var l3a1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("child1.gif"));
l3a1.scale = 0.65;
l3a1.x = 0 + l2aW / 2;
l3a1.y = -50 + l2aH / 2;
l2a.addChild(l3a1, -1);
// child left top
var l3a2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("child1.gif"));
l3a2.scale = 0.65;
l3a2.x = 0 + l2aW / 2;
l3a2.y = +50 + l2aH / 2;
l2a.addChild(l3a2, 1);
// child right bottom
var l3b1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("child1.gif"));
l3b1.scale = 0.65;
l3b1.x = 0 + l2bW / 2;
l3b1.y = -50 + l2bH / 2;
l2b.addChild(l3b1, -1);
// child right top
var l3b2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("child1.gif"));
l3b2.scale = 0.65;
l3b2.x = 0 + l2bW / 2;
l3b2.y = +50 + l2bH / 2;
l2b.addChild(l3b2, 1);
this.schedule(this.reorderSprites, 1);
//----end18----
},
reorderSprites:function (dt) {
//----start18----reorderSprites
var spritebatch = this.getChildByTag(TAG_SPRITE1);
var father = spritebatch.getChildByTag(TAG_SPRITE2);
var left = father.getChildByTag(TAG_SPRITE_LEFT);
var right = father.getChildByTag(TAG_SPRITE_RIGHT);
var newZLeft = 1;
if (left.zIndex === 1)
newZLeft = -1;
father.reorderChild(left, newZLeft);
father.reorderChild(right, -newZLeft);
//----end18----
},
//
// Automation
//
testDuration:1.5,
pixel1:{"0":255, "1":204, "2":153, "3":255},
pixel2:{"0":255, "1":255, "2":255, "3":255},
curPixel1:null,
curPixel2:null,
setupAutomation:function () {
var fun = function(){
this.curPixel1 = this.readPixels(winSize.width / 2 + 11, winSize.height / 2 - 11, 2, 2);
}
this.scheduleOnce(fun, 0.5);
},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
this.curPixel2 = this.readPixels(winSize.width / 2 + 11, winSize.height / 2 - 11, 2, 2);
var ret = {"pixel1":this.containsPixel(this.curPixel1, this.pixel1) ? "yes" : "no",
"pixel2":this.containsPixel(this.curPixel2, this.pixel2) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteZVertex
//
//------------------------------------------------------------------
var SpriteZVertex = SpriteTestDemo.extend({
_dir:0,
_time:0,
_title:"Sprite: openGL Z vertex",
_subtitle:"Scene should rotate",
ctor:function () {
//----start19----ctor
this._super(cc.color(255, 0, 0, 80), cc.color(255, 98, 117, 20));
if ("opengl" in cc.sys.capabilities) {
gl.enable(gl.DEPTH_TEST);
//
// This test tests z-order
// If you are going to use it is better to use a 3D projection
//
// WARNING:
// The developer is resposible for ordering it's sprites according to it's Z if the sprite has
// transparent parts.
//
//
// Configure shader to mimic glAlphaTest
//
var alphaTestShader = cc.shaderCache.getProgram("ShaderPositionTextureColorAlphaTest");
var glprogram = alphaTestShader.getProgram();
var alphaValueLocation = gl.getUniformLocation(glprogram, cc.UNIFORM_ALPHA_TEST_VALUE_S);
// set alpha test value
// NOTE: alpha test shader is hard-coded to use the equivalent of a glAlphaFunc(GL_GREATER) comparison
gl.useProgram(glprogram);
alphaTestShader.setUniformLocationF32(alphaValueLocation, 0.5);
this._dir = 1;
this._time = 0;
var step = winSize.width / 12;
var node = new cc.Node();
// camera uses the center of the image as the pivoting point
node.width = winSize.width;
node.height = winSize.height;
node.anchorX = 0.5;
node.anchorY = 0.5;
node.x = winSize.width / 2;
node.y = winSize.height / 2;
this.addChild(node, 0);
var sprite;
for (var i = 0; i < 5; i++) {
sprite = new cc.Sprite(s_grossini_dance_atlas, cc.rect(0, 121, 85, 121));
sprite.x = (i + 1) * step;
sprite.y = winSize.height / 2;
sprite.vertexZ = 10 + i * 40;
sprite.shaderProgram = alphaTestShader;
node.addChild(sprite, 0);
}
for (i = 5; i < 11; i++) {
sprite = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85, 0, 85, 121));
sprite.x = (i + 1) * step;
sprite.y = winSize.height / 2;
sprite.vertexZ = 10 + (10 - i) * 40;
sprite.shaderProgram = alphaTestShader;
node.addChild(sprite, 0);
}
this.runAction(cc.orbitCamera(10, 1, 0, 0, 360, 0, 0));
} else {
var label = new cc.LabelTTF("Not supported on HTML5-canvas", "Times New Roman", 30);
this.addChild(label);
label.x = winSize.width / 2;
label.y = winSize.height / 2;
}
//----end19----
},
onEnter:function () {
//----start19----onEnter
this._super();
if ("opengl" in cc.sys.capabilities) {
director.setProjection(cc.Director.PROJECTION_3D);
gl.enable(gl.DEPTH_TEST);
// Avoid Z-fighting with menu and title
var menu = this.getChildByTag(BASE_TEST_MENU_TAG);
menu.vertexZ = 1;
var title = this.getChildByTag(BASE_TEST_TITLE_TAG);
title.vertexZ = 1;
var subtitle = this.getChildByTag(BASE_TEST_SUBTITLE_TAG);
subtitle.vertexZ = 1;
}
//----end19----
},
onExit:function () {
//----start19----onExit
if ("opengl" in cc.sys.capabilities) {
director.setProjection(cc.Director.PROJECTION_2D);
gl.disable(gl.DEPTH_TEST);
}
this._super();
//----end19----
},
// Automation
testDuration:2.2,
pixel1:{"0":51, "1":0, "2":51, "3":255},
pixel2:{"0":0, "1":0, "2":0, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2 - 171, winSize.height / 2, 5, 5);
var ret2 = this.readPixels(winSize.width / 2 - 189, winSize.height / 2, 5, 5);
var ret3 = this.readPixels(winSize.width / 2 - 146, winSize.height / 2, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1, false) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel2, false) ? "yes" : "no",
"pixel3":this.containsPixel(ret3, this.pixel2, false) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeZVertex
//
//------------------------------------------------------------------
var SpriteBatchNodeZVertex = SpriteTestDemo.extend({
_dir:0,
_time:0,
_title:"SpriteBatchNode: openGL Z vertex",
_subtitle:"Scene should rotate",
ctor:function () {
//----start20----ctor
this._super(cc.color(255, 0, 0, 80), cc.color(255, 98, 117, 20));
if ("opengl" in cc.sys.capabilities) {
//
// This test tests z-order
// If you are going to use it is better to use a 3D projection
//
// WARNING:
// The developer is resposible for ordering it's sprites according to it's Z if the sprite has
// transparent parts.
//
//
// Configure shader to mimic glAlphaTest
//
var alphaTestShader = cc.shaderCache.getProgram("ShaderPositionTextureColorAlphaTest");
var glprogram = alphaTestShader.getProgram();
var alphaValueLocation = gl.getUniformLocation(glprogram, cc.UNIFORM_ALPHA_TEST_VALUE_S);
// set alpha test value
// NOTE: alpha test shader is hard-coded to use the equivalent of a glAlphaFunc(GL_GREATER) comparison
gl.useProgram(glprogram);
alphaTestShader.setUniformLocationF32(alphaValueLocation, 0.5);
var step = winSize.width / 12;
// small capacity. Testing resizing.
// Don't use capacity=1 in your real game. It is expensive to resize the capacity
var batch = new cc.SpriteBatchNode(s_grossini_dance_atlas, 1);
// camera uses the center of the image as the pivoting point
batch.width = winSize.width;
batch.height = winSize.height;
batch.anchorX = 0.5;
batch.anchorY = 0.5;
batch.x = winSize.width / 2;
batch.y = winSize.height / 2;
batch.shaderProgram = alphaTestShader;
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
var sprite;
for (var i = 0; i < 5; i++) {
sprite = new cc.Sprite(batch.texture, cc.rect(0, 121, 85, 121));
sprite.x = (i + 1) * step;
sprite.y = winSize.height / 2;
sprite.vertexZ = 10 + i * 40;
batch.addChild(sprite, 0);
}
for (i = 5; i < 11; i++) {
sprite = new cc.Sprite(batch.texture, cc.rect(85, 0, 85, 121));
sprite.x = (i + 1) * step;
sprite.y = winSize.height / 2;
sprite.vertexZ = 10 + (10 - i) * 40;
batch.addChild(sprite, 0);
}
this.runAction(cc.orbitCamera(10, 1, 0, 0, 360, 0, 0));
} else {
var label = new cc.LabelTTF("Not supported on HTML5-canvas", "Times New Roman", 30);
this.addChild(label);
label.x = winSize.width / 2;
label.y = winSize.height / 2;
}
//----end20----
},
onEnter:function () {
//----start20----onEnter
this._super();
if ("opengl" in cc.sys.capabilities) {
director.setProjection(cc.Director.PROJECTION_3D);
gl.enable(gl.DEPTH_TEST);
// Avoid Z-fighting with menu and title
var menu = this.getChildByTag(BASE_TEST_MENU_TAG);
menu.vertexZ = 1;
var title = this.getChildByTag(BASE_TEST_TITLE_TAG);
title.vertexZ = 1;
var subtitle = this.getChildByTag(BASE_TEST_SUBTITLE_TAG);
subtitle.vertexZ = 1;
}
//----end20----
},
onExit:function () {
//----start20----onExit
if ("opengl" in cc.sys.capabilities) {
director.setProjection(cc.Director.PROJECTION_2D);
gl.disable(gl.DEPTH_TEST);
}
this._super();
//----end20----
},
// Automation
testDuration:2.2,
pixel1:{"0":51, "1":0, "2":51, "3":255},
pixel2:{"0":0, "1":0, "2":0, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2 - 171, winSize.height / 2, 5, 5);
var ret2 = this.readPixels(winSize.width / 2 - 189, winSize.height / 2, 5, 5);
var ret3 = this.readPixels(winSize.width / 2 - 146, winSize.height / 2, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1, false) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel2, false) ? "yes" : "no",
"pixel3":this.containsPixel(ret3, this.pixel2, false) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteAnchorPoint
//
//------------------------------------------------------------------
var SpriteAnchorPoint = SpriteTestDemo.extend({
_title:"Sprite: anchor point",
ctor:function () {
//----start4----ctor
this._super();
for (var i = 0; i < 3; i++) {
var rotate = cc.rotateBy(10, 360);
var action = rotate.repeatForever();
var sprite = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85 * i, 121, 85, 121));
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite.x;
point.y = sprite.y;
this.addChild(point, 10);
switch (i) {
case 0:
sprite.anchorX = 0;
sprite.anchorY = 0;
break;
case 1:
sprite.anchorX = 0.5;
sprite.anchorY = 0.5;
break;
case 2:
sprite.anchorX = 1;
sprite.anchorY = 1;
break;
}
point.x = sprite.x;
point.y = sprite.y;
//var copy = action.clone();
sprite.runAction(action);
this.addChild(sprite, i);
}
//----end4----
},
//
// Automation
//
testDuration:0.15,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 + 45, winSize.height / 2 + 104, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 2 - 3, winSize.height / 2 + 44, 5, 5);
var ret3 = this.readPixels(winSize.width / 4 * 3 - 44, winSize.height / 2 - 16, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no", "pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeAnchorPoint
//
//------------------------------------------------------------------
var SpriteBatchNodeAnchorPoint = SpriteTestDemo.extend({
_title:"SpriteBatchNode: anchor point",
ctor:function () {
//----start5----ctor
this._super();
// small capacity. Testing resizing.
// Don't use capacity=1 in your real game. It is expensive to resize the capacity
var batch = new cc.SpriteBatchNode(s_grossini_dance_atlas, 1);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
for (var i = 0; i < 3; i++) {
var rotate = cc.rotateBy(10, 360);
var action = rotate.repeatForever();
var sprite = new cc.Sprite(batch.texture, cc.rect(85 * i, 121, 85, 121));
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite.x;
point.y = sprite.y;
this.addChild(point, 1);
switch (i) {
case 0:
sprite.anchorX = 0;
sprite.anchorY = 0;
break;
case 1:
sprite.anchorX = 0.5;
sprite.anchorY = 0.5;
break;
case 2:
sprite.anchorX = 1;
sprite.anchorY = 1;
break;
}
point.x = sprite.x;
point.y = sprite.y;
sprite.runAction(action);
batch.addChild(sprite, i);
}
//----end5----
},
//
// Automation
//
testDuration:0.15,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 + 45, winSize.height / 2 + 104, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 2 - 3, winSize.height / 2 + 44, 5, 5);
var ret3 = this.readPixels(winSize.width / 4 * 3 - 44, winSize.height / 2 - 16, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no", "pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// Sprite6
//
//------------------------------------------------------------------
var Sprite6 = SpriteTestDemo.extend({
_title:"SpriteBatchNode transformation",
ctor:function () {
//----start21----ctor
this._super();
// small capacity. Testing resizing
// Don't use capacity=1 in your real game. It is expensive to resize the capacity
var batch = new cc.SpriteBatchNode(s_grossini_dance_atlas, 1);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
batch.ignoreAnchorPointForPosition(true);
batch.anchorX = 0.5;
batch.anchorY = 0.5;
batch.width = winSize.width;
batch.height = winSize.height;
// SpriteBatchNode actions
var rotate1 = cc.rotateBy(5, 360);
var rotate_back = rotate1.reverse();
var rotate_seq = cc.sequence(rotate1, rotate_back);
var rotate_forever = rotate_seq.repeatForever();
var scale = cc.scaleBy(5, 1.5);
var scale_back = scale.reverse();
var scale_seq = cc.sequence(scale, scale_back);
var scale_forever = scale_seq.repeatForever();
for (var i = 0; i < 3; i++) {
var sprite = new cc.Sprite(batch.texture, cc.rect(85 * i, 121, 85, 121));
switch (i) {
case 0:
sprite.x = winSize.width / 2 - 100;
sprite.y = winSize.height / 2;
break;
case 1:
sprite.x = winSize.width / 2;
sprite.y = winSize.height / 2;
break;
case 2:
sprite.x = winSize.width / 2 + 100;
sprite.y = winSize.height / 2;
break;
}
var rotate = cc.rotateBy(5, 360);
var action = rotate.repeatForever();
sprite.runAction(action.clone());
batch.addChild(sprite, i);
}
batch.runAction(scale_forever);
batch.runAction(rotate_forever);
//----end21----
},
// Automation
testDuration:2,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2 + 111, winSize.height / 2 + 82, 5, 5);
var ret2 = this.readPixels(winSize.width / 2 - 148, winSize.height / 2 - 58, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel, false) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel, false) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteFlip
//
//------------------------------------------------------------------
var SpriteFlip = SpriteTestDemo.extend({
_title:"Sprite Flip X & Y",
ctor:function () {
//----start22----ctor
this._super();
var sprite1 = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85, 121, 85, 121));
sprite1.x = winSize.width / 2 - 100;
sprite1.y = winSize.height / 2;
this.addChild(sprite1, 0, TAG_SPRITE1);
var sprite2 = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85, 121, 85, 121));
sprite2.x = winSize.width / 2 + 100;
sprite2.y = winSize.height / 2;
this.addChild(sprite2, 0, TAG_SPRITE2);
this.schedule(this.onFlipSprites, 1);
//----end22----
},
onFlipSprites:function (dt) {
//----start22----onFlipSprites
var sprite1 = this.getChildByTag(TAG_SPRITE1);
var sprite2 = this.getChildByTag(TAG_SPRITE2);
sprite1.flippedX = !sprite1.flippedX;
sprite2.flippedY = !sprite2.flippedY;
//----end22----
},
//
// Automation
//
testDuration:1.5,
pixel:{"0":255, "1":204, "2":153, "3":255},
pixel1:null,
pixel2:null,
pixel3:null,
pixel4:null,
setupAutomation:function () {
this.scheduleOnce(this.getBeforePixel, 0.5);
},
getBeforePixel:function () {
this.pixel1 = this.readPixels(winSize.width / 2 - 131, winSize.height / 2 - 11, 5, 5);
this.pixel2 = this.readPixels(winSize.width / 2 + 100, winSize.height / 2 + 44, 5, 5);
},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes", "pixel4":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
this.pixel3 = this.readPixels(winSize.width / 2 - 69, winSize.height / 2 - 11, 5, 5);
this.pixel4 = this.readPixels(winSize.width / 2 + 100, winSize.height / 2 - 44, 5, 5);
var ret = {"pixel1":this.containsPixel(this.pixel1, this.pixel) ? "yes" : "no",
"pixel2":this.containsPixel(this.pixel2, this.pixel) ? "yes" : "no",
"pixel3":this.containsPixel(this.pixel3, this.pixel) ? "yes" : "no",
"pixel4":this.containsPixel(this.pixel4, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeFlip
//
//------------------------------------------------------------------
var SpriteBatchNodeFlip = SpriteTestDemo.extend({
_title:"SpriteBatchNode Flip X & Y",
ctor:function () {
//----start23----ctor
this._super();
var batch = new cc.SpriteBatchNode(s_grossini_dance_atlas, 10);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
var sprite1 = new cc.Sprite(batch.texture, cc.rect(85, 121, 85, 121));
sprite1.x = winSize.width / 2 - 100;
sprite1.y = winSize.height / 2;
batch.addChild(sprite1, 0, TAG_SPRITE1);
var sprite2 = new cc.Sprite(batch.texture, cc.rect(85, 121, 85, 121));
sprite2.x = winSize.width / 2 + 100;
sprite2.y = winSize.height / 2;
batch.addChild(sprite2, 0, TAG_SPRITE2);
this.schedule(this.onFlipSprites, 1);
//----end23----
},
onFlipSprites:function (dt) {
//----start23----onFlipSprites
var batch = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
var sprite1 = batch.getChildByTag(TAG_SPRITE1);
var sprite2 = batch.getChildByTag(TAG_SPRITE2);
sprite1.flippedX = !sprite1.flippedX;
sprite2.flippedY = !sprite2.flippedY;
//----end23----
},
//
// Automation
//
testDuration:1.5,
pixel:{"0":255, "1":204, "2":153, "3":255},
pixel1:null,
pixel2:null,
pixel3:null,
pixel4:null,
setupAutomation:function () {
this.scheduleOnce(this.getBeforePixel, 0.5);
},
getBeforePixel:function () {
this.pixel1 = this.readPixels(winSize.width / 2 - 131, winSize.height / 2 - 11, 5, 5);
this.pixel2 = this.readPixels(winSize.width / 2 + 100, winSize.height / 2 + 44, 5, 5);
},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes", "pixel4":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
this.pixel3 = this.readPixels(winSize.width / 2 - 69, winSize.height / 2 - 11, 5, 5);
this.pixel4 = this.readPixels(winSize.width / 2 + 100, winSize.height / 2 - 44, 5, 5);
var ret = {"pixel1":this.containsPixel(this.pixel1, this.pixel) ? "yes" : "no",
"pixel2":this.containsPixel(this.pixel2, this.pixel) ? "yes" : "no",
"pixel3":this.containsPixel(this.pixel3, this.pixel) ? "yes" : "no",
"pixel4":this.containsPixel(this.pixel4, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteAliased
//
//------------------------------------------------------------------
var SpriteAliased = SpriteTestDemo.extend({
_title:"Sprite Aliased",
_subtitle:"You should see pixelated sprites",
ctor:function () {
//----start24----ctor
this._super();
var sprite1 = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85, 121, 85, 121));
sprite1.x = winSize.width / 2 - 100;
sprite1.y = winSize.height / 2;
this.addChild(sprite1, 0, TAG_SPRITE1);
var sprite2 = new cc.Sprite(s_grossini_dance_atlas, cc.rect(85, 121, 85, 121));
sprite2.x = winSize.width / 2 + 100;
sprite2.y = winSize.height / 2;
this.addChild(sprite2, 0, TAG_SPRITE2);
var scale = cc.scaleBy(2, 5);
var scale_back = scale.reverse();
var seq = cc.sequence(scale, scale_back);
var repeat = seq.repeatForever();
var scale2 = cc.scaleBy(2, 5);
var scale_back2 = scale2.reverse();
var seq2 = cc.sequence(scale2, scale_back2);
var repeat2 = seq2.repeatForever();
sprite1.runAction(repeat);
sprite2.runAction(repeat2);
//----end24----
},
onEnter:function () {
//----start24----onEnter
this._super();
//
// IMPORTANT:
// This change will affect every sprite that uses the same texture
// So sprite1 and sprite2 will be affected by this change
//
if (!cc.sys.isNative && !("opengl" in cc.sys.capabilities)) {
var label = new cc.LabelTTF("Not supported on HTML5-canvas", "Times New Roman", 30);
this.addChild(label);
label.x = winSize.width / 2;
label.y = winSize.height / 2;
} else {
var sprite = this.getChildByTag(TAG_SPRITE1);
sprite.texture.setAliasTexParameters();
}
//----end24----
},
onExit:function () {
//----start24----onExit
if (cc.sys.isNative || ("opengl" in cc.sys.capabilities)) {
var sprite = this.getChildByTag(TAG_SPRITE1);
sprite.texture.setAntiAliasTexParameters();
}
this._super();
//----end24----
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeAliased
//
//------------------------------------------------------------------
var SpriteBatchNodeAliased = SpriteTestDemo.extend({
_title:"SpriteBatchNode Aliased",
_subtitle:"You should see pixelated sprites",
ctor:function () {
//----start25----ctor
this._super();
var batch = new cc.SpriteBatchNode(s_grossini_dance_atlas, 10);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
var sprite1 = new cc.Sprite(batch.texture, cc.rect(85, 121, 85, 121));
sprite1.x = winSize.width / 2 - 100;
sprite1.y = winSize.height / 2;
batch.addChild(sprite1, 0, TAG_SPRITE1);
var sprite2 = new cc.Sprite(batch.texture, cc.rect(85, 121, 85, 121));
sprite2.x = winSize.width / 2 + 100;
sprite2.y = winSize.height / 2;
batch.addChild(sprite2, 0, TAG_SPRITE2);
var scale = cc.scaleBy(2, 5);
var scale_back = scale.reverse();
var seq = cc.sequence(scale, scale_back);
var repeat = seq.repeatForever();
var scale2 = cc.scaleBy(2, 5);
var scale_back2 = scale2.reverse();
var seq2 = cc.sequence(scale2, scale_back2);
var repeat2 = seq2.repeatForever();
sprite1.runAction(repeat);
sprite2.runAction(repeat2);
//----end25----
},
onEnter:function () {
//----start25----onEnter
this._super();
//
// IMPORTANT:
// This change will affect every sprite that uses the same texture
// So sprite1 and sprite2 will be affected by this change
//
if (!cc.sys.isNative && !("opengl" in cc.sys.capabilities)) {
var label = new cc.LabelTTF("Not supported on HTML5-canvas", "Times New Roman", 30);
this.addChild(label);
label.x = winSize.width / 2;
label.y = winSize.height / 2;
} else {
var sprite = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
sprite.texture.setAliasTexParameters();
}
//----end25----
},
onExit:function () {
//----start25----onExit
if (cc.sys.isNative || ("opengl" in cc.sys.capabilities)) {
var sprite = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
sprite.texture.setAntiAliasTexParameters();
}
this._super();
//----end25----
}
});
//------------------------------------------------------------------
//
// SpriteNewTexture
//
//------------------------------------------------------------------
var SpriteNewTexture = SpriteTestDemo.extend({
_usingTexture1:false,
_texture1:null,
_texture2:null,
_title:"Sprite New texture (tap)",
ctor:function () {
//----start26----ctor
this._super();
if ('touches' in cc.sys.capabilities){
cc.eventManager.addListener({
event: cc.EventListener.TOUCH_ALL_AT_ONCE,
onTouchesEnded:function (touches, event) {
event.getCurrentTarget().onChangeTexture();
}
}, this);
} else if ('mouse' in cc.sys.capabilities)
cc.eventManager.addListener({
event: cc.EventListener.MOUSE,
onMouseUp: function(event){
event.getCurrentTarget().onChangeTexture();
}
}, this);
var node = new cc.Node();
this.addChild(node, 0, TAG_SPRITE_BATCH_NODE);
this._texture1 = cc.textureCache.addImage(s_grossini_dance_atlas);
this._texture2 = cc.textureCache.addImage(s_grossini_dance_atlas_mono);
this._usingTexture1 = true;
for (var i = 0; i < 30; i++) {
this.addNewSprite();
}
//----end26----
},
addNewSprite:function () {
//----start26----addNewSprite
var p = cc.p(Math.random() * winSize.width, Math.random() * winSize.height);
var idx = 0 | (Math.random() * 14);
var x = (idx % 5) * 85;
var y = (0 | (idx / 5)) * 121;
var node = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
var sprite = new cc.Sprite(this._texture1, cc.rect(x, y, 85, 121));
node.addChild(sprite);
sprite.x = p.x;
sprite.y = p.y;
var action;
var random = Math.random();
if (random < 0.20)
action = cc.scaleBy(3, 2);
else if (random < 0.40)
action = cc.rotateBy(3, 360);
else if (random < 0.60)
action = cc.blink(1, 3);
// else if (random < 0.8)
// action = cc.tintBy(2, 0, -255, -255);
else
action = cc.fadeOut(2);
var action_back = action.reverse();
var seq = cc.sequence(action, action_back);
sprite.runAction(seq.repeatForever());
//----end26----
},
onChangeTexture:function () {
//----start26----onChangeTexture
var node = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
var children = node.children, sprite, i;
if (this._usingTexture1) { //-. win32 : Let's it make just simple sentence
for (i = 0; i < children.length; i++) {
sprite = children[i];
if (!sprite)
break;
sprite.texture = this._texture2;
}
this._usingTexture1 = false;
} else {
for (i = 0; i < children.length; i++) {
sprite = children[i];
if (!sprite)
break;
sprite.texture = this._texture1;
}
this._usingTexture1 = true;
}
//----end26----
},
//
// Automation
//
testDuration:1,
pixel:{"0":51, "1":0, "2":51, "3":255},
setupAutomation:function () {
this.scheduleOnce(this.addTestSprite, 0.5);
},
addTestSprite:function () {
var node = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
var sprite = new cc.Sprite(this._texture1, cc.rect(0, 0, 85, 121));
sprite.x = winSize.width / 2;
sprite.y = winSize.height / 2;
node.addChild(sprite);
},
getExpectedResult:function () {
var ret = {"pixel":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
var ret = {"pixel":this.containsPixel(ret1, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeNewTexture
//
//------------------------------------------------------------------
var SpriteBatchNodeNewTexture = SpriteTestDemo.extend({
_texture1:null,
_texture2:null,
_title:"SpriteBatchNode new texture (tap)",
ctor:function () {
//----start27----ctor
this._super();
if ('touches' in cc.sys.capabilities){
cc.eventManager.addListener({
event: cc.EventListener.TOUCH_ALL_AT_ONCE,
onTouchesEnded:function (touches, event) {
event.getCurrentTarget().onChangeTexture();
}
}, this);
} else if ('mouse' in cc.sys.capabilities)
cc.eventManager.addListener({
event: cc.EventListener.MOUSE,
onMouseUp: function(event){
event.getCurrentTarget().onChangeTexture();
}
}, this);
var batch = new cc.SpriteBatchNode(s_grossini_dance_atlas, 50);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
this._texture1 = batch.texture;
this._texture2 = cc.textureCache.addImage(s_grossini_dance_atlas_mono);
for (var i = 0; i < 30; i++) {
this.addNewSprite();
}
//----end27----
},
addNewSprite:function () {
//----start27----addNewSprite
var s = winSize;
var p = cc.p(Math.random() * winSize.width, Math.random() * winSize.height);
var batch = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
var idx = 0 | (Math.random() * 14);
var x = (idx % 5) * 85;
var y = (0 | (idx / 5)) * 121;
var sprite = new cc.Sprite(batch.texture, cc.rect(x, y, 85, 121));
batch.addChild(sprite);
sprite.x = p.x;
sprite.y = p.y;
var action;
var random = Math.random();
if (random < 0.20)
action = cc.scaleBy(3, 2);
else if (random < 0.40)
action = cc.rotateBy(3, 360);
else if (random < 0.60)
action = cc.blink(1, 3);
//else if (random < 0.8)
// action = cc.tintBy(2, 0, -255, -255);
else
action = cc.fadeOut(2);
var action_back = action.reverse();
var seq = cc.sequence(action, action_back);
sprite.runAction(seq.repeatForever());
//----end27----
},
onChangeTexture:function () {
//----start27----onChangeTexture
var batch = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
if (batch.texture == this._texture1)
batch.texture = this._texture2;
else
batch.texture = this._texture1;
//----end27----
},
//
// Automation
//
testDuration:1,
pixel:{"0":51, "1":0, "2":51, "3":255},
setupAutomation:function () {
this.scheduleOnce(this.addTestSprite, 0.5);
},
addTestSprite:function () {
var node = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
var sprite = new cc.Sprite(this._texture1, cc.rect(0, 0, 85, 121));
sprite.x = winSize.width / 2;
sprite.y = winSize.height / 2;
node.addChild(sprite);
},
getExpectedResult:function () {
var ret = {"pixel":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
var ret = {"pixel":this.containsPixel(ret1, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteFrameTest
//
//------------------------------------------------------------------
var SpriteFrameTest = SpriteTestDemo.extend({
_sprite1:null,
_sprite2:null,
_counter:0,
_title:"Sprite vs. SpriteBatchNode animation",
_subtitle:"Testing issue #792",
onEnter:function () {
//----start2----onEnter
this._super();
// IMPORTANT:
// The sprite frames will be cached AND RETAINED, and they won't be released unless you call
// cc.spriteFrameCache.removeUnusedSpriteFrames);
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
spriteFrameCache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
spriteFrameCache.addSpriteFrames(s_grossini_bluePlist, s_grossini_blue);
//
// Animation using Sprite BatchNode
//
this._sprite1 = new cc.Sprite("#grossini_dance_01.png");
this._sprite1.x = winSize.width / 2 - 80;
this._sprite1.y = winSize.height / 2;
var spritebatch = new cc.SpriteBatchNode(s_grossini);
spritebatch.addChild(this._sprite1);
this.addChild(spritebatch);
var animFrames = [];
var str = "";
var frame;
for (var i = 1; i < 15; i++) {
str = "grossini_dance_" + (i < 10 ? ("0" + i) : i) + ".png";
frame = spriteFrameCache.getSpriteFrame(str);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.3);
this._sprite1.runAction(cc.animate(animation).repeatForever());
// to test issue #732, uncomment the following line
this._sprite1.flippedX = false;
this._sprite1.flippedY = false;
//
// Animation using standard Sprite
//
this._sprite2 = new cc.Sprite("#grossini_dance_01.png");
this._sprite2.x = winSize.width / 2 + 80;
this._sprite2.y = winSize.height / 2;
this.addChild(this._sprite2);
var moreFrames = [];
for (i = 1; i < 15; i++) {
str = "grossini_dance_gray_" + (i < 10 ? ("0" + i) : i) + ".png";
frame = spriteFrameCache.getSpriteFrame(str);
moreFrames.push(frame);
}
for (i = 1; i < 5; i++) {
str = "grossini_blue_0" + i + ".png";
frame = spriteFrameCache.getSpriteFrame(str);
moreFrames.push(frame);
}
// append frames from another batch
moreFrames = moreFrames.concat(animFrames);
var animMixed = new cc.Animation(moreFrames, 0.3);
this._sprite2.runAction(cc.animate(animMixed).repeatForever());
// to test issue #732, uncomment the following line
this._sprite2.flippedX = false;
this._sprite2.flippedY = false;
this.schedule(this.onStartIn05Secs, 0.5);
this._counter = 0;
//----end2----
},
onExit:function () {
//----start2----onExit
this._super();
spriteFrameCache.removeSpriteFramesFromFile(s_grossiniPlist);
spriteFrameCache.removeSpriteFramesFromFile(s_grossini_grayPlist);
spriteFrameCache.removeSpriteFramesFromFile(s_grossini_bluePlist);
//----end2----
},
onStartIn05Secs:function () {
//----start2----onStartIn05Secs
this.unschedule(this.onStartIn05Secs);
this.schedule(this.onFlipSprites, 1.0);
//----end2----
},
onFlipSprites:function (dt) {
//----start2----onFlipSprites
this._counter++;
var fx = false;
var fy = false;
var i = this._counter % 4;
switch (i) {
case 0:
fx = false;
fy = false;
break;
case 1:
fx = true;
fy = false;
break;
case 2:
fx = false;
fy = true;
break;
case 3:
fx = true;
fy = true;
break;
}
this._sprite1.flippedX = fx;
this._sprite1.flippedY = fy;
this._sprite2.flippedX = fx;
this._sprite2.flippedY = fy;
//----end2----
},
//
// Automation
//
testDuration:3.1,
pixel1:{"0":255, "1":204, "2":153, "3":255},
pixel2:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2 - 50, winSize.height / 2 + 8, 5, 5);
var ret2 = this.readPixels(winSize.width / 2 - 80, winSize.height / 2 - 42, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel2) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteFrameAliasNameTest
//
//------------------------------------------------------------------
var SpriteFrameAliasNameTest = SpriteTestDemo.extend({
_title:"SpriteFrame Alias Name",
_subtitle:"SpriteFrames are obtained using the alias name",
onEnter:function (){
//----start3----onEnter
this._super();
// IMPORTANT:
// The sprite frames will be cached AND RETAINED, and they won't be released unless you call
//
// cc.SpriteFrameCache is a cache of cc.SpriteFrames
// cc.SpriteFrames each contain a texture id and a rect (frame).
spriteFrameCache.addSpriteFrames(s_grossini_aliasesPlist, s_grossini_aliases);
//
// Animation using Sprite batch
//
// A cc.SpriteBatchNode can reference one and only one texture (one .png file)
// Sprites that are contained in that texture can be instantiatied as cc.Sprites and then added to the cc.SpriteBatchNode
// All cc.Sprites added to a cc.SpriteBatchNode are drawn in one OpenGL ES draw call
// If the cc.Sprites are not added to a cc.SpriteBatchNode then an OpenGL ES draw call will be needed for each one, which is less efficient
//
// When you animate a sprite, CCAnimation changes the frame of the sprite using setDisplayFrame: (this is why the animation must be in the same texture)
// When setDisplayFrame: is used in the CCAnimation it changes the frame to one specified by the cc.SpriteFrames that were added to the animation,
// but texture id is still the same and so the sprite is still a child of the cc.SpriteBatchNode,
// and therefore all the animation sprites are also drawn as part of the cc.SpriteBatchNode
//
var sprite = new cc.Sprite("#grossini_dance_01.png");
sprite.x = winSize.width / 2;
sprite.y = winSize.height / 2;
var spriteBatch = new cc.SpriteBatchNode(s_grossini_aliases);
spriteBatch.addChild(sprite);
this.addChild(spriteBatch);
var animFrames = [];
var str = "";
for (var i = 1; i < 15; i++) {
// Obtain frames by alias name
str = "dance_" + (i < 10 ? ("0" + i) : i);
var frame = spriteFrameCache.getSpriteFrame(str);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.3);
// 14 frames * 1sec = 14 seconds
sprite.runAction(cc.animate(animation).repeatForever());
this.testSprite = sprite;
//----end3----
},
onExit:function () {
this._super();
spriteFrameCache.removeSpriteFramesFromFile(s_grossini_aliasesPlist);
},
//
// Automation
//
testDuration:0.5,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2 - 32, winSize.height / 2 - 10, 5, 5);
var ret = {"pixel":this.containsPixel(ret1, this.pixel, false) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteOffsetAnchorRotation
//
//------------------------------------------------------------------
var SpriteOffsetAnchorRotation = SpriteTestDemo.extend({
_title:"Sprite offset + anchor + rot",
ctor:function () {
//----start6----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
spriteFrameCache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
for (var i = 0; i < 3; i++) {
//
// Animation using Sprite BatchNode
//
var sprite = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite.x;
point.y = sprite.y;
this.addChild(point, 1);
switch (i) {
case 0:
sprite.anchorX = 0;
sprite.anchorY = 0;
break;
case 1:
sprite.anchorX = 0.5;
sprite.anchorY = 0.5;
break;
case 2:
sprite.anchorX = 1;
sprite.anchorY = 1;
break;
}
point.x = sprite.x;
point.y = sprite.y;
var animFrames = [];
var str = "";
for (var j = 1; j < 15; j++) {
str = "grossini_dance_" + (j < 10 ? ("0" + j) : j) + ".png";
var frame = spriteFrameCache.getSpriteFrame(str);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.3);
sprite.runAction(cc.animate(animation).repeatForever());
sprite.runAction(cc.rotateBy(10, 360).repeatForever());
this.addChild(sprite, 0);
}
//----end6----
},
onExit:function () {
//----start6----onExit
this._super();
spriteFrameCache.removeSpriteFramesFromFile(s_grossiniPlist);
spriteFrameCache.removeSpriteFramesFromFile(s_grossini_grayPlist);
//----end6----
},
//
// Automation
//
testDuration:5,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 - 13, winSize.height / 2 - 50, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 2 + 29, winSize.height / 2 + 11, 5, 5);
var ret3 = this.readPixels(winSize.width / 4 * 3 + 71, winSize.height / 2 + 71, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no", "pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeOffsetAnchorRotation
//
//------------------------------------------------------------------
var SpriteBatchNodeOffsetAnchorRotation = SpriteTestDemo.extend({
_title:"SpriteBatchNode offset + anchor + rot",
ctor:function () {
//----start7----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
spriteFrameCache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
var spritebatch = new cc.SpriteBatchNode(s_grossini);
this.addChild(spritebatch);
for (var i = 0; i < 3; i++) {
//
// Animation using Sprite BatchNode
//
var sprite = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite.x;
point.y = sprite.y;
this.addChild(point, 200);
switch (i) {
case 0:
sprite.anchorX = 0;
sprite.anchorY = 0;
break;
case 1:
sprite.anchorX = 0.5;
sprite.anchorY = 0.5;
break;
case 2:
sprite.anchorX = 1;
sprite.anchorY = 1;
break;
}
point.x = sprite.x;
point.y = sprite.y;
var animFrames = [];
var str = "";
for (var k = 1; k < 15; k++) {
str = "grossini_dance_" + (k < 10 ? ("0" + k) : k) + ".png";
var frame = spriteFrameCache.getSpriteFrame(str);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.3);
sprite.runAction(cc.animate(animation).repeatForever());
sprite.runAction(cc.rotateBy(10, 360).repeatForever());
spritebatch.addChild(sprite, i);
}
//----end7----
},
onExit:function () {
this._super();
spriteFrameCache.removeSpriteFramesFromFile(s_grossiniPlist);
spriteFrameCache.removeSpriteFramesFromFile(s_grossini_grayPlist);
},
//
// Automation
//
testDuration:5,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 - 13, winSize.height / 2 - 50, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 2 + 29, winSize.height / 2 + 11, 5, 5);
var ret3 = this.readPixels(winSize.width / 4 * 3 + 71, winSize.height / 2 + 71, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no", "pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteOffsetAnchorScale
//
//------------------------------------------------------------------
var SpriteOffsetAnchorScale = SpriteTestDemo.extend({
_title:"Sprite offset + anchor + scale",
ctor:function () {
//----start8----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
spriteFrameCache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
for (var i = 0; i < 3; i++) {
//
// Animation using Sprite BatchNode
//
var sprite = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite.x;
point.y = sprite.y;
this.addChild(point, 1);
switch (i) {
case 0:
sprite.anchorX = 0;
sprite.anchorY = 0;
break;
case 1:
sprite.anchorX = 0.5;
sprite.anchorY = 0.5;
break;
case 2:
sprite.anchorX = 1;
sprite.anchorY = 1;
break;
}
point.x = sprite.x;
point.y = sprite.y;
var animFrames = [];
var str = "";
for (var k = 1; k <= 14; k++) {
str = "grossini_dance_" + (k < 10 ? ("0" + k) : k) + ".png";
var frame = spriteFrameCache.getSpriteFrame(str);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.3);
sprite.runAction(cc.animate(animation).repeatForever());
var scale = cc.scaleBy(2, 2);
var scale_back = scale.reverse();
var delay = cc.delayTime(0.25);
var seq_scale = cc.sequence(scale, delay, scale_back);
sprite.runAction(seq_scale.repeatForever());
this.addChild(sprite, 0);
}
//----end8----
},
onExit:function () {
//----start8----onExit
this._super();
spriteFrameCache.removeSpriteFramesFromFile(s_grossiniPlist);
spriteFrameCache.removeSpriteFramesFromFile(s_grossini_grayPlist);
//----end8----
},
//
// Automation
//
testDuration:2.1,
pixel:{"0":153, "1":0, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 * 3 - 85, winSize.height / 2 - 106, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 2, winSize.height / 2 + 13, 5, 5);
var ret3 = this.readPixels(winSize.width / 4 + 82, winSize.height / 2 + 133, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no", "pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeOffsetAnchorScale
//
//------------------------------------------------------------------
var SpriteBatchNodeOffsetAnchorScale = SpriteTestDemo.extend({
_title:"SpriteBatchNode offset + anchor + scale",
ctor:function () {
this._super();
//----start9----ctor
var batch = new cc.SpriteBatchNode(s_grossini);
this.addChild(batch);
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
spriteFrameCache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
for (var i = 0; i < 3; i++) {
//
// Animation using Sprite BatchNode
//
var sprite = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite.x;
point.y = sprite.y;
this.addChild(point, 200);
switch (i) {
case 0:
sprite.anchorX = 0;
sprite.anchorY = 0;
break;
case 1:
sprite.anchorX = 0.5;
sprite.anchorY = 0.5;
break;
case 2:
sprite.anchorX = 1;
sprite.anchorY = 1;
break;
}
point.x = sprite.x;
point.y = sprite.y;
var animFrames = [];
var str = "";
for (var k = 1; k <= 14; k++) {
str = "grossini_dance_" + (k < 10 ? ("0" + k) : k) + ".png";
var frame = spriteFrameCache.getSpriteFrame(str);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.3);
sprite.runAction(cc.animate(animation).repeatForever());
var scale = cc.scaleBy(2, 2);
var scale_back = scale.reverse();
var seq_scale = cc.sequence(scale, scale_back);
sprite.runAction(seq_scale.repeatForever());
batch.addChild(sprite, i);
}
//----end9----
},
onExit:function () {
//----start9----onExit
this._super();
spriteFrameCache.removeSpriteFramesFromFile(s_grossiniPlist);
spriteFrameCache.removeSpriteFramesFromFile(s_grossini_grayPlist);
//----end9----
},
//
// Automation
//
testDuration:2.1,
pixel:{"0":153, "1":0, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 * 3 - 85, winSize.height / 2 - 106, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 2, winSize.height / 2 + 13, 5, 5);
var ret3 = this.readPixels(winSize.width / 4 + 82, winSize.height / 2 + 133, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no", "pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//
// SpriteOffsetAnchorSkew
//
var SpriteOffsetAnchorSkew = SpriteTestDemo.extend({
_title:"Sprite offset + anchor + skew",
ctor:function () {
//----start41----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
spriteFrameCache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
for (var i = 0; i < 3; i++) {
//
// Animation using Sprite batch
//
var sprite = new cc.Sprite("#grossini_dance_01.png");
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite.x;
point.y = sprite.y;
this.addChild(point, 1);
switch (i) {
case 0:
sprite.anchorX = 0;
sprite.anchorY = 0;
break;
case 1:
sprite.anchorX = 0.5;
sprite.anchorY = 0.5;
break;
case 2:
sprite.anchorX = 1;
sprite.anchorY = 1;
break;
}
point.x = sprite.x;
point.y = sprite.y;
var animFrames = [];
var tmp = "";
for (var j = 1; j <= 14; j++) {
tmp = "grossini_dance_" + (j < 10 ? ("0" + j) : j) + ".png";
var frame = spriteFrameCache.getSpriteFrame(tmp);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.3);
sprite.runAction(cc.animate(animation).repeatForever());
var skewX = cc.skewBy(2, 45, 0);
var skewX_back = skewX.reverse();
var skewY = cc.skewBy(2, 0, 45);
var skewY_back = skewY.reverse();
var seq_skew = cc.sequence(skewX, skewX_back, skewY, skewY_back);
sprite.runAction(seq_skew.repeatForever());
this.addChild(sprite, 0);
}
//----end41----
},
//
// Automation
//
testDuration:2,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 + 142, winSize.height / 2 + 98, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 2 + 50, winSize.height / 2 + 43, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//
// SpriteBatchNodeOffsetAnchorSkew
//
var SpriteBatchNodeOffsetAnchorSkew = SpriteTestDemo.extend({
_title:"SpriteBatchNode offset + anchor + skew",
ctor:function () {
//----start42----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
spriteFrameCache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
var spritebatch = new cc.SpriteBatchNode(s_grossini);
this.addChild(spritebatch);
for (var i = 0; i < 3; i++) {
//
// Animation using Sprite batch
//
var sprite = new cc.Sprite("#grossini_dance_01.png");
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite.x;
point.y = sprite.y;
this.addChild(point, 200);
switch (i) {
case 0:
sprite.anchorX = 0;
sprite.anchorY = 0;
break;
case 1:
sprite.anchorX = 0.5;
sprite.anchorY = 0.5;
break;
case 2:
sprite.anchorX = 1;
sprite.anchorY = 1;
break;
}
point.x = sprite.x;
point.y = sprite.y;
var animFrames = [];
var tmp = "";
for (var j = 1; j <= 14; j++) {
tmp = "grossini_dance_" + (j < 10 ? ("0" + j) : j) + ".png";
var frame = spriteFrameCache.getSpriteFrame(tmp);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.3);
sprite.runAction(cc.animate(animation).repeatForever());
animFrames = null;
var skewX = cc.skewBy(2, 45, 0);
var skewX_back = skewX.reverse();
var skewY = cc.skewBy(2, 0, 45);
var skewY_back = skewY.reverse();
var seq_skew = cc.sequence(skewX, skewX_back, skewY, skewY_back);
sprite.runAction(seq_skew.repeatForever());
spritebatch.addChild(sprite, i);
}
//----end42----
},
//
// Automation
//
testDuration:2,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 + 142, winSize.height / 2 + 98, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 2 + 50, winSize.height / 2 + 43, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//
// SpriteOffsetAnchorSkewScale
//
var SpriteOffsetAnchorSkewScale = SpriteTestDemo.extend({
_title:"Sprite anchor + skew + scale",
ctor:function () {
//----start43----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
spriteFrameCache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
for (var i = 0; i < 3; i++) {
//
// Animation using Sprite batch
//
var sprite = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite.x;
point.y = sprite.y;
this.addChild(point, 1);
switch (i) {
case 0:
sprite.anchorX = 0;
sprite.anchorY = 0;
break;
case 1:
sprite.anchorX = 0.5;
sprite.anchorY = 0.5;
break;
case 2:
sprite.anchorX = 1;
sprite.anchorY = 1;
break;
}
point.x = sprite.x;
point.y = sprite.y;
var animFrames = [];
var tmp = "";
for (var j = 1; j <= 14; j++) {
tmp = "grossini_dance_" + (j < 10 ? ("0" + j) : j) + ".png";
var frame = spriteFrameCache.getSpriteFrame(tmp);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.3);
sprite.runAction(cc.animate(animation).repeatForever());
animFrames = null;
// Skew
var skewX = cc.skewBy(2, 45, 0);
var skewX_back = skewX.reverse();
var skewY = cc.skewBy(2, 0, 45);
var skewY_back = skewY.reverse();
var seq_skew = cc.sequence(skewX, skewX_back, skewY, skewY_back);
sprite.runAction(seq_skew.repeatForever());
// Scale
var scale = cc.scaleBy(2, 2);
var scale_back = scale.reverse();
var seq_scale = cc.sequence(scale, scale_back);
sprite.runAction(seq_scale.repeatForever());
this.addChild(sprite, 0);
}
//----end43----
},
//
// Automation
//
testDuration:2,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 + 121, winSize.height / 2 + 99, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 2 - 83, winSize.height / 2 - 21, 5, 5);
var ret3 = this.readPixels(winSize.width / 4 * 3 - 286, winSize.height / 2 - 140, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no",
"pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//
// SpriteBatchNodeOffsetAnchorSkewScale
//
var SpriteBatchNodeOffsetAnchorSkewScale = SpriteTestDemo.extend({
_title:"SpriteBatchNode anchor + skew + scale",
ctor:function () {
//----start44----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
spriteFrameCache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
var spritebatch = new cc.SpriteBatchNode(s_grossini);
this.addChild(spritebatch);
for (var i = 0; i < 3; i++) {
//
// Animation using Sprite batch
//
var sprite = new cc.Sprite("#grossini_dance_01.png");
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite.x;
point.y = sprite.y;
this.addChild(point, 200);
switch (i) {
case 0:
sprite.anchorX = 0;
sprite.anchorY = 0;
break;
case 1:
sprite.anchorX = 0.5;
sprite.anchorY = 0.5;
break;
case 2:
sprite.anchorX = 1;
sprite.anchorY = 1;
break;
}
point.x = sprite.x;
point.y = sprite.y;
var animFrames = [];
var tmp = "";
for (var j = 1; j <= 14; j++) {
tmp = "grossini_dance_" + (j < 10 ? ("0" + j) : j) + ".png";
var frame = spriteFrameCache.getSpriteFrame(tmp);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.3);
sprite.runAction(cc.animate(animation).repeatForever());
animFrames = null;
// skew
var skewX = cc.skewBy(2, 45, 0);
var skewX_back = skewX.reverse();
var skewY = cc.skewBy(2, 0, 45);
var skewY_back = skewY.reverse();
var seq_skew = cc.sequence(skewX, skewX_back, skewY, skewY_back);
sprite.runAction(seq_skew.repeatForever());
// scale
var scale = cc.scaleBy(2, 2);
var scale_back = scale.reverse();
var seq_scale = cc.sequence(scale, scale_back);
sprite.runAction(seq_scale.repeatForever());
spritebatch.addChild(sprite, i);
}
//----end44----
},
//
// Automation
//
testDuration:2,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 + 121, winSize.height / 2 + 99, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 2 - 83, winSize.height / 2 - 21, 5, 5);
var ret3 = this.readPixels(winSize.width / 4 * 3 - 286, winSize.height / 2 - 140, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no",
"pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//
// SpriteOffsetAnchorFlip
//
var SpriteOffsetAnchorFlip = SpriteTestDemo.extend({
_title:"Sprite offset + anchor + flip",
_subtitle:"issue #1078",
ctor:function () {
//----start45----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
spriteFrameCache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
for (var i = 0; i < 3; i++) {
//
// Animation using Sprite batch
//
var sprite = new cc.Sprite("#grossini_dance_01.png");
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite.x;
point.y = sprite.y;
this.addChild(point, 1);
switch (i) {
case 0:
sprite.anchorX = 0;
sprite.anchorY = 0;
break;
case 1:
sprite.anchorX = 0.5;
sprite.anchorY = 0.5;
break;
case 2:
sprite.anchorX = 1;
sprite.anchorY = 1;
break;
}
point.x = sprite.x;
point.y = sprite.y;
var animFrames = [];
var tmp = "";
for (var j = 1; j <= 14; j++) {
tmp = "grossini_dance_" + (j < 10 ? ("0" + j) : j) + ".png";
var frame = spriteFrameCache.getSpriteFrame(tmp);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.3);
sprite.runAction(cc.animate(animation).repeatForever());
animFrames = null;
var flip = cc.flipY(true);
var flip_back = cc.flipY(false);
var delay = cc.delayTime(1);
var delay1 = cc.delayTime(1);
var seq = cc.sequence(delay, flip, delay1, flip_back);
sprite.runAction(seq.repeatForever());
this.addChild(sprite, 0);
}
//----end45----
},
//
// Automation
//
testDuration:1.5,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 + 40, winSize.height / 2 + 18, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 2, winSize.height / 2 - 44, 5, 5);
var ret3 = this.readPixels(winSize.width / 4 * 3 - 45, winSize.height / 2 - 105, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no", "pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//
// SpriteBatchNodeOffsetAnchorFlip
//
var SpriteBatchNodeOffsetAnchorFlip = SpriteTestDemo.extend({
_title:"SpriteBatchNode offset + anchor + flip",
_subtitle:"issue #1078",
ctor:function () {
//----start46----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
spriteFrameCache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
var spritebatch = new cc.SpriteBatchNode(s_grossini);
this.addChild(spritebatch);
for (var i = 0; i < 3; i++) {
//
// Animation using Sprite batch
//
var sprite = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite.x;
point.y = sprite.y;
this.addChild(point, 200);
switch (i) {
case 0:
sprite.anchorX = 0;
sprite.anchorY = 0;
break;
case 1:
sprite.anchorX = 0.5;
sprite.anchorY = 0.5;
break;
case 2:
sprite.anchorX = 1;
sprite.anchorY = 1;
break;
}
point.x = sprite.x;
point.y = sprite.y;
var animFrames = [];
var tmp = "";
for (var j = 1; j <= 14; j++) {
tmp = "grossini_dance_" + (j < 10 ? ("0" + j) : j) + ".png";
var frame = spriteFrameCache.getSpriteFrame(tmp);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.3);
sprite.runAction(cc.animate(animation).repeatForever());
animFrames = null;
var flip = cc.flipY(true);
var flip_back = cc.flipY(false);
var delay = cc.delayTime(1);
var seq = cc.sequence(delay, flip, delay.clone(), flip_back);
sprite.runAction(seq.repeatForever());
spritebatch.addChild(sprite, i);
}
//----end46----
},
//
// Automation
//
testDuration:1.5,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 + 40, winSize.height / 2 + 18, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 2, winSize.height / 2 - 44, 5, 5);
var ret3 = this.readPixels(winSize.width / 4 * 3 - 45, winSize.height / 2 - 105, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no", "pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteAnimationSplit
//
//------------------------------------------------------------------
var SpriteAnimationSplit = SpriteTestDemo.extend({
_title:"Sprite: Animation + flip",
ctor:function () {
//----start10----ctor
this._super();
var texture = cc.textureCache.addImage(s_dragon_animation);
// manually add frames to the frame cache
var frame0 = new cc.SpriteFrame(texture, cc.rect(132 * 0, 132 * 0, 132, 132));
var frame1 = new cc.SpriteFrame(texture, cc.rect(132 * 1, 132 * 0, 132, 132));
var frame2 = new cc.SpriteFrame(texture, cc.rect(132 * 2, 132 * 0, 132, 132));
var frame3 = new cc.SpriteFrame(texture, cc.rect(132 * 3, 132 * 0, 132, 132));
var frame4 = new cc.SpriteFrame(texture, cc.rect(132 * 0, 132 * 1, 132, 132));
var frame5 = new cc.SpriteFrame(texture, cc.rect(132 * 1, 132 * 1, 132, 132));
//
// Animation using Sprite BatchNode
//
var sprite = new cc.Sprite(frame0);
sprite.x = winSize.width / 2;
sprite.y = winSize.height / 2;
this.addChild(sprite);
var animFrames = [];
animFrames.push(frame0);
animFrames.push(frame1);
animFrames.push(frame2);
animFrames.push(frame3);
animFrames.push(frame4);
animFrames.push(frame5);
var animation = new cc.Animation(animFrames, 0.2);
var animate = cc.animate(animation);
var delay = cc.delayTime(0.5);
var seq = cc.sequence(animate,
cc.flipX(true),
animate.clone(),
delay,
cc.flipX(false));
sprite.runAction(seq.repeatForever());
//----end10----
},
onExit:function () {
this._super();
},
//
// Automation
//
testDuration:2.8,
pixel1:{"0":208, "1":208, "2":208, "3":255},
pixel2:{"0":0, "1":0, "2":0, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2 + 52, winSize.height / 2 - 29, 5, 5);
var ret2 = this.readPixels(winSize.width / 2, winSize.height / 2 - 22, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1, true, 3) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel2, false) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteHybrid
//
//------------------------------------------------------------------
var SpriteHybrid = SpriteTestDemo.extend({
_usingSpriteBatchNode:false,
_title:"Hybrid.Sprite* sprite Test",
ctor:function () {
//----start28----ctor
this._super();
// parents
var parent1 = new cc.Node();
var parent2 = new cc.SpriteBatchNode(s_grossini, 50);
this.addChild(parent1, 0, TAG_NODE);
this.addChild(parent2, 0, TAG_SPRITE_BATCH_NODE);
// IMPORTANT:
// The sprite frames will be cached AND RETAINED, and they won't be released unless you call
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
// create 250 sprites
// only show 80% of them
for (var i = 1; i <= 250; i++) {
var spriteIdx = Math.round(Math.random() * 14);
if (spriteIdx === 0)
spriteIdx = 1;
var str = "grossini_dance_" + (spriteIdx < 10 ? ("0" + spriteIdx) : spriteIdx) + ".png";
var frame = spriteFrameCache.getSpriteFrame(str);
var sprite = new cc.Sprite(frame);
parent1.addChild(sprite, i, i);
var x = -1000;
var y = -1000;
if (Math.random() < 0.2) {
x = Math.random() * winSize.width;
y = Math.random() * winSize.height;
}
sprite.x = x;
sprite.y = y;
var action = cc.rotateBy(4, 360);
sprite.runAction(action.repeatForever());
}
this._usingSpriteBatchNode = false;
this.schedule(this.reparentSprite, 2);
//----end28----
},
onExit:function () {
//----start28----onExit
this._super();
spriteFrameCache.removeSpriteFramesFromFile(s_grossiniPlist);
//----end28----
},
reparentSprite:function () {
//----start28----reparentSprite
var p1 = this.getChildByTag(TAG_NODE);
var p2 = this.getChildByTag(TAG_SPRITE_BATCH_NODE);
var retArray = [];
var node;
if (this._usingSpriteBatchNode) {
var tempNode = p2;
p2 = p1;
p1 = tempNode;
}
////----UXLog("New parent is: %x", p2);
var children = p1.children;
for (var i = 0; i < children.length; i++) {
node = children[i];
if (!node)
break;
retArray.push(node);
}
p1.removeAllChildren(false);
for (i = 0; i < retArray.length; i++) {
node = retArray[i];
if (!node)
break;
p2.addChild(node, i, i);
}
this._usingSpriteBatchNode = !this._usingSpriteBatchNode;
//----end28----
},
//
// Automation
//
testDuration:2.5,
pixel:{"0":51, "1":0, "2":51, "3":255},
firstPixel1:false,
firstPixel2:false,
setupAutomation:function () {
this.scheduleOnce(this.addTestSprite, 1);
this.scheduleOnce(this.checkFirstPixel, 1.5);
},
addTestSprite:function () {
var p = this.getChildByTag(TAG_NODE);
var frame = spriteFrameCache.getSpriteFrame("grossini_dance_01.png");
var sprite1 = new cc.Sprite(frame);
sprite1.retain();
p.addChild(sprite1, 1000);
sprite1.x = winSize.width / 4;
sprite1.y = winSize.height / 2;
var sprite2 = new cc.Sprite(frame);
sprite2.retain();
p.addChild(sprite2, 1000);
sprite2.x = winSize.width / 2;
sprite2.y = winSize.height / 2;
},
checkFirstPixel:function () {
var ret1 = this.readPixels(winSize.width / 4, winSize.height / 2, 5, 5);
var ret2 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
this.firstPixel1 = this.containsPixel(ret1, this.pixel);
this.firstPixel2 = this.containsPixel(ret2, this.pixel);
},
getExpectedResult:function () {
var ret = {"firstPixel1":true, "firstPixel2":true, "secondPixel1":true, "pixel2":true};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var pixel1 = this.readPixels(winSize.width / 4, winSize.height / 2, 5, 5);
var pixel2 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
var secondPixel1 = this.containsPixel(pixel1, this.pixel);
var secondPixel2 = this.containsPixel(pixel2, this.pixel);
var ret = {"firstPixel1":this.firstPixel1, "firstPixel2":this.firstPixel2, "secondPixel1":secondPixel1, "pixel2":secondPixel2};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeChildren
//
//------------------------------------------------------------------
var SpriteBatchNodeChildren = SpriteTestDemo.extend({
_title:"SpriteBatchNode Grand Children",
ctor:function () {
//----start29----ctor
this._super();
// parents
var batch = new cc.SpriteBatchNode(s_grossini, 50);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
var sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite1.x = winSize.width / 3;
sprite1.y = winSize.height / 2;
var sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 50;
sprite2.y = 50;
var sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -50;
sprite3.y = -50;
batch.addChild(sprite1);
sprite1.addChild(sprite2);
sprite1.addChild(sprite3);
// BEGIN NEW CODE
var animFrames = [];
var str = "";
for (var i = 1; i < 15; i++) {
str = "grossini_dance_" + (i < 10 ? ("0" + i) : i) + ".png";
var frame = spriteFrameCache.getSpriteFrame(str);
animFrames.push(frame);
}
var animation = new cc.Animation(animFrames, 0.2);
sprite1.runAction(cc.animate(animation).repeatForever());
// END NEW CODE
var action = cc.moveBy(2, cc.p(200, 0));
var action_back = action.reverse();
var action_rot = cc.rotateBy(2, 360);
var action_s = cc.scaleBy(2, 2);
var action_s_back = action_s.reverse();
var seq2 = action_rot.reverse();
sprite2.runAction(seq2.repeatForever());
sprite1.runAction(action_rot.repeatForever());
sprite1.runAction(cc.sequence(action, action_back).repeatForever());
sprite1.runAction(cc.sequence(action_s, action_s_back).repeatForever());
//----end29----
},
//
// Automation
//
testDuration:0.5,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 3 - 47, winSize.height / 2 + 107, 5, 5);
var ret2 = this.readPixels(winSize.width / 3 + 95, winSize.height / 2 - 5, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeChildrenZ
//
//------------------------------------------------------------------
var SpriteBatchNodeChildrenZ = SpriteTestDemo.extend({
_title:"SpriteBatchNode Children Z",
ctor:function () {
//----start30----ctor
this._super();
// parents
var batch;
var sprite1, sprite2, sprite3;
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
// test 1
batch = new cc.SpriteBatchNode(s_grossini, 50);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite1.x = winSize.width / 3;
sprite1.y = winSize.height / 2;
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 20;
sprite2.y = 30;
sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -20;
sprite3.y = 30;
batch.addChild(sprite1);
sprite1.addChild(sprite2, 2);
sprite1.addChild(sprite3, -2);
// test 2
batch = new cc.SpriteBatchNode(s_grossini, 50);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite1.x = 2 * winSize.width / 3;
sprite1.y = winSize.height / 2;
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 20;
sprite2.y = 30;
sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -20;
sprite3.y = 30;
batch.addChild(sprite1);
sprite1.addChild(sprite2, -2);
sprite1.addChild(sprite3, 2);
// test 3
batch = new cc.SpriteBatchNode(s_grossini, 50);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite1.x = winSize.width / 2 - 90;
sprite1.y = winSize.height / 4;
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = winSize.width / 2 - 60;
sprite2.y = winSize.height / 4;
sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = winSize.width / 2 - 30;
sprite3.y = winSize.height / 4;
batch.addChild(sprite1, 10);
batch.addChild(sprite2, -10);
batch.addChild(sprite3, -5);
// test 4
batch = new cc.SpriteBatchNode(s_grossini, 50);
this.addChild(batch, 0, TAG_SPRITE_BATCH_NODE);
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite1.x = winSize.width / 2 + 30;
sprite1.y = winSize.height / 4;
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = winSize.width / 2 + 60;
sprite2.y = winSize.height / 4;
sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = winSize.width / 2 + 90;
sprite3.y = winSize.height / 4;
batch.addChild(sprite1, -10);
batch.addChild(sprite2, -5);
batch.addChild(sprite3, -2);
//----end30----
},
//
// Automation
//
testDuration:1,
pixel1:{"0":51, "1":0, "2":51, "3":255},
pixel2:{"0":51, "1":0, "2":51, "3":255},
pixel3:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(2 * winSize.width / 3 - 20, winSize.height / 2, 5, 5);
var ret2 = this.readPixels(winSize.width / 3 - 20, winSize.height / 2 + 115, 5, 5);
var ret3 = this.readPixels(winSize.width / 2 + 30, winSize.height / 4 - 10, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1) ? "yes" : "no",
"pixel2":!this.containsPixel(ret2, this.pixel2) ? "yes" : "no",
"pixel3":this.containsPixel(ret3, this.pixel3) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteChildrenVisibility
//
//------------------------------------------------------------------
var SpriteChildrenVisibility = SpriteTestDemo.extend({
_title:"Sprite & SpriteBatchNode Visibility",
ctor:function () {
//----start31----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
//
// SpriteBatchNode
//
// parents
var aParent = new cc.SpriteBatchNode(s_grossini, 50);
aParent.x = winSize.width / 3;
aParent.y = winSize.height / 2;
this.addChild(aParent, 0);
var sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite1.x = 0;
sprite1.y = 0;
var sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 20;
sprite2.y = 30;
var sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -20;
sprite3.y = 30;
aParent.addChild(sprite1);
sprite1.addChild(sprite2, -2);
sprite1.addChild(sprite3, 2);
sprite1.runAction(cc.blink(5, 10));
//
// Sprite
//
aParent = new cc.Node();
aParent.x = 2 * winSize.width / 3;
aParent.y = winSize.height / 2;
this.addChild(aParent, 0);
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite1.x = 0;
sprite1.y = 0;
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 20;
sprite2.y = 30;
sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -20;
sprite3.y = 30;
aParent.addChild(sprite1);
sprite1.addChild(sprite2, -2);
sprite1.addChild(sprite3, 2);
sprite1.runAction(cc.blink(5, 10));
//----end31----
},
//
// Automation
//
testDuration:1.7,
pixel1:{"0":0, "1":0, "2":0, "3":255},
pixel2:{"0":255, "1":204, "2":153, "3":255},
visible1:null,
visible2:null,
setupAutomation:function () {
this.scheduleOnce(this.getSpriteVisible, 1.2);
},
getSpriteVisible:function () {
var ret1 = this.readPixels(winSize.width / 3, winSize.height / 2 + 38, 5, 5);
var ret2 = this.readPixels(2 * winSize.width / 3, winSize.height / 2 + 38, 5, 5);
this.visible1 = this.containsPixel(ret1, this.pixel1) ? "true" : "false";
this.visible2 = this.containsPixel(ret2, this.pixel1) ? "true" : "false";
},
getExpectedResult:function () {
var ret = {"visible1":"true", "visible2":"true", "visible3":"false", "visible4":"false"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 3, winSize.height / 2 + 38, 5, 5);
var ret2 = this.readPixels(2 * winSize.width / 3, winSize.height / 2 + 38, 5, 5);
this.visible3 = this.containsPixel(ret1, this.pixel2) ? "true" : "false";
this.visible4 = this.containsPixel(ret2, this.pixel2) ? "true" : "false";
var ret = {"visible1":this.visible1, "visible2":this.visible2, "visible3":this.visible3, "visible4":this.visible4};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteChildrenVisibilityIssue665
//
//------------------------------------------------------------------
var SpriteChildrenVisibilityIssue665 = SpriteTestDemo.extend({
_title:"Sprite & SpriteBatchNode Visibility",
_subtitle:"No sprites should be visible",
ctor:function () {
//----start32----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
//
// SpriteBatchNode
//
// parents
var aParent = new cc.SpriteBatchNode(s_grossini, 50);
aParent.x = winSize.width / 3;
aParent.y = winSize.height / 2;
this.addChild(aParent, 0);
var sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite1.x = 0;
sprite1.y = 0;
var sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 20;
sprite2.y = 30;
var sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -20;
sprite3.y = 30;
// test issue #665
sprite1.visible = false;
aParent.addChild(sprite1);
sprite1.addChild(sprite2, -2);
sprite1.addChild(sprite3, 2);
//
// Sprite
//
aParent = new cc.Node();
aParent.x = 2 * winSize.width / 3;
aParent.y = winSize.height / 2;
this.addChild(aParent, 0);
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_01.png"));
sprite1.x = 0;
sprite1.y = 0;
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 20;
sprite2.y = 30;
sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -20;
sprite3.y = 30;
// test issue #665
sprite1.visible = false;
aParent.addChild(sprite1);
sprite1.addChild(sprite2, -2);
sprite1.addChild(sprite3, 2);
//----end32----
},
//
// Automation
//
testDuration:1,
pixel:{"0":0, "1":0, "2":0, "3":255},
getExpectedResult:function () {
var ret = {"visible1":"false", "visible2":"false"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 3, winSize.height / 2 + 38, 5, 5);
var ret2 = this.readPixels(2 * winSize.width / 3, winSize.height / 2 + 38, 5, 5);
var ret = {"visible1":this.containsPixel(ret1, this.pixel) ? "false" : "true", "visible2":this.containsPixel(ret2, this.pixel) ? "false" : "true"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteChildrenAnchorPoint
//
//------------------------------------------------------------------
var SpriteChildrenAnchorPoint = SpriteTestDemo.extend({
_title:"Sprite: children + anchor",
ctor:function () {
//----start33----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
var aParent = new cc.Node();
this.addChild(aParent, 0);
// anchor (0,0)
var sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_08.png"));
sprite1.x = winSize.width / 4;
sprite1.y = winSize.height / 2;
sprite1.anchorX = 0;
sprite1.anchorY = 0;
var sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 20;
sprite2.y = 30;
var sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -20;
sprite3.y = 30;
var sprite4 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_04.png"));
sprite4.x = 0;
sprite4.y = 0;
sprite4.scale = 0.5;
aParent.addChild(sprite1);
sprite1.addChild(sprite2, -2);
sprite1.addChild(sprite3, -2);
sprite1.addChild(sprite4, 3);
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite1.x;
point.y = sprite1.y;
this.addChild(point, 10);
// anchor (0.5, 0.5)
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_08.png"));
sprite1.x = winSize.width / 2;
sprite1.y = winSize.height / 2;
sprite1.anchorX = 0.5;
sprite1.anchorY = 0.5;
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 20;
sprite2.y = 30;
sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -20;
sprite3.y = 30;
sprite4 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_04.png"));
sprite4.x = 0;
sprite4.y = 0;
sprite4.scale = 0.5;
aParent.addChild(sprite1);
sprite1.addChild(sprite2, -2);
sprite1.addChild(sprite3, -2);
sprite1.addChild(sprite4, 3);
point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite1.x;
point.y = sprite1.y;
this.addChild(point, 10);
// anchor (1,1)
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_08.png"));
sprite1.x = winSize.width / 2 + winSize.width / 4;
sprite1.y = winSize.height / 2;
sprite1.anchorX = 1;
sprite1.anchorY = 1;
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 20;
sprite2.y = 30;
sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -20;
sprite3.y = 30;
sprite4 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_04.png"));
sprite4.x = 0;
sprite4.y = 0;
sprite4.scale = 0.5;
aParent.addChild(sprite1);
sprite1.addChild(sprite2, -2);
sprite1.addChild(sprite3, -2);
sprite1.addChild(sprite4, 3);
point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite1.x;
point.y = sprite1.y;
this.addChild(point, 10);
//----end33----
},
//
// Automation
//
testDuration:1,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(3 * winSize.width / 4 - 87, winSize.height / 2 - 99, 5, 5);
var ret2 = this.readPixels(2 * winSize.width / 4 - 59, winSize.height / 2 - 66, 5, 5);
var ret3 = this.readPixels(winSize.width / 4 - 15, winSize.height / 2 - 6, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no", "pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeChildrenAnchorPoint
//
//------------------------------------------------------------------
var SpriteBatchNodeChildrenAnchorPoint = SpriteTestDemo.extend({
_title:"SpriteBatchNode: children + anchor",
ctor:function () {
//----start34----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
//
// SpriteBatchNode
//
// parents
var aParent = new cc.SpriteBatchNode(s_grossini, 50);
this.addChild(aParent, 0);
// anchor (0,0)
var sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_08.png"));
sprite1.x = winSize.width / 4;
sprite1.y = winSize.height / 2;
sprite1.anchorX = 0;
sprite1.anchorY = 0;
var sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 20;
sprite2.y = 30;
var sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -20;
sprite3.y = 30;
var sprite4 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_04.png"));
sprite4.x = 0;
sprite4.y = 0;
sprite4.scale = 0.5;
aParent.addChild(sprite1);
sprite1.addChild(sprite2, -2);
sprite1.addChild(sprite3, -2);
sprite1.addChild(sprite4, 3);
var point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite1.x;
point.y = sprite1.y;
this.addChild(point, 10);
// anchor (0.5, 0.5)
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_08.png"));
sprite1.x = winSize.width / 2;
sprite1.y = winSize.height / 2;
sprite1.anchorX = 0.5;
sprite1.anchorY = 0.5;
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 20;
sprite2.y = 30;
sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -20;
sprite3.y = 30;
sprite4 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_04.png"));
sprite4.x = 0;
sprite4.y = 0;
sprite4.scale = 0.5;
aParent.addChild(sprite1);
sprite1.addChild(sprite2, -2);
sprite1.addChild(sprite3, -2);
sprite1.addChild(sprite4, 3);
point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite1.x;
point.y = sprite1.y;
this.addChild(point, 10);
// anchor (1,1)
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_08.png"));
sprite1.x = winSize.width / 2 + winSize.width / 4;
sprite1.y = winSize.height / 2;
sprite1.anchorX = 1;
sprite1.anchorY = 1;
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_02.png"));
sprite2.x = 20;
sprite2.y = 30;
sprite3 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_03.png"));
sprite3.x = -20;
sprite3.y = 30;
sprite4 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossini_dance_04.png"));
sprite4.x = 0;
sprite4.y = 0;
sprite4.scale = 0.5;
aParent.addChild(sprite1);
sprite1.addChild(sprite2, -2);
sprite1.addChild(sprite3, -2);
sprite1.addChild(sprite4, 3);
point = new cc.Sprite(s_pathR1);
point.scale = 0.25;
point.x = sprite1.x;
point.y = sprite1.y;
this.addChild(point, 10);
//----end34----
},
//
// Automation
//
testDuration:1,
pixel:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(3 * winSize.width / 4 - 87, winSize.height / 2 - 99, 5, 5);
var ret2 = this.readPixels(2 * winSize.width / 4 - 59, winSize.height / 2 - 66, 5, 5);
var ret3 = this.readPixels(winSize.width / 4 - 15, winSize.height / 2 - 6, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no", "pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeChildrenScale
//
//------------------------------------------------------------------
var SpriteBatchNodeChildrenScale = SpriteTestDemo.extend({
_title:"Sprite/BatchNode + child + scale + rot",
ctor:function () {
//----start35----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossini_familyPlist);
var rot = cc.rotateBy(10, 360);
var seq = rot.repeatForever();
//
// Children + Scale using Sprite
// Test 1
//
var aParent = new cc.Node();
var sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossinis_sister1.png"));
sprite1.x = winSize.width / 4;
sprite1.y = winSize.height / 4;
sprite1.scaleX = 0.5;
sprite1.scaleY = 2.0;
sprite1.runAction(seq);
var sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossinis_sister2.png"));
sprite2.x = 50;
sprite2.y = 0;
this.addChild(aParent);
aParent.addChild(sprite1);
sprite1.addChild(sprite2);
rot = cc.rotateBy(10, 360);
seq = rot.repeatForever();
//
// Children + Scale using SpriteBatchNode
// Test 2
//
aParent = new cc.SpriteBatchNode(s_grossini_family);
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossinis_sister1.png"));
sprite1.x = 3 * winSize.width / 4;
sprite1.y = winSize.height / 4;
sprite1.scaleX = 0.5;
sprite1.scaleY = 2.0;
sprite1.runAction(seq);
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossinis_sister2.png"));
sprite2.x = 50;
sprite2.y = 0;
this.addChild(aParent);
aParent.addChild(sprite1);
sprite1.addChild(sprite2);
rot = cc.rotateBy(10, 360);
seq = rot.repeatForever();
//
// Children + Scale using Sprite
// Test 3
//
aParent = new cc.Node();
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossinis_sister1.png"));
sprite1.x = winSize.width / 4;
sprite1.y = 2 * winSize.height / 3;
sprite1.scaleX = 1.5;
sprite1.scaleY = 0.5;
sprite1.runAction(seq);
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossinis_sister2.png"));
sprite2.x = 50;
sprite2.y = 0;
this.addChild(aParent);
aParent.addChild(sprite1);
sprite1.addChild(sprite2);
rot = cc.rotateBy(10, 360);
seq = rot.repeatForever();
//
// Children + Scale using Sprite
// Test 4
//
aParent = new cc.SpriteBatchNode(s_grossini_family);
sprite1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossinis_sister1.png"));
sprite1.x = 3 * winSize.width / 4;
sprite1.y = 2 * winSize.height / 3;
sprite1.scaleX = 1.5;
sprite1.scaleY = 0.5;
sprite1.runAction(seq);
sprite2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("grossinis_sister2.png"));
sprite2.x = 50;
sprite2.y = 0;
this.addChild(aParent);
aParent.addChild(sprite1);
sprite1.addChild(sprite2);
//----end35----
},
//
// Automation
//
testDuration:2.5,
pixel1:{"0":56, "1":116, "2":142, "3":255},
pixel2:{"0":0, "1":0, "2":0, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes", "pixel4":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 - 31, 2 * winSize.height / 3 + 16, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 - 38, 2 * winSize.height / 3 + 16, 3, 3);
var ret3 = this.readPixels(3 * winSize.width / 4 - 31, 2 * winSize.height / 3 + 16, 5, 5);
var ret4 = this.readPixels(3 * winSize.width / 4 - 38, 2 * winSize.height / 3 + 16, 3, 3);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel2) ? "yes" : "no",
"pixel3":this.containsPixel(ret3, this.pixel1) ? "yes" : "no",
"pixel4":this.containsPixel(ret4, this.pixel2) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteChildrenChildren
//
//------------------------------------------------------------------
var SpriteChildrenChildren = SpriteTestDemo.extend({
_title:"Sprite multiple levels of children",
ctor:function () {
//----start36----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_ghostsPlist);
var rot = cc.rotateBy(10, 360);
var seq = rot.repeatForever();
var rot_back = rot.reverse();
var rot_back_fe = rot_back.repeatForever();
//
// SpriteBatchNode: 3 levels of children
//
var aParent = new cc.Node();
this.addChild(aParent);
// parent
var l1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("father.gif"));
l1.x = winSize.width / 2;
l1.y = winSize.height / 2;
l1.runAction(seq.clone());
aParent.addChild(l1);
var l1W = l1.width, l1H = l1.height;
// child left
var l2a = new cc.Sprite(spriteFrameCache.getSpriteFrame("sister1.gif"));
l2a.x = -50 + l1W / 2;
l2a.y = 0 + l1H / 2;
l2a.runAction(rot_back_fe.clone());
l1.addChild(l2a);
var l2aW = l2a.width, l2aH = l2a.height;
// child right
var l2b = new cc.Sprite(spriteFrameCache.getSpriteFrame("sister2.gif"));
l2b.x = +50 + l1W / 2;
l2b.y = 0 + l1H / 2;
l2b.runAction(rot_back_fe.clone());
l1.addChild(l2b);
var l2bW = l2b.width, l2bH = l2b.height;
// child left bottom
var l3a1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("child1.gif"));
l3a1.scale = 0.45;
l3a1.x = 0 + l2aW / 2;
l3a1.y = -100 + l2aH / 2;
l2a.addChild(l3a1);
// child left top
var l3a2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("child1.gif"));
l3a2.scale = 0.45;
l3a2.x = 0 + l2aW / 2;
l3a2.y = +100 + l2aH / 2;
l2a.addChild(l3a2);
// child right bottom
var l3b1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("child1.gif"));
l3b1.scale = 0.45;
l3b1.setFlippedY(true);
l3b1.x = 0 + l2bW / 2;
l3b1.y = -100 + l2bH / 2;
l2b.addChild(l3b1);
// child right top
var l3b2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("child1.gif"));
l3b2.scale = 0.45;
l3b2.setFlippedY(true);
l3b2.x = 0 + l2bW / 2;
l3b2.y = +100 + l2bH / 2;
l2b.addChild(l3b2);
//----end36----
},
//
// Automation
//
testDuration:4,
pixel:{"0":153, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes", "pixel4":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2 + 42, winSize.height / 2 + 145, 5, 5);
var ret2 = this.readPixels(winSize.width / 2 - 39, winSize.height / 2 + 55, 5, 5);
var ret3 = this.readPixels(winSize.width / 2 - 39, winSize.height / 2 - 146, 5, 5);
var ret4 = this.readPixels(winSize.width / 2 + 42, winSize.height / 2 - 56, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no",
"pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no",
"pixel4":this.containsPixel(ret4, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteBatchNodeChildrenChildren
//
//------------------------------------------------------------------
var SpriteBatchNodeChildrenChildren = SpriteTestDemo.extend({
_title:"SpriteBatchNode multiple levels of children",
ctor:function () {
//----start37----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_ghostsPlist);
var rot = cc.rotateBy(10, 360);
var seq = rot.repeatForever();
var rot_back = rot.reverse();
var rot_back_fe = rot_back.repeatForever();
//
// SpriteBatchNode: 3 levels of children
//
var aParent = new cc.SpriteBatchNode(s_ghosts);
if ("opengl" in cc.sys.capabilities)
aParent.texture.generateMipmap();
this.addChild(aParent);
// parent
var l1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("father.gif"));
l1.x = winSize.width / 2;
l1.y = winSize.height / 2;
l1.runAction(seq.clone());
aParent.addChild(l1);
var l1W = l1.width, l1H = l1.height;
// child left
var l2a = new cc.Sprite(spriteFrameCache.getSpriteFrame("sister1.gif"));
l2a.x = -50 + l1W / 2;
l2a.y = 0 + l1H / 2;
l2a.runAction(rot_back_fe.clone());
l1.addChild(l2a);
var l2aW = l2a.width, l2aH = l2a.height;
// child right
var l2b = new cc.Sprite(spriteFrameCache.getSpriteFrame("sister2.gif"));
l2b.x = 50 + l1W / 2;
l2b.y = 0 + l1H / 2;
l2b.runAction(rot_back_fe.clone());
l1.addChild(l2b);
var l2bW = l2b.width, l2bH = l2b.height;
// child left bottom
var l3a1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("child1.gif"));
l3a1.scale = 0.45;
l3a1.x = 0 + l2aW / 2;
l3a1.y = -100 + l2aH / 2;
l2a.addChild(l3a1);
// child left top
var l3a2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("child1.gif"));
l3a2.scale = 0.45;
l3a2.x = 0 + l2aW / 2;
l3a2.y = +100 + l2aH / 2;
l2a.addChild(l3a2);
// child right bottom
var l3b1 = new cc.Sprite(spriteFrameCache.getSpriteFrame("child1.gif"));
l3b1.scale = 0.45;
l3b1.setFlippedY(true);
l3b1.x = 0 + l2bW / 2;
l3b1.y = -100 + l2bH / 2;
l2b.addChild(l3b1);
// child right top
var l3b2 = new cc.Sprite(spriteFrameCache.getSpriteFrame("child1.gif"));
l3b2.scale = 0.45;
l3b2.setFlippedY(true);
l3b2.x = 0 + l2bW / 2;
l3b2.y = +100 + l2bH / 2;
l2b.addChild(l3b2);
//----end37----
},
//
// Automation
//
testDuration:4,
pixel:{"0":153, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes", "pixel4":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2 + 42, winSize.height / 2 + 145, 5, 5);
var ret2 = this.readPixels(winSize.width / 2 - 39, winSize.height / 2 + 55, 5, 5);
var ret3 = this.readPixels(winSize.width / 2 - 39, winSize.height / 2 - 146, 5, 5);
var ret4 = this.readPixels(winSize.width / 2 + 42, winSize.height / 2 - 56, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel) ? "yes" : "no",
"pixel3":this.containsPixel(ret3, this.pixel) ? "yes" : "no",
"pixel4":this.containsPixel(ret4, this.pixel) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteNilTexture
//
//------------------------------------------------------------------
var SpriteNilTexture = SpriteTestDemo.extend({
_title:"Sprite without texture",
_subtitle:"opacity and color should work",
ctor:function () {
//----start38----ctor
this._super();
// TEST: If no texture is given, then Opacity + Color should work.
var sprite = new cc.Sprite();
sprite.setTextureRect(cc.rect(0, 0, 300, 300));
// sprite.color = cc.color.RED;
sprite.color = cc.color(255, 0, 0);
sprite.opacity = 128;
sprite.x = 3 * winSize.width / 4;
sprite.y = winSize.height / 2;
this.addChild(sprite, 100);
sprite = new cc.Sprite();
sprite.setTextureRect(cc.rect(0, 0, 300, 300));
//sprite.color = cc.color.BLUE;
sprite.color = cc.color(0, 0, 255);
sprite.opacity = 128;
sprite.x = winSize.width / 4;
sprite.y = winSize.height / 2;
this.addChild(sprite, 100);
//----end38----
},
//
// Automation
//
testDuration:1,
pixel1:{"0":0, "1":0, "2":128, "3":255},
pixel2:{"0":128, "1":0, "2":0, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4, winSize.height / 2, 5, 5);
var ret2 = this.readPixels(3 * winSize.width / 4, winSize.height / 2, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel2) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// SpriteSubclass
//
//------------------------------------------------------------------
var MySprite1 = cc.Sprite.extend({
_ivar:0,
ctor: function(spriteFrameName) {
this._super(spriteFrameName);
}
});
var MySprite2 = cc.Sprite.extend({
_ivar:0,
ctor: function(name) {
this._super(name);
}
});
var SpriteSubclass = SpriteTestDemo.extend({
_title:"Sprite subclass",
_subtitle:"Testing initWithTexture:rect method",
ctor:function () {
//----start39----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_ghostsPlist);
var aParent = new cc.SpriteBatchNode(s_ghosts);
// MySprite1
var sprite = new MySprite1("#father.gif");
sprite.x = winSize.width / 4;
sprite.y = winSize.height / 2;
aParent.addChild(sprite);
this.addChild(aParent);
// MySprite2
var sprite2 = new MySprite2(s_pathGrossini);
this.addChild(sprite2);
sprite2.x = winSize.width / 4 * 3;
sprite2.y = winSize.height / 2;
//----end39----
},
//
// Automation
//
testDuration:1,
pixel1:{"0":249, "1":30, "2":20, "3":255},
pixel2:{"0":255, "1":204, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4, winSize.height / 2 - 15, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 * 3, winSize.height / 2 + 44, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1) ? "yes" : "no", "pixel2":this.containsPixel(ret2, this.pixel2) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
//------------------------------------------------------------------
//
// AnimationCache
//
//------------------------------------------------------------------
var AnimationCacheTest = SpriteTestDemo.extend({
_title:"AnimationCache",
_subtitle:"Sprite should be animated",
ctor:function () {
//----start40----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_grossiniPlist);
spriteFrameCache.addSpriteFrames(s_grossini_grayPlist);
spriteFrameCache.addSpriteFrames(s_grossini_bluePlist);
//
// create animation "dance"
//
var animFrames = [];
var frame, animFrame;
var str = "";
for (var i = 1; i < 15; i++) {
str = "grossini_dance_" + (i < 10 ? ("0" + i) : i) + ".png";
frame = spriteFrameCache.getSpriteFrame(str);
animFrame = new cc.AnimationFrame(frame, 1);
animFrames.push(animFrame);
}
var animation = new cc.Animation(animFrames, 0.2);
// Add an animation to the Cache
cc.animationCache.addAnimation(animation, "dance");
//
// create animation "dance gray"
//
animFrames = [];
for (i = 1; i < 15; i++) {
str = "grossini_dance_gray_" + (i < 10 ? ("0" + i) : i) + ".png";
frame = spriteFrameCache.getSpriteFrame(str);
animFrames.push(frame);
}
animation = new cc.Animation(animFrames, 0.2);
// Add an animation to the Cache
cc.animationCache.addAnimation(animation, "dance_gray");
//
// create animation "dance blue"
//
animFrames = [];
for (i = 1; i < 4; i++) {
str = "grossini_blue_0" + i + ".png";
frame = spriteFrameCache.getSpriteFrame(str);
animFrames.push(frame);
}
animation = new cc.Animation(animFrames, 0.2);
// Add an animation to the Cache
cc.animationCache.addAnimation(animation, "dance_blue");
var animCache = cc.animationCache;
var normal = animCache.getAnimation("dance");
normal.setRestoreOriginalFrame(true);
var dance_grey = animCache.getAnimation("dance_gray");
dance_grey.setRestoreOriginalFrame(true);
var dance_blue = animCache.getAnimation("dance_blue");
dance_blue.setRestoreOriginalFrame(true);
var animN = cc.animate(normal);
var animG = cc.animate(dance_grey);
var animB = cc.animate(dance_blue);
var seq = cc.sequence(animN, animG, animB);
frame = spriteFrameCache.getSpriteFrame("grossini_dance_01.png");
var grossini = new cc.Sprite(frame);
grossini.x = winSize.width / 2;
grossini.y = winSize.height / 2;
this.addChild(grossini);
// run the animation
grossini.runAction(seq);
//----end40----
},
//
// Automation
//
testDuration:6.5,
ePixel1:{"0":51, "1":0, "2":51, "3":255},
ePixel2:{"0":15, "1":15, "2":15, "3":255},
ePixel3:{"0":0, "1":38, "2":0, "3":255},
cPixel1:null,
cPixel2:null,
cPixel3:null,
setupAutomation:function () {
//----start40----setupAutomation
var fun1 = function () {
this.cPixel1 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
}
this.scheduleOnce(fun1, 0.4);
var fun2 = function () {
this.cPixel2 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
}
this.scheduleOnce(fun2, 3.2);
var fun3 = function () {
this.cPixel3 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
}
this.scheduleOnce(fun3, 6);
//----end40----
},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret = {"pixel1":this.containsPixel(this.cPixel1, this.ePixel1) ? "yes" : "no", "pixel2":this.containsPixel(this.cPixel2, this.ePixel2) ? "yes" : "no", "pixel3":this.containsPixel(this.cPixel3, this.ePixel3, true, 5) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
var NodeSort = SpriteTestDemo.extend({
_node:null,
_sprite1:null,
_sprite2:null,
_sprite3:null,
_sprite4:null,
_sprite5:null,
_title:"node sort same index",
_subtitle:"tag order in console should be 2,1,3,4,5",
ctor:function () {
//----start49----ctor
this._super();
this._node = new cc.Node();
this.addChild(this._node, 0, 0);
this._sprite1 = new cc.Sprite(s_piece, cc.rect(128, 0, 64, 64));
this._sprite1.x = 100;
this._sprite1.y = 160;
this._node.addChild(this._sprite1, -6, 1);
this._sprite2 = new cc.Sprite(s_piece, cc.rect(128, 0, 64, 64));
this._sprite2.x = 164;
this._sprite2.y = 160;
this._node.addChild(this._sprite2, -6, 2);
this._sprite4 = new cc.Sprite(s_piece, cc.rect(128, 0, 64, 64));
this._sprite4.x = 292;
this._sprite4.y = 160;
this._node.addChild(this._sprite4, -3, 4);
this._sprite3 = new cc.Sprite(s_piece, cc.rect(128, 0, 64, 64));
this._sprite3.x = 228;
this._sprite3.y = 160;
this._node.addChild(this._sprite3, -4, 3);
this._sprite5 = new cc.Sprite(s_piece, cc.rect(128, 0, 64, 64));
this._sprite5.x = 356;
this._sprite5.y = 160;
this._node.addChild(this._sprite5, -3, 5);
this.schedule(this.reorderSprite);
//----end49----
},
reorderSprite:function (dt) {
//----start49----reorderSprite
this.unschedule(this.reorderSprite);
cc.log("Before reorder--");
var i = 0;
var child;
var nodeChildren = this._node.children;
for (i = 0; i < nodeChildren.length; i++) {
child = nodeChildren[i];
cc.log("tag:" + child.tag + " z: " + child.zIndex);
}
//z-4
this._node.reorderChild(this._node.children[0], -6);
this._node.sortAllChildren();
cc.log("After reorder--");
nodeChildren = this._node.children;
for (i = 0; i < nodeChildren.length; i++) {
child = nodeChildren[i];
cc.log("tag:" + child.tag + " z: " +
child.zIndex);
this.testOrders.push(child.tag);
}
//----end49----
},
//
// Automation
//
testDuration:1,
testOrders:[],
getExpectedResult:function () {
return JSON.stringify([2, 1, 3, 4, 5]);
},
getCurrentResult:function () {
return JSON.stringify(this.testOrders);
}
});
var SpriteBatchNodeReorderSameIndex = SpriteTestDemo.extend({
_batchNode:null,
_sprite1:null,
_sprite2:null,
_sprite3:null,
_sprite4:null,
_sprite5:null,
_title:"SpriteBatchNodeReorder same index",
_subtitle:"tag order in console should be 2,3,4,5,1",
ctor:function () {
//----start47----ctor
this._super();
this._batchNode = new cc.SpriteBatchNode(s_piece, 15);
this.addChild(this._batchNode, 1, 0);
this._sprite1 = new cc.Sprite(this._batchNode.texture, cc.rect(128, 0, 64, 64));
this._sprite1.x = 100;
this._sprite1.y = 160;
this._batchNode.addChild(this._sprite1, 3, 1);
this._sprite2 = new cc.Sprite(this._batchNode.texture, cc.rect(128, 0, 64, 64));
this._sprite2.x = 164;
this._sprite2.y = 160;
this._batchNode.addChild(this._sprite2, 4, 2);
this._sprite3 = new cc.Sprite(this._batchNode.texture, cc.rect(128, 0, 64, 64));
this._sprite3.x = 228;
this._sprite3.y = 160;
this._batchNode.addChild(this._sprite3, 4, 3);
this._sprite4 = new cc.Sprite(this._batchNode.texture, cc.rect(128, 0, 64, 64));
this._sprite4.x = 292;
this._sprite4.y = 160;
this._batchNode.addChild(this._sprite4, 5, 4);
this._sprite5 = new cc.Sprite(this._batchNode.texture, cc.rect(128, 0, 64, 64));
this._sprite5.x = 356;
this._sprite5.y = 160;
this._batchNode.addChild(this._sprite5, 6, 5);
this.scheduleOnce(this.reorderSprite, 2);
//----end47----
},
reorderSprite:function (dt) {
//----start47----reorderSprite
this._batchNode.reorderChild(this._sprite4, 4);
this._batchNode.reorderChild(this._sprite5, 4);
this._batchNode.reorderChild(this._sprite1, 4);
this._batchNode.sortAllChildren();
var descendants = this._batchNode.descendants;
for (var i = 0; i < descendants.length; i++) {
var child = descendants[i];
cc.log("tag:" + child.tag);
this.testDescendants.push(child.tag);
}
//----end47----
},
//
// Automation
//
testDuration:2.2,
testDescendants:[],
getExpectedResult:function () {
return JSON.stringify([2, 3, 4, 5, 1]);
},
getCurrentResult:function () {
return JSON.stringify(this.testDescendants);
}
});
var SpriteBatchNodeReorderOneChild = SpriteTestDemo.extend({
_batchNode:null,
_reoderSprite:null,
_title:"SpriteBatchNode reorder 1 child",
ctor:function () {
//----start48----ctor
this._super();
spriteFrameCache.addSpriteFrames(s_ghostsPlist);
//
// SpriteBatchNode: 3 levels of children
//
var aParent = new cc.SpriteBatchNode(s_ghosts);
this._batchNode = aParent;
//[[aParent texture] generateMipmap];
if ("opengl" in cc.sys.capabilities)
aParent.texture.generateMipmap();
this.addChild(aParent);
// parent
var l1 = new cc.Sprite("#father.gif");
l1.x = winSize.width / 2;
l1.y = winSize.height / 2;
aParent.addChild(l1);
var l1W = l1.width, l1H = l1.height;
// child left
var l2a = new cc.Sprite("#sister1.gif");
l2a.x = -10 + l1W / 2;
l2a.y = 0 + l1H / 2;
l1.addChild(l2a, 1);
var l2aW = l2a.width, l2aH = l2a.height;
// child right
var l2b = new cc.Sprite("#sister2.gif");
l2b.x = +50 + l1W / 2;
l2b.y = 0 + l1H / 2;
l1.addChild(l2b, 2);
var l2bW = l2b.width, l2bH = l2b.height;
// child left bottom
var l3a1 = new cc.Sprite("#child1.gif");
l3a1.scale = 0.45;
l3a1.x = 0 + l2aW / 2;
l3a1.y = -50 + l2aH / 2;
l2a.addChild(l3a1, 1);
// child left top
var l3a2 = new cc.Sprite("#child1.gif");
l3a2.scale = 0.45;
l3a2.x = 0 + l2aW / 2;
l3a2.y = +50 + l2aH / 2;
l2a.addChild(l3a2, 2);
this._reoderSprite = l2a;
// child right bottom
var l3b1 = new cc.Sprite("#child1.gif");
l3b1.scale = 0.45;
l3b1.setFlippedY(true);
l3b1.x = 0 + l2bW / 2;
l3b1.y = -50 + l2bH / 2;
l2b.addChild(l3b1);
// child right top
var l3b2 = new cc.Sprite("#child1.gif");
l3b2.scale = 0.45;
l3b2.setFlippedY(true);
l3b2.x = 0 + l2bW / 2;
l3b2.y = 50 + l2bH / 2;
l2b.addChild(l3b2);
this.scheduleOnce(this.reorderSprite, 2.0);
//----end48----
},
reorderSprite:function (dt) {
this._reoderSprite.parent.reorderChild(this._reoderSprite, -1);
this._batchNode.sortAllChildren();
//cc.Sprite* child;
//CCARRAY_FOREACH(batchNode.descendants,child) NSLog(@"tag %i",child.tag);
},
//
// Automation
//
testDuration:2.5,
pixel:{"0":0, "1":102, "2":255, "3":255},
getExpectedResult:function () {
var ret = {"pixel":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2 - 11, winSize.height / 2 + 33, 3, 3);
var ret = {"pixel":this.containsPixel(ret1, this.pixel, false) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
var SpriteBatchNodeSkewNegativeScaleChildren = SpriteTestDemo.extend({
_title:"SpriteBatchNode + children + skew",
_subtitle:"SpriteBatchNode skew + negative scale with children",
ctor:function () {
//----start51----ctor
this._super();
var cache = spriteFrameCache;
cache.addSpriteFrames(s_grossiniPlist);
cache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
var spritebatch = new cc.SpriteBatchNode(s_grossini);
this.addChild(spritebatch);
for (var i = 0; i < 2; i++) {
var sprite = new cc.Sprite("#grossini_dance_01.png");
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
// Skew
var skewX = cc.skewBy(2, 45, 0);
var skewX_back = skewX.reverse();
var skewY = cc.skewBy(2, 0, 45);
var skewY_back = skewY.reverse();
if (i === 1)
sprite.scale = -1.0;
var seq_skew = cc.sequence(skewX, skewX_back, skewY, skewY_back);
sprite.runAction(seq_skew.repeatForever());
var child1 = new cc.Sprite("#grossini_dance_01.png");
child1.x = sprite.width / 2.0;
child1.y = sprite.height / 2.0;
child1.scale = 0.8;
sprite.addChild(child1);
spritebatch.addChild(sprite, i);
}
//----end51----
},
//
// Automation
//
testDuration:6,
pixel1:{"0":51, "1":0, "2":51, "3":255},
pixel2:{"0":0, "1":0, "2":0, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 + 21, winSize.height / 2 + 22, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 + 11, winSize.height / 2 + 14, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1) ? "yes" : "no",
"pixel2":!this.containsPixel(ret2, this.pixel2) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
var SpriteSkewNegativeScaleChildren = SpriteTestDemo.extend({
_title:"Sprite + children + skew",
_subtitle:"Sprite skew + negative scale with children",
ctor:function () {
//----start50----ctor
this._super();
var cache = spriteFrameCache;
cache.addSpriteFrames(s_grossiniPlist);
cache.addSpriteFrames(s_grossini_grayPlist, s_grossini_gray);
var parent = new cc.Node();
this.addChild(parent);
for (var i = 0; i < 2; i++) {
var sprite = new cc.Sprite("#grossini_dance_01.png");
sprite.x = winSize.width / 4 * (i + 1);
sprite.y = winSize.height / 2;
// Skew
var skewX = cc.skewBy(2, 45, 0);
var skewX_back = skewX.reverse();
var skewY = cc.skewBy(2, 0, 45);
var skewY_back = skewY.reverse();
if (i === 1)
sprite.scale = -1.0;
var seq_skew = cc.sequence(skewX, skewX_back, skewY, skewY_back);
sprite.runAction(seq_skew.repeatForever());
var child1 = new cc.Sprite("#grossini_dance_01.png");
child1.x = sprite.width / 2.0;
child1.y = sprite.height / 2.0;
sprite.addChild(child1);
child1.scale = 0.8;
parent.addChild(sprite, i);
}
//----end50----
},
//
// Automation
//
testDuration:6,
pixel1:{"0":51, "1":0, "2":51, "3":255},
pixel2:{"0":0, "1":0, "2":0, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 4 + 21, winSize.height / 2 + 22, 5, 5);
var ret2 = this.readPixels(winSize.width / 4 + 11, winSize.height / 2 + 14, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1, false) ? "yes" : "no",
"pixel2":!this.containsPixel(ret2, this.pixel2, false) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
var DoubleSprite = cc.Sprite.extend({
HD:false,
ctor:function (fileName) {
this._super(fileName);
//var resolutionType = texture.getResolutionType();
//this.HD = ( resolutionType == cc.kCCResolutioniPhoneRetinaDisplay || resolutionType == kCCResolutioniPadRetinaDisplay );
},
setContentSize:function (size) {
var newSize = cc.size(size.width, size.height);
// If Retina Display and Texture is in HD then scale the vertex rect
if (cc.contentScaleFactor() == 2 && !this.HD) {
newSize.width *= 2;
newSize.height *= 2;
}
this._super(newSize);
},
_setWidth:function (value) {
// If Retina Display and Texture is in HD then scale the vertex rect
if (cc.contentScaleFactor() == 2 && !this.HD) {
value *= 2;
}
this._super(value);
},
_setHeight:function (value) {
// If Retina Display and Texture is in HD then scale the vertex rect
if (cc.contentScaleFactor() == 2 && !this.HD) {
value *= 2;
}
this._super(value);
},
setVertexRect:function (rect) {
// If Retina Display and Texture is in HD then scale the vertex rect
if (cc.contentScaleFactor() == 2 && !this.HD) {
rect.width *= 2;
rect.height *= 2;
}
this._super(rect);
}
});
cc.defineGetterSetter(DoubleSprite.prototype, "width", DoubleSprite.prototype._getWidth, DoubleSprite.prototype._setWidth);
cc.defineGetterSetter(DoubleSprite.prototype, "height", DoubleSprite.prototype._getHeight, DoubleSprite.prototype._setHeight);
var SpriteDoubleResolution = SpriteTestDemo.extend({
_title:"Sprite Double resolution",
_subtitle:"Retina Display. SD (left) should be equal to HD (right)",
ctor:function () {
//----start52----ctor
this._super();
//
// LEFT: SD sprite
//
// there is no HD resolution file of grossini_dance_08.
var spriteSD = new DoubleSprite(s_grossiniDance08);
this.addChild(spriteSD);
spriteSD.x = winSize.width / 4;
spriteSD.y = winSize.height / 2;
var child1_left = new DoubleSprite(s_grossiniDance08);
spriteSD.addChild(child1_left);
child1_left.x = -30;
child1_left.y = 0;
var child1_right = new cc.Sprite(s_pathGrossini);
spriteSD.addChild(child1_right);
child1_left.x = spriteSD.height;
child1_left.y = 0;
//
// RIGHT: HD sprite
//
// there is an HD version of grossini.png
var spriteHD = new cc.Sprite(s_pathGrossini);
this.addChild(spriteHD);
spriteHD.x = winSize.width / 4 * 3;
spriteHD.y = winSize.height / 2;
var child2_left = new DoubleSprite(s_grossiniDance08);
spriteHD.addChild(child2_left);
child2_left.x = -30;
child2_left.y = 0;
var child2_right = new cc.Sprite(s_pathGrossini);
spriteHD.addChild(child2_right);
child2_left.x = spriteHD.height;
child2_left.y = 0;
// Actions
var scale = cc.scaleBy(2, 0.5);
var scale_back = scale.reverse();
var seq = cc.sequence(scale, scale_back);
var seq_copy = seq.clone();
spriteSD.runAction(seq);
spriteHD.runAction(seq_copy);
//----end52----
}
});
var AnimationCacheFile = SpriteTestDemo.extend({
_title:"AnimationCache - Load file",
_subtitle:"Sprite should be animated",
ctor:function () {
//----start54----ctor
this._super();
var frameCache = spriteFrameCache;
frameCache.addSpriteFrames(s_grossiniPlist);
frameCache.addSpriteFrames(s_grossini_grayPlist);
frameCache.addSpriteFrames(s_grossini_bluePlist);
// Purge previously loaded animation
if(cc.animationCache._clear)
cc.animationCache._clear();
var animCache = cc.animationCache;
// Add an animation to the Cache
// XXX API-FIX XXX
// renamed from addAnimationsWithFile to addAnimations
animCache.addAnimations(s_animationsPlist);
var normal = animCache.getAnimation("dance_1");
normal.setRestoreOriginalFrame(true);
var dance_grey = animCache.getAnimation("dance_2");
dance_grey.setRestoreOriginalFrame(true);
var dance_blue = animCache.getAnimation("dance_3");
dance_blue.setRestoreOriginalFrame(true);
var animN = cc.animate(normal);
var animG = cc.animate(dance_grey);
var animB = cc.animate(dance_blue);
var seq = cc.sequence(animN, animG, animB);
// create an sprite with frame name
// texture-less sprites are not supported
var grossini = new cc.Sprite("#grossini_dance_01.png");
grossini.x = winSize.width / 2;
grossini.y = winSize.height / 2;
this.addChild(grossini);
// run the animation
grossini.runAction(seq);
//----end54----
},
//
// Automation
//
testDuration:6.5,
ePixel1:{"0":51, "1":0, "2":51, "3":255},
ePixel2:{"0":15, "1":15, "2":15, "3":255},
ePixel3:{"0":0, "1":38, "2":0, "3":255},
cPixel1:null,
cPixel2:null,
cPixel3:null,
setupAutomation:function () {
this.scheduleOnce(this.getPixel1, 0.4);
this.scheduleOnce(this.getPixel2, 3.2);
this.scheduleOnce(this.getPixel3, 6);
},
getPixel1:function () {
this.cPixel1 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
},
getPixel2:function () {
this.cPixel2 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
},
getPixel3:function () {
this.cPixel3 = this.readPixels(winSize.width / 2, winSize.height / 2, 5, 5);
},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret = {"pixel1":this.containsPixel(this.cPixel1, this.ePixel1) ? "yes" : "no", "pixel2":this.containsPixel(this.cPixel2, this.ePixel2) ? "yes" : "no", "pixel3":this.containsPixel(this.cPixel3, this.ePixel3, true, 5) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
var SpriteBatchBug1217 = SpriteTestDemo.extend({
_title:"SpriteBatch - Bug 1217",
_subtitle:"Adding big family to spritebatch. You shall see 3 heads",
ctor:function () {
//----start53----ctor
this._super();
var bn = new cc.SpriteBatchNode(s_grossini_dance_atlas, 15);
var s1 = new cc.Sprite(bn.texture, cc.rect(0, 0, 57, 57));
var s2 = new cc.Sprite(bn.texture, cc.rect(0, 0, 57, 57));
var s3 = new cc.Sprite(bn.texture, cc.rect(0, 0, 57, 57));
s1.color = cc.color(255, 0, 0);
s2.color = cc.color(0, 255, 0);
s3.color = cc.color(0, 0, 255);
s1.x = 20;
s1.y = 200;
s2.x = 100;
s2.y = 0;
s3.x = 100;
s3.y = 0;
bn.x = 0;
bn.y = 0;
//!!!!!
s1.addChild(s2);
s2.addChild(s3);
bn.addChild(s1);
this.addChild(bn);
//----end53----
},
// Automation
testDuration:2.1,
pixel1:{"0":51, "1":0, "2":0, "3":255},
pixel2:{"0":0, "1":0, "2":0, "3":255},
pixel3:{"0":0, "1":0, "2":51, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes", "pixel3":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(20, 174, 3, 3);
var ret2 = this.readPixels(90, 145, 3, 3);
var ret3 = this.readPixels(163, 116, 3, 3);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1, false) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel2, false) ? "yes" : "no",
"pixel3":this.containsPixel(ret3, this.pixel3, false) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
var TextureColorCacheIssue = SpriteTestDemo.extend({
_title:"Texture Color Cache Issue Test",
_subtitle:"You should see two different sprites colored green and blue",
ctor:function () {
//----start55----ctor
this._super();
var spriteFrameCache = cc.spriteFrameCache;
spriteFrameCache.addSpriteFrames(s_tcc_issue_1_plist, s_tcc_issue_1);
spriteFrameCache.addSpriteFrames(s_tcc_issue_2_plist, s_tcc_issue_2);
var grossini = new cc.Sprite('#tcc_grossini_dance_01.png');
grossini.x = winSize.width / 3;
grossini.y = winSize.height / 2;
var sister = new cc.Sprite('#tcc_grossinis_sister1.png');
sister.x = winSize.width / 3 * 2;
sister.y = winSize.height / 2;
this.addChild(grossini);
this.addChild(sister);
grossini.color = cc.color(1, 255, 1);
sister.color = cc.color(1, 1, 255);
//----end55----
},
onExit:function () {
//----start55----onExit
spriteFrameCache.removeSpriteFramesFromFile(s_tcc_issue_1_plist);
spriteFrameCache.removeSpriteFramesFromFile(s_tcc_issue_2_plist);
this._super();
//----end55----
},
// Automation
pixel1:{"0":0, "1":204, "2":0, "3":255},
pixel2:{"0":0, "1":0, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 3, winSize.height / 2 + 43, 5, 5);
var ret2 = this.readPixels(winSize.width / 3 * 2, winSize.height / 2 - 6, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1, true, 3) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel2, true, 3) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
var TextureColorCacheIssue2 = SpriteTestDemo.extend({
_title:"Texture Color Cache Issue Test #2",
_subtitle:"You should see two different sprites magenta and yellow",
ctor:function () {
//----start56----ctor
this._super();
var spriteFrameCache = cc.spriteFrameCache;
spriteFrameCache.addSpriteFrames(s_tcc_issue_1_plist, s_tcc_issue_1);
spriteFrameCache.addSpriteFrames(s_tcc_issue_2_plist, s_tcc_issue_2);
var grossini = new cc.Sprite('#tcc_grossini_dance_01.png');
grossini.x = winSize.width / 3;
grossini.y = winSize.height / 2;
var sister = new cc.Sprite('#tcc_grossinis_sister1.png');
sister.x = winSize.width / 3 * 2;
sister.y = winSize.height / 2;
this.addChild(grossini);
this.addChild(sister);
grossini.color = cc.color(255, 255, 0);
sister.color = cc.color(255, 0, 255);
//----end56----
},
onExit:function () {
//----start56----onExit
spriteFrameCache.removeSpriteFramesFromFile(s_tcc_issue_1_plist);
spriteFrameCache.removeSpriteFramesFromFile(s_tcc_issue_2_plist);
this._super();
//----end56----
},
// Automation
pixel1:{"0":255, "1":204, "2":0, "3":255},
pixel2:{"0":255, "1":0, "2":153, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 3, winSize.height / 2 + 43, 5, 5);
var ret2 = this.readPixels(winSize.width / 3 * 2, winSize.height / 2 - 3, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1, true, 5) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel2, true, 5) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
var TextureRotatedSpriteFrame = SpriteTestDemo.extend({
_title:"Sub Sprite (rotated source)",
_subtitle:"createWithSpriteFrameName(); sub sprite",
ctor:function () {
//----start57----ctor
this._super();
cc.spriteFrameCache.addSpriteFrames(s_s9s_blocks9_plist);
var block = new cc.Sprite('#blocks9r.png');
var x = winSize.width / 2;
var y = 0 + (winSize.height / 2);
block.setTextureRect(cc.rect(32, 32, 32, 32), true, cc.rect(32, 32, 32, 32));
block.x = x;
block.y = y;
this.addChild(block);
//----end57----
},
// Automation
pixel1:{"0":255, "1":204, "2":153, "3":255},
pixel2:{"0":51, "1":0, "2":51, "3":255},
getExpectedResult:function () {
var ret = {"pixel1":"yes", "pixel2":"yes"};
return JSON.stringify(ret);
},
getCurrentResult:function () {
var ret1 = this.readPixels(winSize.width / 2 - 14, winSize.height / 2 - 8, 5, 5);
var ret2 = this.readPixels(winSize.width / 2 + 12, winSize.height / 2, 5, 5);
var ret = {"pixel1":this.containsPixel(ret1, this.pixel1, true, 5) ? "yes" : "no",
"pixel2":this.containsPixel(ret2, this.pixel2, true, 5) ? "yes" : "no"};
return JSON.stringify(ret);
}
});
var SpriteWithRepeatingTexture = SpriteTestDemo.extend({
_title:"Sprite with Repeating texture",
_subtitle:"aTexture.setTexParameters(cc.LINEAR, cc.LINEAR, cc.REPEAT, cc.REPEAT);",
ctor:function () {
//----start58----ctor
this._super();
var block = new cc.Sprite(s_pathBlock);
var x = winSize.width / 2;
var y = (winSize.height / 2);
block.setTextureRect(cc.rect(0,0, 320,240));
block.setPosition(x, y);
block.getTexture().setTexParameters(cc.LINEAR, cc.LINEAR, cc.REPEAT, cc.REPEAT);
this.addChild(block);
//----end58----
}
});
var SpriteBlendFuncTest = SpriteTestDemo.extend({
//webgl only
_title: "", //Sprite BlendFunc test
_subtitle: "",
ctor: function(){
//----start59----ctor
this._super();
var destFactors = [gl.ZERO, gl.ONE, gl.SRC_COLOR, gl.ONE_MINUS_SRC_COLOR, gl.SRC_ALPHA, gl.ONE_MINUS_SRC_ALPHA],
srcFactors = [gl.ZERO, gl.ONE, gl.DST_COLOR, gl.ONE_MINUS_DST_COLOR, gl.DST_ALPHA, gl.ONE_MINUS_DST_ALPHA];
var destTitles = ["ZERO", "ONE", "SRC_COLOR", "ONE_MINUS_SRC_COLOR", "SRC_ALPHA", "ONE_MINUS_SRC_ALPHA"],
srcTitles = ["ZERO", "ONE", "DST_COLOR", "ONE_MINUS_DST_COLOR", "SRC_ALPHA", "ONE_MINUS_SRC_ALPHA"];
var sourceImg = "res/Images/dot.png", destImg = "res/Images/wood.jpg";
var sourceTexture = cc.textureCache.addImage(sourceImg);
sourceTexture.handleLoadedTexture(true);
var sourceSprite = new cc.Sprite(sourceImg);
var destSprite = new cc.Sprite(destImg);
sourceSprite.setScale(0.8);
destSprite.setScale(0.8);
sourceSprite.setPosition(60,400);
destSprite.setPosition(120,400);
this.addChild(sourceSprite);
this.addChild(destSprite);
var i, j, title, fontSize, titleLabel;
for(i = 0; i < destTitles.length; i++){
title = destTitles[i];
fontSize = (title.length > 10) ? 14 : 18;
titleLabel = new cc.LabelTTF(title, "Arial", fontSize);
titleLabel.setAnchorPoint(0, 0.5);
titleLabel.setPosition(0, 355 - 60 * i);
this.addChild(titleLabel);
}
for(i = 0; i < srcTitles.length; i++){
title = srcTitles[i];
fontSize = (title.length > 10) ? 14 : 18;
titleLabel = new cc.LabelTTF(title, "Arial", fontSize);
titleLabel.setAnchorPoint(0, 0.5);
titleLabel.setPosition(220 + i * 60, 390);
titleLabel.setRotation(-20);
this.addChild(titleLabel);
}
//j = 0;
for(i = 0; i < srcFactors.length; i++){
for(j = 0; j < destFactors.length; j++){
sourceSprite = new cc.Sprite(sourceImg);
//sourceSprite.setScale(0.8);
sourceSprite.setPosition( 220 + i * 60, 355 - j * 60);
sourceSprite.setBlendFunc(srcFactors[i], destFactors[j]);
destSprite = new cc.Sprite(destImg);
//destSprite.setScale(0.8);
destSprite.setPosition( 220 + i * 60, 355 - j * 60);
// destSprite.setBlendFunc(srcFactors[j], destFactors[i]);
this.addChild(destSprite,1);
this.addChild(sourceSprite,2);
}
}
//----end59----
}
});
var SpriteTestScene = TestScene.extend({
runThisTest:function (num) {
spriteTestIdx = (num || num == 0) ? (num - 1) : -1;
var layer = nextSpriteTest();
this.addChild(layer);
director.runScene(this);
}
});
//
// Flow control
//
var arrayOfSpriteTest = [
Sprite1,
SpriteBatchNode1,
SpriteFrameTest,
SpriteFrameAliasNameTest,
SpriteAnchorPoint,
SpriteBatchNodeAnchorPoint,
SpriteOffsetAnchorRotation,
SpriteBatchNodeOffsetAnchorRotation,
SpriteOffsetAnchorScale,
SpriteBatchNodeOffsetAnchorScale,
SpriteAnimationSplit,
SpriteColorOpacity,
SpriteBatchNodeColorOpacity,
SpriteZOrder,
SpriteBatchNodeZOrder,
SpriteBatchNodeReorder,
SpriteBatchNodeReorderIssue744,
SpriteBatchNodeReorderIssue766,
SpriteBatchNodeReorderIssue767,
SpriteZVertex,
SpriteBatchNodeZVertex,
Sprite6,
SpriteFlip,
SpriteBatchNodeFlip,
SpriteAliased,
SpriteBatchNodeAliased,
SpriteNewTexture,
SpriteBatchNodeNewTexture,
SpriteHybrid,
SpriteBatchNodeChildren,
SpriteBatchNodeChildrenZ,
SpriteChildrenVisibility,
SpriteChildrenVisibilityIssue665,
SpriteChildrenAnchorPoint,
SpriteBatchNodeChildrenAnchorPoint,
SpriteBatchNodeChildrenScale,
SpriteChildrenChildren,
SpriteBatchNodeChildrenChildren,
SpriteNilTexture,
SpriteSubclass,
AnimationCacheTest,
SpriteOffsetAnchorSkew,
SpriteBatchNodeOffsetAnchorSkew,
SpriteOffsetAnchorSkewScale,
SpriteBatchNodeOffsetAnchorSkewScale,
SpriteOffsetAnchorFlip,
SpriteBatchNodeOffsetAnchorFlip,
SpriteBatchNodeReorderSameIndex,
SpriteBatchNodeReorderOneChild,
NodeSort,
SpriteSkewNegativeScaleChildren,
SpriteBatchNodeSkewNegativeScaleChildren,
SpriteDoubleResolution,
SpriteBatchBug1217,
AnimationCacheFile,
TextureColorCacheIssue,
TextureColorCacheIssue2,
TextureRotatedSpriteFrame,
SpriteWithRepeatingTexture,
SpriteBlendFuncTest
];
var nextSpriteTest = function () {
spriteTestIdx++;
spriteTestIdx = spriteTestIdx % arrayOfSpriteTest.length;
if(window.sideIndexBar){
spriteTestIdx = window.sideIndexBar.changeTest(spriteTestIdx, 36);
}
return new arrayOfSpriteTest[spriteTestIdx ]();
};
var previousSpriteTest = function () {
spriteTestIdx--;
if (spriteTestIdx < 0)
spriteTestIdx += arrayOfSpriteTest.length;
if(window.sideIndexBar){
spriteTestIdx = window.sideIndexBar.changeTest(spriteTestIdx, 36);
}
return new arrayOfSpriteTest[spriteTestIdx ]();
};
var restartSpriteTest = function () {
return new arrayOfSpriteTest[spriteTestIdx ]();
};