Merge pull request #12182 from VisualSJ/v3-jsb

[ci skip] Synchronization studio parser
This commit is contained in:
pandamicro 2015-06-11 17:35:15 +08:00
commit 12de53726d
7 changed files with 61 additions and 34 deletions

View File

@ -36,7 +36,7 @@ ccs._load = (function(){
var json = cc.loader.getRes(file); var json = cc.loader.getRes(file);
if(!json) if(!json)
return cc.log("%s is not exists", file); return cc.log("%s does not exist", file);
var ext = extname(file).toLocaleLowerCase(); var ext = extname(file).toLocaleLowerCase();
if(ext !== "json" && ext !== "exportjson") if(ext !== "json" && ext !== "exportjson")
return cc.log("%s load error, must be json file", file); return cc.log("%s load error, must be json file", file);

View File

@ -51,11 +51,11 @@
if(parser) if(parser)
frame = parser.call(self, timeline, resourcePath); frame = parser.call(self, timeline, resourcePath);
else else
cc.log("parser is not exists : %s", timeline["frameType"]); cc.log("parser does not exist : %s", timeline["frameType"]);
if(frame) if(frame)
action.addTimeline(frame); action.addTimeline(frame);
if(timeline["frameType"] == "ColorFrame"){ if(timeline["frameType"] === "ColorFrame"){
action.addTimeline( action.addTimeline(
self.parsers["AlphaFrame"].call(self, timeline, resourcePath) self.parsers["AlphaFrame"].call(self, timeline, resourcePath)
); );

View File

@ -149,8 +149,16 @@
frame.setAnchorPoint(cc.p(anchorx, anchory)); frame.setAnchorPoint(cc.p(anchorx, anchory));
return frame; return frame;
} }
}, },{
{ name: "AnchorPoint",
handle: function(options){
var frame = new ccs.AnchorPointFrame();
var anchorx = options["X"];
var anchory = options["Y"];
frame.setAnchorPoint(cc.p(anchorx, anchory));
return frame;
}
},{
name: "InnerAction", name: "InnerAction",
handle: function(options){ handle: function(options){
var frame = new ccs.InnerActionFrame(); var frame = new ccs.InnerActionFrame();
@ -186,11 +194,20 @@
{ {
name: "FileData", name: "FileData",
handle: function(options, resourcePath){ handle: function(options, resourcePath){
var frame = new ccs.TextureFrame(); var frame, texture, plist, path, spriteFrame;
var texture = options["TextureFile"]; frame = new ccs.TextureFrame();
texture = options["TextureFile"];
if(texture != null) { if(texture != null) {
var path = texture["Path"]; plist = texture["Plist"];
var spriteFrame = cc.spriteFrameCache.getSpriteFrame(path); path = texture["Path"];
spriteFrame = cc.spriteFrameCache.getSpriteFrame(path);
if(!spriteFrame && plist){
if(cc.loader.getRes(resourcePath + plist)){
cc.spriteFrameCache.addSpriteFrames(resourcePath + plist);
}else{
cc.log("%s need to be preloaded", resourcePath + plist);
}
}
if(spriteFrame == null){ if(spriteFrame == null){
path = resourcePath + path; path = resourcePath + path;
} }
@ -249,11 +266,13 @@
var type = options["Type"]; var type = options["Type"];
frame.setTweenType(type); frame.setTweenType(type);
var points = options["Points"]; var points = options["Points"];
var result = [];
if(points){ if(points){
points = points.map(function(p){ points.forEach(function(p){
return cc.p(p["X"], p["Y"]); result.push(p["X"]);
result.push(p["Y"]);
}); });
frame.setEasingParams(points); frame.setEasingParams(result);
} }
}; };

View File

@ -41,7 +41,7 @@
* @returns {*} * @returns {*}
*/ */
widgetFromJsonFile: function(file){ widgetFromJsonFile: function(file){
var json = cc.loader.getRes(file); var json = cc.loader.getRes(cc.path.join(cc.loader.resPath, file));
if(json) if(json)
this._fileDesignSizes[file] = cc.size(json["designWidth"]||0, json["designHeight"]||0); this._fileDesignSizes[file] = cc.size(json["designWidth"]||0, json["designHeight"]||0);
@ -91,9 +91,9 @@
* @returns {Number} * @returns {Number}
*/ */
getVersionInteger: function(version){ getVersionInteger: function(version){
if(!version || typeof version != "string") return 0; if(!version || typeof version !== "string") return 0;
var arr = version.split("."); var arr = version.split(".");
if (arr.length != 4) if (arr.length !== 4)
return 0; return 0;
var num = 0; var num = 0;
arr.forEach(function(n, i){ arr.forEach(function(n, i){
@ -199,7 +199,7 @@
getNodeByTag: function(tag){ getNodeByTag: function(tag){
if (this._node == null) if (this._node == null)
return null; return null;
if (this._node.getTag() == tag) if (this._node.getTag() === tag)
return this._node; return this._node;
return this._nodeByTag(this._node, tag); return this._nodeByTag(this._node, tag);
}, },
@ -211,7 +211,7 @@
var children = parent.getChildren(); var children = parent.getChildren();
for (var i = 0; i < children.length; i++) { for (var i = 0; i < children.length; i++) {
var child = children[i]; var child = children[i];
if (child && child.getTag() == tag) { if (child && child.getTag() === tag) {
retNode = child; retNode = child;
break; break;
} else { } else {

View File

@ -92,9 +92,9 @@
"CCSprite": function(node, component, resourcePath){ "CCSprite": function(node, component, resourcePath){
var child = new cc.Sprite(); var child = new cc.Sprite();
loadTexture(component["fileData"], resourcePath, function(path, type){ loadTexture(component["fileData"], resourcePath, function(path, type){
if(type == 0) if(type === 0)
child.setTexture(path); child.setTexture(path);
else if(type == 1){ else if(type === 1){
var spriteFrame = cc.spriteFrameCache.getSpriteFrame(path); var spriteFrame = cc.spriteFrameCache.getSpriteFrame(path);
child.setSpriteFrame(spriteFrame); child.setSpriteFrame(spriteFrame);
} }
@ -106,7 +106,7 @@
"CCTMXTiledMap": function(node, component, resourcePath){ "CCTMXTiledMap": function(node, component, resourcePath){
var child = null; var child = null;
loadTexture(component["fileData"], resourcePath, function(path, type){ loadTexture(component["fileData"], resourcePath, function(path, type){
if(type == 0) if(type === 0)
child = new cc.TMXTiledMap(path); child = new cc.TMXTiledMap(path);
}); });
var render = new ccs.ComRender(child, "CCTMXTiledMap"); var render = new ccs.ComRender(child, "CCTMXTiledMap");
@ -116,7 +116,7 @@
"CCParticleSystemQuad": function(node, component, resourcePath){ "CCParticleSystemQuad": function(node, component, resourcePath){
var child = null; var child = null;
loadTexture(component["fileData"], resourcePath, function(path, type){ loadTexture(component["fileData"], resourcePath, function(path, type){
if(type == 0) if(type === 0)
child = new cc.ParticleSystem(path); child = new cc.ParticleSystem(path);
else else
cc.log("unknown resourcetype on CCParticleSystemQuad!"); cc.log("unknown resourcetype on CCParticleSystemQuad!");
@ -129,7 +129,7 @@
"CCArmature": function(node, component, resourcePath){ "CCArmature": function(node, component, resourcePath){
var child = null; var child = null;
loadTexture(component["fileData"], resourcePath, function(path, type){ loadTexture(component["fileData"], resourcePath, function(path, type){
if(type == 0){ if(type === 0){
var jsonDict = cc.loader.getRes(path); var jsonDict = cc.loader.getRes(path);
if (!jsonDict) cc.log("Please load the resource [%s] first!", path); if (!jsonDict) cc.log("Please load the resource [%s] first!", path);
var armature_data = jsonDict["armature_data"]; var armature_data = jsonDict["armature_data"];
@ -153,7 +153,7 @@
"CCComAudio": function(node, component, resourcePath){ "CCComAudio": function(node, component, resourcePath){
var audio = null; var audio = null;
loadTexture(component["fileData"], resourcePath, function(path, type){ loadTexture(component["fileData"], resourcePath, function(path, type){
if(type == 0){ if(type === 0){
audio = new ccs.ComAudio(); audio = new ccs.ComAudio();
audio.preloadEffect(path); audio.preloadEffect(path);
var name = component["name"]; var name = component["name"];
@ -166,9 +166,9 @@
"CCComAttribute": function(node, component, resourcePath){ "CCComAttribute": function(node, component, resourcePath){
var attribute = null; var attribute = null;
loadTexture(component["fileData"], resourcePath, function(path, type){ loadTexture(component["fileData"], resourcePath, function(path, type){
if(type == 0){ if(type === 0){
attribute = new ccs.ComAttribute(); attribute = new ccs.ComAttribute();
if (path != "") if (path !== "")
attribute.parse(path); attribute.parse(path);
node.addComponent(attribute); node.addComponent(attribute);
}else }else
@ -179,7 +179,7 @@
"CCBackgroundAudio": function(node, component, resourcePath){ "CCBackgroundAudio": function(node, component, resourcePath){
var audio = null; var audio = null;
loadTexture(component["fileData"], resourcePath, function(path, type){ loadTexture(component["fileData"], resourcePath, function(path, type){
if(type == 0){ if(type === 0){
audio = new ccs.ComAudio(); audio = new ccs.ComAudio();
audio.preloadBackgroundMusic(path); audio.preloadBackgroundMusic(path);
audio.setFile(path);var bLoop = Boolean(component["loop"] || 0); audio.setFile(path);var bLoop = Boolean(component["loop"] || 0);

View File

@ -121,6 +121,8 @@
node.setCascadeColorEnabled(true); node.setCascadeColorEnabled(true);
node.setCascadeOpacityEnabled(true); node.setCascadeOpacityEnabled(true);
setLayoutComponent(node, json);
}; };
parser.parseChild = function(node, children, resourcePath){ parser.parseChild = function(node, children, resourcePath){
@ -327,6 +329,11 @@
if (color != null) if (color != null)
widget.setColor(getColor(color)); widget.setColor(getColor(color));
setLayoutComponent(widget, json);
};
var setLayoutComponent = function(widget, json){
var layoutComponent = ccui.LayoutComponent.bindLayoutComponent(widget); var layoutComponent = ccui.LayoutComponent.bindLayoutComponent(widget);
if(!layoutComponent) if(!layoutComponent)
return; return;
@ -562,8 +569,11 @@
widget.setUnifySizeEnabled(false); widget.setUnifySizeEnabled(false);
var color = json["CColor"];
json["CColor"] = null;
widget.setTextColor(getColor(color));
this.widgetAttributes(widget, json, widget.isIgnoreContentAdaptWithSize()); this.widgetAttributes(widget, json, widget.isIgnoreContentAdaptWithSize());
json["CColor"] = color;
return widget; return widget;
}; };
@ -1131,13 +1141,10 @@
var volume = json["Volume"] || 0; var volume = json["Volume"] || 0;
cc.audioEngine.setMusicVolume(volume); cc.audioEngine.setMusicVolume(volume);
//var name = json["Name"]; //var name = json["Name"];
var resPath = "";
if(cc.loader.resPath)
resPath = (cc.loader.resPath + "/").replace(/\/\/$/, "/");
loadTexture(json["FileData"], resourcePath, function(path, type){ loadTexture(json["FileData"], resourcePath, function(path, type){
cc.loader.load(path, function(){ cc.loader.load(path, function(){
cc.audioEngine.playMusic(resPath + path, loop); cc.audioEngine.playMusic(path, loop);
}); });
}); });
@ -1235,6 +1242,7 @@
node.getAnimation().play(currentAnimationName, -1, isLoop); node.getAnimation().play(currentAnimationName, -1, isLoop);
}); });
node.setColor(getColor(json["CColor"]));
return node; return node;
}; };

View File

@ -186,7 +186,7 @@
widget.pushBackCustomItem(child); widget.pushBackCustomItem(child);
} else { } else {
if(!(widget instanceof ccui.Layout)) { if(!(widget instanceof ccui.Layout)) {
if(child.getPositionType() == ccui.Widget.POSITION_PERCENT) { if(child.getPositionType() === ccui.Widget.POSITION_PERCENT) {
var position = child.getPositionPercent(); var position = child.getPositionPercent();
var anchor = widget.getAnchorPoint(); var anchor = widget.getAnchorPoint();
child.setPositionPercent(cc.p(position.x + anchor.x, position.y + anchor.y)); child.setPositionPercent(cc.p(position.x + anchor.x, position.y + anchor.y));
@ -203,7 +203,7 @@
var getPath = function(res, type, path, cb){ var getPath = function(res, type, path, cb){
if(path){ if(path){
if(type == 0) if(type === 0)
cb(res + path, type); cb(res + path, type);
else else
cb(path, type); cb(path, type);