From ed49250b9bbe38cd3586c275dab61bf47cb1b596 Mon Sep 17 00:00:00 2001 From: Liam Date: Thu, 27 Aug 2015 18:23:13 +0800 Subject: [PATCH] update for reader 1.update for sprite3d cullface 2.sync js code --- .../cocostudio/CSParse3DBinary_generated.h | 226 +++++++++--------- .../Sprite3DReader/Sprite3DReader.cpp | 17 +- .../script/jsb_opengl_constants.js | 5 + .../studio/parsers/timelineParser-2.x.js | 79 +++--- 4 files changed, 187 insertions(+), 140 deletions(-) diff --git a/cocos/editor-support/cocostudio/CSParse3DBinary_generated.h b/cocos/editor-support/cocostudio/CSParse3DBinary_generated.h index e8ef83081d..70dcda6f98 100644 --- a/cocos/editor-support/cocostudio/CSParse3DBinary_generated.h +++ b/cocos/editor-support/cocostudio/CSParse3DBinary_generated.h @@ -43,6 +43,7 @@ struct EventFrame; struct IntFrame; struct BoolFrame; struct InnerActionFrame; +struct EasingData; struct RotationSkew; struct Position; struct Scale; @@ -51,7 +52,9 @@ struct Color; struct ColorVector; struct FlatSize; struct CapInsets; +struct BlendFunc; struct ResourceData; +struct BlendFrame; } // namespace flatbuffers namespace flatbuffers { @@ -60,6 +63,7 @@ struct Node3DOption; struct Sprite3DOptions; struct Particle3DOptions; struct UserCameraOptions; +struct GameNode3DOption; struct Vector2; struct Vector3; @@ -93,92 +97,6 @@ MANUALLY_ALIGNED_STRUCT(4) Vector3 { }; STRUCT_END(Vector3, 12); -struct GameNode3DOption : private flatbuffers::Table { - const flatbuffers::String *name() const { return GetPointer(4); } - int32_t skyBoxMask() const { return GetField(6, 0); } - uint8_t skyBoxEnabled() const { return GetField(8, 0); } - const ResourceData *leftFileData() const { return GetPointer(10); } - const ResourceData *rightFileData() const { return GetPointer(12); } - const ResourceData *upFileData() const { return GetPointer(14); } - const ResourceData *downFileData() const { return GetPointer(16); } - const ResourceData *forwardFileData() const { return GetPointer(18); } - const ResourceData *backFileData() const { return GetPointer(20); } - const flatbuffers::String *frameEvent() const { return GetPointer(22); } - const flatbuffers::String *customProperty() const { return GetPointer(24); } - bool Verify(flatbuffers::Verifier &verifier) const { - return VerifyTableStart(verifier) && - VerifyField(verifier, 4 /* nodeOptions */) && - verifier.Verify(name()) && - VerifyField(verifier, 6 /* skyBoxMask */) && - VerifyField(verifier, 8 /* skyBoxEnabled */) && - VerifyField(verifier, 10 /* leftFileData */) && - verifier.VerifyTable(leftFileData()) && - VerifyField(verifier, 12 /* rightFileData */) && - verifier.VerifyTable(rightFileData()) && - VerifyField(verifier, 14 /* upFileData */) && - verifier.VerifyTable(upFileData()) && - VerifyField(verifier, 16 /* downFileData */) && - verifier.VerifyTable(downFileData()) && - VerifyField(verifier, 18 /* forwardFileData */) && - verifier.VerifyTable(forwardFileData()) && - VerifyField(verifier, 20 /* backFileData */) && - verifier.VerifyTable(backFileData()) && - VerifyField(verifier, 22 /* frameEvent */) && - verifier.Verify(frameEvent()) && - VerifyField(verifier, 24 /* customProperty */) && - verifier.Verify(customProperty()) && - verifier.EndTable(); - } -}; - -struct GameNode3DOptionBuilder { - flatbuffers::FlatBufferBuilder &fbb_; - flatbuffers::uoffset_t start_; - void add_name(flatbuffers::Offset name) { fbb_.AddOffset(4, name); } - void add_skyBoxMask(int32_t skyBoxMask) { fbb_.AddElement(6, skyBoxMask, 0); } - void add_skyboxEnabled(uint8_t skyBoxEnabled) { fbb_.AddElement(8, skyBoxEnabled, 0); } - void add_leftFileData(flatbuffers::Offset leftFileData) { fbb_.AddOffset(10, leftFileData); } - void add_rightFileData(flatbuffers::Offset rightFileData) { fbb_.AddOffset(12, rightFileData); } - void add_upFileData(flatbuffers::Offset upFileData) { fbb_.AddOffset(14, upFileData); } - void add_downFileData(flatbuffers::Offset downFileData) { fbb_.AddOffset(16, downFileData); } - void add_forwardFileData(flatbuffers::Offset forwardFileData) { fbb_.AddOffset(18, forwardFileData); } - void add_backFileData(flatbuffers::Offset backFileData) { fbb_.AddOffset(20, backFileData); } - void add_frameEvent(flatbuffers::Offset frameEvent) { fbb_.AddOffset(22, frameEvent); } - void add_customProperty(flatbuffers::Offset customProperty) { fbb_.AddOffset(24, customProperty); } - GameNode3DOptionBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); } - flatbuffers::Offset Finish() { - auto o = flatbuffers::Offset(fbb_.EndTable(start_, 11)); - return o; - } -}; - -inline flatbuffers::Offset CreateGameNode3DOption(flatbuffers::FlatBufferBuilder &_fbb, - flatbuffers::Offset name = 0, - int32_t skyBoxMask = 0, - uint8_t skyBoxEnabled = 0, - flatbuffers::Offset leftFileData = 0, - flatbuffers::Offset rightFileData = 0, - flatbuffers::Offset upFileData = 0, - flatbuffers::Offset downFileData = 0, - flatbuffers::Offset forwardFileData = 0, - flatbuffers::Offset backFileData = 0, - flatbuffers::Offset frameEvent = 0, - flatbuffers::Offset customProperty = 0) { - GameNode3DOptionBuilder builder_(_fbb); - builder_.add_customProperty(customProperty); - builder_.add_frameEvent(frameEvent); - builder_.add_backFileData(backFileData); - builder_.add_forwardFileData(forwardFileData); - builder_.add_downFileData(downFileData); - builder_.add_upFileData(upFileData); - builder_.add_rightFileData(rightFileData); - builder_.add_leftFileData(leftFileData); - builder_.add_skyboxEnabled(skyBoxEnabled); - builder_.add_skyBoxMask(skyBoxMask); - builder_.add_name(name); - return builder_.Finish(); -} - struct Node3DOption : private flatbuffers::Table { const flatbuffers::WidgetOptions *nodeOptions() const { return GetPointer(4); } const Vector3 *position3D() const { return GetStruct(6); } @@ -232,6 +150,7 @@ struct Sprite3DOptions : private flatbuffers::Table { const Node3DOption *node3DOption() const { return GetPointer(4); } const flatbuffers::ResourceData *fileData() const { return GetPointer(6); } uint8_t runAction() const { return GetField(8, 0); } + uint8_t isFlipped() const { return GetField(10, 0); } bool Verify(flatbuffers::Verifier &verifier) const { return VerifyTableStart(verifier) && VerifyField(verifier, 4 /* node3DOption */) && @@ -239,6 +158,7 @@ struct Sprite3DOptions : private flatbuffers::Table { VerifyField(verifier, 6 /* fileData */) && verifier.VerifyTable(fileData()) && VerifyField(verifier, 8 /* runAction */) && + VerifyField(verifier, 10 /* isFlipped */) && verifier.EndTable(); } }; @@ -249,10 +169,11 @@ struct Sprite3DOptionsBuilder { void add_node3DOption(flatbuffers::Offset node3DOption) { fbb_.AddOffset(4, node3DOption); } void add_fileData(flatbuffers::Offset fileData) { fbb_.AddOffset(6, fileData); } void add_runAction(uint8_t runAction) { fbb_.AddElement(8, runAction, 0); } + void add_isFlipped(uint8_t isFlipped) { fbb_.AddElement(10, isFlipped, 0); } Sprite3DOptionsBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); } Sprite3DOptionsBuilder &operator=(const Sprite3DOptionsBuilder &); flatbuffers::Offset Finish() { - auto o = flatbuffers::Offset(fbb_.EndTable(start_, 3)); + auto o = flatbuffers::Offset(fbb_.EndTable(start_, 4)); return o; } }; @@ -260,10 +181,12 @@ struct Sprite3DOptionsBuilder { inline flatbuffers::Offset CreateSprite3DOptions(flatbuffers::FlatBufferBuilder &_fbb, flatbuffers::Offset node3DOption = 0, flatbuffers::Offset fileData = 0, - uint8_t runAction = 0) { + uint8_t runAction = 0, + uint8_t isFlipped = 0) { Sprite3DOptionsBuilder builder_(_fbb); builder_.add_fileData(fileData); builder_.add_node3DOption(node3DOption); + builder_.add_isFlipped(isFlipped); builder_.add_runAction(runAction); return builder_.Finish(); } @@ -310,12 +233,12 @@ struct UserCameraOptions : private flatbuffers::Table { float farClip() const { return GetField(10, 1000); } int32_t cameraFlag() const { return GetField(12, 0); } uint8_t skyBoxEnabled() const { return GetField(14, 0); } - const ResourceData *leftFileData() const { return GetPointer(16); } - const ResourceData *rightFileData() const { return GetPointer(18); } - const ResourceData *upFileData() const { return GetPointer(20); } - const ResourceData *downFileData() const { return GetPointer(22); } - const ResourceData *forwardFileData() const { return GetPointer(24); } - const ResourceData *backFileData() const { return GetPointer(26); } + const flatbuffers::ResourceData *leftFileData() const { return GetPointer(16); } + const flatbuffers::ResourceData *rightFileData() const { return GetPointer(18); } + const flatbuffers::ResourceData *upFileData() const { return GetPointer(20); } + const flatbuffers::ResourceData *downFileData() const { return GetPointer(22); } + const flatbuffers::ResourceData *forwardFileData() const { return GetPointer(24); } + const flatbuffers::ResourceData *backFileData() const { return GetPointer(26); } bool Verify(flatbuffers::Verifier &verifier) const { return VerifyTableStart(verifier) && VerifyField(verifier, 4 /* node3DOption */) && @@ -349,13 +272,13 @@ struct UserCameraOptionsBuilder { void add_nearClip(float nearClip) { fbb_.AddElement(8, nearClip, 1); } void add_farClip(float farClip) { fbb_.AddElement(10, farClip, 1000); } void add_cameraFlag(int32_t cameraFlag) { fbb_.AddElement(12, cameraFlag, 0); } - void add_skyboxEnabled(uint8_t skyBoxEnabled) { fbb_.AddElement(14, skyBoxEnabled, 0); } - void add_leftFileData(flatbuffers::Offset leftFileData) { fbb_.AddOffset(16, leftFileData); } - void add_rightFileData(flatbuffers::Offset rightFileData) { fbb_.AddOffset(18, rightFileData); } - void add_upFileData(flatbuffers::Offset upFileData) { fbb_.AddOffset(20, upFileData); } - void add_downFileData(flatbuffers::Offset downFileData) { fbb_.AddOffset(22, downFileData); } - void add_forwardFileData(flatbuffers::Offset forwardFileData) { fbb_.AddOffset(24, forwardFileData); } - void add_backFileData(flatbuffers::Offset backFileData) { fbb_.AddOffset(26, backFileData); } + void add_skyBoxEnabled(uint8_t skyBoxEnabled) { fbb_.AddElement(14, skyBoxEnabled, 0); } + void add_leftFileData(flatbuffers::Offset leftFileData) { fbb_.AddOffset(16, leftFileData); } + void add_rightFileData(flatbuffers::Offset rightFileData) { fbb_.AddOffset(18, rightFileData); } + void add_upFileData(flatbuffers::Offset upFileData) { fbb_.AddOffset(20, upFileData); } + void add_downFileData(flatbuffers::Offset downFileData) { fbb_.AddOffset(22, downFileData); } + void add_forwardFileData(flatbuffers::Offset forwardFileData) { fbb_.AddOffset(24, forwardFileData); } + void add_backFileData(flatbuffers::Offset backFileData) { fbb_.AddOffset(26, backFileData); } UserCameraOptionsBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); } UserCameraOptionsBuilder &operator=(const UserCameraOptionsBuilder &); flatbuffers::Offset Finish() { @@ -371,12 +294,12 @@ inline flatbuffers::Offset CreateUserCameraOptions(flatbuffer float farClip = 1000, int32_t cameraFlag = 0, uint8_t skyBoxEnabled = 0, - flatbuffers::Offset leftFileData = 0, - flatbuffers::Offset rightFileData = 0, - flatbuffers::Offset upFileData = 0, - flatbuffers::Offset downFileData = 0, - flatbuffers::Offset forwardFileData = 0, - flatbuffers::Offset backFileData = 0) { + flatbuffers::Offset leftFileData = 0, + flatbuffers::Offset rightFileData = 0, + flatbuffers::Offset upFileData = 0, + flatbuffers::Offset downFileData = 0, + flatbuffers::Offset forwardFileData = 0, + flatbuffers::Offset backFileData = 0) { UserCameraOptionsBuilder builder_(_fbb); builder_.add_backFileData(backFileData); builder_.add_forwardFileData(forwardFileData); @@ -384,12 +307,99 @@ inline flatbuffers::Offset CreateUserCameraOptions(flatbuffer builder_.add_upFileData(upFileData); builder_.add_rightFileData(rightFileData); builder_.add_leftFileData(leftFileData); - builder_.add_skyboxEnabled(skyBoxEnabled); builder_.add_cameraFlag(cameraFlag); builder_.add_farClip(farClip); builder_.add_nearClip(nearClip); builder_.add_fov(fov); builder_.add_node3DOption(node3DOption); + builder_.add_skyBoxEnabled(skyBoxEnabled); + return builder_.Finish(); +} + +struct GameNode3DOption : private flatbuffers::Table { + const flatbuffers::String *name() const { return GetPointer(4); } + int32_t skyBoxMask() const { return GetField(6, 0); } + uint8_t skyBoxEnabled() const { return GetField(8, 0); } + const flatbuffers::ResourceData *leftFileData() const { return GetPointer(10); } + const flatbuffers::ResourceData *rightFileData() const { return GetPointer(12); } + const flatbuffers::ResourceData *upFileData() const { return GetPointer(14); } + const flatbuffers::ResourceData *downFileData() const { return GetPointer(16); } + const flatbuffers::ResourceData *forwardFileData() const { return GetPointer(18); } + const flatbuffers::ResourceData *backFileData() const { return GetPointer(20); } + const flatbuffers::String *frameEvent() const { return GetPointer(22); } + const flatbuffers::String *customProperty() const { return GetPointer(24); } + bool Verify(flatbuffers::Verifier &verifier) const { + return VerifyTableStart(verifier) && + VerifyField(verifier, 4 /* name */) && + verifier.Verify(name()) && + VerifyField(verifier, 6 /* skyBoxMask */) && + VerifyField(verifier, 8 /* skyBoxEnabled */) && + VerifyField(verifier, 10 /* leftFileData */) && + verifier.VerifyTable(leftFileData()) && + VerifyField(verifier, 12 /* rightFileData */) && + verifier.VerifyTable(rightFileData()) && + VerifyField(verifier, 14 /* upFileData */) && + verifier.VerifyTable(upFileData()) && + VerifyField(verifier, 16 /* downFileData */) && + verifier.VerifyTable(downFileData()) && + VerifyField(verifier, 18 /* forwardFileData */) && + verifier.VerifyTable(forwardFileData()) && + VerifyField(verifier, 20 /* backFileData */) && + verifier.VerifyTable(backFileData()) && + VerifyField(verifier, 22 /* frameEvent */) && + verifier.Verify(frameEvent()) && + VerifyField(verifier, 24 /* customProperty */) && + verifier.Verify(customProperty()) && + verifier.EndTable(); + } +}; + +struct GameNode3DOptionBuilder { + flatbuffers::FlatBufferBuilder &fbb_; + flatbuffers::uoffset_t start_; + void add_name(flatbuffers::Offset name) { fbb_.AddOffset(4, name); } + void add_skyBoxMask(int32_t skyBoxMask) { fbb_.AddElement(6, skyBoxMask, 0); } + void add_skyBoxEnabled(uint8_t skyBoxEnabled) { fbb_.AddElement(8, skyBoxEnabled, 0); } + void add_leftFileData(flatbuffers::Offset leftFileData) { fbb_.AddOffset(10, leftFileData); } + void add_rightFileData(flatbuffers::Offset rightFileData) { fbb_.AddOffset(12, rightFileData); } + void add_upFileData(flatbuffers::Offset upFileData) { fbb_.AddOffset(14, upFileData); } + void add_downFileData(flatbuffers::Offset downFileData) { fbb_.AddOffset(16, downFileData); } + void add_forwardFileData(flatbuffers::Offset forwardFileData) { fbb_.AddOffset(18, forwardFileData); } + void add_backFileData(flatbuffers::Offset backFileData) { fbb_.AddOffset(20, backFileData); } + void add_frameEvent(flatbuffers::Offset frameEvent) { fbb_.AddOffset(22, frameEvent); } + void add_customProperty(flatbuffers::Offset customProperty) { fbb_.AddOffset(24, customProperty); } + GameNode3DOptionBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); } + GameNode3DOptionBuilder &operator=(const GameNode3DOptionBuilder &); + flatbuffers::Offset Finish() { + auto o = flatbuffers::Offset(fbb_.EndTable(start_, 11)); + return o; + } +}; + +inline flatbuffers::Offset CreateGameNode3DOption(flatbuffers::FlatBufferBuilder &_fbb, + flatbuffers::Offset name = 0, + int32_t skyBoxMask = 0, + uint8_t skyBoxEnabled = 0, + flatbuffers::Offset leftFileData = 0, + flatbuffers::Offset rightFileData = 0, + flatbuffers::Offset upFileData = 0, + flatbuffers::Offset downFileData = 0, + flatbuffers::Offset forwardFileData = 0, + flatbuffers::Offset backFileData = 0, + flatbuffers::Offset frameEvent = 0, + flatbuffers::Offset customProperty = 0) { + GameNode3DOptionBuilder builder_(_fbb); + builder_.add_customProperty(customProperty); + builder_.add_frameEvent(frameEvent); + builder_.add_backFileData(backFileData); + builder_.add_forwardFileData(forwardFileData); + builder_.add_downFileData(downFileData); + builder_.add_upFileData(upFileData); + builder_.add_rightFileData(rightFileData); + builder_.add_leftFileData(leftFileData); + builder_.add_skyBoxMask(skyBoxMask); + builder_.add_name(name); + builder_.add_skyBoxEnabled(skyBoxEnabled); return builder_.Finish(); } diff --git a/cocos/editor-support/cocostudio/WidgetReader/Sprite3DReader/Sprite3DReader.cpp b/cocos/editor-support/cocostudio/WidgetReader/Sprite3DReader/Sprite3DReader.cpp index 48ea48db4c..b9a7e588e8 100644 --- a/cocos/editor-support/cocostudio/WidgetReader/Sprite3DReader/Sprite3DReader.cpp +++ b/cocos/editor-support/cocostudio/WidgetReader/Sprite3DReader/Sprite3DReader.cpp @@ -109,6 +109,7 @@ namespace cocostudio bool runAction = false; std::string path; int resourceType = 0; + bool isFlipped = false; std::string attriname; const tinyxml2::XMLAttribute* attribute = objectData->FirstAttribute(); @@ -120,7 +121,10 @@ namespace cocostudio if(attriname == "RunAction3D") { runAction = value == "True" ? true : false; - break; + } + else if (attriname == "IsFlipped") + { + isFlipped = value == "True" ? true : false; } attribute = attribute->Next(); @@ -170,7 +174,8 @@ namespace cocostudio builder->CreateString(path), builder->CreateString(""), resourceType), - runAction + runAction, + isFlipped ); return *(Offset*)(&options); @@ -184,6 +189,7 @@ namespace cocostudio auto options = (Sprite3DOptions*)sprite3DOptions; bool runAction = options->runAction() != 0; + bool isFlipped = options->isFlipped() != 0; auto fileData = options->fileData(); std::string path = fileData->path()->c_str(); @@ -213,6 +219,11 @@ namespace cocostudio { sprite3D->setColor(Color3B(red, green, blue)); } + if (isFlipped) + { + sprite3D->setCullFaceEnabled(true); + sprite3D->setCullFace(GL_FRONT); + } auto node3DReader = Node3DReader::getInstance(); node3DReader->setPropsWithFlatBuffers(sprite3D, (Table*)(options->node3DOption())); @@ -230,7 +241,7 @@ namespace cocostudio { ret->initWithFile(path); } - + setPropsWithFlatBuffers(ret, sprite3DOptions); return ret; diff --git a/cocos/scripting/js-bindings/script/jsb_opengl_constants.js b/cocos/scripting/js-bindings/script/jsb_opengl_constants.js index d9bed9393c..da648e6e1a 100644 --- a/cocos/scripting/js-bindings/script/jsb_opengl_constants.js +++ b/cocos/scripting/js-bindings/script/jsb_opengl_constants.js @@ -826,6 +826,11 @@ gl.WRITEONLY_RENDERING_QCOM = 0x8823; gl.WRITE_ONLY_OES = 0x88b9; gl.Z400_BINARY_AMD = 0x8740; gl.ZERO = 0x0; +gl.FRONT = 0x0404; +gl.BACK = 0x0405; +gl.LEFT = 0x0406; +gl.RIGHT = 0x0407; +gl.FRONT_AND_BACK = 0x0408; //------------Shader Name--------------- /** diff --git a/cocos/scripting/js-bindings/script/studio/parsers/timelineParser-2.x.js b/cocos/scripting/js-bindings/script/studio/parsers/timelineParser-2.x.js index 1ecc5a070b..5699352c79 100644 --- a/cocos/scripting/js-bindings/script/studio/parsers/timelineParser-2.x.js +++ b/cocos/scripting/js-bindings/script/studio/parsers/timelineParser-2.x.js @@ -160,6 +160,7 @@ } }; + var skyBoxBrushInstance = null; var getSkyboxRes = function(json, key) { if(json.hasOwnProperty(key) && json[key].hasOwnProperty("Path")) { return json[key]["Path"]; @@ -172,7 +173,7 @@ * @param json * @returns {cc.Node} */ - parser.initSingleNode = function(json){ + parser.initSingleNode = function(json, resourcePath){ var node = new cc.Node(); this.generalAttributes(node, json); @@ -180,23 +181,25 @@ if(color != null) node.setColor(getColor(color)); - if(json.hasOwnProperty("SkyBoxEnabled") && true == json["SkyBoxEnabled"]) + if(json.hasOwnProperty("SkyBoxEnabled") && true == json["SkyBoxEnabled"]&& + json.hasOwnProperty("SkyBoxValid") && true == json["SkyBoxValid"]) { - var leftFileData = getSkyboxRes(json, "LeftImage"); - var rightFileData = getSkyboxRes(json, "RightImage"); - var upFileData = getSkyboxRes(json, "UpImage"); - var downFileData = getSkyboxRes(json, "DownImage"); - var forwardFileData = getSkyboxRes(json, "ForwardImage"); - var backFileData = getSkyboxRes(json, "BackImage"); - var cameraFlag = json["SkyBoxMask"]; - if(undefined === cameraFlag || isNaN(cameraFlag)) { - cameraFlag = 1024; + var leftFileData = resourcePath + getSkyboxRes(json, "LeftImage"); + var rightFileData = resourcePath + getSkyboxRes(json, "RightImage"); + var upFileData = resourcePath + getSkyboxRes(json, "UpImage"); + var downFileData = resourcePath + getSkyboxRes(json, "DownImage"); + var forwardFileData = resourcePath + getSkyboxRes(json, "ForwardImage"); + var backFileData = resourcePath + getSkyboxRes(json, "BackImage"); + var fileUtil = jsb.fileUtils; + if(fileUtil.isFileExist(leftFileData)&& + fileUtil.isFileExist(rightFileData)&& + fileUtil.isFileExist(upFileData)&& + fileUtil.isFileExist(downFileData)&& + fileUtil.isFileExist(forwardFileData)&& + fileUtil.isFileExist(backFileData)) + { + skyBoxBrushInstance = cc.CameraBackgroundSkyBoxBrush.create(leftFileData,rightFileData,upFileData,downFileData,forwardFileData,backFileData); } - - var skyBox = new jsb.Skybox(); - skyBox.init(leftFileData,rightFileData,upFileData,downFileData,forwardFileData,backFileData); - skyBox.setCameraMask(cameraFlag, false); - node.addChild(skyBox); } return node; @@ -1439,7 +1442,7 @@ * @param json * @returns {*} */ - parser.initCamera = function(json){ + parser.initCamera = function(json,resourcePath){ var s = cc.winSize; var fov = json["Fov"] ? json["Fov"] : 60; @@ -1500,21 +1503,34 @@ node.setCameraFlag(cameraFlag); } - if(json.hasOwnProperty("SkyBoxEnabled") && true == json["SkyBoxEnabled"]) + if(json.hasOwnProperty("SkyBoxEnabled") && true == json["SkyBoxEnabled"] && + json.hasOwnProperty("SkyBoxValid") && true == json["SkyBoxValid"]) { - var leftFileData = getSkyboxRes(json, "LeftImage"); - var rightFileData = getSkyboxRes(json, "RightImage"); - var upFileData = getSkyboxRes(json, "UpImage"); - var downFileData = getSkyboxRes(json, "DownImage"); - var forwardFileData = getSkyboxRes(json, "ForwardImage"); - var backFileData = getSkyboxRes(json, "BackImage"); + var leftFileData = resourcePath + getSkyboxRes(json, "LeftImage"); + var rightFileData = resourcePath + getSkyboxRes(json, "RightImage"); + var upFileData = resourcePath + getSkyboxRes(json, "UpImage"); + var downFileData = resourcePath + getSkyboxRes(json, "DownImage"); + var forwardFileData = resourcePath + getSkyboxRes(json, "ForwardImage"); + var backFileData = resourcePath + getSkyboxRes(json, "BackImage"); - var skyBox = new jsb.Skybox(); - skyBox.init(leftFileData,rightFileData,upFileData,downFileData,forwardFileData,backFileData); - skyBox.setCameraMask(cameraFlag); - node.addChild(skyBox); + var fileUtil = jsb.fileUtils; + if(fileUtil.isFileExist(leftFileData)&& + fileUtil.isFileExist(rightFileData)&& + fileUtil.isFileExist(upFileData)&& + fileUtil.isFileExist(downFileData)&& + fileUtil.isFileExist(forwardFileData)&& + fileUtil.isFileExist(backFileData)) + { + var innerBrush = cc.CameraBackgroundSkyBoxBrush.create(leftFileData,rightFileData,upFileData,downFileData,forwardFileData,backFileData); + node.setBackgroundBrush(innerBrush); + } + else + node.setBackgroundBrush(skyBoxBrushInstance); } - + else if(skyBoxBrushInstance != null) + { + node.setBackgroundBrush(skyBoxBrushInstance); + } return node; }; @@ -1546,6 +1562,11 @@ node.setColor(col); } + if(json.hasOwnProperty("IsFlipped") && true == json["IsFlipped"]) { + node.setCullFaceEnabled(true); + node.setCullFace(gl.FRONT); + } + var autoAction = getParam(json["RunAction3D"], false); if(autoAction && resFile){ var animation = jsb.Animation3D.create(resFile, "");