mirror of https://github.com/axmolengine/axmol.git
commit
3be083680a
3
AUTHORS
3
AUTHORS
|
@ -1157,7 +1157,10 @@ Developers:
|
||||||
perminovVS
|
perminovVS
|
||||||
Optimize Vec3 and Vec2
|
Optimize Vec3 and Vec2
|
||||||
Added `UserDefault::setDelegate()`
|
Added `UserDefault::setDelegate()`
|
||||||
|
FileUtils: Added FileUtils::getSuitableFOpen() for convert utf8 to locale, for specific platform
|
||||||
platform: Correct all usage of unicode version winapi in FileUtils for win32
|
platform: Correct all usage of unicode version winapi in FileUtils for win32
|
||||||
|
FileUtils: Added FileUtils::getFileExtension for getting file's extension name
|
||||||
|
utils: Made utils::captureScreen saving file in another thread to improve the performance
|
||||||
|
|
||||||
qiutaoleo
|
qiutaoleo
|
||||||
Added a feature to check case characters for filename on windows
|
Added a feature to check case characters for filename on windows
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
cocos2d-x-3.8 rc0 ??
|
cocos2d-x-3.8 rc0 August.26 2015
|
||||||
cocos2d-x-3.8 beta0 August.14 2015
|
cocos2d-x-3.8 beta0 August.14 2015
|
||||||
|
|
||||||
[HIGHLIGHT] 3D: Added 3d physics collider
|
[HIGHLIGHT] 3D: Added 3d physics collider
|
||||||
|
|
|
@ -308,6 +308,9 @@ void CameraBackgroundSkyBoxBrush::drawBackground(Camera* camera)
|
||||||
glEnable(GL_DEPTH_TEST);
|
glEnable(GL_DEPTH_TEST);
|
||||||
RenderState::StateBlock::_defaultState->setDepthTest(true);
|
RenderState::StateBlock::_defaultState->setDepthTest(true);
|
||||||
|
|
||||||
|
glDepthMask(GL_TRUE);
|
||||||
|
RenderState::StateBlock::_defaultState->setDepthWrite(true);
|
||||||
|
|
||||||
glDepthFunc(GL_ALWAYS);
|
glDepthFunc(GL_ALWAYS);
|
||||||
RenderState::StateBlock::_defaultState->setDepthFunction(RenderState::DEPTH_ALWAYS);
|
RenderState::StateBlock::_defaultState->setDepthFunction(RenderState::DEPTH_ALWAYS);
|
||||||
|
|
||||||
|
|
|
@ -359,6 +359,7 @@ void Mesh::draw(Renderer* renderer, float globalZOrder, const Mat4& transform, u
|
||||||
_meshCommand.setSkipBatching(isTransparent);
|
_meshCommand.setSkipBatching(isTransparent);
|
||||||
_meshCommand.setTransparent(isTransparent);
|
_meshCommand.setTransparent(isTransparent);
|
||||||
_meshCommand.set3D(!_force2DQueue);
|
_meshCommand.set3D(!_force2DQueue);
|
||||||
|
_material->getStateBlock()->setBlend(_force2DQueue || isTransparent);
|
||||||
|
|
||||||
// set default uniforms for Mesh
|
// set default uniforms for Mesh
|
||||||
// 'u_color' and others
|
// 'u_color' and others
|
||||||
|
|
|
@ -130,19 +130,15 @@ void Timer::update(float dt)
|
||||||
trigger(interval);
|
trigger(interval);
|
||||||
_elapsed -= interval;
|
_elapsed -= interval;
|
||||||
_timesExecuted += 1;
|
_timesExecuted += 1;
|
||||||
if (_elapsed <= 0.f)
|
|
||||||
|
if (!_runForever && _timesExecuted > _repeat)
|
||||||
{
|
{
|
||||||
|
cancel();
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
|
|
||||||
if (_runForever)
|
if (_elapsed <= 0.f)
|
||||||
{
|
{
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (_timesExecuted > _repeat)
|
|
||||||
{ //unschedule timer
|
|
||||||
cancel();
|
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -31,7 +31,7 @@ NS_CC_BEGIN
|
||||||
|
|
||||||
CC_DLL const char* cocos2dVersion()
|
CC_DLL const char* cocos2dVersion()
|
||||||
{
|
{
|
||||||
return "cocos2d-x-3.8-github";
|
return "cocos2d-x-3.8";
|
||||||
}
|
}
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
|
@ -588,6 +588,12 @@ bool BoneNode::isPointOnRack(const cocos2d::Vec2& bonePoint)
|
||||||
|
|
||||||
void BoneNode::batchBoneDrawToSkeleton(BoneNode* bone) const
|
void BoneNode::batchBoneDrawToSkeleton(BoneNode* bone) const
|
||||||
{
|
{
|
||||||
|
bool visibleByCamera = bone->isVisitableByVisitingCamera();
|
||||||
|
if (!visibleByCamera)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
cocos2d::Vec3 vpos[4];
|
cocos2d::Vec3 vpos[4];
|
||||||
for (int i = 0; i < 4; i++)
|
for (int i = 0; i < 4; i++)
|
||||||
{
|
{
|
||||||
|
|
|
@ -43,6 +43,7 @@ struct EventFrame;
|
||||||
struct IntFrame;
|
struct IntFrame;
|
||||||
struct BoolFrame;
|
struct BoolFrame;
|
||||||
struct InnerActionFrame;
|
struct InnerActionFrame;
|
||||||
|
struct EasingData;
|
||||||
struct RotationSkew;
|
struct RotationSkew;
|
||||||
struct Position;
|
struct Position;
|
||||||
struct Scale;
|
struct Scale;
|
||||||
|
@ -51,7 +52,9 @@ struct Color;
|
||||||
struct ColorVector;
|
struct ColorVector;
|
||||||
struct FlatSize;
|
struct FlatSize;
|
||||||
struct CapInsets;
|
struct CapInsets;
|
||||||
|
struct BlendFunc;
|
||||||
struct ResourceData;
|
struct ResourceData;
|
||||||
|
struct BlendFrame;
|
||||||
} // namespace flatbuffers
|
} // namespace flatbuffers
|
||||||
|
|
||||||
namespace flatbuffers {
|
namespace flatbuffers {
|
||||||
|
@ -60,6 +63,7 @@ struct Node3DOption;
|
||||||
struct Sprite3DOptions;
|
struct Sprite3DOptions;
|
||||||
struct Particle3DOptions;
|
struct Particle3DOptions;
|
||||||
struct UserCameraOptions;
|
struct UserCameraOptions;
|
||||||
|
struct GameNode3DOption;
|
||||||
struct Vector2;
|
struct Vector2;
|
||||||
struct Vector3;
|
struct Vector3;
|
||||||
|
|
||||||
|
@ -93,92 +97,6 @@ MANUALLY_ALIGNED_STRUCT(4) Vector3 {
|
||||||
};
|
};
|
||||||
STRUCT_END(Vector3, 12);
|
STRUCT_END(Vector3, 12);
|
||||||
|
|
||||||
struct GameNode3DOption : private flatbuffers::Table {
|
|
||||||
const flatbuffers::String *name() const { return GetPointer<const flatbuffers::String *>(4); }
|
|
||||||
int32_t skyBoxMask() const { return GetField<int32_t>(6, 0); }
|
|
||||||
uint8_t skyBoxEnabled() const { return GetField<uint8_t>(8, 0); }
|
|
||||||
const ResourceData *leftFileData() const { return GetPointer<const ResourceData *>(10); }
|
|
||||||
const ResourceData *rightFileData() const { return GetPointer<const ResourceData *>(12); }
|
|
||||||
const ResourceData *upFileData() const { return GetPointer<const ResourceData *>(14); }
|
|
||||||
const ResourceData *downFileData() const { return GetPointer<const ResourceData *>(16); }
|
|
||||||
const ResourceData *forwardFileData() const { return GetPointer<const ResourceData *>(18); }
|
|
||||||
const ResourceData *backFileData() const { return GetPointer<const ResourceData *>(20); }
|
|
||||||
const flatbuffers::String *frameEvent() const { return GetPointer<const flatbuffers::String *>(22); }
|
|
||||||
const flatbuffers::String *customProperty() const { return GetPointer<const flatbuffers::String *>(24); }
|
|
||||||
bool Verify(flatbuffers::Verifier &verifier) const {
|
|
||||||
return VerifyTableStart(verifier) &&
|
|
||||||
VerifyField<flatbuffers::uoffset_t>(verifier, 4 /* nodeOptions */) &&
|
|
||||||
verifier.Verify(name()) &&
|
|
||||||
VerifyField<int32_t>(verifier, 6 /* skyBoxMask */) &&
|
|
||||||
VerifyField<uint8_t>(verifier, 8 /* skyBoxEnabled */) &&
|
|
||||||
VerifyField<flatbuffers::uoffset_t>(verifier, 10 /* leftFileData */) &&
|
|
||||||
verifier.VerifyTable(leftFileData()) &&
|
|
||||||
VerifyField<flatbuffers::uoffset_t>(verifier, 12 /* rightFileData */) &&
|
|
||||||
verifier.VerifyTable(rightFileData()) &&
|
|
||||||
VerifyField<flatbuffers::uoffset_t>(verifier, 14 /* upFileData */) &&
|
|
||||||
verifier.VerifyTable(upFileData()) &&
|
|
||||||
VerifyField<flatbuffers::uoffset_t>(verifier, 16 /* downFileData */) &&
|
|
||||||
verifier.VerifyTable(downFileData()) &&
|
|
||||||
VerifyField<flatbuffers::uoffset_t>(verifier, 18 /* forwardFileData */) &&
|
|
||||||
verifier.VerifyTable(forwardFileData()) &&
|
|
||||||
VerifyField<flatbuffers::uoffset_t>(verifier, 20 /* backFileData */) &&
|
|
||||||
verifier.VerifyTable(backFileData()) &&
|
|
||||||
VerifyField<flatbuffers::uoffset_t>(verifier, 22 /* frameEvent */) &&
|
|
||||||
verifier.Verify(frameEvent()) &&
|
|
||||||
VerifyField<flatbuffers::uoffset_t>(verifier, 24 /* customProperty */) &&
|
|
||||||
verifier.Verify(customProperty()) &&
|
|
||||||
verifier.EndTable();
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
struct GameNode3DOptionBuilder {
|
|
||||||
flatbuffers::FlatBufferBuilder &fbb_;
|
|
||||||
flatbuffers::uoffset_t start_;
|
|
||||||
void add_name(flatbuffers::Offset<flatbuffers::String> name) { fbb_.AddOffset(4, name); }
|
|
||||||
void add_skyBoxMask(int32_t skyBoxMask) { fbb_.AddElement<int32_t>(6, skyBoxMask, 0); }
|
|
||||||
void add_skyboxEnabled(uint8_t skyBoxEnabled) { fbb_.AddElement<uint8_t>(8, skyBoxEnabled, 0); }
|
|
||||||
void add_leftFileData(flatbuffers::Offset<ResourceData> leftFileData) { fbb_.AddOffset(10, leftFileData); }
|
|
||||||
void add_rightFileData(flatbuffers::Offset<ResourceData> rightFileData) { fbb_.AddOffset(12, rightFileData); }
|
|
||||||
void add_upFileData(flatbuffers::Offset<ResourceData> upFileData) { fbb_.AddOffset(14, upFileData); }
|
|
||||||
void add_downFileData(flatbuffers::Offset<ResourceData> downFileData) { fbb_.AddOffset(16, downFileData); }
|
|
||||||
void add_forwardFileData(flatbuffers::Offset<ResourceData> forwardFileData) { fbb_.AddOffset(18, forwardFileData); }
|
|
||||||
void add_backFileData(flatbuffers::Offset<ResourceData> backFileData) { fbb_.AddOffset(20, backFileData); }
|
|
||||||
void add_frameEvent(flatbuffers::Offset<flatbuffers::String> frameEvent) { fbb_.AddOffset(22, frameEvent); }
|
|
||||||
void add_customProperty(flatbuffers::Offset<flatbuffers::String> customProperty) { fbb_.AddOffset(24, customProperty); }
|
|
||||||
GameNode3DOptionBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); }
|
|
||||||
flatbuffers::Offset<GameNode3DOption> Finish() {
|
|
||||||
auto o = flatbuffers::Offset<GameNode3DOption>(fbb_.EndTable(start_, 11));
|
|
||||||
return o;
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
inline flatbuffers::Offset<GameNode3DOption> CreateGameNode3DOption(flatbuffers::FlatBufferBuilder &_fbb,
|
|
||||||
flatbuffers::Offset<flatbuffers::String> name = 0,
|
|
||||||
int32_t skyBoxMask = 0,
|
|
||||||
uint8_t skyBoxEnabled = 0,
|
|
||||||
flatbuffers::Offset<ResourceData> leftFileData = 0,
|
|
||||||
flatbuffers::Offset<ResourceData> rightFileData = 0,
|
|
||||||
flatbuffers::Offset<ResourceData> upFileData = 0,
|
|
||||||
flatbuffers::Offset<ResourceData> downFileData = 0,
|
|
||||||
flatbuffers::Offset<ResourceData> forwardFileData = 0,
|
|
||||||
flatbuffers::Offset<ResourceData> backFileData = 0,
|
|
||||||
flatbuffers::Offset<flatbuffers::String> frameEvent = 0,
|
|
||||||
flatbuffers::Offset<flatbuffers::String> 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 {
|
struct Node3DOption : private flatbuffers::Table {
|
||||||
const flatbuffers::WidgetOptions *nodeOptions() const { return GetPointer<const flatbuffers::WidgetOptions *>(4); }
|
const flatbuffers::WidgetOptions *nodeOptions() const { return GetPointer<const flatbuffers::WidgetOptions *>(4); }
|
||||||
const Vector3 *position3D() const { return GetStruct<const Vector3 *>(6); }
|
const Vector3 *position3D() const { return GetStruct<const Vector3 *>(6); }
|
||||||
|
@ -232,6 +150,7 @@ struct Sprite3DOptions : private flatbuffers::Table {
|
||||||
const Node3DOption *node3DOption() const { return GetPointer<const Node3DOption *>(4); }
|
const Node3DOption *node3DOption() const { return GetPointer<const Node3DOption *>(4); }
|
||||||
const flatbuffers::ResourceData *fileData() const { return GetPointer<const flatbuffers::ResourceData *>(6); }
|
const flatbuffers::ResourceData *fileData() const { return GetPointer<const flatbuffers::ResourceData *>(6); }
|
||||||
uint8_t runAction() const { return GetField<uint8_t>(8, 0); }
|
uint8_t runAction() const { return GetField<uint8_t>(8, 0); }
|
||||||
|
uint8_t isFlipped() const { return GetField<uint8_t>(10, 0); }
|
||||||
bool Verify(flatbuffers::Verifier &verifier) const {
|
bool Verify(flatbuffers::Verifier &verifier) const {
|
||||||
return VerifyTableStart(verifier) &&
|
return VerifyTableStart(verifier) &&
|
||||||
VerifyField<flatbuffers::uoffset_t>(verifier, 4 /* node3DOption */) &&
|
VerifyField<flatbuffers::uoffset_t>(verifier, 4 /* node3DOption */) &&
|
||||||
|
@ -239,6 +158,7 @@ struct Sprite3DOptions : private flatbuffers::Table {
|
||||||
VerifyField<flatbuffers::uoffset_t>(verifier, 6 /* fileData */) &&
|
VerifyField<flatbuffers::uoffset_t>(verifier, 6 /* fileData */) &&
|
||||||
verifier.VerifyTable(fileData()) &&
|
verifier.VerifyTable(fileData()) &&
|
||||||
VerifyField<uint8_t>(verifier, 8 /* runAction */) &&
|
VerifyField<uint8_t>(verifier, 8 /* runAction */) &&
|
||||||
|
VerifyField<uint8_t>(verifier, 10 /* isFlipped */) &&
|
||||||
verifier.EndTable();
|
verifier.EndTable();
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -249,10 +169,11 @@ struct Sprite3DOptionsBuilder {
|
||||||
void add_node3DOption(flatbuffers::Offset<Node3DOption> node3DOption) { fbb_.AddOffset(4, node3DOption); }
|
void add_node3DOption(flatbuffers::Offset<Node3DOption> node3DOption) { fbb_.AddOffset(4, node3DOption); }
|
||||||
void add_fileData(flatbuffers::Offset<flatbuffers::ResourceData> fileData) { fbb_.AddOffset(6, fileData); }
|
void add_fileData(flatbuffers::Offset<flatbuffers::ResourceData> fileData) { fbb_.AddOffset(6, fileData); }
|
||||||
void add_runAction(uint8_t runAction) { fbb_.AddElement<uint8_t>(8, runAction, 0); }
|
void add_runAction(uint8_t runAction) { fbb_.AddElement<uint8_t>(8, runAction, 0); }
|
||||||
|
void add_isFlipped(uint8_t isFlipped) { fbb_.AddElement<uint8_t>(10, isFlipped, 0); }
|
||||||
Sprite3DOptionsBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); }
|
Sprite3DOptionsBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); }
|
||||||
Sprite3DOptionsBuilder &operator=(const Sprite3DOptionsBuilder &);
|
Sprite3DOptionsBuilder &operator=(const Sprite3DOptionsBuilder &);
|
||||||
flatbuffers::Offset<Sprite3DOptions> Finish() {
|
flatbuffers::Offset<Sprite3DOptions> Finish() {
|
||||||
auto o = flatbuffers::Offset<Sprite3DOptions>(fbb_.EndTable(start_, 3));
|
auto o = flatbuffers::Offset<Sprite3DOptions>(fbb_.EndTable(start_, 4));
|
||||||
return o;
|
return o;
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -260,10 +181,12 @@ struct Sprite3DOptionsBuilder {
|
||||||
inline flatbuffers::Offset<Sprite3DOptions> CreateSprite3DOptions(flatbuffers::FlatBufferBuilder &_fbb,
|
inline flatbuffers::Offset<Sprite3DOptions> CreateSprite3DOptions(flatbuffers::FlatBufferBuilder &_fbb,
|
||||||
flatbuffers::Offset<Node3DOption> node3DOption = 0,
|
flatbuffers::Offset<Node3DOption> node3DOption = 0,
|
||||||
flatbuffers::Offset<flatbuffers::ResourceData> fileData = 0,
|
flatbuffers::Offset<flatbuffers::ResourceData> fileData = 0,
|
||||||
uint8_t runAction = 0) {
|
uint8_t runAction = 0,
|
||||||
|
uint8_t isFlipped = 0) {
|
||||||
Sprite3DOptionsBuilder builder_(_fbb);
|
Sprite3DOptionsBuilder builder_(_fbb);
|
||||||
builder_.add_fileData(fileData);
|
builder_.add_fileData(fileData);
|
||||||
builder_.add_node3DOption(node3DOption);
|
builder_.add_node3DOption(node3DOption);
|
||||||
|
builder_.add_isFlipped(isFlipped);
|
||||||
builder_.add_runAction(runAction);
|
builder_.add_runAction(runAction);
|
||||||
return builder_.Finish();
|
return builder_.Finish();
|
||||||
}
|
}
|
||||||
|
@ -310,12 +233,12 @@ struct UserCameraOptions : private flatbuffers::Table {
|
||||||
float farClip() const { return GetField<float>(10, 1000); }
|
float farClip() const { return GetField<float>(10, 1000); }
|
||||||
int32_t cameraFlag() const { return GetField<int32_t>(12, 0); }
|
int32_t cameraFlag() const { return GetField<int32_t>(12, 0); }
|
||||||
uint8_t skyBoxEnabled() const { return GetField<uint8_t>(14, 0); }
|
uint8_t skyBoxEnabled() const { return GetField<uint8_t>(14, 0); }
|
||||||
const ResourceData *leftFileData() const { return GetPointer<const ResourceData *>(16); }
|
const flatbuffers::ResourceData *leftFileData() const { return GetPointer<const flatbuffers::ResourceData *>(16); }
|
||||||
const ResourceData *rightFileData() const { return GetPointer<const ResourceData *>(18); }
|
const flatbuffers::ResourceData *rightFileData() const { return GetPointer<const flatbuffers::ResourceData *>(18); }
|
||||||
const ResourceData *upFileData() const { return GetPointer<const ResourceData *>(20); }
|
const flatbuffers::ResourceData *upFileData() const { return GetPointer<const flatbuffers::ResourceData *>(20); }
|
||||||
const ResourceData *downFileData() const { return GetPointer<const ResourceData *>(22); }
|
const flatbuffers::ResourceData *downFileData() const { return GetPointer<const flatbuffers::ResourceData *>(22); }
|
||||||
const ResourceData *forwardFileData() const { return GetPointer<const ResourceData *>(24); }
|
const flatbuffers::ResourceData *forwardFileData() const { return GetPointer<const flatbuffers::ResourceData *>(24); }
|
||||||
const ResourceData *backFileData() const { return GetPointer<const ResourceData *>(26); }
|
const flatbuffers::ResourceData *backFileData() const { return GetPointer<const flatbuffers::ResourceData *>(26); }
|
||||||
bool Verify(flatbuffers::Verifier &verifier) const {
|
bool Verify(flatbuffers::Verifier &verifier) const {
|
||||||
return VerifyTableStart(verifier) &&
|
return VerifyTableStart(verifier) &&
|
||||||
VerifyField<flatbuffers::uoffset_t>(verifier, 4 /* node3DOption */) &&
|
VerifyField<flatbuffers::uoffset_t>(verifier, 4 /* node3DOption */) &&
|
||||||
|
@ -349,13 +272,13 @@ struct UserCameraOptionsBuilder {
|
||||||
void add_nearClip(float nearClip) { fbb_.AddElement<float>(8, nearClip, 1); }
|
void add_nearClip(float nearClip) { fbb_.AddElement<float>(8, nearClip, 1); }
|
||||||
void add_farClip(float farClip) { fbb_.AddElement<float>(10, farClip, 1000); }
|
void add_farClip(float farClip) { fbb_.AddElement<float>(10, farClip, 1000); }
|
||||||
void add_cameraFlag(int32_t cameraFlag) { fbb_.AddElement<int32_t>(12, cameraFlag, 0); }
|
void add_cameraFlag(int32_t cameraFlag) { fbb_.AddElement<int32_t>(12, cameraFlag, 0); }
|
||||||
void add_skyboxEnabled(uint8_t skyBoxEnabled) { fbb_.AddElement<uint8_t>(14, skyBoxEnabled, 0); }
|
void add_skyBoxEnabled(uint8_t skyBoxEnabled) { fbb_.AddElement<uint8_t>(14, skyBoxEnabled, 0); }
|
||||||
void add_leftFileData(flatbuffers::Offset<ResourceData> leftFileData) { fbb_.AddOffset(16, leftFileData); }
|
void add_leftFileData(flatbuffers::Offset<flatbuffers::ResourceData> leftFileData) { fbb_.AddOffset(16, leftFileData); }
|
||||||
void add_rightFileData(flatbuffers::Offset<ResourceData> rightFileData) { fbb_.AddOffset(18, rightFileData); }
|
void add_rightFileData(flatbuffers::Offset<flatbuffers::ResourceData> rightFileData) { fbb_.AddOffset(18, rightFileData); }
|
||||||
void add_upFileData(flatbuffers::Offset<ResourceData> upFileData) { fbb_.AddOffset(20, upFileData); }
|
void add_upFileData(flatbuffers::Offset<flatbuffers::ResourceData> upFileData) { fbb_.AddOffset(20, upFileData); }
|
||||||
void add_downFileData(flatbuffers::Offset<ResourceData> downFileData) { fbb_.AddOffset(22, downFileData); }
|
void add_downFileData(flatbuffers::Offset<flatbuffers::ResourceData> downFileData) { fbb_.AddOffset(22, downFileData); }
|
||||||
void add_forwardFileData(flatbuffers::Offset<ResourceData> forwardFileData) { fbb_.AddOffset(24, forwardFileData); }
|
void add_forwardFileData(flatbuffers::Offset<flatbuffers::ResourceData> forwardFileData) { fbb_.AddOffset(24, forwardFileData); }
|
||||||
void add_backFileData(flatbuffers::Offset<ResourceData> backFileData) { fbb_.AddOffset(26, backFileData); }
|
void add_backFileData(flatbuffers::Offset<flatbuffers::ResourceData> backFileData) { fbb_.AddOffset(26, backFileData); }
|
||||||
UserCameraOptionsBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); }
|
UserCameraOptionsBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); }
|
||||||
UserCameraOptionsBuilder &operator=(const UserCameraOptionsBuilder &);
|
UserCameraOptionsBuilder &operator=(const UserCameraOptionsBuilder &);
|
||||||
flatbuffers::Offset<UserCameraOptions> Finish() {
|
flatbuffers::Offset<UserCameraOptions> Finish() {
|
||||||
|
@ -371,12 +294,12 @@ inline flatbuffers::Offset<UserCameraOptions> CreateUserCameraOptions(flatbuffer
|
||||||
float farClip = 1000,
|
float farClip = 1000,
|
||||||
int32_t cameraFlag = 0,
|
int32_t cameraFlag = 0,
|
||||||
uint8_t skyBoxEnabled = 0,
|
uint8_t skyBoxEnabled = 0,
|
||||||
flatbuffers::Offset<ResourceData> leftFileData = 0,
|
flatbuffers::Offset<flatbuffers::ResourceData> leftFileData = 0,
|
||||||
flatbuffers::Offset<ResourceData> rightFileData = 0,
|
flatbuffers::Offset<flatbuffers::ResourceData> rightFileData = 0,
|
||||||
flatbuffers::Offset<ResourceData> upFileData = 0,
|
flatbuffers::Offset<flatbuffers::ResourceData> upFileData = 0,
|
||||||
flatbuffers::Offset<ResourceData> downFileData = 0,
|
flatbuffers::Offset<flatbuffers::ResourceData> downFileData = 0,
|
||||||
flatbuffers::Offset<ResourceData> forwardFileData = 0,
|
flatbuffers::Offset<flatbuffers::ResourceData> forwardFileData = 0,
|
||||||
flatbuffers::Offset<ResourceData> backFileData = 0) {
|
flatbuffers::Offset<flatbuffers::ResourceData> backFileData = 0) {
|
||||||
UserCameraOptionsBuilder builder_(_fbb);
|
UserCameraOptionsBuilder builder_(_fbb);
|
||||||
builder_.add_backFileData(backFileData);
|
builder_.add_backFileData(backFileData);
|
||||||
builder_.add_forwardFileData(forwardFileData);
|
builder_.add_forwardFileData(forwardFileData);
|
||||||
|
@ -384,12 +307,99 @@ inline flatbuffers::Offset<UserCameraOptions> CreateUserCameraOptions(flatbuffer
|
||||||
builder_.add_upFileData(upFileData);
|
builder_.add_upFileData(upFileData);
|
||||||
builder_.add_rightFileData(rightFileData);
|
builder_.add_rightFileData(rightFileData);
|
||||||
builder_.add_leftFileData(leftFileData);
|
builder_.add_leftFileData(leftFileData);
|
||||||
builder_.add_skyboxEnabled(skyBoxEnabled);
|
|
||||||
builder_.add_cameraFlag(cameraFlag);
|
builder_.add_cameraFlag(cameraFlag);
|
||||||
builder_.add_farClip(farClip);
|
builder_.add_farClip(farClip);
|
||||||
builder_.add_nearClip(nearClip);
|
builder_.add_nearClip(nearClip);
|
||||||
builder_.add_fov(fov);
|
builder_.add_fov(fov);
|
||||||
builder_.add_node3DOption(node3DOption);
|
builder_.add_node3DOption(node3DOption);
|
||||||
|
builder_.add_skyBoxEnabled(skyBoxEnabled);
|
||||||
|
return builder_.Finish();
|
||||||
|
}
|
||||||
|
|
||||||
|
struct GameNode3DOption : private flatbuffers::Table {
|
||||||
|
const flatbuffers::String *name() const { return GetPointer<const flatbuffers::String *>(4); }
|
||||||
|
int32_t skyBoxMask() const { return GetField<int32_t>(6, 0); }
|
||||||
|
uint8_t skyBoxEnabled() const { return GetField<uint8_t>(8, 0); }
|
||||||
|
const flatbuffers::ResourceData *leftFileData() const { return GetPointer<const flatbuffers::ResourceData *>(10); }
|
||||||
|
const flatbuffers::ResourceData *rightFileData() const { return GetPointer<const flatbuffers::ResourceData *>(12); }
|
||||||
|
const flatbuffers::ResourceData *upFileData() const { return GetPointer<const flatbuffers::ResourceData *>(14); }
|
||||||
|
const flatbuffers::ResourceData *downFileData() const { return GetPointer<const flatbuffers::ResourceData *>(16); }
|
||||||
|
const flatbuffers::ResourceData *forwardFileData() const { return GetPointer<const flatbuffers::ResourceData *>(18); }
|
||||||
|
const flatbuffers::ResourceData *backFileData() const { return GetPointer<const flatbuffers::ResourceData *>(20); }
|
||||||
|
const flatbuffers::String *frameEvent() const { return GetPointer<const flatbuffers::String *>(22); }
|
||||||
|
const flatbuffers::String *customProperty() const { return GetPointer<const flatbuffers::String *>(24); }
|
||||||
|
bool Verify(flatbuffers::Verifier &verifier) const {
|
||||||
|
return VerifyTableStart(verifier) &&
|
||||||
|
VerifyField<flatbuffers::uoffset_t>(verifier, 4 /* name */) &&
|
||||||
|
verifier.Verify(name()) &&
|
||||||
|
VerifyField<int32_t>(verifier, 6 /* skyBoxMask */) &&
|
||||||
|
VerifyField<uint8_t>(verifier, 8 /* skyBoxEnabled */) &&
|
||||||
|
VerifyField<flatbuffers::uoffset_t>(verifier, 10 /* leftFileData */) &&
|
||||||
|
verifier.VerifyTable(leftFileData()) &&
|
||||||
|
VerifyField<flatbuffers::uoffset_t>(verifier, 12 /* rightFileData */) &&
|
||||||
|
verifier.VerifyTable(rightFileData()) &&
|
||||||
|
VerifyField<flatbuffers::uoffset_t>(verifier, 14 /* upFileData */) &&
|
||||||
|
verifier.VerifyTable(upFileData()) &&
|
||||||
|
VerifyField<flatbuffers::uoffset_t>(verifier, 16 /* downFileData */) &&
|
||||||
|
verifier.VerifyTable(downFileData()) &&
|
||||||
|
VerifyField<flatbuffers::uoffset_t>(verifier, 18 /* forwardFileData */) &&
|
||||||
|
verifier.VerifyTable(forwardFileData()) &&
|
||||||
|
VerifyField<flatbuffers::uoffset_t>(verifier, 20 /* backFileData */) &&
|
||||||
|
verifier.VerifyTable(backFileData()) &&
|
||||||
|
VerifyField<flatbuffers::uoffset_t>(verifier, 22 /* frameEvent */) &&
|
||||||
|
verifier.Verify(frameEvent()) &&
|
||||||
|
VerifyField<flatbuffers::uoffset_t>(verifier, 24 /* customProperty */) &&
|
||||||
|
verifier.Verify(customProperty()) &&
|
||||||
|
verifier.EndTable();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
struct GameNode3DOptionBuilder {
|
||||||
|
flatbuffers::FlatBufferBuilder &fbb_;
|
||||||
|
flatbuffers::uoffset_t start_;
|
||||||
|
void add_name(flatbuffers::Offset<flatbuffers::String> name) { fbb_.AddOffset(4, name); }
|
||||||
|
void add_skyBoxMask(int32_t skyBoxMask) { fbb_.AddElement<int32_t>(6, skyBoxMask, 0); }
|
||||||
|
void add_skyBoxEnabled(uint8_t skyBoxEnabled) { fbb_.AddElement<uint8_t>(8, skyBoxEnabled, 0); }
|
||||||
|
void add_leftFileData(flatbuffers::Offset<flatbuffers::ResourceData> leftFileData) { fbb_.AddOffset(10, leftFileData); }
|
||||||
|
void add_rightFileData(flatbuffers::Offset<flatbuffers::ResourceData> rightFileData) { fbb_.AddOffset(12, rightFileData); }
|
||||||
|
void add_upFileData(flatbuffers::Offset<flatbuffers::ResourceData> upFileData) { fbb_.AddOffset(14, upFileData); }
|
||||||
|
void add_downFileData(flatbuffers::Offset<flatbuffers::ResourceData> downFileData) { fbb_.AddOffset(16, downFileData); }
|
||||||
|
void add_forwardFileData(flatbuffers::Offset<flatbuffers::ResourceData> forwardFileData) { fbb_.AddOffset(18, forwardFileData); }
|
||||||
|
void add_backFileData(flatbuffers::Offset<flatbuffers::ResourceData> backFileData) { fbb_.AddOffset(20, backFileData); }
|
||||||
|
void add_frameEvent(flatbuffers::Offset<flatbuffers::String> frameEvent) { fbb_.AddOffset(22, frameEvent); }
|
||||||
|
void add_customProperty(flatbuffers::Offset<flatbuffers::String> customProperty) { fbb_.AddOffset(24, customProperty); }
|
||||||
|
GameNode3DOptionBuilder(flatbuffers::FlatBufferBuilder &_fbb) : fbb_(_fbb) { start_ = fbb_.StartTable(); }
|
||||||
|
GameNode3DOptionBuilder &operator=(const GameNode3DOptionBuilder &);
|
||||||
|
flatbuffers::Offset<GameNode3DOption> Finish() {
|
||||||
|
auto o = flatbuffers::Offset<GameNode3DOption>(fbb_.EndTable(start_, 11));
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
inline flatbuffers::Offset<GameNode3DOption> CreateGameNode3DOption(flatbuffers::FlatBufferBuilder &_fbb,
|
||||||
|
flatbuffers::Offset<flatbuffers::String> name = 0,
|
||||||
|
int32_t skyBoxMask = 0,
|
||||||
|
uint8_t skyBoxEnabled = 0,
|
||||||
|
flatbuffers::Offset<flatbuffers::ResourceData> leftFileData = 0,
|
||||||
|
flatbuffers::Offset<flatbuffers::ResourceData> rightFileData = 0,
|
||||||
|
flatbuffers::Offset<flatbuffers::ResourceData> upFileData = 0,
|
||||||
|
flatbuffers::Offset<flatbuffers::ResourceData> downFileData = 0,
|
||||||
|
flatbuffers::Offset<flatbuffers::ResourceData> forwardFileData = 0,
|
||||||
|
flatbuffers::Offset<flatbuffers::ResourceData> backFileData = 0,
|
||||||
|
flatbuffers::Offset<flatbuffers::String> frameEvent = 0,
|
||||||
|
flatbuffers::Offset<flatbuffers::String> 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();
|
return builder_.Finish();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -109,6 +109,7 @@ namespace cocostudio
|
||||||
bool runAction = false;
|
bool runAction = false;
|
||||||
std::string path;
|
std::string path;
|
||||||
int resourceType = 0;
|
int resourceType = 0;
|
||||||
|
bool isFlipped = false;
|
||||||
|
|
||||||
std::string attriname;
|
std::string attriname;
|
||||||
const tinyxml2::XMLAttribute* attribute = objectData->FirstAttribute();
|
const tinyxml2::XMLAttribute* attribute = objectData->FirstAttribute();
|
||||||
|
@ -120,7 +121,10 @@ namespace cocostudio
|
||||||
if(attriname == "RunAction3D")
|
if(attriname == "RunAction3D")
|
||||||
{
|
{
|
||||||
runAction = value == "True" ? true : false;
|
runAction = value == "True" ? true : false;
|
||||||
break;
|
}
|
||||||
|
else if (attriname == "IsFlipped")
|
||||||
|
{
|
||||||
|
isFlipped = value == "True" ? true : false;
|
||||||
}
|
}
|
||||||
|
|
||||||
attribute = attribute->Next();
|
attribute = attribute->Next();
|
||||||
|
@ -170,7 +174,8 @@ namespace cocostudio
|
||||||
builder->CreateString(path),
|
builder->CreateString(path),
|
||||||
builder->CreateString(""),
|
builder->CreateString(""),
|
||||||
resourceType),
|
resourceType),
|
||||||
runAction
|
runAction,
|
||||||
|
isFlipped
|
||||||
);
|
);
|
||||||
|
|
||||||
return *(Offset<Table>*)(&options);
|
return *(Offset<Table>*)(&options);
|
||||||
|
@ -184,6 +189,7 @@ namespace cocostudio
|
||||||
auto options = (Sprite3DOptions*)sprite3DOptions;
|
auto options = (Sprite3DOptions*)sprite3DOptions;
|
||||||
|
|
||||||
bool runAction = options->runAction() != 0;
|
bool runAction = options->runAction() != 0;
|
||||||
|
bool isFlipped = options->isFlipped() != 0;
|
||||||
auto fileData = options->fileData();
|
auto fileData = options->fileData();
|
||||||
std::string path = fileData->path()->c_str();
|
std::string path = fileData->path()->c_str();
|
||||||
|
|
||||||
|
@ -213,6 +219,11 @@ namespace cocostudio
|
||||||
{
|
{
|
||||||
sprite3D->setColor(Color3B(red, green, blue));
|
sprite3D->setColor(Color3B(red, green, blue));
|
||||||
}
|
}
|
||||||
|
if (isFlipped)
|
||||||
|
{
|
||||||
|
sprite3D->setCullFaceEnabled(true);
|
||||||
|
sprite3D->setCullFace(GL_FRONT);
|
||||||
|
}
|
||||||
|
|
||||||
auto node3DReader = Node3DReader::getInstance();
|
auto node3DReader = Node3DReader::getInstance();
|
||||||
node3DReader->setPropsWithFlatBuffers(sprite3D, (Table*)(options->node3DOption()));
|
node3DReader->setPropsWithFlatBuffers(sprite3D, (Table*)(options->node3DOption()));
|
||||||
|
|
|
@ -108,6 +108,7 @@ public abstract class Cocos2dxActivity extends Activity implements Cocos2dxHelpe
|
||||||
private Cocos2dxVideoHelper mVideoHelper = null;
|
private Cocos2dxVideoHelper mVideoHelper = null;
|
||||||
private Cocos2dxWebViewHelper mWebViewHelper = null;
|
private Cocos2dxWebViewHelper mWebViewHelper = null;
|
||||||
private Cocos2dxEditBoxHelper mEditBoxHelper = null;
|
private Cocos2dxEditBoxHelper mEditBoxHelper = null;
|
||||||
|
private boolean hasFocus = false;
|
||||||
|
|
||||||
public Cocos2dxGLSurfaceView getGLSurfaceView(){
|
public Cocos2dxGLSurfaceView getGLSurfaceView(){
|
||||||
return mGLSurfaceView;
|
return mGLSurfaceView;
|
||||||
|
@ -338,21 +339,30 @@ public abstract class Cocos2dxActivity extends Activity implements Cocos2dxHelpe
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onResume() {
|
protected void onResume() {
|
||||||
|
Log.d(TAG, "onResume()");
|
||||||
super.onResume();
|
super.onResume();
|
||||||
|
resumeIfHasFocus();
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
public void onWindowFocusChanged(boolean hasFocus) {
|
public void onWindowFocusChanged(boolean hasFocus) {
|
||||||
|
Log.d(TAG, "onWindowFocusChanged() hasFocus=" + hasFocus);
|
||||||
super.onWindowFocusChanged(hasFocus);
|
super.onWindowFocusChanged(hasFocus);
|
||||||
|
|
||||||
if (hasFocus) {
|
this.hasFocus = hasFocus;
|
||||||
Cocos2dxHelper.onResume();
|
resumeIfHasFocus();
|
||||||
mGLSurfaceView.onResume();
|
}
|
||||||
|
|
||||||
|
private void resumeIfHasFocus() {
|
||||||
|
if(hasFocus) {
|
||||||
|
Cocos2dxHelper.onResume();
|
||||||
|
mGLSurfaceView.onResume();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
@Override
|
@Override
|
||||||
protected void onPause() {
|
protected void onPause() {
|
||||||
|
Log.d(TAG, "onPause()");
|
||||||
super.onPause();
|
super.onPause();
|
||||||
Cocos2dxHelper.onPause();
|
Cocos2dxHelper.onPause();
|
||||||
mGLSurfaceView.onPause();
|
mGLSurfaceView.onPause();
|
||||||
|
|
|
@ -543,15 +543,19 @@ void Renderer::visitRenderQueue(RenderQueue& queue)
|
||||||
{
|
{
|
||||||
glEnable(GL_DEPTH_TEST);
|
glEnable(GL_DEPTH_TEST);
|
||||||
glDepthMask(true);
|
glDepthMask(true);
|
||||||
|
glEnable(GL_BLEND);
|
||||||
RenderState::StateBlock::_defaultState->setDepthTest(true);
|
RenderState::StateBlock::_defaultState->setDepthTest(true);
|
||||||
RenderState::StateBlock::_defaultState->setDepthWrite(true);
|
RenderState::StateBlock::_defaultState->setDepthWrite(true);
|
||||||
|
RenderState::StateBlock::_defaultState->setBlend(true);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
glDisable(GL_DEPTH_TEST);
|
glDisable(GL_DEPTH_TEST);
|
||||||
glDepthMask(false);
|
glDepthMask(false);
|
||||||
|
glEnable(GL_BLEND);
|
||||||
RenderState::StateBlock::_defaultState->setDepthTest(false);
|
RenderState::StateBlock::_defaultState->setDepthTest(false);
|
||||||
RenderState::StateBlock::_defaultState->setDepthWrite(false);
|
RenderState::StateBlock::_defaultState->setDepthWrite(false);
|
||||||
|
RenderState::StateBlock::_defaultState->setBlend(true);
|
||||||
}
|
}
|
||||||
for (auto it = zNegQueue.cbegin(); it != zNegQueue.cend(); ++it)
|
for (auto it = zNegQueue.cbegin(); it != zNegQueue.cend(); ++it)
|
||||||
{
|
{
|
||||||
|
@ -569,8 +573,10 @@ void Renderer::visitRenderQueue(RenderQueue& queue)
|
||||||
//Clear depth to achieve layered rendering
|
//Clear depth to achieve layered rendering
|
||||||
glEnable(GL_DEPTH_TEST);
|
glEnable(GL_DEPTH_TEST);
|
||||||
glDepthMask(true);
|
glDepthMask(true);
|
||||||
|
glDisable(GL_BLEND);
|
||||||
RenderState::StateBlock::_defaultState->setDepthTest(true);
|
RenderState::StateBlock::_defaultState->setDepthTest(true);
|
||||||
RenderState::StateBlock::_defaultState->setDepthWrite(true);
|
RenderState::StateBlock::_defaultState->setDepthWrite(true);
|
||||||
|
RenderState::StateBlock::_defaultState->setBlend(false);
|
||||||
|
|
||||||
|
|
||||||
for (auto it = opaqueQueue.cbegin(); it != opaqueQueue.cend(); ++it)
|
for (auto it = opaqueQueue.cbegin(); it != opaqueQueue.cend(); ++it)
|
||||||
|
@ -588,9 +594,11 @@ void Renderer::visitRenderQueue(RenderQueue& queue)
|
||||||
{
|
{
|
||||||
glEnable(GL_DEPTH_TEST);
|
glEnable(GL_DEPTH_TEST);
|
||||||
glDepthMask(false);
|
glDepthMask(false);
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
|
||||||
RenderState::StateBlock::_defaultState->setDepthTest(true);
|
RenderState::StateBlock::_defaultState->setDepthTest(true);
|
||||||
RenderState::StateBlock::_defaultState->setDepthWrite(false);
|
RenderState::StateBlock::_defaultState->setDepthWrite(false);
|
||||||
|
RenderState::StateBlock::_defaultState->setBlend(true);
|
||||||
|
|
||||||
|
|
||||||
for (auto it = transQueue.cbegin(); it != transQueue.cend(); ++it)
|
for (auto it = transQueue.cbegin(); it != transQueue.cend(); ++it)
|
||||||
|
@ -610,18 +618,22 @@ void Renderer::visitRenderQueue(RenderQueue& queue)
|
||||||
{
|
{
|
||||||
glEnable(GL_DEPTH_TEST);
|
glEnable(GL_DEPTH_TEST);
|
||||||
glDepthMask(true);
|
glDepthMask(true);
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
|
||||||
RenderState::StateBlock::_defaultState->setDepthTest(true);
|
RenderState::StateBlock::_defaultState->setDepthTest(true);
|
||||||
RenderState::StateBlock::_defaultState->setDepthWrite(true);
|
RenderState::StateBlock::_defaultState->setDepthWrite(true);
|
||||||
|
RenderState::StateBlock::_defaultState->setBlend(true);
|
||||||
|
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
glDisable(GL_DEPTH_TEST);
|
glDisable(GL_DEPTH_TEST);
|
||||||
glDepthMask(false);
|
glDepthMask(false);
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
|
||||||
RenderState::StateBlock::_defaultState->setDepthTest(false);
|
RenderState::StateBlock::_defaultState->setDepthTest(false);
|
||||||
RenderState::StateBlock::_defaultState->setDepthWrite(false);
|
RenderState::StateBlock::_defaultState->setDepthWrite(false);
|
||||||
|
RenderState::StateBlock::_defaultState->setBlend(true);
|
||||||
|
|
||||||
}
|
}
|
||||||
for (auto it = zZeroQueue.cbegin(); it != zZeroQueue.cend(); ++it)
|
for (auto it = zZeroQueue.cbegin(); it != zZeroQueue.cend(); ++it)
|
||||||
|
@ -637,6 +649,29 @@ void Renderer::visitRenderQueue(RenderQueue& queue)
|
||||||
const auto& zPosQueue = queue.getSubQueue(RenderQueue::QUEUE_GROUP::GLOBALZ_POS);
|
const auto& zPosQueue = queue.getSubQueue(RenderQueue::QUEUE_GROUP::GLOBALZ_POS);
|
||||||
if (zPosQueue.size() > 0)
|
if (zPosQueue.size() > 0)
|
||||||
{
|
{
|
||||||
|
if(_isDepthTestFor2D)
|
||||||
|
{
|
||||||
|
glEnable(GL_DEPTH_TEST);
|
||||||
|
glDepthMask(true);
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
|
||||||
|
RenderState::StateBlock::_defaultState->setDepthTest(true);
|
||||||
|
RenderState::StateBlock::_defaultState->setDepthWrite(true);
|
||||||
|
RenderState::StateBlock::_defaultState->setBlend(true);
|
||||||
|
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
glDisable(GL_DEPTH_TEST);
|
||||||
|
glDepthMask(false);
|
||||||
|
glEnable(GL_BLEND);
|
||||||
|
|
||||||
|
RenderState::StateBlock::_defaultState->setDepthTest(false);
|
||||||
|
RenderState::StateBlock::_defaultState->setDepthWrite(false);
|
||||||
|
RenderState::StateBlock::_defaultState->setBlend(true);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
for (auto it = zPosQueue.cbegin(); it != zPosQueue.cend(); ++it)
|
for (auto it = zPosQueue.cbegin(); it != zPosQueue.cend(); ++it)
|
||||||
{
|
{
|
||||||
processRenderCommand(*it);
|
processRenderCommand(*it);
|
||||||
|
|
|
@ -39,7 +39,7 @@
|
||||||
#include <assert.h>
|
#include <assert.h>
|
||||||
#include <memory>
|
#include <memory>
|
||||||
|
|
||||||
#define ENGINE_VERSION "Cocos2d-JS v3.8 RC0"
|
#define ENGINE_VERSION "Cocos2d-JS v3.8"
|
||||||
|
|
||||||
void js_log(const char *format, ...);
|
void js_log(const char *format, ...);
|
||||||
|
|
||||||
|
|
|
@ -26,7 +26,7 @@
|
||||||
|
|
||||||
// CCConfig.js
|
// CCConfig.js
|
||||||
//
|
//
|
||||||
cc.ENGINE_VERSION = "Cocos2d-JS v3.8 RC0";
|
cc.ENGINE_VERSION = "Cocos2d-JS v3.8";
|
||||||
|
|
||||||
cc.FIX_ARTIFACTS_BY_STRECHING_TEXEL = 0;
|
cc.FIX_ARTIFACTS_BY_STRECHING_TEXEL = 0;
|
||||||
cc.DIRECTOR_STATS_POSITION = {x: 0, y: 0};
|
cc.DIRECTOR_STATS_POSITION = {x: 0, y: 0};
|
||||||
|
|
|
@ -381,6 +381,7 @@ gl.INVERT = 0x150a;
|
||||||
gl.KEEP = 0x1e00;
|
gl.KEEP = 0x1e00;
|
||||||
gl.KHR_debug = 0x1;
|
gl.KHR_debug = 0x1;
|
||||||
gl.KHR_texture_compression_astc_ldr = 0x1;
|
gl.KHR_texture_compression_astc_ldr = 0x1;
|
||||||
|
gl.LEFT = 0x0406;
|
||||||
gl.LEQUAL = 0x203;
|
gl.LEQUAL = 0x203;
|
||||||
gl.LESS = 0x201;
|
gl.LESS = 0x201;
|
||||||
gl.LINEAR = 0x2601;
|
gl.LINEAR = 0x2601;
|
||||||
|
@ -620,6 +621,7 @@ gl.RGBA4_OES = 0x8056;
|
||||||
gl.RGBA8_OES = 0x8058;
|
gl.RGBA8_OES = 0x8058;
|
||||||
gl.RGB_422_APPLE = 0x8a1f;
|
gl.RGB_422_APPLE = 0x8a1f;
|
||||||
gl.RG_EXT = 0x8227;
|
gl.RG_EXT = 0x8227;
|
||||||
|
gl.RIGHT = 0x0407;
|
||||||
gl.SAMPLER = 0x82e6;
|
gl.SAMPLER = 0x82e6;
|
||||||
gl.SAMPLER_2D = 0x8b5e;
|
gl.SAMPLER_2D = 0x8b5e;
|
||||||
gl.SAMPLER_2D_ARRAY_SHADOW_NV = 0x8dc4;
|
gl.SAMPLER_2D_ARRAY_SHADOW_NV = 0x8dc4;
|
||||||
|
|
|
@ -160,6 +160,7 @@
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
var skyBoxBrushInstance = null;
|
||||||
var getSkyboxRes = function(json, key) {
|
var getSkyboxRes = function(json, key) {
|
||||||
if(json.hasOwnProperty(key) && json[key].hasOwnProperty("Path")) {
|
if(json.hasOwnProperty(key) && json[key].hasOwnProperty("Path")) {
|
||||||
return json[key]["Path"];
|
return json[key]["Path"];
|
||||||
|
@ -172,7 +173,7 @@
|
||||||
* @param json
|
* @param json
|
||||||
* @returns {cc.Node}
|
* @returns {cc.Node}
|
||||||
*/
|
*/
|
||||||
parser.initSingleNode = function(json){
|
parser.initSingleNode = function(json, resourcePath){
|
||||||
var node = new cc.Node();
|
var node = new cc.Node();
|
||||||
|
|
||||||
this.generalAttributes(node, json);
|
this.generalAttributes(node, json);
|
||||||
|
@ -180,23 +181,25 @@
|
||||||
if(color != null)
|
if(color != null)
|
||||||
node.setColor(getColor(color));
|
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 leftFileData = resourcePath + getSkyboxRes(json, "LeftImage");
|
||||||
var rightFileData = getSkyboxRes(json, "RightImage");
|
var rightFileData = resourcePath + getSkyboxRes(json, "RightImage");
|
||||||
var upFileData = getSkyboxRes(json, "UpImage");
|
var upFileData = resourcePath + getSkyboxRes(json, "UpImage");
|
||||||
var downFileData = getSkyboxRes(json, "DownImage");
|
var downFileData = resourcePath + getSkyboxRes(json, "DownImage");
|
||||||
var forwardFileData = getSkyboxRes(json, "ForwardImage");
|
var forwardFileData = resourcePath + getSkyboxRes(json, "ForwardImage");
|
||||||
var backFileData = getSkyboxRes(json, "BackImage");
|
var backFileData = resourcePath + getSkyboxRes(json, "BackImage");
|
||||||
var cameraFlag = json["SkyBoxMask"];
|
var fileUtil = jsb.fileUtils;
|
||||||
if(undefined === cameraFlag || isNaN(cameraFlag)) {
|
if(fileUtil.isFileExist(leftFileData)&&
|
||||||
cameraFlag = 1024;
|
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;
|
return node;
|
||||||
|
@ -1439,7 +1442,7 @@
|
||||||
* @param json
|
* @param json
|
||||||
* @returns {*}
|
* @returns {*}
|
||||||
*/
|
*/
|
||||||
parser.initCamera = function(json){
|
parser.initCamera = function(json,resourcePath){
|
||||||
var s = cc.winSize;
|
var s = cc.winSize;
|
||||||
var fov = json["Fov"] ? json["Fov"] : 60;
|
var fov = json["Fov"] ? json["Fov"] : 60;
|
||||||
|
|
||||||
|
@ -1500,21 +1503,34 @@
|
||||||
node.setCameraFlag(cameraFlag);
|
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 leftFileData = resourcePath + getSkyboxRes(json, "LeftImage");
|
||||||
var rightFileData = getSkyboxRes(json, "RightImage");
|
var rightFileData = resourcePath + getSkyboxRes(json, "RightImage");
|
||||||
var upFileData = getSkyboxRes(json, "UpImage");
|
var upFileData = resourcePath + getSkyboxRes(json, "UpImage");
|
||||||
var downFileData = getSkyboxRes(json, "DownImage");
|
var downFileData = resourcePath + getSkyboxRes(json, "DownImage");
|
||||||
var forwardFileData = getSkyboxRes(json, "ForwardImage");
|
var forwardFileData = resourcePath + getSkyboxRes(json, "ForwardImage");
|
||||||
var backFileData = getSkyboxRes(json, "BackImage");
|
var backFileData = resourcePath + getSkyboxRes(json, "BackImage");
|
||||||
|
|
||||||
var skyBox = new jsb.Skybox();
|
var fileUtil = jsb.fileUtils;
|
||||||
skyBox.init(leftFileData,rightFileData,upFileData,downFileData,forwardFileData,backFileData);
|
if(fileUtil.isFileExist(leftFileData)&&
|
||||||
skyBox.setCameraMask(cameraFlag);
|
fileUtil.isFileExist(rightFileData)&&
|
||||||
node.addChild(skyBox);
|
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;
|
return node;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
@ -1546,6 +1562,11 @@
|
||||||
node.setColor(col);
|
node.setColor(col);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if(json.hasOwnProperty("IsFlipped") && true == json["IsFlipped"]) {
|
||||||
|
node.setCullFaceEnabled(true);
|
||||||
|
node.setCullFace(gl.FRONT);
|
||||||
|
}
|
||||||
|
|
||||||
var autoAction = getParam(json["RunAction3D"], false);
|
var autoAction = getParam(json["RunAction3D"], false);
|
||||||
if(autoAction && resFile){
|
if(autoAction && resFile){
|
||||||
var animation = jsb.Animation3D.create(resFile, "");
|
var animation = jsb.Animation3D.create(resFile, "");
|
||||||
|
|
|
@ -98,8 +98,8 @@ Slider* Slider::create(const std::string& barTextureName,
|
||||||
Slider* widget = new (std::nothrow) Slider();
|
Slider* widget = new (std::nothrow) Slider();
|
||||||
if (widget && widget->init())
|
if (widget && widget->init())
|
||||||
{
|
{
|
||||||
widget->loadBarTexture(barTextureName);
|
widget->loadBarTexture(barTextureName, resType);
|
||||||
widget->loadSlidBallTextureNormal(normalBallTextureName);
|
widget->loadSlidBallTextureNormal(normalBallTextureName, resType);
|
||||||
widget->autorelease();
|
widget->autorelease();
|
||||||
return widget;
|
return widget;
|
||||||
}
|
}
|
||||||
|
|
|
@ -181,7 +181,7 @@ Here is some highlighted improvments and API changes:
|
||||||
|
|
||||||
## Download
|
## Download
|
||||||
|
|
||||||
[Cocos2d-x v3.8 rc0](http://www.cocos2d-x.org/filedown/cocos2d-x-3.8-rc0.zip) including : C++, Lua & JS
|
[Cocos2d-x v3.8](http://www.cocos2d-x.org/filedown/cocos2d-x-3.8.zip) including : C++, Lua & JS
|
||||||
|
|
||||||
## The main features in detail:
|
## The main features in detail:
|
||||||
|
|
||||||
|
@ -270,9 +270,12 @@ Here is some highlighted improvments and API changes:
|
||||||
|
|
||||||
1. Reimplemented EditBox
|
1. Reimplemented EditBox
|
||||||
|
|
||||||
The usage of EditBox is the same as before. It is more likely a iOS version EditBox remake plus a few improvments.
|
The usage of EditBox is the same as before, but we have reimplemented it for Android platform. The use experience is highly improved, important improvements are:
|
||||||
|
|
||||||
Besides, it supports multi-line input now, you should set InputMode to `ANY` to enable multi-line input.
|
- Display cursor in EditBox
|
||||||
|
- Support copy, cut, paste and select actions in EditBox
|
||||||
|
- Support multi-line input, you should set InputMode to `ANY` to enable multi-line input
|
||||||
|
- EditBox won't be masked by the keyboard UI anymore
|
||||||
|
|
||||||
2. ScrollViewBar
|
2. ScrollViewBar
|
||||||
|
|
||||||
|
|
|
@ -193,7 +193,7 @@ var SocketIOTestLayer = cc.Layer.extend({
|
||||||
onMenuSIOEndpointClicked: function(sender) {
|
onMenuSIOEndpointClicked: function(sender) {
|
||||||
|
|
||||||
//repeat the same connection steps for the namespace "testpoint"
|
//repeat the same connection steps for the namespace "testpoint"
|
||||||
var sioendpoint = SocketIO.connect("ws://tools.itharbors.com:4000/testpoint");
|
var sioendpoint = SocketIO.connect("ws://tools.itharbors.com:4000/testpoint", {"force new connection" : true});
|
||||||
|
|
||||||
//a tag to differentiate in shared callbacks
|
//a tag to differentiate in shared callbacks
|
||||||
sioendpoint.tag = "Test Endpoint";
|
sioendpoint.tag = "Test Endpoint";
|
||||||
|
|
2
web
2
web
|
@ -1 +1 @@
|
||||||
Subproject commit 3aac6645cf36f40077d642daf8876913361fc930
|
Subproject commit 31263de3f661cdf42760884f162c56af0824ed0d
|
Loading…
Reference in New Issue