mirror of https://github.com/axmolengine/axmol.git
Merge branch 'v3' of https://github.com/cocos2d/cocos2d-x into v3_armature_reader
This commit is contained in:
commit
d543f8f6a2
|
@ -256,21 +256,8 @@ cocos_find_package(TIFF TIFF REQUIRED)
|
||||||
cocos_find_package(WEBSOCKETS WEBSOCKETS REQUIRED)
|
cocos_find_package(WEBSOCKETS WEBSOCKETS REQUIRED)
|
||||||
cocos_find_package(CURL CURL REQUIRED)
|
cocos_find_package(CURL CURL REQUIRED)
|
||||||
|
|
||||||
# flatbuffers (not prebuilded, exists as source)
|
add_subdirectory(external/flatbuffers)
|
||||||
# TODO: for now we can't use upstream flatbuffers because these files:
|
set(FLATBUFFERS_INCLUDE_DIRS ${CMAKE_CURRENT_SOURCE_DIR}/external)
|
||||||
# cocos/editor-support/cocostudio/CSParseBinary_generated.h
|
|
||||||
# was generated by concrete version of flatbuffers compiler
|
|
||||||
# and source file not provided. So these files can be
|
|
||||||
# compiled only with our in-source version of flatbuffers
|
|
||||||
## if(USE_PREBUILT_LIBS)
|
|
||||||
add_subdirectory(external/flatbuffers)
|
|
||||||
set(FLATBUFFERS_INCLUDE_DIRS ${CMAKE_CURRENT_SOURCE_DIR}/external)
|
|
||||||
set(FLATBUFFERS_LIBRARIES flatbuffers)
|
|
||||||
## else()
|
|
||||||
## cocos_find_package(Flatbuffers REQUIRED FLATBUFFERS_LIBRARIES)
|
|
||||||
## set(FLATBUFFERS_INCLUDE_DIRS ${FLATBUFFERS_INCLUDE_DIRS})
|
|
||||||
## endif()
|
|
||||||
message(STATUS "Flatbuffers libs: ${FLATBUFFERS_LIBRARIES}")
|
|
||||||
message(STATUS "Flatbuffers include dirs: ${FLATBUFFERS_INCLUDE_DIRS}")
|
message(STATUS "Flatbuffers include dirs: ${FLATBUFFERS_INCLUDE_DIRS}")
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1929,6 +1929,10 @@
|
||||||
B60C5BD519AC68B10056FBDE /* CCBillBoard.cpp in Sources */ = {isa = PBXBuildFile; fileRef = B60C5BD219AC68B10056FBDE /* CCBillBoard.cpp */; };
|
B60C5BD519AC68B10056FBDE /* CCBillBoard.cpp in Sources */ = {isa = PBXBuildFile; fileRef = B60C5BD219AC68B10056FBDE /* CCBillBoard.cpp */; };
|
||||||
B60C5BD619AC68B10056FBDE /* CCBillBoard.h in Headers */ = {isa = PBXBuildFile; fileRef = B60C5BD319AC68B10056FBDE /* CCBillBoard.h */; };
|
B60C5BD619AC68B10056FBDE /* CCBillBoard.h in Headers */ = {isa = PBXBuildFile; fileRef = B60C5BD319AC68B10056FBDE /* CCBillBoard.h */; };
|
||||||
B60C5BD719AC68B10056FBDE /* CCBillBoard.h in Headers */ = {isa = PBXBuildFile; fileRef = B60C5BD319AC68B10056FBDE /* CCBillBoard.h */; };
|
B60C5BD719AC68B10056FBDE /* CCBillBoard.h in Headers */ = {isa = PBXBuildFile; fileRef = B60C5BD319AC68B10056FBDE /* CCBillBoard.h */; };
|
||||||
|
B63990CC1A490AFE00B07923 /* CCAsyncTaskPool.cpp in Sources */ = {isa = PBXBuildFile; fileRef = B63990CA1A490AFE00B07923 /* CCAsyncTaskPool.cpp */; };
|
||||||
|
B63990CD1A490AFE00B07923 /* CCAsyncTaskPool.cpp in Sources */ = {isa = PBXBuildFile; fileRef = B63990CA1A490AFE00B07923 /* CCAsyncTaskPool.cpp */; };
|
||||||
|
B63990CE1A490AFE00B07923 /* CCAsyncTaskPool.h in Headers */ = {isa = PBXBuildFile; fileRef = B63990CB1A490AFE00B07923 /* CCAsyncTaskPool.h */; };
|
||||||
|
B63990CF1A490AFE00B07923 /* CCAsyncTaskPool.h in Headers */ = {isa = PBXBuildFile; fileRef = B63990CB1A490AFE00B07923 /* CCAsyncTaskPool.h */; };
|
||||||
D0FD03491A3B51AA00825BB5 /* CCAllocatorBase.h in Headers */ = {isa = PBXBuildFile; fileRef = D0FD033B1A3B51AA00825BB5 /* CCAllocatorBase.h */; };
|
D0FD03491A3B51AA00825BB5 /* CCAllocatorBase.h in Headers */ = {isa = PBXBuildFile; fileRef = D0FD033B1A3B51AA00825BB5 /* CCAllocatorBase.h */; };
|
||||||
D0FD034A1A3B51AA00825BB5 /* CCAllocatorBase.h in Headers */ = {isa = PBXBuildFile; fileRef = D0FD033B1A3B51AA00825BB5 /* CCAllocatorBase.h */; };
|
D0FD034A1A3B51AA00825BB5 /* CCAllocatorBase.h in Headers */ = {isa = PBXBuildFile; fileRef = D0FD033B1A3B51AA00825BB5 /* CCAllocatorBase.h */; };
|
||||||
D0FD034B1A3B51AA00825BB5 /* CCAllocatorDiagnostics.cpp in Sources */ = {isa = PBXBuildFile; fileRef = D0FD033C1A3B51AA00825BB5 /* CCAllocatorDiagnostics.cpp */; };
|
D0FD034B1A3B51AA00825BB5 /* CCAllocatorDiagnostics.cpp in Sources */ = {isa = PBXBuildFile; fileRef = D0FD033C1A3B51AA00825BB5 /* CCAllocatorDiagnostics.cpp */; };
|
||||||
|
@ -3009,6 +3013,8 @@
|
||||||
B3AF019F1842FBA400A98B85 /* b2MotorJoint.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = b2MotorJoint.h; sourceTree = "<group>"; };
|
B3AF019F1842FBA400A98B85 /* b2MotorJoint.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = b2MotorJoint.h; sourceTree = "<group>"; };
|
||||||
B60C5BD219AC68B10056FBDE /* CCBillBoard.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CCBillBoard.cpp; sourceTree = "<group>"; };
|
B60C5BD219AC68B10056FBDE /* CCBillBoard.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CCBillBoard.cpp; sourceTree = "<group>"; };
|
||||||
B60C5BD319AC68B10056FBDE /* CCBillBoard.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CCBillBoard.h; sourceTree = "<group>"; };
|
B60C5BD319AC68B10056FBDE /* CCBillBoard.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CCBillBoard.h; sourceTree = "<group>"; };
|
||||||
|
B63990CA1A490AFE00B07923 /* CCAsyncTaskPool.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = CCAsyncTaskPool.cpp; path = ../base/CCAsyncTaskPool.cpp; sourceTree = "<group>"; };
|
||||||
|
B63990CB1A490AFE00B07923 /* CCAsyncTaskPool.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = CCAsyncTaskPool.h; path = ../base/CCAsyncTaskPool.h; sourceTree = "<group>"; };
|
||||||
B67C624319D4186F00F11FC6 /* ccShader_3D_ColorNormal.frag */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.glsl; path = ccShader_3D_ColorNormal.frag; sourceTree = "<group>"; };
|
B67C624319D4186F00F11FC6 /* ccShader_3D_ColorNormal.frag */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.glsl; path = ccShader_3D_ColorNormal.frag; sourceTree = "<group>"; };
|
||||||
B67C624419D4186F00F11FC6 /* ccShader_3D_ColorNormalTex.frag */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.glsl; path = ccShader_3D_ColorNormalTex.frag; sourceTree = "<group>"; };
|
B67C624419D4186F00F11FC6 /* ccShader_3D_ColorNormalTex.frag */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.glsl; path = ccShader_3D_ColorNormalTex.frag; sourceTree = "<group>"; };
|
||||||
B67C624519D4186F00F11FC6 /* ccShader_3D_PositionNormalTex.vert */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.glsl; path = ccShader_3D_PositionNormalTex.vert; sourceTree = "<group>"; };
|
B67C624519D4186F00F11FC6 /* ccShader_3D_PositionNormalTex.vert */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.glsl; path = ccShader_3D_PositionNormalTex.vert; sourceTree = "<group>"; };
|
||||||
|
@ -3232,6 +3238,8 @@
|
||||||
1A5700A2180BC5E60088DEC7 /* base */ = {
|
1A5700A2180BC5E60088DEC7 /* base */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
|
B63990CA1A490AFE00B07923 /* CCAsyncTaskPool.cpp */,
|
||||||
|
B63990CB1A490AFE00B07923 /* CCAsyncTaskPool.h */,
|
||||||
D0FD03391A3B51AA00825BB5 /* allocator */,
|
D0FD03391A3B51AA00825BB5 /* allocator */,
|
||||||
299CF1F919A434BC00C378C1 /* ccRandom.cpp */,
|
299CF1F919A434BC00C378C1 /* ccRandom.cpp */,
|
||||||
299CF1FA19A434BC00C378C1 /* ccRandom.h */,
|
299CF1FA19A434BC00C378C1 /* ccRandom.h */,
|
||||||
|
@ -5217,6 +5225,7 @@
|
||||||
5034CA3F191D591100CE6051 /* ccShader_Position_uColor.vert in Headers */,
|
5034CA3F191D591100CE6051 /* ccShader_Position_uColor.vert in Headers */,
|
||||||
B29A7DD319EE1B7700872B35 /* Skin.h in Headers */,
|
B29A7DD319EE1B7700872B35 /* Skin.h in Headers */,
|
||||||
50ABBD461925AB0000A911A9 /* CCVertex.h in Headers */,
|
50ABBD461925AB0000A911A9 /* CCVertex.h in Headers */,
|
||||||
|
B63990CE1A490AFE00B07923 /* CCAsyncTaskPool.h in Headers */,
|
||||||
15AE180A19AAD2F700C27E9E /* CCAABB.h in Headers */,
|
15AE180A19AAD2F700C27E9E /* CCAABB.h in Headers */,
|
||||||
46A170E71807CECA005B8026 /* CCPhysicsBody.h in Headers */,
|
46A170E71807CECA005B8026 /* CCPhysicsBody.h in Headers */,
|
||||||
15AE1A5A19AAD40300C27E9E /* b2StackAllocator.h in Headers */,
|
15AE1A5A19AAD40300C27E9E /* b2StackAllocator.h in Headers */,
|
||||||
|
@ -6229,6 +6238,7 @@
|
||||||
B29A7DF019EE1B7700872B35 /* SkeletonBounds.h in Headers */,
|
B29A7DF019EE1B7700872B35 /* SkeletonBounds.h in Headers */,
|
||||||
15AE1BE919AAE01E00C27E9E /* CCControl.h in Headers */,
|
15AE1BE919AAE01E00C27E9E /* CCControl.h in Headers */,
|
||||||
15AE193719AAD35100C27E9E /* CCArmature.h in Headers */,
|
15AE193719AAD35100C27E9E /* CCArmature.h in Headers */,
|
||||||
|
B63990CF1A490AFE00B07923 /* CCAsyncTaskPool.h in Headers */,
|
||||||
15AE1BC319AADFFB00C27E9E /* cocos-ext.h in Headers */,
|
15AE1BC319AADFFB00C27E9E /* cocos-ext.h in Headers */,
|
||||||
15AE1B8B19AADA9A00C27E9E /* UIImageView.h in Headers */,
|
15AE1B8B19AADA9A00C27E9E /* UIImageView.h in Headers */,
|
||||||
15AE1A4619AAD3D500C27E9E /* b2TimeOfImpact.h in Headers */,
|
15AE1A4619AAD3D500C27E9E /* b2TimeOfImpact.h in Headers */,
|
||||||
|
@ -6497,6 +6507,7 @@
|
||||||
B24AA985195A675C007B4522 /* CCFastTMXLayer.cpp in Sources */,
|
B24AA985195A675C007B4522 /* CCFastTMXLayer.cpp in Sources */,
|
||||||
15AE1A6A19AAD40300C27E9E /* b2ChainAndCircleContact.cpp in Sources */,
|
15AE1A6A19AAD40300C27E9E /* b2ChainAndCircleContact.cpp in Sources */,
|
||||||
15B3708819EE414C00ABE682 /* Manifest.cpp in Sources */,
|
15B3708819EE414C00ABE682 /* Manifest.cpp in Sources */,
|
||||||
|
B63990CC1A490AFE00B07923 /* CCAsyncTaskPool.cpp in Sources */,
|
||||||
1A5701EA180BCB8C0088DEC7 /* CCTransitionPageTurn.cpp in Sources */,
|
1A5701EA180BCB8C0088DEC7 /* CCTransitionPageTurn.cpp in Sources */,
|
||||||
15AE186B19AAD31D00C27E9E /* SimpleAudioEngine.mm in Sources */,
|
15AE186B19AAD31D00C27E9E /* SimpleAudioEngine.mm in Sources */,
|
||||||
50ABBDAD1925AB4100A911A9 /* CCRenderer.cpp in Sources */,
|
50ABBDAD1925AB4100A911A9 /* CCRenderer.cpp in Sources */,
|
||||||
|
@ -7174,6 +7185,7 @@
|
||||||
15AE180919AAD2F700C27E9E /* CCAABB.cpp in Sources */,
|
15AE180919AAD2F700C27E9E /* CCAABB.cpp in Sources */,
|
||||||
15AE1AA719AAD40300C27E9E /* b2Island.cpp in Sources */,
|
15AE1AA719AAD40300C27E9E /* b2Island.cpp in Sources */,
|
||||||
3E6176741960F89B00DE83F5 /* CCEventController.cpp in Sources */,
|
3E6176741960F89B00DE83F5 /* CCEventController.cpp in Sources */,
|
||||||
|
B63990CD1A490AFE00B07923 /* CCAsyncTaskPool.cpp in Sources */,
|
||||||
50ABBE361925AB6F00A911A9 /* CCConsole.cpp in Sources */,
|
50ABBE361925AB6F00A911A9 /* CCConsole.cpp in Sources */,
|
||||||
B29A7E1419EE1B7700872B35 /* Bone.c in Sources */,
|
B29A7E1419EE1B7700872B35 /* Bone.c in Sources */,
|
||||||
503DD8E51926736A00CD74DD /* CCDirectorCaller-ios.mm in Sources */,
|
503DD8E51926736A00CD74DD /* CCDirectorCaller-ios.mm in Sources */,
|
||||||
|
|
|
@ -248,6 +248,7 @@ xcopy /Y /Q "$(ProjectDir)..\..\external\chipmunk\prebuilt\win32\release-lib\*.*
|
||||||
<ClCompile Include="..\base\allocator\CCAllocatorGlobalNewDelete.cpp" />
|
<ClCompile Include="..\base\allocator\CCAllocatorGlobalNewDelete.cpp" />
|
||||||
<ClCompile Include="..\base\atitc.cpp" />
|
<ClCompile Include="..\base\atitc.cpp" />
|
||||||
<ClCompile Include="..\base\base64.cpp" />
|
<ClCompile Include="..\base\base64.cpp" />
|
||||||
|
<ClCompile Include="..\base\CCAsyncTaskPool.cpp" />
|
||||||
<ClCompile Include="..\base\CCAutoreleasePool.cpp" />
|
<ClCompile Include="..\base\CCAutoreleasePool.cpp" />
|
||||||
<ClCompile Include="..\base\ccCArray.cpp" />
|
<ClCompile Include="..\base\ccCArray.cpp" />
|
||||||
<ClCompile Include="..\base\CCConfiguration.cpp" />
|
<ClCompile Include="..\base\CCConfiguration.cpp" />
|
||||||
|
@ -625,6 +626,7 @@ xcopy /Y /Q "$(ProjectDir)..\..\external\chipmunk\prebuilt\win32\release-lib\*.*
|
||||||
<ClInclude Include="..\base\allocator\CCAllocatorStrategyPool.h" />
|
<ClInclude Include="..\base\allocator\CCAllocatorStrategyPool.h" />
|
||||||
<ClInclude Include="..\base\atitc.h" />
|
<ClInclude Include="..\base\atitc.h" />
|
||||||
<ClInclude Include="..\base\base64.h" />
|
<ClInclude Include="..\base\base64.h" />
|
||||||
|
<ClInclude Include="..\base\CCAsyncTaskPool.h" />
|
||||||
<ClInclude Include="..\base\CCAutoreleasePool.h" />
|
<ClInclude Include="..\base\CCAutoreleasePool.h" />
|
||||||
<ClInclude Include="..\base\ccCArray.h" />
|
<ClInclude Include="..\base\ccCArray.h" />
|
||||||
<ClInclude Include="..\base\ccConfig.h" />
|
<ClInclude Include="..\base\ccConfig.h" />
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
<?xml version="1.0" encoding="utf-8"?>
|
<?xml version="1.0" encoding="utf-8"?>
|
||||||
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
<Project ToolsVersion="4.0" xmlns="http://schemas.microsoft.com/developer/msbuild/2003">
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<Filter Include="physics">
|
<Filter Include="physics">
|
||||||
|
@ -1295,6 +1295,9 @@
|
||||||
<ClCompile Include="..\editor-support\cocostudio\WidgetCallBackHandlerProtocol.cpp">
|
<ClCompile Include="..\editor-support\cocostudio\WidgetCallBackHandlerProtocol.cpp">
|
||||||
<Filter>cocostudio\json</Filter>
|
<Filter>cocostudio\json</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\base\CCAsyncTaskPool.cpp">
|
||||||
|
<Filter>base</Filter>
|
||||||
|
</ClCompile>
|
||||||
<ClCompile Include="..\base\allocator\CCAllocatorDiagnostics.cpp">
|
<ClCompile Include="..\base\allocator\CCAllocatorDiagnostics.cpp">
|
||||||
<Filter>base\allocator</Filter>
|
<Filter>base\allocator</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
@ -2523,6 +2526,9 @@
|
||||||
<ClInclude Include="..\editor-support\cocostudio\WidgetCallBackHandlerProtocol.h">
|
<ClInclude Include="..\editor-support\cocostudio\WidgetCallBackHandlerProtocol.h">
|
||||||
<Filter>cocostudio\json</Filter>
|
<Filter>cocostudio\json</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\base\CCAsyncTaskPool.h">
|
||||||
|
<Filter>base</Filter>
|
||||||
|
</ClInclude>
|
||||||
<ClInclude Include="..\base\allocator\CCAllocatorGlobal.h">
|
<ClInclude Include="..\base\allocator\CCAllocatorGlobal.h">
|
||||||
<Filter>base\allocator</Filter>
|
<Filter>base\allocator</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
|
|
@ -38,7 +38,7 @@ Animation3D* Animation3D::create(const std::string& fileName, const std::string&
|
||||||
|
|
||||||
//load animation here
|
//load animation here
|
||||||
animation = new (std::nothrow) Animation3D();
|
animation = new (std::nothrow) Animation3D();
|
||||||
auto bundle = Bundle3D::getInstance();
|
auto bundle = Bundle3D::createBundle();
|
||||||
Animation3DData animationdata;
|
Animation3DData animationdata;
|
||||||
if (bundle->load(fullPath) && bundle->loadAnimationData(animationName, &animationdata) && animation->init(animationdata))
|
if (bundle->load(fullPath) && bundle->loadAnimationData(animationName, &animationdata) && animation->init(animationdata))
|
||||||
{
|
{
|
||||||
|
@ -51,6 +51,7 @@ Animation3D* Animation3D::create(const std::string& fileName, const std::string&
|
||||||
animation = nullptr;
|
animation = nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Bundle3D::destroyBundle(bundle);
|
||||||
return animation;
|
return animation;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -146,24 +146,15 @@ void getChildMap(std::map<int, std::vector<int> >& map, SkinData* skinData, cons
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
Bundle3D* Bundle3D::_instance = nullptr;
|
Bundle3D* Bundle3D::createBundle()
|
||||||
|
|
||||||
void Bundle3D::setBundleInstance(Bundle3D* bundleInstance)
|
|
||||||
{
|
{
|
||||||
CC_SAFE_DELETE(_instance);
|
auto bundle = new (std::nothrow) Bundle3D();
|
||||||
_instance = bundleInstance;
|
return bundle;
|
||||||
}
|
}
|
||||||
|
|
||||||
Bundle3D* Bundle3D::getInstance()
|
void Bundle3D::destroyBundle(Bundle3D* bundle)
|
||||||
{
|
{
|
||||||
if (_instance == nullptr)
|
delete bundle;
|
||||||
_instance = new (std::nothrow) Bundle3D();
|
|
||||||
return _instance;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Bundle3D::destroyInstance()
|
|
||||||
{
|
|
||||||
CC_SAFE_DELETE(_instance);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void Bundle3D::clear()
|
void Bundle3D::clear()
|
||||||
|
|
|
@ -42,12 +42,10 @@ class Data;
|
||||||
class CC_DLL Bundle3D
|
class CC_DLL Bundle3D
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/**you can define yourself bundle and set it, use default bundle otherwise*/
|
// create a new bundle, destroy it when finish using it
|
||||||
static void setBundleInstance(Bundle3D* bundleInstance);
|
static Bundle3D* createBundle();
|
||||||
|
|
||||||
static Bundle3D* getInstance();
|
static void destroyBundle(Bundle3D* bundle);
|
||||||
|
|
||||||
static void destroyInstance();
|
|
||||||
|
|
||||||
virtual void clear();
|
virtual void clear();
|
||||||
|
|
||||||
|
@ -158,7 +156,6 @@ CC_CONSTRUCTOR_ACCESS:
|
||||||
virtual ~Bundle3D();
|
virtual ~Bundle3D();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
static Bundle3D* _instance;
|
|
||||||
std::string _modelPath;
|
std::string _modelPath;
|
||||||
std::string _path;
|
std::string _path;
|
||||||
std::string _version;// the c3b or c3t version
|
std::string _version;// the c3b or c3t version
|
||||||
|
|
|
@ -31,6 +31,7 @@
|
||||||
#include "3d/CCMesh.h"
|
#include "3d/CCMesh.h"
|
||||||
|
|
||||||
#include "base/CCDirector.h"
|
#include "base/CCDirector.h"
|
||||||
|
#include "base/CCAsyncTaskPool.h"
|
||||||
#include "2d/CCLight.h"
|
#include "2d/CCLight.h"
|
||||||
#include "2d/CCCamera.h"
|
#include "2d/CCCamera.h"
|
||||||
#include "base/ccMacros.h"
|
#include "base/ccMacros.h"
|
||||||
|
@ -73,6 +74,87 @@ Sprite3D* Sprite3D::create(const std::string &modelPath, const std::string &text
|
||||||
return sprite;
|
return sprite;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void Sprite3D::createAsync(const std::string &modelPath, const std::function<void(Sprite3D*, void*)>& callback, void* callbackparam)
|
||||||
|
{
|
||||||
|
createAsync(modelPath, "", callback, callbackparam);
|
||||||
|
}
|
||||||
|
|
||||||
|
void Sprite3D::createAsync(const std::string &modelPath, const std::string &texturePath, const std::function<void(Sprite3D*, void*)>& callback, void* callbackparam)
|
||||||
|
{
|
||||||
|
Sprite3D *sprite = new (std::nothrow) Sprite3D();
|
||||||
|
if (sprite->loadFromCache(modelPath))
|
||||||
|
{
|
||||||
|
sprite->autorelease();
|
||||||
|
if (!texturePath.empty())
|
||||||
|
sprite->setTexture(texturePath);
|
||||||
|
callback(sprite, callbackparam);
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
sprite->_asyncLoadParam.afterLoadCallback = callback;
|
||||||
|
sprite->_asyncLoadParam.texPath = texturePath;
|
||||||
|
sprite->_asyncLoadParam.modlePath = modelPath;
|
||||||
|
sprite->_asyncLoadParam.callbackParam = callbackparam;
|
||||||
|
sprite->_asyncLoadParam.materialdatas = new (std::nothrow) MaterialDatas();
|
||||||
|
sprite->_asyncLoadParam.meshdatas = new (std::nothrow) MeshDatas();
|
||||||
|
sprite->_asyncLoadParam.nodeDatas = new (std::nothrow) NodeDatas();
|
||||||
|
AsyncTaskPool::getInstance()->enqueue(AsyncTaskPool::TaskType::TASK_IO, CC_CALLBACK_1(Sprite3D::afterAsyncLoad, sprite), (void*)(&sprite->_asyncLoadParam), [sprite]()
|
||||||
|
{
|
||||||
|
sprite->_asyncLoadParam.result = sprite->loadFromFile(sprite->_asyncLoadParam.modlePath, sprite->_asyncLoadParam.nodeDatas, sprite->_asyncLoadParam.meshdatas, sprite->_asyncLoadParam.materialdatas);
|
||||||
|
});
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
void Sprite3D::afterAsyncLoad(void* param)
|
||||||
|
{
|
||||||
|
Sprite3D::AsyncLoadParam* asyncParam = (Sprite3D::AsyncLoadParam*)param;
|
||||||
|
autorelease();
|
||||||
|
if (asyncParam)
|
||||||
|
{
|
||||||
|
if (asyncParam->result)
|
||||||
|
{
|
||||||
|
_meshes.clear();
|
||||||
|
_meshVertexDatas.clear();
|
||||||
|
CC_SAFE_RELEASE_NULL(_skeleton);
|
||||||
|
removeAllAttachNode();
|
||||||
|
|
||||||
|
//create in the main thread
|
||||||
|
auto& meshdatas = asyncParam->meshdatas;
|
||||||
|
auto& materialdatas = asyncParam->materialdatas;
|
||||||
|
auto& nodeDatas = asyncParam->nodeDatas;
|
||||||
|
if (initFrom(*nodeDatas, *meshdatas, *materialdatas))
|
||||||
|
{
|
||||||
|
auto spritedata = Sprite3DCache::getInstance()->getSpriteData(asyncParam->modlePath);
|
||||||
|
if (spritedata == nullptr)
|
||||||
|
{
|
||||||
|
//add to cache
|
||||||
|
auto data = new (std::nothrow) Sprite3DCache::Sprite3DData();
|
||||||
|
data->materialdatas = materialdatas;
|
||||||
|
data->nodedatas = nodeDatas;
|
||||||
|
data->meshVertexDatas = _meshVertexDatas;
|
||||||
|
for (const auto mesh : _meshes) {
|
||||||
|
data->glProgramStates.pushBack(mesh->getGLProgramState());
|
||||||
|
}
|
||||||
|
|
||||||
|
Sprite3DCache::getInstance()->addSprite3DData(asyncParam->modlePath, data);
|
||||||
|
meshdatas = nullptr;
|
||||||
|
materialdatas = nullptr;
|
||||||
|
nodeDatas = nullptr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
delete meshdatas;
|
||||||
|
delete materialdatas;
|
||||||
|
delete nodeDatas;
|
||||||
|
|
||||||
|
if (asyncParam->texPath != "")
|
||||||
|
{
|
||||||
|
setTexture(asyncParam->texPath);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
asyncParam->afterLoadCallback(this, asyncParam->callbackParam);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
bool Sprite3D::loadFromCache(const std::string& path)
|
bool Sprite3D::loadFromCache(const std::string& path)
|
||||||
{
|
{
|
||||||
auto spritedata = Sprite3DCache::getInstance()->getSpriteData(path);
|
auto spritedata = Sprite3DCache::getInstance()->getSpriteData(path);
|
||||||
|
@ -109,66 +191,32 @@ bool Sprite3D::loadFromCache(const std::string& path)
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
//.mtl file should at the same directory with the same name if exist
|
bool Sprite3D::loadFromFile(const std::string& path, NodeDatas* nodedatas, MeshDatas* meshdatas, MaterialDatas* materialdatas)
|
||||||
bool Sprite3D::loadFromObj(const std::string& path)
|
|
||||||
{
|
{
|
||||||
std::string fullPath = FileUtils::getInstance()->fullPathForFilename(path);
|
std::string fullPath = FileUtils::getInstance()->fullPathForFilename(path);
|
||||||
|
|
||||||
MeshDatas meshdatas;
|
std::string ext = path.substr(path.length() - 4, 4);
|
||||||
MaterialDatas* materialdatas = new (std::nothrow) MaterialDatas();
|
std::transform(ext.begin(), ext.end(), ext.begin(), tolower);
|
||||||
NodeDatas* nodeDatas = new (std::nothrow) NodeDatas();
|
if (ext == ".obj")
|
||||||
bool ret = Bundle3D::loadObj(meshdatas, *materialdatas, *nodeDatas, fullPath);
|
|
||||||
if (ret && initFrom(*nodeDatas, meshdatas, *materialdatas))
|
|
||||||
{
|
{
|
||||||
//add to cache
|
return Bundle3D::loadObj(*meshdatas, *materialdatas, *nodedatas, fullPath);
|
||||||
auto data = new (std::nothrow) Sprite3DCache::Sprite3DData();
|
|
||||||
data->materialdatas = materialdatas;
|
|
||||||
data->nodedatas = nodeDatas;
|
|
||||||
data->meshVertexDatas = _meshVertexDatas;
|
|
||||||
for (const auto mesh : _meshes) {
|
|
||||||
data->glProgramStates.pushBack(mesh->getGLProgramState());
|
|
||||||
}
|
}
|
||||||
|
else if (ext == ".c3b" || ext == ".c3t")
|
||||||
Sprite3DCache::getInstance()->addSprite3DData(path, data);
|
{
|
||||||
return true;
|
|
||||||
}
|
|
||||||
delete materialdatas;
|
|
||||||
delete nodeDatas;
|
|
||||||
|
|
||||||
return false;
|
|
||||||
}
|
|
||||||
bool Sprite3D::loadFromC3x(const std::string& path)
|
|
||||||
{
|
|
||||||
std::string fullPath = FileUtils::getInstance()->fullPathForFilename(path);
|
|
||||||
|
|
||||||
//load from .c3b or .c3t
|
//load from .c3b or .c3t
|
||||||
auto bundle = Bundle3D::getInstance();
|
auto bundle = Bundle3D::createBundle();
|
||||||
if (!bundle->load(fullPath))
|
if (!bundle->load(fullPath))
|
||||||
return false;
|
|
||||||
|
|
||||||
MeshDatas meshdatas;
|
|
||||||
MaterialDatas* materialdatas = new (std::nothrow) MaterialDatas();
|
|
||||||
NodeDatas* nodeDatas = new (std::nothrow) NodeDatas();
|
|
||||||
if (bundle->loadMeshDatas(meshdatas)
|
|
||||||
&& bundle->loadMaterials(*materialdatas)
|
|
||||||
&& bundle->loadNodes(*nodeDatas)
|
|
||||||
&& initFrom(*nodeDatas, meshdatas, *materialdatas))
|
|
||||||
{
|
{
|
||||||
//add to cache
|
Bundle3D::destroyBundle(bundle);
|
||||||
auto data = new (std::nothrow) Sprite3DCache::Sprite3DData();
|
return false;
|
||||||
data->materialdatas = materialdatas;
|
|
||||||
data->nodedatas = nodeDatas;
|
|
||||||
data->meshVertexDatas = _meshVertexDatas;
|
|
||||||
for (const auto mesh : _meshes) {
|
|
||||||
data->glProgramStates.pushBack(mesh->getGLProgramState());
|
|
||||||
}
|
|
||||||
Sprite3DCache::getInstance()->addSprite3DData(path, data);
|
|
||||||
return true;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
delete materialdatas;
|
auto ret = bundle->loadMeshDatas(*meshdatas)
|
||||||
delete nodeDatas;
|
&& bundle->loadMaterials(*materialdatas) && bundle->loadNodes(*nodedatas);
|
||||||
|
Bundle3D::destroyBundle(bundle);
|
||||||
|
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -199,18 +247,29 @@ bool Sprite3D::initWithFile(const std::string &path)
|
||||||
if (loadFromCache(path))
|
if (loadFromCache(path))
|
||||||
return true;
|
return true;
|
||||||
|
|
||||||
//load from file
|
MeshDatas* meshdatas = new (std::nothrow) MeshDatas();
|
||||||
std::string ext = path.substr(path.length() - 4, 4);
|
MaterialDatas* materialdatas = new (std::nothrow) MaterialDatas();
|
||||||
std::transform(ext.begin(), ext.end(), ext.begin(), tolower);
|
NodeDatas* nodeDatas = new (std::nothrow) NodeDatas();
|
||||||
|
if (loadFromFile(path, nodeDatas, meshdatas, materialdatas))
|
||||||
|
{
|
||||||
|
if (initFrom(*nodeDatas, *meshdatas, *materialdatas))
|
||||||
|
{
|
||||||
|
//add to cache
|
||||||
|
auto data = new (std::nothrow) Sprite3DCache::Sprite3DData();
|
||||||
|
data->materialdatas = materialdatas;
|
||||||
|
data->nodedatas = nodeDatas;
|
||||||
|
data->meshVertexDatas = _meshVertexDatas;
|
||||||
|
for (const auto mesh : _meshes) {
|
||||||
|
data->glProgramStates.pushBack(mesh->getGLProgramState());
|
||||||
|
}
|
||||||
|
|
||||||
if (ext == ".obj")
|
Sprite3DCache::getInstance()->addSprite3DData(path, data);
|
||||||
{
|
return true;
|
||||||
return loadFromObj(path);
|
|
||||||
}
|
}
|
||||||
else if (ext == ".c3b" || ext == ".c3t")
|
|
||||||
{
|
|
||||||
return loadFromC3x(path);
|
|
||||||
}
|
}
|
||||||
|
delete meshdatas;
|
||||||
|
delete materialdatas;
|
||||||
|
delete nodeDatas;
|
||||||
|
|
||||||
return false;
|
return false;
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,6 +56,18 @@ public:
|
||||||
// creates a Sprite3D. It only supports one texture, and overrides the internal texture with 'texturePath'
|
// creates a Sprite3D. It only supports one texture, and overrides the internal texture with 'texturePath'
|
||||||
static Sprite3D* create(const std::string &modelPath, const std::string &texturePath);
|
static Sprite3D* create(const std::string &modelPath, const std::string &texturePath);
|
||||||
|
|
||||||
|
/** create 3d sprite asynchronously
|
||||||
|
* If the 3d model was previously loaded, it will create a new 3d sprite and the callback will be called at once.
|
||||||
|
* Otherwise it will load the model file in a new thread, and when the 3d sprite is loaded, the callback will be called with the created Sprite3D and a userdefined parameter.
|
||||||
|
* The callback will be called from the main thread, so it is safe to create any cocos2d object from the callback.
|
||||||
|
* @param modelPath model to be loaded
|
||||||
|
* @param callback callback after loading
|
||||||
|
* @param callbackparam user defined parameter for the callback
|
||||||
|
*/
|
||||||
|
static void createAsync(const std::string &modelPath, const std::function<void(Sprite3D*, void*)>& callback, void* callbackparam);
|
||||||
|
|
||||||
|
static void createAsync(const std::string &modelPath, const std::string &texturePath, const std::function<void(Sprite3D*, void*)>& callback, void* callbackparam);
|
||||||
|
|
||||||
/**set texture, set the first if multiple textures exist*/
|
/**set texture, set the first if multiple textures exist*/
|
||||||
void setTexture(const std::string& texFile);
|
void setTexture(const std::string& texFile);
|
||||||
void setTexture(Texture2D* texture);
|
void setTexture(Texture2D* texture);
|
||||||
|
@ -133,11 +145,8 @@ CC_CONSTRUCTOR_ACCESS:
|
||||||
/**load sprite3d from cache, return true if succeed, false otherwise*/
|
/**load sprite3d from cache, return true if succeed, false otherwise*/
|
||||||
bool loadFromCache(const std::string& path);
|
bool loadFromCache(const std::string& path);
|
||||||
|
|
||||||
/**.mtl file should at the same directory with the same name if exist*/
|
/** load file and set it to meshedatas, nodedatas and materialdatas, obj file .mtl file should be at the same directory if exist */
|
||||||
bool loadFromObj(const std::string& path);
|
bool loadFromFile(const std::string& path, NodeDatas* nodedatas, MeshDatas* meshdatas, MaterialDatas* materialdatas);
|
||||||
|
|
||||||
/**load from .c3b or .c3t*/
|
|
||||||
bool loadFromC3x(const std::string& path);
|
|
||||||
|
|
||||||
/**draw*/
|
/**draw*/
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
|
@ -156,6 +165,8 @@ CC_CONSTRUCTOR_ACCESS:
|
||||||
|
|
||||||
void onAABBDirty() { _aabbDirty = true; }
|
void onAABBDirty() { _aabbDirty = true; }
|
||||||
|
|
||||||
|
void afterAsyncLoad(void* param);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
Skeleton3D* _skeleton; //skeleton
|
Skeleton3D* _skeleton; //skeleton
|
||||||
|
@ -173,10 +184,23 @@ protected:
|
||||||
bool _aabbDirty;
|
bool _aabbDirty;
|
||||||
unsigned int _lightMask;
|
unsigned int _lightMask;
|
||||||
bool _shaderUsingLight; // is current shader using light ?
|
bool _shaderUsingLight; // is current shader using light ?
|
||||||
|
|
||||||
|
struct AsyncLoadParam
|
||||||
|
{
|
||||||
|
std::function<void(Sprite3D*, void*)> afterLoadCallback; // callback after load
|
||||||
|
void* callbackParam;
|
||||||
|
bool result; // sprite load result
|
||||||
|
std::string modlePath;
|
||||||
|
std::string texPath; //
|
||||||
|
MeshDatas* meshdatas;
|
||||||
|
MaterialDatas* materialdatas;
|
||||||
|
NodeDatas* nodeDatas;
|
||||||
|
};
|
||||||
|
AsyncLoadParam _asyncLoadParam;
|
||||||
};
|
};
|
||||||
|
|
||||||
///////////////////////////////////////////////////////
|
///////////////////////////////////////////////////////
|
||||||
class Sprite3DCache
|
class CC_DLL Sprite3DCache
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
struct Sprite3DData
|
struct Sprite3DData
|
||||||
|
|
|
@ -92,6 +92,7 @@ math/TransformUtils.cpp \
|
||||||
math/Vec2.cpp \
|
math/Vec2.cpp \
|
||||||
math/Vec3.cpp \
|
math/Vec3.cpp \
|
||||||
math/Vec4.cpp \
|
math/Vec4.cpp \
|
||||||
|
base/CCAsyncTaskPool.cpp \
|
||||||
base/CCAutoreleasePool.cpp \
|
base/CCAutoreleasePool.cpp \
|
||||||
base/CCConfiguration.cpp \
|
base/CCConfiguration.cpp \
|
||||||
base/CCConsole.cpp \
|
base/CCConsole.cpp \
|
||||||
|
|
|
@ -0,0 +1,55 @@
|
||||||
|
/****************************************************************************
|
||||||
|
Copyright (c) 2010 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.
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#include "base/CCAsyncTaskPool.h"
|
||||||
|
|
||||||
|
NS_CC_BEGIN
|
||||||
|
|
||||||
|
AsyncTaskPool* AsyncTaskPool::s_asyncTaskPool = nullptr;
|
||||||
|
|
||||||
|
AsyncTaskPool* AsyncTaskPool::getInstance()
|
||||||
|
{
|
||||||
|
if (s_asyncTaskPool == nullptr)
|
||||||
|
{
|
||||||
|
s_asyncTaskPool = new (std::nothrow) AsyncTaskPool();
|
||||||
|
}
|
||||||
|
return s_asyncTaskPool;
|
||||||
|
}
|
||||||
|
|
||||||
|
void AsyncTaskPool::destoryInstance()
|
||||||
|
{
|
||||||
|
delete s_asyncTaskPool;
|
||||||
|
s_asyncTaskPool = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
AsyncTaskPool::AsyncTaskPool()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
AsyncTaskPool::~AsyncTaskPool()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
NS_CC_END
|
|
@ -0,0 +1,205 @@
|
||||||
|
/****************************************************************************
|
||||||
|
Copyright (c) 2010 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.
|
||||||
|
****************************************************************************/
|
||||||
|
|
||||||
|
#ifndef __CCSYNC_TASK_POOL_H_
|
||||||
|
#define __CCSYNC_TASK_POOL_H_
|
||||||
|
|
||||||
|
#include "platform/CCPlatformMacros.h"
|
||||||
|
#include "base/CCDirector.h"
|
||||||
|
#include "base/CCScheduler.h"
|
||||||
|
#include <vector>
|
||||||
|
#include <queue>
|
||||||
|
#include <memory>
|
||||||
|
#include <thread>
|
||||||
|
#include <mutex>
|
||||||
|
#include <condition_variable>
|
||||||
|
#include <future>
|
||||||
|
#include <functional>
|
||||||
|
#include <stdexcept>
|
||||||
|
|
||||||
|
NS_CC_BEGIN
|
||||||
|
/////////////////////////////////////////////////////////////////////////////
|
||||||
|
|
||||||
|
class CC_DLL AsyncTaskPool
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
typedef std::function<void(void*)> TaskCallBack;
|
||||||
|
|
||||||
|
enum class TaskType
|
||||||
|
{
|
||||||
|
TASK_IO,
|
||||||
|
TASK_NETWORK,
|
||||||
|
TASK_OTHER,
|
||||||
|
TASK_MAX_TYPE,
|
||||||
|
};
|
||||||
|
/**
|
||||||
|
* get instance
|
||||||
|
*/
|
||||||
|
static AsyncTaskPool* getInstance();
|
||||||
|
/**
|
||||||
|
* destroy instance
|
||||||
|
*/
|
||||||
|
static void destoryInstance();
|
||||||
|
|
||||||
|
/**
|
||||||
|
* stop tasks
|
||||||
|
* @param type task type you want to stop
|
||||||
|
*/
|
||||||
|
void stopTasks(TaskType type);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* enqueue a asynchronous task
|
||||||
|
* @param type task type is io task, network task or others, each type of task has a thread to deal with it.
|
||||||
|
* @param callback callback when the task is finished. The callback is called in the main thread instead of task thread
|
||||||
|
* @param callbackParam parameter used by the callback
|
||||||
|
* @param f task can be lambda function
|
||||||
|
* @param args task parameters
|
||||||
|
*/
|
||||||
|
template<class F>
|
||||||
|
inline void enqueue(TaskType type, const TaskCallBack& callback, void* callbackParam, F&& f);
|
||||||
|
|
||||||
|
CC_CONSTRUCTOR_ACCESS:
|
||||||
|
AsyncTaskPool();
|
||||||
|
~AsyncTaskPool();
|
||||||
|
|
||||||
|
protected:
|
||||||
|
|
||||||
|
// thread tasks internally used
|
||||||
|
class ThreadTasks {
|
||||||
|
struct AsyncTaskCallBack
|
||||||
|
{
|
||||||
|
TaskCallBack callback;
|
||||||
|
void* callbackParam;
|
||||||
|
};
|
||||||
|
public:
|
||||||
|
ThreadTasks()
|
||||||
|
: _stop(false)
|
||||||
|
{
|
||||||
|
_thread = std::thread(
|
||||||
|
[this]
|
||||||
|
{
|
||||||
|
for(;;)
|
||||||
|
{
|
||||||
|
std::function<void()> task;
|
||||||
|
AsyncTaskCallBack callback;
|
||||||
|
{
|
||||||
|
std::unique_lock<std::mutex> lock(this->_queueMutex);
|
||||||
|
this->_condition.wait(lock,
|
||||||
|
[this]{ return this->_stop || !this->_tasks.empty(); });
|
||||||
|
if(this->_stop && this->_tasks.empty())
|
||||||
|
return;
|
||||||
|
task = std::move(this->_tasks.front());
|
||||||
|
callback = std::move(this->_taskCallBacks.front());
|
||||||
|
this->_tasks.pop();
|
||||||
|
this->_taskCallBacks.pop();
|
||||||
|
}
|
||||||
|
|
||||||
|
task();
|
||||||
|
Director::getInstance()->getScheduler()->performFunctionInCocosThread([&, callback]{ callback.callback(callback.callbackParam); });
|
||||||
|
}
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
~ThreadTasks()
|
||||||
|
{
|
||||||
|
{
|
||||||
|
std::unique_lock<std::mutex> lock(_queueMutex);
|
||||||
|
_stop = true;
|
||||||
|
|
||||||
|
while(_tasks.size())
|
||||||
|
_tasks.pop();
|
||||||
|
while (_taskCallBacks.size())
|
||||||
|
_taskCallBacks.pop();
|
||||||
|
}
|
||||||
|
_condition.notify_all();
|
||||||
|
_thread.join();
|
||||||
|
}
|
||||||
|
void clear()
|
||||||
|
{
|
||||||
|
std::unique_lock<std::mutex> lock(_queueMutex);
|
||||||
|
while(_tasks.size())
|
||||||
|
_tasks.pop();
|
||||||
|
while (_taskCallBacks.size())
|
||||||
|
_taskCallBacks.pop();
|
||||||
|
}
|
||||||
|
template<class F>
|
||||||
|
void enqueue(const TaskCallBack& callback, void* callbackParam, F&& f)
|
||||||
|
{
|
||||||
|
auto task = f;//std::bind(std::forward<F>(f), std::forward<Args>(args)...);
|
||||||
|
|
||||||
|
{
|
||||||
|
std::unique_lock<std::mutex> lock(_queueMutex);
|
||||||
|
|
||||||
|
// don't allow enqueueing after stopping the pool
|
||||||
|
if(_stop)
|
||||||
|
{
|
||||||
|
CC_ASSERT(0 && "already stop");
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
AsyncTaskCallBack taskCallBack;
|
||||||
|
taskCallBack.callback = callback;
|
||||||
|
taskCallBack.callbackParam = callbackParam;
|
||||||
|
_tasks.emplace([task](){ task(); });
|
||||||
|
_taskCallBacks.emplace(taskCallBack);
|
||||||
|
}
|
||||||
|
_condition.notify_one();
|
||||||
|
}
|
||||||
|
private:
|
||||||
|
|
||||||
|
// need to keep track of thread so we can join them
|
||||||
|
std::thread _thread;
|
||||||
|
// the task queue
|
||||||
|
std::queue< std::function<void()> > _tasks;
|
||||||
|
std::queue<AsyncTaskCallBack> _taskCallBacks;
|
||||||
|
|
||||||
|
// synchronization
|
||||||
|
std::mutex _queueMutex;
|
||||||
|
std::condition_variable _condition;
|
||||||
|
bool _stop;
|
||||||
|
};
|
||||||
|
|
||||||
|
//tasks
|
||||||
|
ThreadTasks _threadTasks[int(TaskType::TASK_MAX_TYPE)];
|
||||||
|
|
||||||
|
static AsyncTaskPool* s_asyncTaskPool;
|
||||||
|
};
|
||||||
|
|
||||||
|
inline void AsyncTaskPool::stopTasks(TaskType type)
|
||||||
|
{
|
||||||
|
auto& threadTask = _threadTasks[(int)type];
|
||||||
|
threadTask.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
template<class F>
|
||||||
|
inline void AsyncTaskPool::enqueue(AsyncTaskPool::TaskType type, const TaskCallBack& callback, void* callbackParam, F&& f)
|
||||||
|
{
|
||||||
|
auto& threadTask = _threadTasks[(int)type];
|
||||||
|
|
||||||
|
threadTask.enqueue(callback, callbackParam, f);
|
||||||
|
}
|
||||||
|
|
||||||
|
NS_CC_END
|
||||||
|
#endif //__CCSYNC_TASK_POOL_H_
|
|
@ -57,6 +57,7 @@ THE SOFTWARE.
|
||||||
#include "base/CCConsole.h"
|
#include "base/CCConsole.h"
|
||||||
#include "base/CCAutoreleasePool.h"
|
#include "base/CCAutoreleasePool.h"
|
||||||
#include "base/CCConfiguration.h"
|
#include "base/CCConfiguration.h"
|
||||||
|
#include "base/CCAsyncTaskPool.h"
|
||||||
#include "platform/CCApplication.h"
|
#include "platform/CCApplication.h"
|
||||||
//#include "platform/CCGLViewImpl.h"
|
//#include "platform/CCGLViewImpl.h"
|
||||||
|
|
||||||
|
@ -982,6 +983,7 @@ void Director::purgeDirector()
|
||||||
GLProgramCache::destroyInstance();
|
GLProgramCache::destroyInstance();
|
||||||
GLProgramStateCache::destroyInstance();
|
GLProgramStateCache::destroyInstance();
|
||||||
FileUtils::destroyInstance();
|
FileUtils::destroyInstance();
|
||||||
|
AsyncTaskPool::destoryInstance();
|
||||||
|
|
||||||
// cocos2d-x specific data structures
|
// cocos2d-x specific data structures
|
||||||
UserDefault::destroyInstance();
|
UserDefault::destroyInstance();
|
||||||
|
|
|
@ -12,6 +12,7 @@ set(COCOS_BASE_SRC
|
||||||
base/allocator/CCAllocatorGlobal.cpp
|
base/allocator/CCAllocatorGlobal.cpp
|
||||||
base/allocator/CCAllocatorGlobalNewDelete.cpp
|
base/allocator/CCAllocatorGlobalNewDelete.cpp
|
||||||
base/ccFPSImages.c
|
base/ccFPSImages.c
|
||||||
|
base/CCAsyncTaskPool.cpp
|
||||||
base/CCAutoreleasePool.cpp
|
base/CCAutoreleasePool.cpp
|
||||||
base/CCConfiguration.cpp
|
base/CCConfiguration.cpp
|
||||||
base/CCConsole.cpp
|
base/CCConsole.cpp
|
||||||
|
|
|
@ -41,7 +41,7 @@
|
||||||
pthread_mutex_lock(&m);
|
pthread_mutex_lock(&m);
|
||||||
#define MUTEX_UNLOCK(m) \
|
#define MUTEX_UNLOCK(m) \
|
||||||
pthread_mutex_unlock(&m);
|
pthread_mutex_unlock(&m);
|
||||||
#elif CC_TARGET_PLATFORM == CC_PLATFORM_WIN32
|
#elif CC_TARGET_PLATFORM == CC_PLATFORM_WIN32 || CC_TARGET_PLATFORM == CC_PLATFORM_WP8 || CC_TARGET_PLATFORM == CC_PLATFORM_WINRT
|
||||||
#include "windows.h"
|
#include "windows.h"
|
||||||
#define MUTEX HANDLE
|
#define MUTEX HANDLE
|
||||||
#define MUTEX_INIT(m) \
|
#define MUTEX_INIT(m) \
|
||||||
|
@ -51,7 +51,11 @@
|
||||||
#define MUTEX_UNLOCK(m) \
|
#define MUTEX_UNLOCK(m) \
|
||||||
ReleaseMutex(m)
|
ReleaseMutex(m)
|
||||||
#else
|
#else
|
||||||
#error "Unsupported platform for AllocatorMutex"
|
#message "Unsupported platform for AllocatorMutex, Locking semantics will not be supported"
|
||||||
|
#define MUTEX
|
||||||
|
#define MUTEX_INIT(...)
|
||||||
|
#define MUTEX_LOCK(...)
|
||||||
|
#define MUTEX_UNLOCK(...)
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
|
@ -100,6 +100,16 @@
|
||||||
-- @param #string texturePath
|
-- @param #string texturePath
|
||||||
-- @return Sprite3D#Sprite3D ret (return value: cc.Sprite3D)
|
-- @return Sprite3D#Sprite3D ret (return value: cc.Sprite3D)
|
||||||
|
|
||||||
|
--------------------------------
|
||||||
|
-- @overload self, string, string, function, void
|
||||||
|
-- @overload self, string, function, void
|
||||||
|
-- @function [parent=#Sprite3D] createAsync
|
||||||
|
-- @param self
|
||||||
|
-- @param #string modelPath
|
||||||
|
-- @param #string texturePath
|
||||||
|
-- @param #function callback
|
||||||
|
-- @param #void callbackparam
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
-- Returns 2d bounding-box<br>
|
-- Returns 2d bounding-box<br>
|
||||||
-- Note: the bouding-box is just get from the AABB which as Z=0, so that is not very accurate.
|
-- Note: the bouding-box is just get from the AABB which as Z=0, so that is not very accurate.
|
||||||
|
|
|
@ -1102,6 +1102,77 @@ int lua_cocos2dx_3d_Sprite3D_create(lua_State* tolua_S)
|
||||||
#endif
|
#endif
|
||||||
return 0;
|
return 0;
|
||||||
}
|
}
|
||||||
|
int lua_cocos2dx_3d_Sprite3D_createAsync(lua_State* tolua_S)
|
||||||
|
{
|
||||||
|
int argc = 0;
|
||||||
|
bool ok = true;
|
||||||
|
#if COCOS2D_DEBUG >= 1
|
||||||
|
tolua_Error tolua_err;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
#if COCOS2D_DEBUG >= 1
|
||||||
|
if (!tolua_isusertable(tolua_S,1,"cc.Sprite3D",0,&tolua_err)) goto tolua_lerror;
|
||||||
|
#endif
|
||||||
|
|
||||||
|
argc = lua_gettop(tolua_S)-1;
|
||||||
|
|
||||||
|
do
|
||||||
|
{
|
||||||
|
if (argc == 4)
|
||||||
|
{
|
||||||
|
std::string arg0;
|
||||||
|
ok &= luaval_to_std_string(tolua_S, 2,&arg0, "cc.Sprite3D:createAsync");
|
||||||
|
if (!ok) { break; }
|
||||||
|
std::string arg1;
|
||||||
|
ok &= luaval_to_std_string(tolua_S, 3,&arg1, "cc.Sprite3D:createAsync");
|
||||||
|
if (!ok) { break; }
|
||||||
|
std::function<void (cocos2d::Sprite3D *, void *)> arg2;
|
||||||
|
do {
|
||||||
|
// Lambda binding for lua is not supported.
|
||||||
|
assert(false);
|
||||||
|
} while(0)
|
||||||
|
;
|
||||||
|
if (!ok) { break; }
|
||||||
|
void* arg3;
|
||||||
|
#pragma warning NO CONVERSION TO NATIVE FOR void*
|
||||||
|
ok = false;
|
||||||
|
if (!ok) { break; }
|
||||||
|
cocos2d::Sprite3D::createAsync(arg0, arg1, arg2, arg3);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
} while (0);
|
||||||
|
ok = true;
|
||||||
|
do
|
||||||
|
{
|
||||||
|
if (argc == 3)
|
||||||
|
{
|
||||||
|
std::string arg0;
|
||||||
|
ok &= luaval_to_std_string(tolua_S, 2,&arg0, "cc.Sprite3D:createAsync");
|
||||||
|
if (!ok) { break; }
|
||||||
|
std::function<void (cocos2d::Sprite3D *, void *)> arg1;
|
||||||
|
do {
|
||||||
|
// Lambda binding for lua is not supported.
|
||||||
|
assert(false);
|
||||||
|
} while(0)
|
||||||
|
;
|
||||||
|
if (!ok) { break; }
|
||||||
|
void* arg2;
|
||||||
|
#pragma warning NO CONVERSION TO NATIVE FOR void*
|
||||||
|
ok = false;
|
||||||
|
if (!ok) { break; }
|
||||||
|
cocos2d::Sprite3D::createAsync(arg0, arg1, arg2);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
} while (0);
|
||||||
|
ok = true;
|
||||||
|
luaL_error(tolua_S, "%s has wrong number of arguments: %d, was expecting %d", "cc.Sprite3D:createAsync",argc, 3);
|
||||||
|
return 0;
|
||||||
|
#if COCOS2D_DEBUG >= 1
|
||||||
|
tolua_lerror:
|
||||||
|
tolua_error(tolua_S,"#ferror in function 'lua_cocos2dx_3d_Sprite3D_createAsync'.",&tolua_err);
|
||||||
|
#endif
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
static int lua_cocos2dx_3d_Sprite3D_finalize(lua_State* tolua_S)
|
static int lua_cocos2dx_3d_Sprite3D_finalize(lua_State* tolua_S)
|
||||||
{
|
{
|
||||||
printf("luabindings: finalizing LUA object (Sprite3D)");
|
printf("luabindings: finalizing LUA object (Sprite3D)");
|
||||||
|
@ -1129,6 +1200,7 @@ int lua_register_cocos2dx_3d_Sprite3D(lua_State* tolua_S)
|
||||||
tolua_function(tolua_S,"getMeshByName",lua_cocos2dx_3d_Sprite3D_getMeshByName);
|
tolua_function(tolua_S,"getMeshByName",lua_cocos2dx_3d_Sprite3D_getMeshByName);
|
||||||
tolua_function(tolua_S,"getAttachNode",lua_cocos2dx_3d_Sprite3D_getAttachNode);
|
tolua_function(tolua_S,"getAttachNode",lua_cocos2dx_3d_Sprite3D_getAttachNode);
|
||||||
tolua_function(tolua_S,"create", lua_cocos2dx_3d_Sprite3D_create);
|
tolua_function(tolua_S,"create", lua_cocos2dx_3d_Sprite3D_create);
|
||||||
|
tolua_function(tolua_S,"createAsync", lua_cocos2dx_3d_Sprite3D_createAsync);
|
||||||
tolua_endmodule(tolua_S);
|
tolua_endmodule(tolua_S);
|
||||||
std::string typeName = typeid(cocos2d::Sprite3D).name();
|
std::string typeName = typeid(cocos2d::Sprite3D).name();
|
||||||
g_luaType[typeName] = "cc.Sprite3D";
|
g_luaType[typeName] = "cc.Sprite3D";
|
||||||
|
|
|
@ -60,6 +60,7 @@ int register_all_cocos2dx_3d(lua_State* tolua_S);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
#endif // __cocos2dx_3d_h__
|
#endif // __cocos2dx_3d_h__
|
||||||
|
|
|
@ -83,9 +83,14 @@ public:
|
||||||
|
|
||||||
static void changeLayoutSystemActiveState(bool bActive);
|
static void changeLayoutSystemActiveState(bool bActive);
|
||||||
|
|
||||||
private:
|
/**
|
||||||
|
*@brief restrict capInsetSize, when the capInsets's width is larger than the textureSize, it will restrict to 0,
|
||||||
|
* the height goes the same way as width.
|
||||||
|
*@param capInsets A user defined capInsets.
|
||||||
|
*@param textureSize The size of a scale9enabled texture
|
||||||
|
*@return a restricted capInset.
|
||||||
|
*/
|
||||||
static Rect restrictCapInsetRect(const Rect& capInsets, const Size& textureSize);
|
static Rect restrictCapInsetRect(const Rect& capInsets, const Size& textureSize);
|
||||||
friend class Button;
|
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -24,6 +24,7 @@ THE SOFTWARE.
|
||||||
|
|
||||||
#include "ui/UIImageView.h"
|
#include "ui/UIImageView.h"
|
||||||
#include "ui/UIScale9Sprite.h"
|
#include "ui/UIScale9Sprite.h"
|
||||||
|
#include "ui/UIHelper.h"
|
||||||
#include "2d/CCSprite.h"
|
#include "2d/CCSprite.h"
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
@ -203,12 +204,12 @@ void ImageView::ignoreContentAdaptWithSize(bool ignore)
|
||||||
|
|
||||||
void ImageView::setCapInsets(const Rect &capInsets)
|
void ImageView::setCapInsets(const Rect &capInsets)
|
||||||
{
|
{
|
||||||
_capInsets = capInsets;
|
_capInsets = ui::Helper::restrictCapInsetRect(capInsets, _imageTextureSize);
|
||||||
if (!_scale9Enabled)
|
if (!_scale9Enabled)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
_imageRenderer->setCapInsets(capInsets);
|
_imageRenderer->setCapInsets(_capInsets);
|
||||||
}
|
}
|
||||||
|
|
||||||
const Rect& ImageView::getCapInsets()const
|
const Rect& ImageView::getCapInsets()const
|
||||||
|
|
|
@ -270,7 +270,7 @@ public:
|
||||||
/**
|
/**
|
||||||
* force refresh widget layout
|
* force refresh widget layout
|
||||||
*/
|
*/
|
||||||
void forceDoLayout();
|
virtual void forceDoLayout();
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* request to refresh widget layout
|
* request to refresh widget layout
|
||||||
|
|
|
@ -453,6 +453,17 @@ void ListView::refreshView()
|
||||||
updateInnerContainerSize();
|
updateInnerContainerSize();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
void ListView::forceDoLayout()
|
||||||
|
{
|
||||||
|
if (_refreshViewDirty)
|
||||||
|
{
|
||||||
|
refreshView();
|
||||||
|
_refreshViewDirty = false;
|
||||||
|
}
|
||||||
|
|
||||||
|
this->_innerContainer->forceDoLayout();
|
||||||
|
}
|
||||||
|
|
||||||
void ListView::doLayout()
|
void ListView::doLayout()
|
||||||
{
|
{
|
||||||
Layout::doLayout();
|
Layout::doLayout();
|
||||||
|
|
|
@ -162,6 +162,8 @@ public:
|
||||||
|
|
||||||
float getItemsMargin()const;
|
float getItemsMargin()const;
|
||||||
|
|
||||||
|
virtual void forceDoLayout()override;
|
||||||
|
|
||||||
virtual void doLayout() override;
|
virtual void doLayout() override;
|
||||||
|
|
||||||
virtual void addChild(Node* child)override;
|
virtual void addChild(Node* child)override;
|
||||||
|
|
|
@ -23,6 +23,7 @@ THE SOFTWARE.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "ui/UILoadingBar.h"
|
#include "ui/UILoadingBar.h"
|
||||||
|
#include "ui/UIHelper.h"
|
||||||
#include "ui/UIScale9Sprite.h"
|
#include "ui/UIScale9Sprite.h"
|
||||||
#include "2d/CCSprite.h"
|
#include "2d/CCSprite.h"
|
||||||
|
|
||||||
|
@ -225,12 +226,12 @@ bool LoadingBar::isScale9Enabled()const
|
||||||
|
|
||||||
void LoadingBar::setCapInsets(const Rect &capInsets)
|
void LoadingBar::setCapInsets(const Rect &capInsets)
|
||||||
{
|
{
|
||||||
_capInsets = capInsets;
|
_capInsets = ui::Helper::restrictCapInsetRect(capInsets, _barRendererTextureSize);
|
||||||
if (!_scale9Enabled)
|
if (!_scale9Enabled)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
_barRenderer->setCapInsets(capInsets);
|
_barRenderer->setCapInsets(_capInsets);
|
||||||
}
|
}
|
||||||
|
|
||||||
const Rect& LoadingBar::getCapInsets()const
|
const Rect& LoadingBar::getCapInsets()const
|
||||||
|
|
|
@ -24,6 +24,7 @@ THE SOFTWARE.
|
||||||
|
|
||||||
#include "ui/UISlider.h"
|
#include "ui/UISlider.h"
|
||||||
#include "ui/UIScale9Sprite.h"
|
#include "ui/UIScale9Sprite.h"
|
||||||
|
#include "ui/UIHelper.h"
|
||||||
#include "2d/CCSprite.h"
|
#include "2d/CCSprite.h"
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
@ -222,12 +223,12 @@ void Slider::setCapInsets(const Rect &capInsets)
|
||||||
|
|
||||||
void Slider::setCapInsetsBarRenderer(const Rect &capInsets)
|
void Slider::setCapInsetsBarRenderer(const Rect &capInsets)
|
||||||
{
|
{
|
||||||
_capInsetsBarRenderer = capInsets;
|
_capInsetsBarRenderer = ui::Helper::restrictCapInsetRect(capInsets, _barRenderer->getContentSize());
|
||||||
if (!_scale9Enabled)
|
if (!_scale9Enabled)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
_barRenderer->setCapInsets(capInsets);
|
_barRenderer->setCapInsets(_capInsetsBarRenderer);
|
||||||
}
|
}
|
||||||
|
|
||||||
const Rect& Slider::getCapInsetsBarRenderer()const
|
const Rect& Slider::getCapInsetsBarRenderer()const
|
||||||
|
@ -237,12 +238,13 @@ const Rect& Slider::getCapInsetsBarRenderer()const
|
||||||
|
|
||||||
void Slider::setCapInsetProgressBarRebderer(const Rect &capInsets)
|
void Slider::setCapInsetProgressBarRebderer(const Rect &capInsets)
|
||||||
{
|
{
|
||||||
_capInsetsProgressBarRenderer = capInsets;
|
_capInsetsProgressBarRenderer = ui::Helper::restrictCapInsetRect(capInsets, _progressBarRenderer->getContentSize());
|
||||||
|
|
||||||
if (!_scale9Enabled)
|
if (!_scale9Enabled)
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
_progressBarRenderer->setCapInsets(capInsets);
|
_progressBarRenderer->setCapInsets(_capInsetsProgressBarRenderer);
|
||||||
}
|
}
|
||||||
|
|
||||||
const Rect& Slider::getCapInsetsProgressBarRebderer()const
|
const Rect& Slider::getCapInsetsProgressBarRebderer()const
|
||||||
|
|
|
@ -346,6 +346,8 @@
|
||||||
"cocos/audio/wp8/MediaStreamer.cpp",
|
"cocos/audio/wp8/MediaStreamer.cpp",
|
||||||
"cocos/audio/wp8/MediaStreamer.h",
|
"cocos/audio/wp8/MediaStreamer.h",
|
||||||
"cocos/audio/wp8/SimpleAudioEngine.cpp",
|
"cocos/audio/wp8/SimpleAudioEngine.cpp",
|
||||||
|
"cocos/base/CCAsyncTaskPool.cpp",
|
||||||
|
"cocos/base/CCAsyncTaskPool.h",
|
||||||
"cocos/base/CCAutoreleasePool.cpp",
|
"cocos/base/CCAutoreleasePool.cpp",
|
||||||
"cocos/base/CCAutoreleasePool.h",
|
"cocos/base/CCAutoreleasePool.h",
|
||||||
"cocos/base/CCConfiguration.cpp",
|
"cocos/base/CCConfiguration.cpp",
|
||||||
|
|
|
@ -24,6 +24,7 @@
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "Sprite3DTest.h"
|
#include "Sprite3DTest.h"
|
||||||
|
#include "base/CCAsyncTaskPool.h"
|
||||||
#include "3d/CCAnimation3D.h"
|
#include "3d/CCAnimation3D.h"
|
||||||
#include "3d/CCAnimate3D.h"
|
#include "3d/CCAnimate3D.h"
|
||||||
#include "3d/CCAttachNode.h"
|
#include "3d/CCAttachNode.h"
|
||||||
|
@ -49,6 +50,7 @@ static std::function<Layer*()> createFunctions[] =
|
||||||
{
|
{
|
||||||
CL(Sprite3DBasicTest),
|
CL(Sprite3DBasicTest),
|
||||||
CL(Sprite3DHitTest),
|
CL(Sprite3DHitTest),
|
||||||
|
CL(AsyncLoadSprite3DTest),
|
||||||
#if (CC_TARGET_PLATFORM != CC_PLATFORM_WP8) && (CC_TARGET_PLATFORM != CC_PLATFORM_WINRT)
|
#if (CC_TARGET_PLATFORM != CC_PLATFORM_WP8) && (CC_TARGET_PLATFORM != CC_PLATFORM_WINRT)
|
||||||
// 3DEffect use custom shader which is not supported on WP8/WinRT yet.
|
// 3DEffect use custom shader which is not supported on WP8/WinRT yet.
|
||||||
CL(Sprite3DEffectTest),
|
CL(Sprite3DEffectTest),
|
||||||
|
@ -1116,6 +1118,73 @@ void Sprite3DEffectTest::onTouchesEnded(const std::vector<Touch*>& touches, Even
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
AsyncLoadSprite3DTest::AsyncLoadSprite3DTest()
|
||||||
|
{
|
||||||
|
_paths.push_back("Sprite3DTest/boss.obj");
|
||||||
|
_paths.push_back("Sprite3DTest/girl.c3b");
|
||||||
|
_paths.push_back("Sprite3DTest/orc.c3b");
|
||||||
|
_paths.push_back("Sprite3DTest/ReskinGirl.c3b");
|
||||||
|
_paths.push_back("Sprite3DTest/axe.c3b");
|
||||||
|
|
||||||
|
TTFConfig ttfConfig("fonts/arial.ttf", 15);
|
||||||
|
auto label1 = Label::createWithTTF(ttfConfig,"AsyncLoad Sprite3D");
|
||||||
|
auto item1 = MenuItemLabel::create(label1,CC_CALLBACK_1(AsyncLoadSprite3DTest::menuCallback_asyncLoadSprite,this) );
|
||||||
|
|
||||||
|
auto s = Director::getInstance()->getWinSize();
|
||||||
|
item1->setPosition( s.width * .5f, s.height * .8f);
|
||||||
|
|
||||||
|
auto pMenu1 = CCMenu::create(item1, nullptr);
|
||||||
|
pMenu1->setPosition(Vec2(0,0));
|
||||||
|
this->addChild(pMenu1, 10);
|
||||||
|
|
||||||
|
auto node = Node::create();
|
||||||
|
node->setTag(101);
|
||||||
|
this->addChild(node);
|
||||||
|
|
||||||
|
menuCallback_asyncLoadSprite(nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
|
AsyncLoadSprite3DTest::~AsyncLoadSprite3DTest()
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string AsyncLoadSprite3DTest::title() const
|
||||||
|
{
|
||||||
|
return "Testing Sprite3D::createAsync";
|
||||||
|
}
|
||||||
|
std::string AsyncLoadSprite3DTest::subtitle() const
|
||||||
|
{
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
void AsyncLoadSprite3DTest::menuCallback_asyncLoadSprite(Ref* sender)
|
||||||
|
{
|
||||||
|
//Note that you must stop the tasks before leaving the scene.
|
||||||
|
AsyncTaskPool::getInstance()->stopTasks(AsyncTaskPool::TaskType::TASK_IO);
|
||||||
|
|
||||||
|
auto node = getChildByTag(101);
|
||||||
|
node->removeAllChildren(); //remove all loaded sprite
|
||||||
|
|
||||||
|
//remove cache data
|
||||||
|
Sprite3DCache::getInstance()->removeAllSprite3DData();
|
||||||
|
long index = 0;
|
||||||
|
for (const auto& path : _paths) {
|
||||||
|
Sprite3D::createAsync(path, CC_CALLBACK_2(AsyncLoadSprite3DTest::asyncLoad_Callback, this), (void*)index++);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
void AsyncLoadSprite3DTest::asyncLoad_Callback(Sprite3D* sprite, void* param)
|
||||||
|
{
|
||||||
|
long index = (long)param;
|
||||||
|
auto node = getChildByTag(101);
|
||||||
|
auto s = Director::getInstance()->getWinSize();
|
||||||
|
float width = s.width / _paths.size();
|
||||||
|
Vec2 point(width * (0.5f + index), s.height / 2.f);
|
||||||
|
sprite->setPosition(point);
|
||||||
|
node->addChild(sprite);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
Sprite3DWithSkinTest::Sprite3DWithSkinTest()
|
Sprite3DWithSkinTest::Sprite3DWithSkinTest()
|
||||||
{
|
{
|
||||||
auto listener = EventListenerTouchAllAtOnce::create();
|
auto listener = EventListenerTouchAllAtOnce::create();
|
||||||
|
|
|
@ -228,6 +228,23 @@ public:
|
||||||
void onTouchesEnded(const std::vector<Touch*>& touches, Event* event);
|
void onTouchesEnded(const std::vector<Touch*>& touches, Event* event);
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class AsyncLoadSprite3DTest : public Sprite3DTestDemo
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
CREATE_FUNC(AsyncLoadSprite3DTest);
|
||||||
|
AsyncLoadSprite3DTest();
|
||||||
|
virtual ~AsyncLoadSprite3DTest();
|
||||||
|
virtual std::string title() const override;
|
||||||
|
virtual std::string subtitle() const override;
|
||||||
|
|
||||||
|
void menuCallback_asyncLoadSprite(Ref* sender);
|
||||||
|
|
||||||
|
void asyncLoad_Callback(Sprite3D* sprite, void* param);
|
||||||
|
|
||||||
|
protected:
|
||||||
|
std::vector<std::string> _paths; //model paths to be loaded
|
||||||
|
};
|
||||||
|
|
||||||
class Sprite3DWithSkinTest : public Sprite3DTestDemo
|
class Sprite3DWithSkinTest : public Sprite3DTestDemo
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
|
|
Loading…
Reference in New Issue