mirror of https://github.com/axmolengine/axmol.git
Merge branch 'v3' of https://github.com/super626/cocos2d-x into v3
Conflicts: cocos/2d/cocos2d.vcxproj.filters cocos/3d/CCBundle3D.cpp cocos/3d/CCBundle3D.h
This commit is contained in:
commit
742ea7f2df
12
AUTHORS
12
AUTHORS
|
@ -716,6 +716,7 @@ Developers:
|
||||||
kicktheken (Kenneth Chan)
|
kicktheken (Kenneth Chan)
|
||||||
Fixed a bug that the setBlendFunc method of some classes wasn't exposed to LUA.
|
Fixed a bug that the setBlendFunc method of some classes wasn't exposed to LUA.
|
||||||
Fix lua project template crash on iOS5.1 device
|
Fix lua project template crash on iOS5.1 device
|
||||||
|
Fix layout constant syntax error in lua-binding
|
||||||
|
|
||||||
andyque
|
andyque
|
||||||
Fixed a bug that missing to check self assignment of Vector<T>, Map<K,V>, Value and String.
|
Fixed a bug that missing to check self assignment of Vector<T>, Map<K,V>, Value and String.
|
||||||
|
@ -830,6 +831,7 @@ Developers:
|
||||||
Fixed incompatible pointer conversion in external/chipmunk/src/cpArray.c
|
Fixed incompatible pointer conversion in external/chipmunk/src/cpArray.c
|
||||||
Fixed memory leak in 'Image'
|
Fixed memory leak in 'Image'
|
||||||
Fixed loosing precision when using 'recv' in 'Console'
|
Fixed loosing precision when using 'recv' in 'Console'
|
||||||
|
Fixed link error with Xcode 6 when building with 32-bit architecture
|
||||||
|
|
||||||
ololomax
|
ololomax
|
||||||
Fixed a potential crash in SceneReader::createNodeWithSceneFile
|
Fixed a potential crash in SceneReader::createNodeWithSceneFile
|
||||||
|
@ -870,6 +872,16 @@ Developers:
|
||||||
uqtimes
|
uqtimes
|
||||||
Fix NSNotificationCenter and NSTimer leaks
|
Fix NSNotificationCenter and NSTimer leaks
|
||||||
|
|
||||||
|
ntotani
|
||||||
|
fix building error in lua-binding in release mode
|
||||||
|
|
||||||
|
kezhuw
|
||||||
|
AutoReleasePool manager improvement
|
||||||
|
|
||||||
|
zhouxiaoxiaoxujian
|
||||||
|
Added TextField::getStringLength()
|
||||||
|
Add shadow, outline, glow filter support for UIText
|
||||||
|
|
||||||
Retired Core Developers:
|
Retired Core Developers:
|
||||||
WenSheng Yang
|
WenSheng Yang
|
||||||
Author of windows port, CCTextField,
|
Author of windows port, CCTextField,
|
||||||
|
|
31
CHANGELOG
31
CHANGELOG
|
@ -1,11 +1,40 @@
|
||||||
cocos2d-x-3.2 ???
|
cocos2d-x-3.2 ???
|
||||||
|
[NEW] Console: add a command to show engine version
|
||||||
|
[NEW] Node: added setter/getter for NormalizedPosition(). Allows to set positions in normalized values (between 0 and 1)
|
||||||
|
[NEW] Scene: Added createWithSize() method
|
||||||
|
[NEW] TextField: added getStringLength()
|
||||||
[NEW] TextureCache: added unbindImageAsync() and unbindAllImageAsync()
|
[NEW] TextureCache: added unbindImageAsync() and unbindAllImageAsync()
|
||||||
|
[NEW] utils: added captureScreen()
|
||||||
|
[NEW] UIText: added shadow, outline, glow filter support
|
||||||
|
|
||||||
[FIX] Application.mk: not output debug message in releae mode on Android
|
[FIX] Application.mk: not output debug message in release mode on Android
|
||||||
|
[FIX] Android: 3d model will be black when coming from background
|
||||||
|
[FIX] Android: don't trigger EVENT_COME_TO_BACKGROUND event when go to background
|
||||||
[FIX] Cocos2dxGLSurfaceView.java: prevent flickering when opening another activity
|
[FIX] Cocos2dxGLSurfaceView.java: prevent flickering when opening another activity
|
||||||
|
[FIX] GLProgramState: sampler can not be changed
|
||||||
[FIX] Image: Set jpeg save quality to 90
|
[FIX] Image: Set jpeg save quality to 90
|
||||||
|
[FIX] Image: premultiply alpha when loading png file to resolve black border issue
|
||||||
[FIX] Label: label is unsharp if it's created by smaller font
|
[FIX] Label: label is unsharp if it's created by smaller font
|
||||||
|
[FIX] Label: Label's display may go bonkers if invoking Label::setString() with outline feature enabled
|
||||||
|
[FIX] Lua-binding: compiling error on release mode
|
||||||
|
[FIX] Lua-binding: Add xxtea encrypt support
|
||||||
|
[FIX] Node: setPhysicsBody() can not work correctly if it is added to a Node
|
||||||
|
[FIX] Node: state of _transformUpdated, _transformDirty and _inverseDirty are wrong in setParent()
|
||||||
|
[FIX] Node: _orderOfArrival is set to 0 after visit
|
||||||
|
[FIX] Other: link error with Xcode 6 when building with 32-bit architecture
|
||||||
[FIX] Repeat: will run one more over in rare situations
|
[FIX] Repeat: will run one more over in rare situations
|
||||||
|
[FIX] Scale9Sprite: support culling
|
||||||
|
[FIX] Schedule: schedulePerFrame() can not be called twice
|
||||||
|
[FIX] SpriteFrameCache: fix memory leak
|
||||||
|
[FIX] Texture2D: use image's pixel format to create texture
|
||||||
|
[FIX] WP8: will restart if app goes to background, then touches icon to go to foreground
|
||||||
|
[FIX] WP8: will be black if: 1. 3rd pops up a view; 2. go to background; 3. come to foreground
|
||||||
|
[FIX] WP8: project name of new project created by console is wrong
|
||||||
|
|
||||||
|
[3RD] curl: will crash if use https request on iOS simulator
|
||||||
|
|
||||||
|
cocos2d-x-3.1.1 May.31 2014
|
||||||
|
[FIX] GLProgramState: restores states after coming from background
|
||||||
|
|
||||||
cocos2d-x-3.1 May.24 2014
|
cocos2d-x-3.1 May.24 2014
|
||||||
[FIX] EventKeyboard::KeyCode: key code for back button changed from KEY_BACKSPACE to KEY_ESCAPE
|
[FIX] EventKeyboard::KeyCode: key code for back button changed from KEY_BACKSPACE to KEY_ESCAPE
|
||||||
|
|
|
@ -151,6 +151,7 @@ include_directories(
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/external/freetype2/include/${PLATFORM_FOLDER}
|
${CMAKE_CURRENT_SOURCE_DIR}/external/freetype2/include/${PLATFORM_FOLDER}
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/external/websockets/include/${PLATFORM_FOLDER}
|
${CMAKE_CURRENT_SOURCE_DIR}/external/websockets/include/${PLATFORM_FOLDER}
|
||||||
${CMAKE_CURRENT_SOURCE_DIR}/external/xxhash
|
${CMAKE_CURRENT_SOURCE_DIR}/external/xxhash
|
||||||
|
${CMAKE_CURRENT_SOURCE_DIR}/external/xxtea
|
||||||
)
|
)
|
||||||
|
|
||||||
if(WIN32 AND NOT MINGW)
|
if(WIN32 AND NOT MINGW)
|
||||||
|
@ -258,6 +259,9 @@ add_subdirectory(external/lua/tolua)
|
||||||
|
|
||||||
# luabinding
|
# luabinding
|
||||||
add_subdirectory(cocos/scripting/lua-bindings)
|
add_subdirectory(cocos/scripting/lua-bindings)
|
||||||
|
|
||||||
|
# xxtea
|
||||||
|
add_subdirectory(external/xxtea)
|
||||||
endif(BUILD_LIBS_LUA)
|
endif(BUILD_LIBS_LUA)
|
||||||
|
|
||||||
# build tests
|
# build tests
|
||||||
|
|
|
@ -40,8 +40,6 @@
|
||||||
/* End PBXAggregateTarget section */
|
/* End PBXAggregateTarget section */
|
||||||
|
|
||||||
/* Begin PBXBuildFile section */
|
/* Begin PBXBuildFile section */
|
||||||
06C0F2EF186AD822003594D5 /* ObjectFactory.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 06CAAABA186AD63B0012A414 /* ObjectFactory.cpp */; };
|
|
||||||
06C0F2F0186AD824003594D5 /* ObjectFactory.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 06CAAABA186AD63B0012A414 /* ObjectFactory.cpp */; };
|
|
||||||
06CAAAC5186AD7E50012A414 /* TriggerObj.h in Headers */ = {isa = PBXBuildFile; fileRef = 06CAAAC1186AD63B0012A414 /* TriggerObj.h */; };
|
06CAAAC5186AD7E50012A414 /* TriggerObj.h in Headers */ = {isa = PBXBuildFile; fileRef = 06CAAAC1186AD63B0012A414 /* TriggerObj.h */; };
|
||||||
06CAAAC6186AD7E60012A414 /* TriggerObj.h in Headers */ = {isa = PBXBuildFile; fileRef = 06CAAAC1186AD63B0012A414 /* TriggerObj.h */; };
|
06CAAAC6186AD7E60012A414 /* TriggerObj.h in Headers */ = {isa = PBXBuildFile; fileRef = 06CAAAC1186AD63B0012A414 /* TriggerObj.h */; };
|
||||||
06CAAAC7186AD7E90012A414 /* TriggerObj.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 06CAAAC0186AD63B0012A414 /* TriggerObj.cpp */; };
|
06CAAAC7186AD7E90012A414 /* TriggerObj.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 06CAAAC0186AD63B0012A414 /* TriggerObj.cpp */; };
|
||||||
|
@ -54,8 +52,6 @@
|
||||||
06CAAACE186AD7FA0012A414 /* TriggerBase.h in Headers */ = {isa = PBXBuildFile; fileRef = 06CAAABD186AD63B0012A414 /* TriggerBase.h */; };
|
06CAAACE186AD7FA0012A414 /* TriggerBase.h in Headers */ = {isa = PBXBuildFile; fileRef = 06CAAABD186AD63B0012A414 /* TriggerBase.h */; };
|
||||||
06CAAACF186AD7FC0012A414 /* TriggerBase.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 06CAAABC186AD63B0012A414 /* TriggerBase.cpp */; };
|
06CAAACF186AD7FC0012A414 /* TriggerBase.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 06CAAABC186AD63B0012A414 /* TriggerBase.cpp */; };
|
||||||
06CAAAD0186AD7FE0012A414 /* TriggerBase.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 06CAAABC186AD63B0012A414 /* TriggerBase.cpp */; };
|
06CAAAD0186AD7FE0012A414 /* TriggerBase.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 06CAAABC186AD63B0012A414 /* TriggerBase.cpp */; };
|
||||||
06CAAAD1186AD8010012A414 /* ObjectFactory.h in Headers */ = {isa = PBXBuildFile; fileRef = 06CAAABB186AD63B0012A414 /* ObjectFactory.h */; };
|
|
||||||
06CAAAD2186AD8030012A414 /* ObjectFactory.h in Headers */ = {isa = PBXBuildFile; fileRef = 06CAAABB186AD63B0012A414 /* ObjectFactory.h */; };
|
|
||||||
1A01C68418F57BE800EFE3A6 /* CCArray.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A01C67618F57BE800EFE3A6 /* CCArray.cpp */; };
|
1A01C68418F57BE800EFE3A6 /* CCArray.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A01C67618F57BE800EFE3A6 /* CCArray.cpp */; };
|
||||||
1A01C68518F57BE800EFE3A6 /* CCArray.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A01C67618F57BE800EFE3A6 /* CCArray.cpp */; };
|
1A01C68518F57BE800EFE3A6 /* CCArray.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1A01C67618F57BE800EFE3A6 /* CCArray.cpp */; };
|
||||||
1A01C68618F57BE800EFE3A6 /* CCArray.h in Headers */ = {isa = PBXBuildFile; fileRef = 1A01C67718F57BE800EFE3A6 /* CCArray.h */; };
|
1A01C68618F57BE800EFE3A6 /* CCArray.h in Headers */ = {isa = PBXBuildFile; fileRef = 1A01C67718F57BE800EFE3A6 /* CCArray.h */; };
|
||||||
|
@ -973,12 +969,14 @@
|
||||||
2905FA8E18CF08D100240AA3 /* UIWidget.h in Headers */ = {isa = PBXBuildFile; fileRef = 2905FA1418CF08D100240AA3 /* UIWidget.h */; };
|
2905FA8E18CF08D100240AA3 /* UIWidget.h in Headers */ = {isa = PBXBuildFile; fileRef = 2905FA1418CF08D100240AA3 /* UIWidget.h */; };
|
||||||
2905FA8F18CF08D100240AA3 /* UIWidget.h in Headers */ = {isa = PBXBuildFile; fileRef = 2905FA1418CF08D100240AA3 /* UIWidget.h */; };
|
2905FA8F18CF08D100240AA3 /* UIWidget.h in Headers */ = {isa = PBXBuildFile; fileRef = 2905FA1418CF08D100240AA3 /* UIWidget.h */; };
|
||||||
2986667F18B1B246000E39CA /* CCTweenFunction.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 2986667818B1B079000E39CA /* CCTweenFunction.cpp */; };
|
2986667F18B1B246000E39CA /* CCTweenFunction.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 2986667818B1B079000E39CA /* CCTweenFunction.cpp */; };
|
||||||
|
299754F4193EC95400A54AC3 /* ObjectFactory.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 299754F2193EC95400A54AC3 /* ObjectFactory.cpp */; };
|
||||||
|
299754F5193EC95400A54AC3 /* ObjectFactory.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 299754F2193EC95400A54AC3 /* ObjectFactory.cpp */; };
|
||||||
|
299754F6193EC95400A54AC3 /* ObjectFactory.h in Headers */ = {isa = PBXBuildFile; fileRef = 299754F3193EC95400A54AC3 /* ObjectFactory.h */; };
|
||||||
|
299754F7193EC95400A54AC3 /* ObjectFactory.h in Headers */ = {isa = PBXBuildFile; fileRef = 299754F3193EC95400A54AC3 /* ObjectFactory.h */; };
|
||||||
29CB8F4C1929D1BB00C841D6 /* UILayoutManager.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 29CB8F4A1929D1BB00C841D6 /* UILayoutManager.cpp */; };
|
29CB8F4C1929D1BB00C841D6 /* UILayoutManager.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 29CB8F4A1929D1BB00C841D6 /* UILayoutManager.cpp */; };
|
||||||
29CB8F4D1929D1BB00C841D6 /* UILayoutManager.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 29CB8F4A1929D1BB00C841D6 /* UILayoutManager.cpp */; };
|
29CB8F4D1929D1BB00C841D6 /* UILayoutManager.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 29CB8F4A1929D1BB00C841D6 /* UILayoutManager.cpp */; };
|
||||||
29CB8F4E1929D1BB00C841D6 /* UILayoutManager.h in Headers */ = {isa = PBXBuildFile; fileRef = 29CB8F4B1929D1BB00C841D6 /* UILayoutManager.h */; };
|
29CB8F4E1929D1BB00C841D6 /* UILayoutManager.h in Headers */ = {isa = PBXBuildFile; fileRef = 29CB8F4B1929D1BB00C841D6 /* UILayoutManager.h */; };
|
||||||
29CB8F4F1929D1BB00C841D6 /* UILayoutManager.h in Headers */ = {isa = PBXBuildFile; fileRef = 29CB8F4B1929D1BB00C841D6 /* UILayoutManager.h */; };
|
29CB8F4F1929D1BB00C841D6 /* UILayoutManager.h in Headers */ = {isa = PBXBuildFile; fileRef = 29CB8F4B1929D1BB00C841D6 /* UILayoutManager.h */; };
|
||||||
29CB8F551929D7A900C841D6 /* UIScrollInterface.h in Headers */ = {isa = PBXBuildFile; fileRef = 29CB8F541929D7A900C841D6 /* UIScrollInterface.h */; };
|
|
||||||
29CB8F561929D7A900C841D6 /* UIScrollInterface.h in Headers */ = {isa = PBXBuildFile; fileRef = 29CB8F541929D7A900C841D6 /* UIScrollInterface.h */; };
|
|
||||||
2AC795DB1862870F005EC8E1 /* SkeletonBounds.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 2AC795D918628689005EC8E1 /* SkeletonBounds.cpp */; };
|
2AC795DB1862870F005EC8E1 /* SkeletonBounds.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 2AC795D918628689005EC8E1 /* SkeletonBounds.cpp */; };
|
||||||
2AC795DC1862870F005EC8E1 /* Event.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 2AC795D51862867D005EC8E1 /* Event.cpp */; };
|
2AC795DC1862870F005EC8E1 /* Event.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 2AC795D51862867D005EC8E1 /* Event.cpp */; };
|
||||||
2AC795DD1862870F005EC8E1 /* EventData.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 2AC795D71862867D005EC8E1 /* EventData.cpp */; };
|
2AC795DD1862870F005EC8E1 /* EventData.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 2AC795D71862867D005EC8E1 /* EventData.cpp */; };
|
||||||
|
@ -1747,6 +1745,8 @@
|
||||||
B29594CF1926D61F003EEF37 /* CCSprite3DDataCache.cpp in Sources */ = {isa = PBXBuildFile; fileRef = B29594BF1926D61F003EEF37 /* CCSprite3DDataCache.cpp */; };
|
B29594CF1926D61F003EEF37 /* CCSprite3DDataCache.cpp in Sources */ = {isa = PBXBuildFile; fileRef = B29594BF1926D61F003EEF37 /* CCSprite3DDataCache.cpp */; };
|
||||||
B29594D01926D61F003EEF37 /* CCSprite3DDataCache.h in Headers */ = {isa = PBXBuildFile; fileRef = B29594C01926D61F003EEF37 /* CCSprite3DDataCache.h */; };
|
B29594D01926D61F003EEF37 /* CCSprite3DDataCache.h in Headers */ = {isa = PBXBuildFile; fileRef = B29594C01926D61F003EEF37 /* CCSprite3DDataCache.h */; };
|
||||||
B29594D11926D61F003EEF37 /* CCSprite3DDataCache.h in Headers */ = {isa = PBXBuildFile; fileRef = B29594C01926D61F003EEF37 /* CCSprite3DDataCache.h */; };
|
B29594D11926D61F003EEF37 /* CCSprite3DDataCache.h in Headers */ = {isa = PBXBuildFile; fileRef = B29594C01926D61F003EEF37 /* CCSprite3DDataCache.h */; };
|
||||||
|
B2D3D3B91948613300BA4831 /* CCBundle3DData.h in Headers */ = {isa = PBXBuildFile; fileRef = B2D3D3B81948613300BA4831 /* CCBundle3DData.h */; };
|
||||||
|
B2D3D3BA1948613300BA4831 /* CCBundle3DData.h in Headers */ = {isa = PBXBuildFile; fileRef = B2D3D3B81948613300BA4831 /* CCBundle3DData.h */; };
|
||||||
B37510711823AC9F00B3BA6A /* CCPhysicsBodyInfo_chipmunk.cpp in Sources */ = {isa = PBXBuildFile; fileRef = B37510451823AC7B00B3BA6A /* CCPhysicsBodyInfo_chipmunk.cpp */; };
|
B37510711823AC9F00B3BA6A /* CCPhysicsBodyInfo_chipmunk.cpp in Sources */ = {isa = PBXBuildFile; fileRef = B37510451823AC7B00B3BA6A /* CCPhysicsBodyInfo_chipmunk.cpp */; };
|
||||||
B37510721823AC9F00B3BA6A /* CCPhysicsBodyInfo_chipmunk.h in Headers */ = {isa = PBXBuildFile; fileRef = B37510461823AC7B00B3BA6A /* CCPhysicsBodyInfo_chipmunk.h */; };
|
B37510721823AC9F00B3BA6A /* CCPhysicsBodyInfo_chipmunk.h in Headers */ = {isa = PBXBuildFile; fileRef = B37510461823AC7B00B3BA6A /* CCPhysicsBodyInfo_chipmunk.h */; };
|
||||||
B37510731823AC9F00B3BA6A /* CCPhysicsContactInfo_chipmunk.cpp in Sources */ = {isa = PBXBuildFile; fileRef = B37510471823AC7B00B3BA6A /* CCPhysicsContactInfo_chipmunk.cpp */; };
|
B37510731823AC9F00B3BA6A /* CCPhysicsContactInfo_chipmunk.cpp in Sources */ = {isa = PBXBuildFile; fileRef = B37510471823AC7B00B3BA6A /* CCPhysicsContactInfo_chipmunk.cpp */; };
|
||||||
|
@ -1887,8 +1887,6 @@
|
||||||
/* End PBXContainerItemProxy section */
|
/* End PBXContainerItemProxy section */
|
||||||
|
|
||||||
/* Begin PBXFileReference section */
|
/* Begin PBXFileReference section */
|
||||||
06CAAABA186AD63B0012A414 /* ObjectFactory.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = ObjectFactory.cpp; sourceTree = "<group>"; };
|
|
||||||
06CAAABB186AD63B0012A414 /* ObjectFactory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = ObjectFactory.h; sourceTree = "<group>"; };
|
|
||||||
06CAAABC186AD63B0012A414 /* TriggerBase.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = TriggerBase.cpp; sourceTree = "<group>"; };
|
06CAAABC186AD63B0012A414 /* TriggerBase.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = TriggerBase.cpp; sourceTree = "<group>"; };
|
||||||
06CAAABD186AD63B0012A414 /* TriggerBase.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = TriggerBase.h; sourceTree = "<group>"; };
|
06CAAABD186AD63B0012A414 /* TriggerBase.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = TriggerBase.h; sourceTree = "<group>"; };
|
||||||
06CAAABE186AD63B0012A414 /* TriggerMng.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = TriggerMng.cpp; sourceTree = "<group>"; };
|
06CAAABE186AD63B0012A414 /* TriggerMng.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = TriggerMng.cpp; sourceTree = "<group>"; };
|
||||||
|
@ -2274,9 +2272,10 @@
|
||||||
29080DEB191B82CE0066F8DF /* UIDeprecated.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = UIDeprecated.h; sourceTree = "<group>"; };
|
29080DEB191B82CE0066F8DF /* UIDeprecated.h */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.c.h; path = UIDeprecated.h; sourceTree = "<group>"; };
|
||||||
2986667818B1B079000E39CA /* CCTweenFunction.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CCTweenFunction.cpp; sourceTree = "<group>"; };
|
2986667818B1B079000E39CA /* CCTweenFunction.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CCTweenFunction.cpp; sourceTree = "<group>"; };
|
||||||
2986667918B1B079000E39CA /* CCTweenFunction.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CCTweenFunction.h; sourceTree = "<group>"; };
|
2986667918B1B079000E39CA /* CCTweenFunction.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CCTweenFunction.h; sourceTree = "<group>"; };
|
||||||
|
299754F2193EC95400A54AC3 /* ObjectFactory.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; name = ObjectFactory.cpp; path = ../base/ObjectFactory.cpp; sourceTree = "<group>"; };
|
||||||
|
299754F3193EC95400A54AC3 /* ObjectFactory.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; name = ObjectFactory.h; path = ../base/ObjectFactory.h; sourceTree = "<group>"; };
|
||||||
29CB8F4A1929D1BB00C841D6 /* UILayoutManager.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = UILayoutManager.cpp; sourceTree = "<group>"; };
|
29CB8F4A1929D1BB00C841D6 /* UILayoutManager.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = UILayoutManager.cpp; sourceTree = "<group>"; };
|
||||||
29CB8F4B1929D1BB00C841D6 /* UILayoutManager.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = UILayoutManager.h; sourceTree = "<group>"; };
|
29CB8F4B1929D1BB00C841D6 /* UILayoutManager.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = UILayoutManager.h; sourceTree = "<group>"; };
|
||||||
29CB8F541929D7A900C841D6 /* UIScrollInterface.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = UIScrollInterface.h; sourceTree = "<group>"; };
|
|
||||||
2AC795D318628672005EC8E1 /* BoundingBoxAttachment.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = BoundingBoxAttachment.cpp; sourceTree = "<group>"; };
|
2AC795D318628672005EC8E1 /* BoundingBoxAttachment.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = BoundingBoxAttachment.cpp; sourceTree = "<group>"; };
|
||||||
2AC795D418628672005EC8E1 /* BoundingBoxAttachment.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = BoundingBoxAttachment.h; sourceTree = "<group>"; };
|
2AC795D418628672005EC8E1 /* BoundingBoxAttachment.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = BoundingBoxAttachment.h; sourceTree = "<group>"; };
|
||||||
2AC795D51862867D005EC8E1 /* Event.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = Event.cpp; sourceTree = "<group>"; };
|
2AC795D51862867D005EC8E1 /* Event.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = Event.cpp; sourceTree = "<group>"; };
|
||||||
|
@ -2815,6 +2814,7 @@
|
||||||
B29594BE1926D61F003EEF37 /* CCSprite3D.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CCSprite3D.h; sourceTree = "<group>"; };
|
B29594BE1926D61F003EEF37 /* CCSprite3D.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CCSprite3D.h; sourceTree = "<group>"; };
|
||||||
B29594BF1926D61F003EEF37 /* CCSprite3DDataCache.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CCSprite3DDataCache.cpp; sourceTree = "<group>"; };
|
B29594BF1926D61F003EEF37 /* CCSprite3DDataCache.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CCSprite3DDataCache.cpp; sourceTree = "<group>"; };
|
||||||
B29594C01926D61F003EEF37 /* CCSprite3DDataCache.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CCSprite3DDataCache.h; sourceTree = "<group>"; };
|
B29594C01926D61F003EEF37 /* CCSprite3DDataCache.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CCSprite3DDataCache.h; sourceTree = "<group>"; };
|
||||||
|
B2D3D3B81948613300BA4831 /* CCBundle3DData.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CCBundle3DData.h; sourceTree = "<group>"; };
|
||||||
B37510451823AC7B00B3BA6A /* CCPhysicsBodyInfo_chipmunk.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CCPhysicsBodyInfo_chipmunk.cpp; sourceTree = "<group>"; };
|
B37510451823AC7B00B3BA6A /* CCPhysicsBodyInfo_chipmunk.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CCPhysicsBodyInfo_chipmunk.cpp; sourceTree = "<group>"; };
|
||||||
B37510461823AC7B00B3BA6A /* CCPhysicsBodyInfo_chipmunk.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CCPhysicsBodyInfo_chipmunk.h; sourceTree = "<group>"; };
|
B37510461823AC7B00B3BA6A /* CCPhysicsBodyInfo_chipmunk.h */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.c.h; path = CCPhysicsBodyInfo_chipmunk.h; sourceTree = "<group>"; };
|
||||||
B37510471823AC7B00B3BA6A /* CCPhysicsContactInfo_chipmunk.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CCPhysicsContactInfo_chipmunk.cpp; sourceTree = "<group>"; };
|
B37510471823AC7B00B3BA6A /* CCPhysicsContactInfo_chipmunk.cpp */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = sourcecode.cpp.cpp; path = CCPhysicsContactInfo_chipmunk.cpp; sourceTree = "<group>"; };
|
||||||
|
@ -3071,6 +3071,8 @@
|
||||||
1A5700A2180BC5E60088DEC7 /* base */ = {
|
1A5700A2180BC5E60088DEC7 /* base */ = {
|
||||||
isa = PBXGroup;
|
isa = PBXGroup;
|
||||||
children = (
|
children = (
|
||||||
|
299754F2193EC95400A54AC3 /* ObjectFactory.cpp */,
|
||||||
|
299754F3193EC95400A54AC3 /* ObjectFactory.h */,
|
||||||
50ABBDC11925AB6E00A911A9 /* atitc.cpp */,
|
50ABBDC11925AB6E00A911A9 /* atitc.cpp */,
|
||||||
50ABBDC21925AB6E00A911A9 /* atitc.h */,
|
50ABBDC21925AB6E00A911A9 /* atitc.h */,
|
||||||
50ABBDC31925AB6E00A911A9 /* base64.cpp */,
|
50ABBDC31925AB6E00A911A9 /* base64.cpp */,
|
||||||
|
@ -3590,8 +3592,6 @@
|
||||||
children = (
|
children = (
|
||||||
50FCEB6818C72017004AD434 /* WidgetReader */,
|
50FCEB6818C72017004AD434 /* WidgetReader */,
|
||||||
06CAAAC1186AD63B0012A414 /* TriggerObj.h */,
|
06CAAAC1186AD63B0012A414 /* TriggerObj.h */,
|
||||||
06CAAABA186AD63B0012A414 /* ObjectFactory.cpp */,
|
|
||||||
06CAAABB186AD63B0012A414 /* ObjectFactory.h */,
|
|
||||||
06CAAABC186AD63B0012A414 /* TriggerBase.cpp */,
|
06CAAABC186AD63B0012A414 /* TriggerBase.cpp */,
|
||||||
06CAAABD186AD63B0012A414 /* TriggerBase.h */,
|
06CAAABD186AD63B0012A414 /* TriggerBase.h */,
|
||||||
06CAAABE186AD63B0012A414 /* TriggerMng.cpp */,
|
06CAAABE186AD63B0012A414 /* TriggerMng.cpp */,
|
||||||
|
@ -4003,7 +4003,6 @@
|
||||||
2905FA0518CF08D000240AA3 /* UIRichText.h */,
|
2905FA0518CF08D000240AA3 /* UIRichText.h */,
|
||||||
2905FA0718CF08D000240AA3 /* UIScrollView.cpp */,
|
2905FA0718CF08D000240AA3 /* UIScrollView.cpp */,
|
||||||
2905FA0818CF08D000240AA3 /* UIScrollView.h */,
|
2905FA0818CF08D000240AA3 /* UIScrollView.h */,
|
||||||
29CB8F541929D7A900C841D6 /* UIScrollInterface.h */,
|
|
||||||
2905FA0918CF08D000240AA3 /* UISlider.cpp */,
|
2905FA0918CF08D000240AA3 /* UISlider.cpp */,
|
||||||
2905FA0A18CF08D100240AA3 /* UISlider.h */,
|
2905FA0A18CF08D100240AA3 /* UISlider.h */,
|
||||||
2905FA0B18CF08D100240AA3 /* UIText.cpp */,
|
2905FA0B18CF08D100240AA3 /* UIText.cpp */,
|
||||||
|
@ -4867,6 +4866,7 @@
|
||||||
B29594BE1926D61F003EEF37 /* CCSprite3D.h */,
|
B29594BE1926D61F003EEF37 /* CCSprite3D.h */,
|
||||||
B29594BF1926D61F003EEF37 /* CCSprite3DDataCache.cpp */,
|
B29594BF1926D61F003EEF37 /* CCSprite3DDataCache.cpp */,
|
||||||
B29594C01926D61F003EEF37 /* CCSprite3DDataCache.h */,
|
B29594C01926D61F003EEF37 /* CCSprite3DDataCache.h */,
|
||||||
|
B2D3D3B81948613300BA4831 /* CCBundle3DData.h */,
|
||||||
);
|
);
|
||||||
name = 3d;
|
name = 3d;
|
||||||
path = ../cocos/3d;
|
path = ../cocos/3d;
|
||||||
|
@ -4921,7 +4921,6 @@
|
||||||
1A570073180BC5A10088DEC7 /* CCActionGrid.h in Headers */,
|
1A570073180BC5A10088DEC7 /* CCActionGrid.h in Headers */,
|
||||||
50FCEBB518C72017004AD434 /* SliderReader.h in Headers */,
|
50FCEBB518C72017004AD434 /* SliderReader.h in Headers */,
|
||||||
5034CA3B191D591100CE6051 /* ccShader_PositionColor.vert in Headers */,
|
5034CA3B191D591100CE6051 /* ccShader_PositionColor.vert in Headers */,
|
||||||
06CAAAD1186AD8010012A414 /* ObjectFactory.h in Headers */,
|
|
||||||
1A570077180BC5A10088DEC7 /* CCActionGrid3D.h in Headers */,
|
1A570077180BC5A10088DEC7 /* CCActionGrid3D.h in Headers */,
|
||||||
1A57007B180BC5A10088DEC7 /* CCActionInstant.h in Headers */,
|
1A57007B180BC5A10088DEC7 /* CCActionInstant.h in Headers */,
|
||||||
1A57007F180BC5A10088DEC7 /* CCActionInterval.h in Headers */,
|
1A57007F180BC5A10088DEC7 /* CCActionInterval.h in Headers */,
|
||||||
|
@ -4935,6 +4934,7 @@
|
||||||
50ABBD8D1925AB4100A911A9 /* CCGLProgram.h in Headers */,
|
50ABBD8D1925AB4100A911A9 /* CCGLProgram.h in Headers */,
|
||||||
50ABBEA11925AB6F00A911A9 /* CCScheduler.h in Headers */,
|
50ABBEA11925AB6F00A911A9 /* CCScheduler.h in Headers */,
|
||||||
50ABBDB71925AB4100A911A9 /* CCTexture2D.h in Headers */,
|
50ABBDB71925AB4100A911A9 /* CCTexture2D.h in Headers */,
|
||||||
|
B2D3D3B91948613300BA4831 /* CCBundle3DData.h in Headers */,
|
||||||
2905FA6C18CF08D100240AA3 /* UIPageView.h in Headers */,
|
2905FA6C18CF08D100240AA3 /* UIPageView.h in Headers */,
|
||||||
50FCEB9518C72017004AD434 /* ButtonReader.h in Headers */,
|
50FCEB9518C72017004AD434 /* ButtonReader.h in Headers */,
|
||||||
50ABBE811925AB6F00A911A9 /* CCEventType.h in Headers */,
|
50ABBE811925AB6F00A911A9 /* CCEventType.h in Headers */,
|
||||||
|
@ -5007,6 +5007,7 @@
|
||||||
1A01C68C18F57BE800EFE3A6 /* CCDeprecated.h in Headers */,
|
1A01C68C18F57BE800EFE3A6 /* CCDeprecated.h in Headers */,
|
||||||
50ABBD561925AB0000A911A9 /* TransformUtils.h in Headers */,
|
50ABBD561925AB0000A911A9 /* TransformUtils.h in Headers */,
|
||||||
2905FA6418CF08D100240AA3 /* UIListView.h in Headers */,
|
2905FA6418CF08D100240AA3 /* UIListView.h in Headers */,
|
||||||
|
299754F6193EC95400A54AC3 /* ObjectFactory.h in Headers */,
|
||||||
50FCEBB918C72017004AD434 /* TextAtlasReader.h in Headers */,
|
50FCEBB918C72017004AD434 /* TextAtlasReader.h in Headers */,
|
||||||
50ABBD991925AB4100A911A9 /* CCGLProgramStateCache.h in Headers */,
|
50ABBD991925AB4100A911A9 /* CCGLProgramStateCache.h in Headers */,
|
||||||
5034CA3D191D591100CE6051 /* ccShader_PositionColor.frag in Headers */,
|
5034CA3D191D591100CE6051 /* ccShader_PositionColor.frag in Headers */,
|
||||||
|
@ -5153,7 +5154,6 @@
|
||||||
50ABBD9D1925AB4100A911A9 /* ccGLStateCache.h in Headers */,
|
50ABBD9D1925AB4100A911A9 /* ccGLStateCache.h in Headers */,
|
||||||
50ABBEB91925AB6F00A911A9 /* ccUTF8.h in Headers */,
|
50ABBEB91925AB6F00A911A9 /* ccUTF8.h in Headers */,
|
||||||
1AAF536E180E3374000584C8 /* HttpRequest.h in Headers */,
|
1AAF536E180E3374000584C8 /* HttpRequest.h in Headers */,
|
||||||
29CB8F551929D7A900C841D6 /* UIScrollInterface.h in Headers */,
|
|
||||||
1AAF5370180E3374000584C8 /* HttpResponse.h in Headers */,
|
1AAF5370180E3374000584C8 /* HttpResponse.h in Headers */,
|
||||||
50ABBE671925AB6F00A911A9 /* CCEventListenerCustom.h in Headers */,
|
50ABBE671925AB6F00A911A9 /* CCEventListenerCustom.h in Headers */,
|
||||||
1AAF5374180E3374000584C8 /* SocketIO.h in Headers */,
|
1AAF5374180E3374000584C8 /* SocketIO.h in Headers */,
|
||||||
|
@ -5423,6 +5423,7 @@
|
||||||
1A01C68918F57BE800EFE3A6 /* CCBool.h in Headers */,
|
1A01C68918F57BE800EFE3A6 /* CCBool.h in Headers */,
|
||||||
1A57007C180BC5A10088DEC7 /* CCActionInstant.h in Headers */,
|
1A57007C180BC5A10088DEC7 /* CCActionInstant.h in Headers */,
|
||||||
50ABBE781925AB6F00A911A9 /* CCEventListenerTouch.h in Headers */,
|
50ABBE781925AB6F00A911A9 /* CCEventListenerTouch.h in Headers */,
|
||||||
|
B2D3D3BA1948613300BA4831 /* CCBundle3DData.h in Headers */,
|
||||||
B37510861823ACA100B3BA6A /* CCPhysicsWorldInfo_chipmunk.h in Headers */,
|
B37510861823ACA100B3BA6A /* CCPhysicsWorldInfo_chipmunk.h in Headers */,
|
||||||
1A570080180BC5A10088DEC7 /* CCActionInterval.h in Headers */,
|
1A570080180BC5A10088DEC7 /* CCActionInterval.h in Headers */,
|
||||||
1A570084180BC5A10088DEC7 /* CCActionManager.h in Headers */,
|
1A570084180BC5A10088DEC7 /* CCActionManager.h in Headers */,
|
||||||
|
@ -5440,6 +5441,7 @@
|
||||||
2905FA7118CF08D100240AA3 /* UIRichText.h in Headers */,
|
2905FA7118CF08D100240AA3 /* UIRichText.h in Headers */,
|
||||||
503DD8E41926736A00CD74DD /* CCDirectorCaller.h in Headers */,
|
503DD8E41926736A00CD74DD /* CCDirectorCaller.h in Headers */,
|
||||||
50ABBD8A1925AB4100A911A9 /* CCCustomCommand.h in Headers */,
|
50ABBD8A1925AB4100A911A9 /* CCCustomCommand.h in Headers */,
|
||||||
|
299754F7193EC95400A54AC3 /* ObjectFactory.h in Headers */,
|
||||||
2905FA6D18CF08D100240AA3 /* UIPageView.h in Headers */,
|
2905FA6D18CF08D100240AA3 /* UIPageView.h in Headers */,
|
||||||
50ABBE881925AB6F00A911A9 /* ccMacros.h in Headers */,
|
50ABBE881925AB6F00A911A9 /* ccMacros.h in Headers */,
|
||||||
50ABC0101926664800A911A9 /* CCFileUtils.h in Headers */,
|
50ABC0101926664800A911A9 /* CCFileUtils.h in Headers */,
|
||||||
|
@ -5523,7 +5525,6 @@
|
||||||
50ABBDB81925AB4100A911A9 /* CCTexture2D.h in Headers */,
|
50ABBDB81925AB4100A911A9 /* CCTexture2D.h in Headers */,
|
||||||
50ABBE341925AB6F00A911A9 /* CCConfiguration.h in Headers */,
|
50ABBE341925AB6F00A911A9 /* CCConfiguration.h in Headers */,
|
||||||
1A570299180BCCAB0088DEC7 /* CCAnimationCache.h in Headers */,
|
1A570299180BCCAB0088DEC7 /* CCAnimationCache.h in Headers */,
|
||||||
06CAAAD2186AD8030012A414 /* ObjectFactory.h in Headers */,
|
|
||||||
50ABBEAA1925AB6F00A911A9 /* CCTouch.h in Headers */,
|
50ABBEAA1925AB6F00A911A9 /* CCTouch.h in Headers */,
|
||||||
2905FA6918CF08D100240AA3 /* UILoadingBar.h in Headers */,
|
2905FA6918CF08D100240AA3 /* UILoadingBar.h in Headers */,
|
||||||
50ABBE741925AB6F00A911A9 /* CCEventListenerMouse.h in Headers */,
|
50ABBE741925AB6F00A911A9 /* CCEventListenerMouse.h in Headers */,
|
||||||
|
@ -5611,7 +5612,6 @@
|
||||||
50ABBD921925AB4100A911A9 /* CCGLProgramCache.h in Headers */,
|
50ABBD921925AB4100A911A9 /* CCGLProgramCache.h in Headers */,
|
||||||
1AD71E0E180E26E600808F54 /* CocosBuilder.h in Headers */,
|
1AD71E0E180E26E600808F54 /* CocosBuilder.h in Headers */,
|
||||||
B29594C91926D61F003EEF37 /* CCObjLoader.h in Headers */,
|
B29594C91926D61F003EEF37 /* CCObjLoader.h in Headers */,
|
||||||
29CB8F561929D7A900C841D6 /* UIScrollInterface.h in Headers */,
|
|
||||||
1AD71E98180E26E600808F54 /* Animation.h in Headers */,
|
1AD71E98180E26E600808F54 /* Animation.h in Headers */,
|
||||||
1AD71E9C180E26E600808F54 /* AnimationState.h in Headers */,
|
1AD71E9C180E26E600808F54 /* AnimationState.h in Headers */,
|
||||||
50ABBE961925AB6F00A911A9 /* CCProfiling.h in Headers */,
|
50ABBE961925AB6F00A911A9 /* CCProfiling.h in Headers */,
|
||||||
|
@ -6153,7 +6153,6 @@
|
||||||
1A57011B180BC90D0088DEC7 /* CCGrabber.cpp in Sources */,
|
1A57011B180BC90D0088DEC7 /* CCGrabber.cpp in Sources */,
|
||||||
1A57011F180BC90D0088DEC7 /* CCGrid.cpp in Sources */,
|
1A57011F180BC90D0088DEC7 /* CCGrid.cpp in Sources */,
|
||||||
50FCEBA718C72017004AD434 /* LoadingBarReader.cpp in Sources */,
|
50FCEBA718C72017004AD434 /* LoadingBarReader.cpp in Sources */,
|
||||||
06C0F2EF186AD822003594D5 /* ObjectFactory.cpp in Sources */,
|
|
||||||
1A57019D180BCB590088DEC7 /* CCFont.cpp in Sources */,
|
1A57019D180BCB590088DEC7 /* CCFont.cpp in Sources */,
|
||||||
1A5701A1180BCB590088DEC7 /* CCFontAtlas.cpp in Sources */,
|
1A5701A1180BCB590088DEC7 /* CCFontAtlas.cpp in Sources */,
|
||||||
1A5701A5180BCB590088DEC7 /* CCFontAtlasCache.cpp in Sources */,
|
1A5701A5180BCB590088DEC7 /* CCFontAtlasCache.cpp in Sources */,
|
||||||
|
@ -6345,6 +6344,7 @@
|
||||||
2905FA5218CF08D100240AA3 /* UIImageView.cpp in Sources */,
|
2905FA5218CF08D100240AA3 /* UIImageView.cpp in Sources */,
|
||||||
50ABBDBD1925AB4100A911A9 /* CCTextureCache.cpp in Sources */,
|
50ABBDBD1925AB4100A911A9 /* CCTextureCache.cpp in Sources */,
|
||||||
B29594CE1926D61F003EEF37 /* CCSprite3DDataCache.cpp in Sources */,
|
B29594CE1926D61F003EEF37 /* CCSprite3DDataCache.cpp in Sources */,
|
||||||
|
299754F4193EC95400A54AC3 /* ObjectFactory.cpp in Sources */,
|
||||||
2905FA7C18CF08D100240AA3 /* UIText.cpp in Sources */,
|
2905FA7C18CF08D100240AA3 /* UIText.cpp in Sources */,
|
||||||
50FCEB9F18C72017004AD434 /* LayoutReader.cpp in Sources */,
|
50FCEB9F18C72017004AD434 /* LayoutReader.cpp in Sources */,
|
||||||
50ABC0211926664800A911A9 /* CCGLView.cpp in Sources */,
|
50ABC0211926664800A911A9 /* CCGLView.cpp in Sources */,
|
||||||
|
@ -6598,7 +6598,6 @@
|
||||||
1A570113180BC8EE0088DEC7 /* CCDrawNode.cpp in Sources */,
|
1A570113180BC8EE0088DEC7 /* CCDrawNode.cpp in Sources */,
|
||||||
1A57011C180BC90D0088DEC7 /* CCGrabber.cpp in Sources */,
|
1A57011C180BC90D0088DEC7 /* CCGrabber.cpp in Sources */,
|
||||||
1A570120180BC90D0088DEC7 /* CCGrid.cpp in Sources */,
|
1A570120180BC90D0088DEC7 /* CCGrid.cpp in Sources */,
|
||||||
06C0F2F0186AD824003594D5 /* ObjectFactory.cpp in Sources */,
|
|
||||||
1A57019E180BCB590088DEC7 /* CCFont.cpp in Sources */,
|
1A57019E180BCB590088DEC7 /* CCFont.cpp in Sources */,
|
||||||
503DD8E21926736A00CD74DD /* CCCommon.mm in Sources */,
|
503DD8E21926736A00CD74DD /* CCCommon.mm in Sources */,
|
||||||
1A5701A2180BCB590088DEC7 /* CCFontAtlas.cpp in Sources */,
|
1A5701A2180BCB590088DEC7 /* CCFontAtlas.cpp in Sources */,
|
||||||
|
@ -6616,6 +6615,7 @@
|
||||||
B375107E1823ACA100B3BA6A /* CCPhysicsContactInfo_chipmunk.cpp in Sources */,
|
B375107E1823ACA100B3BA6A /* CCPhysicsContactInfo_chipmunk.cpp in Sources */,
|
||||||
1A5701C8180BCB5A0088DEC7 /* CCLabelTextFormatter.cpp in Sources */,
|
1A5701C8180BCB5A0088DEC7 /* CCLabelTextFormatter.cpp in Sources */,
|
||||||
1A5701CC180BCB5A0088DEC7 /* CCLabelTTF.cpp in Sources */,
|
1A5701CC180BCB5A0088DEC7 /* CCLabelTTF.cpp in Sources */,
|
||||||
|
299754F5193EC95400A54AC3 /* ObjectFactory.cpp in Sources */,
|
||||||
1A5701DF180BCB8C0088DEC7 /* CCLayer.cpp in Sources */,
|
1A5701DF180BCB8C0088DEC7 /* CCLayer.cpp in Sources */,
|
||||||
50ABBDBE1925AB4100A911A9 /* CCTextureCache.cpp in Sources */,
|
50ABBDBE1925AB4100A911A9 /* CCTextureCache.cpp in Sources */,
|
||||||
1A5701E3180BCB8C0088DEC7 /* CCScene.cpp in Sources */,
|
1A5701E3180BCB8C0088DEC7 /* CCScene.cpp in Sources */,
|
||||||
|
@ -7117,6 +7117,7 @@
|
||||||
CC_TARGET_OS_MAC,
|
CC_TARGET_OS_MAC,
|
||||||
CC_KEYBOARD_SUPPORT,
|
CC_KEYBOARD_SUPPORT,
|
||||||
);
|
);
|
||||||
|
GCC_TREAT_WARNINGS_AS_ERRORS = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
LIBRARY_SEARCH_PATHS = (
|
LIBRARY_SEARCH_PATHS = (
|
||||||
"$(inherited)",
|
"$(inherited)",
|
||||||
|
@ -7143,6 +7144,7 @@
|
||||||
CC_KEYBOARD_SUPPORT,
|
CC_KEYBOARD_SUPPORT,
|
||||||
CC_TARGET_OS_MAC,
|
CC_TARGET_OS_MAC,
|
||||||
);
|
);
|
||||||
|
GCC_TREAT_WARNINGS_AS_ERRORS = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
LIBRARY_SEARCH_PATHS = (
|
LIBRARY_SEARCH_PATHS = (
|
||||||
"$(inherited)",
|
"$(inherited)",
|
||||||
|
@ -7235,6 +7237,7 @@
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
ALWAYS_SEARCH_USER_PATHS = YES;
|
ALWAYS_SEARCH_USER_PATHS = YES;
|
||||||
GCC_PREPROCESSOR_DEFINITIONS = CC_TARGET_OS_MAC;
|
GCC_PREPROCESSOR_DEFINITIONS = CC_TARGET_OS_MAC;
|
||||||
|
GCC_TREAT_WARNINGS_AS_ERRORS = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
USER_HEADER_SEARCH_PATHS = "$(inherited) $(SRCROOT)/../cocos/platform/mac";
|
USER_HEADER_SEARCH_PATHS = "$(inherited) $(SRCROOT)/../cocos/platform/mac";
|
||||||
};
|
};
|
||||||
|
@ -7245,6 +7248,7 @@
|
||||||
buildSettings = {
|
buildSettings = {
|
||||||
ALWAYS_SEARCH_USER_PATHS = YES;
|
ALWAYS_SEARCH_USER_PATHS = YES;
|
||||||
GCC_PREPROCESSOR_DEFINITIONS = CC_TARGET_OS_MAC;
|
GCC_PREPROCESSOR_DEFINITIONS = CC_TARGET_OS_MAC;
|
||||||
|
GCC_TREAT_WARNINGS_AS_ERRORS = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
USER_HEADER_SEARCH_PATHS = "$(inherited) $(SRCROOT)/../cocos/platform/mac";
|
USER_HEADER_SEARCH_PATHS = "$(inherited) $(SRCROOT)/../cocos/platform/mac";
|
||||||
};
|
};
|
||||||
|
@ -7259,6 +7263,7 @@
|
||||||
CC_TARGET_OS_MAC,
|
CC_TARGET_OS_MAC,
|
||||||
CC_KEYBOARD_SUPPORT,
|
CC_KEYBOARD_SUPPORT,
|
||||||
);
|
);
|
||||||
|
GCC_TREAT_WARNINGS_AS_ERRORS = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
LIBRARY_SEARCH_PATHS = "$(inherited)";
|
LIBRARY_SEARCH_PATHS = "$(inherited)";
|
||||||
USER_HEADER_SEARCH_PATHS = "$(inherited) $(SRCROOT)/../cocos/platform/mac $(SRCROOT)/../cocos/platform/desktop $(SRCROOT)/../external/glfw3/include/mac";
|
USER_HEADER_SEARCH_PATHS = "$(inherited) $(SRCROOT)/../cocos/platform/mac $(SRCROOT)/../cocos/platform/desktop $(SRCROOT)/../external/glfw3/include/mac";
|
||||||
|
@ -7274,6 +7279,7 @@
|
||||||
CC_TARGET_OS_MAC,
|
CC_TARGET_OS_MAC,
|
||||||
CC_KEYBOARD_SUPPORT,
|
CC_KEYBOARD_SUPPORT,
|
||||||
);
|
);
|
||||||
|
GCC_TREAT_WARNINGS_AS_ERRORS = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
LIBRARY_SEARCH_PATHS = "$(inherited)";
|
LIBRARY_SEARCH_PATHS = "$(inherited)";
|
||||||
USER_HEADER_SEARCH_PATHS = "$(inherited) $(SRCROOT)/../cocos/platform/mac $(SRCROOT)/../cocos/platform/desktop $(SRCROOT)/../external/glfw3/include/mac";
|
USER_HEADER_SEARCH_PATHS = "$(inherited) $(SRCROOT)/../cocos/platform/mac $(SRCROOT)/../cocos/platform/desktop $(SRCROOT)/../external/glfw3/include/mac";
|
||||||
|
@ -7291,6 +7297,7 @@
|
||||||
"$(inherited)",
|
"$(inherited)",
|
||||||
CC_TARGET_OS_IPHONE,
|
CC_TARGET_OS_IPHONE,
|
||||||
);
|
);
|
||||||
|
GCC_TREAT_WARNINGS_AS_ERRORS = NO;
|
||||||
GCC_WARN_ABOUT_DEPRECATED_FUNCTIONS = YES;
|
GCC_WARN_ABOUT_DEPRECATED_FUNCTIONS = YES;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 5.1.1;
|
IPHONEOS_DEPLOYMENT_TARGET = 5.1.1;
|
||||||
|
@ -7329,6 +7336,7 @@
|
||||||
"$(inherited)",
|
"$(inherited)",
|
||||||
CC_TARGET_OS_IPHONE,
|
CC_TARGET_OS_IPHONE,
|
||||||
);
|
);
|
||||||
|
GCC_TREAT_WARNINGS_AS_ERRORS = NO;
|
||||||
GCC_WARN_ABOUT_DEPRECATED_FUNCTIONS = YES;
|
GCC_WARN_ABOUT_DEPRECATED_FUNCTIONS = YES;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 5.1.1;
|
IPHONEOS_DEPLOYMENT_TARGET = 5.1.1;
|
||||||
|
@ -7385,6 +7393,7 @@
|
||||||
"$(inherited)",
|
"$(inherited)",
|
||||||
CC_TARGET_OS_IPHONE,
|
CC_TARGET_OS_IPHONE,
|
||||||
);
|
);
|
||||||
|
GCC_TREAT_WARNINGS_AS_ERRORS = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 5.1.1;
|
IPHONEOS_DEPLOYMENT_TARGET = 5.1.1;
|
||||||
LIBRARY_SEARCH_PATHS = "$(inherited)";
|
LIBRARY_SEARCH_PATHS = "$(inherited)";
|
||||||
|
@ -7403,6 +7412,7 @@
|
||||||
"$(inherited)",
|
"$(inherited)",
|
||||||
CC_TARGET_OS_IPHONE,
|
CC_TARGET_OS_IPHONE,
|
||||||
);
|
);
|
||||||
|
GCC_TREAT_WARNINGS_AS_ERRORS = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 5.1.1;
|
IPHONEOS_DEPLOYMENT_TARGET = 5.1.1;
|
||||||
LIBRARY_SEARCH_PATHS = "$(inherited)";
|
LIBRARY_SEARCH_PATHS = "$(inherited)";
|
||||||
|
@ -7481,6 +7491,7 @@
|
||||||
"$(inherited)",
|
"$(inherited)",
|
||||||
CC_TARGET_OS_IPHONE,
|
CC_TARGET_OS_IPHONE,
|
||||||
);
|
);
|
||||||
|
GCC_TREAT_WARNINGS_AS_ERRORS = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 5.1.1;
|
IPHONEOS_DEPLOYMENT_TARGET = 5.1.1;
|
||||||
SDKROOT = iphoneos;
|
SDKROOT = iphoneos;
|
||||||
|
@ -7498,6 +7509,7 @@
|
||||||
"$(inherited)",
|
"$(inherited)",
|
||||||
CC_TARGET_OS_IPHONE,
|
CC_TARGET_OS_IPHONE,
|
||||||
);
|
);
|
||||||
|
GCC_TREAT_WARNINGS_AS_ERRORS = NO;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
IPHONEOS_DEPLOYMENT_TARGET = 5.1.1;
|
IPHONEOS_DEPLOYMENT_TARGET = 5.1.1;
|
||||||
SDKROOT = iphoneos;
|
SDKROOT = iphoneos;
|
||||||
|
|
|
@ -570,8 +570,6 @@
|
||||||
1AC35CD718CED84500F37B72 /* CocosBuilderExample.ccbproj in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CAF18CED84500F37B72 /* CocosBuilderExample.ccbproj */; };
|
1AC35CD718CED84500F37B72 /* CocosBuilderExample.ccbproj in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CAF18CED84500F37B72 /* CocosBuilderExample.ccbproj */; };
|
||||||
1AC35CD818CED84500F37B72 /* CocosBuilderExample.ccbresourcelog in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB018CED84500F37B72 /* CocosBuilderExample.ccbresourcelog */; };
|
1AC35CD818CED84500F37B72 /* CocosBuilderExample.ccbresourcelog in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB018CED84500F37B72 /* CocosBuilderExample.ccbresourcelog */; };
|
||||||
1AC35CD918CED84500F37B72 /* CocosBuilderExample.ccbresourcelog in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB018CED84500F37B72 /* CocosBuilderExample.ccbresourcelog */; };
|
1AC35CD918CED84500F37B72 /* CocosBuilderExample.ccbresourcelog in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB018CED84500F37B72 /* CocosBuilderExample.ccbresourcelog */; };
|
||||||
1AC35CDC18CED84500F37B72 /* commonly_used_words.txt in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB218CED84500F37B72 /* commonly_used_words.txt */; };
|
|
||||||
1AC35CDD18CED84500F37B72 /* commonly_used_words.txt in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB218CED84500F37B72 /* commonly_used_words.txt */; };
|
|
||||||
1AC35CDE18CED84500F37B72 /* components in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB318CED84500F37B72 /* components */; };
|
1AC35CDE18CED84500F37B72 /* components in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB318CED84500F37B72 /* components */; };
|
||||||
1AC35CDF18CED84500F37B72 /* components in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB318CED84500F37B72 /* components */; };
|
1AC35CDF18CED84500F37B72 /* components in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB318CED84500F37B72 /* components */; };
|
||||||
1AC35CE018CED84500F37B72 /* configs in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB418CED84500F37B72 /* configs */; };
|
1AC35CE018CED84500F37B72 /* configs in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB418CED84500F37B72 /* configs */; };
|
||||||
|
@ -697,7 +695,6 @@
|
||||||
1AC35DE318CEE65900F37B72 /* fileLookup.plist in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB918CED84500F37B72 /* fileLookup.plist */; };
|
1AC35DE318CEE65900F37B72 /* fileLookup.plist in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB918CED84500F37B72 /* fileLookup.plist */; };
|
||||||
1AC35DE518CEE65900F37B72 /* Hello.png in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CBD18CED84500F37B72 /* Hello.png */; };
|
1AC35DE518CEE65900F37B72 /* Hello.png in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CBD18CED84500F37B72 /* Hello.png */; };
|
||||||
1AC35DE618CEE65900F37B72 /* effect1.raw in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB518CED84500F37B72 /* effect1.raw */; };
|
1AC35DE618CEE65900F37B72 /* effect1.raw in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB518CED84500F37B72 /* effect1.raw */; };
|
||||||
1AC35DE718CEE65900F37B72 /* commonly_used_words.txt in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB218CED84500F37B72 /* commonly_used_words.txt */; };
|
|
||||||
1AC35DE918CEE65900F37B72 /* effect1.wav in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB618CED84500F37B72 /* effect1.wav */; };
|
1AC35DE918CEE65900F37B72 /* effect1.wav in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB618CED84500F37B72 /* effect1.wav */; };
|
||||||
1AC35DEA18CEE65900F37B72 /* pew-pew-lei.wav in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CC418CED84500F37B72 /* pew-pew-lei.wav */; };
|
1AC35DEA18CEE65900F37B72 /* pew-pew-lei.wav in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CC418CED84500F37B72 /* pew-pew-lei.wav */; };
|
||||||
1AC35DEB18CEE65B00F37B72 /* CocosBuilderExample.ccbproj in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CAF18CED84500F37B72 /* CocosBuilderExample.ccbproj */; };
|
1AC35DEB18CEE65B00F37B72 /* CocosBuilderExample.ccbproj in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CAF18CED84500F37B72 /* CocosBuilderExample.ccbproj */; };
|
||||||
|
@ -709,7 +706,6 @@
|
||||||
1AC35DF118CEE65B00F37B72 /* fileLookup.plist in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB918CED84500F37B72 /* fileLookup.plist */; };
|
1AC35DF118CEE65B00F37B72 /* fileLookup.plist in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB918CED84500F37B72 /* fileLookup.plist */; };
|
||||||
1AC35DF318CEE65B00F37B72 /* Hello.png in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CBD18CED84500F37B72 /* Hello.png */; };
|
1AC35DF318CEE65B00F37B72 /* Hello.png in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CBD18CED84500F37B72 /* Hello.png */; };
|
||||||
1AC35DF418CEE65B00F37B72 /* effect1.raw in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB518CED84500F37B72 /* effect1.raw */; };
|
1AC35DF418CEE65B00F37B72 /* effect1.raw in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB518CED84500F37B72 /* effect1.raw */; };
|
||||||
1AC35DF518CEE65B00F37B72 /* commonly_used_words.txt in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB218CED84500F37B72 /* commonly_used_words.txt */; };
|
|
||||||
1AC35DF718CEE65B00F37B72 /* effect1.wav in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB618CED84500F37B72 /* effect1.wav */; };
|
1AC35DF718CEE65B00F37B72 /* effect1.wav in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CB618CED84500F37B72 /* effect1.wav */; };
|
||||||
1AC35DF818CEE65B00F37B72 /* pew-pew-lei.wav in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CC418CED84500F37B72 /* pew-pew-lei.wav */; };
|
1AC35DF818CEE65B00F37B72 /* pew-pew-lei.wav in Resources */ = {isa = PBXBuildFile; fileRef = 1AC35CC418CED84500F37B72 /* pew-pew-lei.wav */; };
|
||||||
1AF152D918FD252A00A52F3D /* PerformanceCallbackTest.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1AF152D718FD252A00A52F3D /* PerformanceCallbackTest.cpp */; };
|
1AF152D918FD252A00A52F3D /* PerformanceCallbackTest.cpp in Sources */ = {isa = PBXBuildFile; fileRef = 1AF152D718FD252A00A52F3D /* PerformanceCallbackTest.cpp */; };
|
||||||
|
@ -1668,7 +1664,6 @@
|
||||||
1AC35CAE18CED84500F37B72 /* ccb */ = {isa = PBXFileReference; lastKnownFileType = folder; name = ccb; path = "../tests/cpp-tests/Resources/ccb"; sourceTree = "<group>"; };
|
1AC35CAE18CED84500F37B72 /* ccb */ = {isa = PBXFileReference; lastKnownFileType = folder; name = ccb; path = "../tests/cpp-tests/Resources/ccb"; sourceTree = "<group>"; };
|
||||||
1AC35CAF18CED84500F37B72 /* CocosBuilderExample.ccbproj */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xml; name = CocosBuilderExample.ccbproj; path = "../tests/cpp-tests/Resources/CocosBuilderExample.ccbproj"; sourceTree = "<group>"; };
|
1AC35CAF18CED84500F37B72 /* CocosBuilderExample.ccbproj */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text.xml; name = CocosBuilderExample.ccbproj; path = "../tests/cpp-tests/Resources/CocosBuilderExample.ccbproj"; sourceTree = "<group>"; };
|
||||||
1AC35CB018CED84500F37B72 /* CocosBuilderExample.ccbresourcelog */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; name = CocosBuilderExample.ccbresourcelog; path = "../tests/cpp-tests/Resources/CocosBuilderExample.ccbresourcelog"; sourceTree = "<group>"; };
|
1AC35CB018CED84500F37B72 /* CocosBuilderExample.ccbresourcelog */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; name = CocosBuilderExample.ccbresourcelog; path = "../tests/cpp-tests/Resources/CocosBuilderExample.ccbresourcelog"; sourceTree = "<group>"; };
|
||||||
1AC35CB218CED84500F37B72 /* commonly_used_words.txt */ = {isa = PBXFileReference; fileEncoding = 4; lastKnownFileType = text; name = commonly_used_words.txt; path = "../tests/cpp-tests/Resources/commonly_used_words.txt"; sourceTree = "<group>"; };
|
|
||||||
1AC35CB318CED84500F37B72 /* components */ = {isa = PBXFileReference; lastKnownFileType = folder; name = components; path = "../tests/cpp-tests/Resources/components"; sourceTree = "<group>"; };
|
1AC35CB318CED84500F37B72 /* components */ = {isa = PBXFileReference; lastKnownFileType = folder; name = components; path = "../tests/cpp-tests/Resources/components"; sourceTree = "<group>"; };
|
||||||
1AC35CB418CED84500F37B72 /* configs */ = {isa = PBXFileReference; lastKnownFileType = folder; name = configs; path = "../tests/cpp-tests/Resources/configs"; sourceTree = "<group>"; };
|
1AC35CB418CED84500F37B72 /* configs */ = {isa = PBXFileReference; lastKnownFileType = folder; name = configs; path = "../tests/cpp-tests/Resources/configs"; sourceTree = "<group>"; };
|
||||||
1AC35CB518CED84500F37B72 /* effect1.raw */ = {isa = PBXFileReference; lastKnownFileType = file; name = effect1.raw; path = "../tests/cpp-tests/Resources/effect1.raw"; sourceTree = "<group>"; };
|
1AC35CB518CED84500F37B72 /* effect1.raw */ = {isa = PBXFileReference; lastKnownFileType = file; name = effect1.raw; path = "../tests/cpp-tests/Resources/effect1.raw"; sourceTree = "<group>"; };
|
||||||
|
@ -3273,7 +3268,6 @@
|
||||||
1AC35CB918CED84500F37B72 /* fileLookup.plist */,
|
1AC35CB918CED84500F37B72 /* fileLookup.plist */,
|
||||||
1AC35CBD18CED84500F37B72 /* Hello.png */,
|
1AC35CBD18CED84500F37B72 /* Hello.png */,
|
||||||
1AC35CB518CED84500F37B72 /* effect1.raw */,
|
1AC35CB518CED84500F37B72 /* effect1.raw */,
|
||||||
1AC35CB218CED84500F37B72 /* commonly_used_words.txt */,
|
|
||||||
1AC35CB618CED84500F37B72 /* effect1.wav */,
|
1AC35CB618CED84500F37B72 /* effect1.wav */,
|
||||||
1AC35CC418CED84500F37B72 /* pew-pew-lei.wav */,
|
1AC35CC418CED84500F37B72 /* pew-pew-lei.wav */,
|
||||||
);
|
);
|
||||||
|
@ -4262,7 +4256,6 @@
|
||||||
1ABCA38818CD9E180087CE3A /* DeprecatedOpenglEnum.lua in Resources */,
|
1ABCA38818CD9E180087CE3A /* DeprecatedOpenglEnum.lua in Resources */,
|
||||||
1AC35DE118CEE65900F37B72 /* background.ogg in Resources */,
|
1AC35DE118CEE65900F37B72 /* background.ogg in Resources */,
|
||||||
15C90B4B18E66C2F00D69802 /* url.lua in Resources */,
|
15C90B4B18E66C2F00D69802 /* url.lua in Resources */,
|
||||||
1AC35DE718CEE65900F37B72 /* commonly_used_words.txt in Resources */,
|
|
||||||
1ABCA37A18CD9E180087CE3A /* CCBReaderLoad.lua in Resources */,
|
1ABCA37A18CD9E180087CE3A /* CCBReaderLoad.lua in Resources */,
|
||||||
1AC35DDF18CEE65900F37B72 /* music.mid in Resources */,
|
1AC35DDF18CEE65900F37B72 /* music.mid in Resources */,
|
||||||
1AC35D7518CEE58500F37B72 /* src in Resources */,
|
1AC35D7518CEE58500F37B72 /* src in Resources */,
|
||||||
|
@ -4352,7 +4345,6 @@
|
||||||
1ABCA39B18CD9E180087CE3A /* StudioConstants.lua in Resources */,
|
1ABCA39B18CD9E180087CE3A /* StudioConstants.lua in Resources */,
|
||||||
1ABCA38D18CD9E180087CE3A /* extern.lua in Resources */,
|
1ABCA38D18CD9E180087CE3A /* extern.lua in Resources */,
|
||||||
1AC35DEB18CEE65B00F37B72 /* CocosBuilderExample.ccbproj in Resources */,
|
1AC35DEB18CEE65B00F37B72 /* CocosBuilderExample.ccbproj in Resources */,
|
||||||
1AC35DF518CEE65B00F37B72 /* commonly_used_words.txt in Resources */,
|
|
||||||
1AC35DCA18CEE65200F37B72 /* animations in Resources */,
|
1AC35DCA18CEE65200F37B72 /* animations in Resources */,
|
||||||
1A1645A9191B6283008C7C7F /* ccs-res in Resources */,
|
1A1645A9191B6283008C7C7F /* ccs-res in Resources */,
|
||||||
1AC35DA118CEE5D100F37B72 /* Icon-72.png in Resources */,
|
1AC35DA118CEE5D100F37B72 /* Icon-72.png in Resources */,
|
||||||
|
@ -4393,7 +4385,6 @@
|
||||||
1AC35CFA18CED84500F37B72 /* Misc in Resources */,
|
1AC35CFA18CED84500F37B72 /* Misc in Resources */,
|
||||||
1AC35D0418CED84500F37B72 /* Shaders in Resources */,
|
1AC35D0418CED84500F37B72 /* Shaders in Resources */,
|
||||||
1AC35CD818CED84500F37B72 /* CocosBuilderExample.ccbresourcelog in Resources */,
|
1AC35CD818CED84500F37B72 /* CocosBuilderExample.ccbresourcelog in Resources */,
|
||||||
1AC35CDC18CED84500F37B72 /* commonly_used_words.txt in Resources */,
|
|
||||||
B2507B6B192589AF00FA4972 /* Shaders3D in Resources */,
|
B2507B6B192589AF00FA4972 /* Shaders3D in Resources */,
|
||||||
1AC35D0618CED84500F37B72 /* spine in Resources */,
|
1AC35D0618CED84500F37B72 /* spine in Resources */,
|
||||||
1AC35CE818CED84500F37B72 /* extensions in Resources */,
|
1AC35CE818CED84500F37B72 /* extensions in Resources */,
|
||||||
|
@ -4471,7 +4462,6 @@
|
||||||
B2507B6C192589AF00FA4972 /* Shaders3D in Resources */,
|
B2507B6C192589AF00FA4972 /* Shaders3D in Resources */,
|
||||||
1AC35CED18CED84500F37B72 /* fonts in Resources */,
|
1AC35CED18CED84500F37B72 /* fonts in Resources */,
|
||||||
1AC35CD718CED84500F37B72 /* CocosBuilderExample.ccbproj in Resources */,
|
1AC35CD718CED84500F37B72 /* CocosBuilderExample.ccbproj in Resources */,
|
||||||
1AC35CDD18CED84500F37B72 /* commonly_used_words.txt in Resources */,
|
|
||||||
1AC35C8918CECF1400F37B72 /* Default.png in Resources */,
|
1AC35C8918CECF1400F37B72 /* Default.png in Resources */,
|
||||||
);
|
);
|
||||||
runOnlyForDeploymentPostprocessing = 0;
|
runOnlyForDeploymentPostprocessing = 0;
|
||||||
|
@ -5514,6 +5504,7 @@
|
||||||
GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS = YES;
|
GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS = YES;
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
GCC_WARN_UNUSED_VARIABLE = YES;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
|
MACOSX_DEPLOYMENT_TARGET = 10.7;
|
||||||
ONLY_ACTIVE_ARCH = YES;
|
ONLY_ACTIVE_ARCH = YES;
|
||||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
PRODUCT_NAME = "$(TARGET_NAME)";
|
||||||
SDKROOT = macosx;
|
SDKROOT = macosx;
|
||||||
|
@ -5540,6 +5531,7 @@
|
||||||
GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS = YES;
|
GCC_WARN_HIDDEN_VIRTUAL_FUNCTIONS = YES;
|
||||||
GCC_WARN_UNUSED_VARIABLE = YES;
|
GCC_WARN_UNUSED_VARIABLE = YES;
|
||||||
HEADER_SEARCH_PATHS = "";
|
HEADER_SEARCH_PATHS = "";
|
||||||
|
MACOSX_DEPLOYMENT_TARGET = 10.7;
|
||||||
PRODUCT_NAME = "$(TARGET_NAME)";
|
PRODUCT_NAME = "$(TARGET_NAME)";
|
||||||
SDKROOT = macosx;
|
SDKROOT = macosx;
|
||||||
USER_HEADER_SEARCH_PATHS = "$(SRCROOT)/.. $(SRCROOT)/../cocos $(SRCROOT)/../cocos/editor-support $(SRCROOT)/../extensions $(SRCROOT)/../external $(SRCROOT)/../external/chipmunk/include/chipmunk";
|
USER_HEADER_SEARCH_PATHS = "$(SRCROOT)/.. $(SRCROOT)/../cocos $(SRCROOT)/../cocos/editor-support $(SRCROOT)/../extensions $(SRCROOT)/../external $(SRCROOT)/../external/chipmunk/include/chipmunk";
|
||||||
|
|
|
@ -133,7 +133,7 @@ void AtlasNode::updateAtlasValues()
|
||||||
}
|
}
|
||||||
|
|
||||||
// AtlasNode - draw
|
// AtlasNode - draw
|
||||||
void AtlasNode::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void AtlasNode::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
_quadCommand.init(
|
_quadCommand.init(
|
||||||
_globalZOrder,
|
_globalZOrder,
|
||||||
|
|
|
@ -69,7 +69,7 @@ public:
|
||||||
|
|
||||||
|
|
||||||
// Overrides
|
// Overrides
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
virtual Texture2D* getTexture() const override;
|
virtual Texture2D* getTexture() const override;
|
||||||
virtual void setTexture(Texture2D *texture) override;
|
virtual void setTexture(Texture2D *texture) override;
|
||||||
virtual bool isOpacityModifyRGB() const override;
|
virtual bool isOpacityModifyRGB() const override;
|
||||||
|
|
|
@ -203,15 +203,12 @@ void ClippingNode::drawFullScreenQuadClearStencil()
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void ClippingNode::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated)
|
void ClippingNode::visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
if(!_visible)
|
if(!_visible)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
bool dirty = parentTransformUpdated || _transformUpdated;
|
uint32_t flags = processParentFlags(parentTransform, parentFlags);
|
||||||
if(dirty)
|
|
||||||
_modelViewTransform = transform(parentTransform);
|
|
||||||
_transformUpdated = false;
|
|
||||||
|
|
||||||
// IMPORTANT:
|
// IMPORTANT:
|
||||||
// To ease the migration to v3.0, we still support the Mat4 stack,
|
// To ease the migration to v3.0, we still support the Mat4 stack,
|
||||||
|
@ -249,7 +246,7 @@ void ClippingNode::visit(Renderer *renderer, const Mat4 &parentTransform, bool p
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
}
|
}
|
||||||
_stencil->visit(renderer, _modelViewTransform, dirty);
|
_stencil->visit(renderer, _modelViewTransform, flags);
|
||||||
|
|
||||||
_afterDrawStencilCmd.init(_globalZOrder);
|
_afterDrawStencilCmd.init(_globalZOrder);
|
||||||
_afterDrawStencilCmd.func = CC_CALLBACK_0(ClippingNode::onAfterDrawStencil, this);
|
_afterDrawStencilCmd.func = CC_CALLBACK_0(ClippingNode::onAfterDrawStencil, this);
|
||||||
|
@ -266,19 +263,19 @@ void ClippingNode::visit(Renderer *renderer, const Mat4 &parentTransform, bool p
|
||||||
auto node = _children.at(i);
|
auto node = _children.at(i);
|
||||||
|
|
||||||
if ( node && node->getLocalZOrder() < 0 )
|
if ( node && node->getLocalZOrder() < 0 )
|
||||||
node->visit(renderer, _modelViewTransform, dirty);
|
node->visit(renderer, _modelViewTransform, flags);
|
||||||
else
|
else
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// self draw
|
// self draw
|
||||||
this->draw(renderer, _modelViewTransform, dirty);
|
this->draw(renderer, _modelViewTransform, flags);
|
||||||
|
|
||||||
for(auto it=_children.cbegin()+i; it != _children.cend(); ++it)
|
for(auto it=_children.cbegin()+i; it != _children.cend(); ++it)
|
||||||
(*it)->visit(renderer, _modelViewTransform, dirty);
|
(*it)->visit(renderer, _modelViewTransform, flags);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
this->draw(renderer, _modelViewTransform, dirty);
|
this->draw(renderer, _modelViewTransform, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
_afterVisitCmd.init(_globalZOrder);
|
_afterVisitCmd.init(_globalZOrder);
|
||||||
|
|
|
@ -95,7 +95,7 @@ public:
|
||||||
* @lua NA
|
* @lua NA
|
||||||
*/
|
*/
|
||||||
virtual void onExit() override;
|
virtual void onExit() override;
|
||||||
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated) override;
|
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags) override;
|
||||||
|
|
||||||
CC_CONSTRUCTOR_ACCESS:
|
CC_CONSTRUCTOR_ACCESS:
|
||||||
ClippingNode();
|
ClippingNode();
|
||||||
|
|
|
@ -205,14 +205,14 @@ bool DrawNode::init()
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void DrawNode::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void DrawNode::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
_customCommand.init(_globalZOrder);
|
_customCommand.init(_globalZOrder);
|
||||||
_customCommand.func = CC_CALLBACK_0(DrawNode::onDraw, this, transform, transformUpdated);
|
_customCommand.func = CC_CALLBACK_0(DrawNode::onDraw, this, transform, flags);
|
||||||
renderer->addCommand(&_customCommand);
|
renderer->addCommand(&_customCommand);
|
||||||
}
|
}
|
||||||
|
|
||||||
void DrawNode::onDraw(const Mat4 &transform, bool transformUpdated)
|
void DrawNode::onDraw(const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
auto glProgram = getGLProgram();
|
auto glProgram = getGLProgram();
|
||||||
glProgram->use();
|
glProgram->use();
|
||||||
|
|
|
@ -89,10 +89,10 @@ public:
|
||||||
*/
|
*/
|
||||||
void setBlendFunc(const BlendFunc &blendFunc);
|
void setBlendFunc(const BlendFunc &blendFunc);
|
||||||
|
|
||||||
void onDraw(const Mat4 &transform, bool transformUpdated);
|
void onDraw(const Mat4 &transform, uint32_t flags);
|
||||||
|
|
||||||
// Overrides
|
// Overrides
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
|
|
||||||
CC_CONSTRUCTOR_ACCESS:
|
CC_CONSTRUCTOR_ACCESS:
|
||||||
DrawNode();
|
DrawNode();
|
||||||
|
|
|
@ -265,7 +265,15 @@ bool FontAtlas::prepareLetterDefinitions(const std::u16string& utf16String)
|
||||||
_currentPageOrigX = 0;
|
_currentPageOrigX = 0;
|
||||||
if(_currentPageOrigY + _commonLineHeight >= CacheTextureHeight)
|
if(_currentPageOrigY + _commonLineHeight >= CacheTextureHeight)
|
||||||
{
|
{
|
||||||
auto data = _currentPageData + CacheTextureWidth * (int)startY;
|
unsigned char *data = nullptr;
|
||||||
|
if(pixelFormat == Texture2D::PixelFormat::AI88)
|
||||||
|
{
|
||||||
|
data = _currentPageData + CacheTextureWidth * (int)startY * 2;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
data = _currentPageData + CacheTextureWidth * (int)startY;
|
||||||
|
}
|
||||||
_atlasTextures[_currentPage]->updateWithData(data, 0, startY,
|
_atlasTextures[_currentPage]->updateWithData(data, 0, startY,
|
||||||
CacheTextureWidth, CacheTextureHeight - startY);
|
CacheTextureWidth, CacheTextureHeight - startY);
|
||||||
|
|
||||||
|
@ -325,7 +333,15 @@ bool FontAtlas::prepareLetterDefinitions(const std::u16string& utf16String)
|
||||||
|
|
||||||
if(existNewLetter)
|
if(existNewLetter)
|
||||||
{
|
{
|
||||||
auto data = _currentPageData + CacheTextureWidth * (int)startY;
|
unsigned char *data = nullptr;
|
||||||
|
if(pixelFormat == Texture2D::PixelFormat::AI88)
|
||||||
|
{
|
||||||
|
data = _currentPageData + CacheTextureWidth * (int)startY * 2;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
data = _currentPageData + CacheTextureWidth * (int)startY;
|
||||||
|
}
|
||||||
_atlasTextures[_currentPage]->updateWithData(data, 0, startY,
|
_atlasTextures[_currentPage]->updateWithData(data, 0, startY,
|
||||||
CacheTextureWidth, _currentPageOrigY - startY + _commonLineHeight);
|
CacheTextureWidth, _currentPageOrigY - startY + _commonLineHeight);
|
||||||
}
|
}
|
||||||
|
|
|
@ -877,14 +877,14 @@ void Label::drawShadowWithoutBlur()
|
||||||
setColor(oldColor);
|
setColor(oldColor);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Label::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void Label::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
// Don't do calculate the culling if the transform was not updated
|
// Don't do calculate the culling if the transform was not updated
|
||||||
_insideBounds = transformUpdated ? renderer->checkVisibility(transform, _contentSize) : _insideBounds;
|
_insideBounds = (flags & FLAGS_TRANSFORM_DIRTY) ? renderer->checkVisibility(transform, _contentSize) : _insideBounds;
|
||||||
|
|
||||||
if(_insideBounds) {
|
if(_insideBounds) {
|
||||||
_customCommand.init(_globalZOrder);
|
_customCommand.init(_globalZOrder);
|
||||||
_customCommand.func = CC_CALLBACK_0(Label::onDraw, this, transform, transformUpdated);
|
_customCommand.func = CC_CALLBACK_0(Label::onDraw, this, transform, flags);
|
||||||
renderer->addCommand(&_customCommand);
|
renderer->addCommand(&_customCommand);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -1019,7 +1019,7 @@ void Label::updateFont()
|
||||||
_systemFontDirty = false;
|
_systemFontDirty = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Label::drawTextSprite(Renderer *renderer, bool parentTransformUpdated)
|
void Label::drawTextSprite(Renderer *renderer, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
if (_fontDefinition._fontFillColor != _textColor)
|
if (_fontDefinition._fontFillColor != _textColor)
|
||||||
{
|
{
|
||||||
|
@ -1044,12 +1044,12 @@ void Label::drawTextSprite(Renderer *renderer, bool parentTransformUpdated)
|
||||||
}
|
}
|
||||||
if (_shadowNode)
|
if (_shadowNode)
|
||||||
{
|
{
|
||||||
_shadowNode->visit(renderer, _modelViewTransform, parentTransformUpdated);
|
_shadowNode->visit(renderer, _modelViewTransform, parentFlags);
|
||||||
}
|
}
|
||||||
_textSprite->visit(renderer, _modelViewTransform, parentTransformUpdated);
|
_textSprite->visit(renderer, _modelViewTransform, parentFlags);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Label::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated)
|
void Label::visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
if (! _visible || _originalUTF8String.empty())
|
if (! _visible || _originalUTF8String.empty())
|
||||||
{
|
{
|
||||||
|
@ -1064,9 +1064,9 @@ void Label::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTr
|
||||||
updateContent();
|
updateContent();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool dirty = parentTransformUpdated || _transformUpdated;
|
uint32_t flags = processParentFlags(parentTransform, parentFlags);
|
||||||
|
|
||||||
if (_shadowEnabled && _shadowBlurRadius <= 0 && (_shadowDirty || dirty))
|
if (_shadowEnabled && _shadowBlurRadius <= 0 && (_shadowDirty || (flags & FLAGS_DIRTY_MASK)))
|
||||||
{
|
{
|
||||||
_position.x += _shadowOffset.width;
|
_position.x += _shadowOffset.width;
|
||||||
_position.y += _shadowOffset.height;
|
_position.y += _shadowOffset.height;
|
||||||
|
@ -1081,12 +1081,6 @@ void Label::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTr
|
||||||
_shadowDirty = false;
|
_shadowDirty = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
if(dirty)
|
|
||||||
{
|
|
||||||
_modelViewTransform = transform(parentTransform);
|
|
||||||
}
|
|
||||||
_transformUpdated = false;
|
|
||||||
|
|
||||||
// IMPORTANT:
|
// IMPORTANT:
|
||||||
// To ease the migration to v3.0, we still support the Mat4 stack,
|
// To ease the migration to v3.0, we still support the Mat4 stack,
|
||||||
// but it is deprecated and your code should not rely on it
|
// but it is deprecated and your code should not rely on it
|
||||||
|
@ -1099,11 +1093,11 @@ void Label::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTr
|
||||||
|
|
||||||
if (_textSprite)
|
if (_textSprite)
|
||||||
{
|
{
|
||||||
drawTextSprite(renderer,dirty);
|
drawTextSprite(renderer, flags);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
draw(renderer, _modelViewTransform, dirty);
|
draw(renderer, _modelViewTransform, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
|
|
|
@ -237,8 +237,8 @@ public:
|
||||||
|
|
||||||
virtual Rect getBoundingBox() const override;
|
virtual Rect getBoundingBox() const override;
|
||||||
|
|
||||||
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated) override;
|
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags) override;
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
|
|
||||||
CC_DEPRECATED_ATTRIBUTE static Label* create(const std::string& text, const std::string& font, float fontSize,
|
CC_DEPRECATED_ATTRIBUTE static Label* create(const std::string& text, const std::string& font, float fontSize,
|
||||||
const Size& dimensions = Size::ZERO, TextHAlignment hAlignment = TextHAlignment::LEFT,
|
const Size& dimensions = Size::ZERO, TextHAlignment hAlignment = TextHAlignment::LEFT,
|
||||||
|
@ -298,7 +298,7 @@ protected:
|
||||||
|
|
||||||
void drawShadowWithoutBlur();
|
void drawShadowWithoutBlur();
|
||||||
|
|
||||||
void drawTextSprite(Renderer *renderer, bool parentTransformUpdated);
|
void drawTextSprite(Renderer *renderer, uint32_t parentFlags);
|
||||||
|
|
||||||
void createSpriteWithFontDefinition();
|
void createSpriteWithFontDefinition();
|
||||||
|
|
||||||
|
|
|
@ -249,7 +249,7 @@ void LabelAtlas::updateColor()
|
||||||
|
|
||||||
//CCLabelAtlas - draw
|
//CCLabelAtlas - draw
|
||||||
#if CC_LABELATLAS_DEBUG_DRAW
|
#if CC_LABELATLAS_DEBUG_DRAW
|
||||||
void LabelAtlas::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void LabelAtlas::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
AtlasNode::draw(renderer, transform, transformUpdated);
|
AtlasNode::draw(renderer, transform, transformUpdated);
|
||||||
|
|
||||||
|
|
|
@ -84,7 +84,7 @@ public:
|
||||||
virtual std::string getDescription() const override;
|
virtual std::string getDescription() const override;
|
||||||
|
|
||||||
#if CC_LABELATLAS_DEBUG_DRAW
|
#if CC_LABELATLAS_DEBUG_DRAW
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
|
@ -207,7 +207,7 @@ Rect LabelBMFont::getBoundingBox() const
|
||||||
return _label->getBoundingBox();
|
return _label->getBoundingBox();
|
||||||
}
|
}
|
||||||
#if CC_LABELBMFONT_DEBUG_DRAW
|
#if CC_LABELBMFONT_DEBUG_DRAW
|
||||||
void LabelBMFont::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void LabelBMFont::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
Node::draw(renderer, transform, transformUpdated);
|
Node::draw(renderer, transform, transformUpdated);
|
||||||
|
|
||||||
|
|
|
@ -124,7 +124,7 @@ public:
|
||||||
|
|
||||||
virtual std::string getDescription() const override;
|
virtual std::string getDescription() const override;
|
||||||
#if CC_LABELBMFONT_DEBUG_DRAW
|
#if CC_LABELBMFONT_DEBUG_DRAW
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
private:
|
private:
|
||||||
|
|
|
@ -262,14 +262,14 @@ void LabelTTF::setFlippedY(bool flippedY)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void LabelTTF::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated)
|
void LabelTTF::visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
if (_contentDirty)
|
if (_contentDirty)
|
||||||
{
|
{
|
||||||
this->setContentSize(_renderLabel->getContentSize());
|
this->setContentSize(_renderLabel->getContentSize());
|
||||||
_contentDirty = false;
|
_contentDirty = false;
|
||||||
}
|
}
|
||||||
Node::visit(renderer,parentTransform,parentTransformUpdated);
|
Node::visit(renderer,parentTransform, parentFlags);
|
||||||
}
|
}
|
||||||
|
|
||||||
const Size& LabelTTF::getContentSize() const
|
const Size& LabelTTF::getContentSize() const
|
||||||
|
|
|
@ -150,7 +150,7 @@ public:
|
||||||
* @lua NA
|
* @lua NA
|
||||||
*/
|
*/
|
||||||
virtual std::string getDescription() const override;
|
virtual std::string getDescription() const override;
|
||||||
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated) override;
|
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags) override;
|
||||||
virtual const Size& getContentSize() const override;
|
virtual const Size& getContentSize() const override;
|
||||||
protected:
|
protected:
|
||||||
Label* _renderLabel;
|
Label* _renderLabel;
|
||||||
|
|
|
@ -75,16 +75,9 @@ Layer::~Layer()
|
||||||
|
|
||||||
bool Layer::init()
|
bool Layer::init()
|
||||||
{
|
{
|
||||||
bool ret = false;
|
Director * director = Director::getInstance();
|
||||||
do
|
setContentSize(director->getWinSize());
|
||||||
{
|
return true;
|
||||||
Director * director;
|
|
||||||
CC_BREAK_IF(!(director = Director::getInstance()));
|
|
||||||
this->setContentSize(director->getWinSize());
|
|
||||||
// success
|
|
||||||
ret = true;
|
|
||||||
} while(0);
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Layer *Layer::create()
|
Layer *Layer::create()
|
||||||
|
@ -584,10 +577,10 @@ void LayerColor::updateColor()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void LayerColor::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void LayerColor::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
_customCommand.init(_globalZOrder);
|
_customCommand.init(_globalZOrder);
|
||||||
_customCommand.func = CC_CALLBACK_0(LayerColor::onDraw, this, transform, transformUpdated);
|
_customCommand.func = CC_CALLBACK_0(LayerColor::onDraw, this, transform, flags);
|
||||||
renderer->addCommand(&_customCommand);
|
renderer->addCommand(&_customCommand);
|
||||||
|
|
||||||
for(int i = 0; i < 4; ++i)
|
for(int i = 0; i < 4; ++i)
|
||||||
|
@ -600,7 +593,7 @@ void LayerColor::draw(Renderer *renderer, const Mat4 &transform, bool transformU
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void LayerColor::onDraw(const Mat4& transform, bool transformUpdated)
|
void LayerColor::onDraw(const Mat4& transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
getGLProgram()->use();
|
getGLProgram()->use();
|
||||||
getGLProgram()->setUniformsForBuiltins(transform);
|
getGLProgram()->setUniformsForBuiltins(transform);
|
||||||
|
|
|
@ -270,7 +270,7 @@ public:
|
||||||
//
|
//
|
||||||
// Overrides
|
// Overrides
|
||||||
//
|
//
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
|
|
||||||
virtual void setContentSize(const Size & var) override;
|
virtual void setContentSize(const Size & var) override;
|
||||||
/** BlendFunction. Conforms to BlendProtocol protocol */
|
/** BlendFunction. Conforms to BlendProtocol protocol */
|
||||||
|
@ -299,7 +299,7 @@ CC_CONSTRUCTOR_ACCESS:
|
||||||
bool initWithColor(const Color4B& color);
|
bool initWithColor(const Color4B& color);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void onDraw(const Mat4& transform, bool transformUpdated);
|
void onDraw(const Mat4& transform, uint32_t flags);
|
||||||
|
|
||||||
virtual void updateColor() override;
|
virtual void updateColor() override;
|
||||||
|
|
||||||
|
|
|
@ -374,7 +374,7 @@ void MotionStreak::reset()
|
||||||
_nuPoints = 0;
|
_nuPoints = 0;
|
||||||
}
|
}
|
||||||
|
|
||||||
void MotionStreak::onDraw(const Mat4 &transform, bool transformUpdated)
|
void MotionStreak::onDraw(const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
getGLProgram()->use();
|
getGLProgram()->use();
|
||||||
getGLProgram()->setUniformsForBuiltins(transform);
|
getGLProgram()->setUniformsForBuiltins(transform);
|
||||||
|
@ -404,12 +404,12 @@ void MotionStreak::onDraw(const Mat4 &transform, bool transformUpdated)
|
||||||
CC_INCREMENT_GL_DRAWN_BATCHES_AND_VERTICES(1, _nuPoints*2);
|
CC_INCREMENT_GL_DRAWN_BATCHES_AND_VERTICES(1, _nuPoints*2);
|
||||||
}
|
}
|
||||||
|
|
||||||
void MotionStreak::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void MotionStreak::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
if(_nuPoints <= 1)
|
if(_nuPoints <= 1)
|
||||||
return;
|
return;
|
||||||
_customCommand.init(_globalZOrder);
|
_customCommand.init(_globalZOrder);
|
||||||
_customCommand.func = CC_CALLBACK_0(MotionStreak::onDraw, this, transform, transformUpdated);
|
_customCommand.func = CC_CALLBACK_0(MotionStreak::onDraw, this, transform, flags);
|
||||||
renderer->addCommand(&_customCommand);
|
renderer->addCommand(&_customCommand);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -85,7 +85,7 @@ public:
|
||||||
* @js NA
|
* @js NA
|
||||||
* @lua NA
|
* @lua NA
|
||||||
*/
|
*/
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
/**
|
/**
|
||||||
* @js NA
|
* @js NA
|
||||||
* @lua NA
|
* @lua NA
|
||||||
|
@ -120,7 +120,7 @@ CC_CONSTRUCTOR_ACCESS:
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
//renderer callback
|
//renderer callback
|
||||||
void onDraw(const Mat4 &transform, bool transformUpdated);
|
void onDraw(const Mat4 &transform, uint32_t flags);
|
||||||
|
|
||||||
bool _fastMode;
|
bool _fastMode;
|
||||||
bool _startingPositionInitialized;
|
bool _startingPositionInitialized;
|
||||||
|
|
|
@ -121,6 +121,7 @@ Node::Node(void)
|
||||||
, _realColor(Color3B::WHITE)
|
, _realColor(Color3B::WHITE)
|
||||||
, _cascadeColorEnabled(false)
|
, _cascadeColorEnabled(false)
|
||||||
, _cascadeOpacityEnabled(false)
|
, _cascadeOpacityEnabled(false)
|
||||||
|
, _usingNormalizedPosition(false)
|
||||||
{
|
{
|
||||||
// set default scheduler and actionManager
|
// set default scheduler and actionManager
|
||||||
Director *director = Director::getInstance();
|
Director *director = Director::getInstance();
|
||||||
|
@ -423,6 +424,7 @@ void Node::setPosition(const Vec2& position)
|
||||||
|
|
||||||
_position = position;
|
_position = position;
|
||||||
_transformUpdated = _transformDirty = _inverseDirty = true;
|
_transformUpdated = _transformDirty = _inverseDirty = true;
|
||||||
|
_usingNormalizedPosition = false;
|
||||||
|
|
||||||
#if CC_USE_PHYSICS
|
#if CC_USE_PHYSICS
|
||||||
if (_physicsBody != nullptr && !_physicsBody->_positionResetTag)
|
if (_physicsBody != nullptr && !_physicsBody->_positionResetTag)
|
||||||
|
@ -498,6 +500,23 @@ void Node::setPositionZ(float positionZ)
|
||||||
setGlobalZOrder(positionZ);
|
setGlobalZOrder(positionZ);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
/// position getter
|
||||||
|
const Vec2& Node::getNormalizedPosition() const
|
||||||
|
{
|
||||||
|
return _normalizedPosition;
|
||||||
|
}
|
||||||
|
|
||||||
|
/// position setter
|
||||||
|
void Node::setNormalizedPosition(const Vec2& position)
|
||||||
|
{
|
||||||
|
if (_normalizedPosition.equals(position))
|
||||||
|
return;
|
||||||
|
|
||||||
|
_normalizedPosition = position;
|
||||||
|
_usingNormalizedPosition = true;
|
||||||
|
_transformUpdated = _transformDirty = _inverseDirty = true;
|
||||||
|
}
|
||||||
|
|
||||||
ssize_t Node::getChildrenCount() const
|
ssize_t Node::getChildrenCount() const
|
||||||
{
|
{
|
||||||
return _children.size();
|
return _children.size();
|
||||||
|
@ -561,7 +580,7 @@ void Node::setContentSize(const Size & size)
|
||||||
_contentSize = size;
|
_contentSize = size;
|
||||||
|
|
||||||
_anchorPointInPoints = Vec2(_contentSize.width * _anchorPoint.x, _contentSize.height * _anchorPoint.y );
|
_anchorPointInPoints = Vec2(_contentSize.width * _anchorPoint.x, _contentSize.height * _anchorPoint.y );
|
||||||
_transformUpdated = _transformDirty = _inverseDirty = true;
|
_transformUpdated = _transformDirty = _inverseDirty = _contentSizeDirty = true;
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -575,6 +594,7 @@ bool Node::isRunning() const
|
||||||
void Node::setParent(Node * parent)
|
void Node::setParent(Node * parent)
|
||||||
{
|
{
|
||||||
_parent = parent;
|
_parent = parent;
|
||||||
|
_transformUpdated = _transformDirty = _inverseDirty = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
/// isRelativeAnchorPoint getter
|
/// isRelativeAnchorPoint getter
|
||||||
|
@ -943,7 +963,7 @@ void Node::draw()
|
||||||
draw(renderer, _modelViewTransform, true);
|
draw(renderer, _modelViewTransform, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Node::draw(Renderer* renderer, const Mat4 &transform, bool transformUpdated)
|
void Node::draw(Renderer* renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -954,7 +974,30 @@ void Node::visit()
|
||||||
visit(renderer, parentTransform, true);
|
visit(renderer, parentTransform, true);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Node::visit(Renderer* renderer, const Mat4 &parentTransform, bool parentTransformUpdated)
|
uint32_t Node::processParentFlags(const Mat4& parentTransform, uint32_t parentFlags)
|
||||||
|
{
|
||||||
|
uint32_t flags = parentFlags;
|
||||||
|
flags |= (_transformUpdated ? FLAGS_TRANSFORM_DIRTY : 0);
|
||||||
|
flags |= (_contentSizeDirty ? FLAGS_CONTENT_SIZE_DIRTY : 0);
|
||||||
|
|
||||||
|
if(_usingNormalizedPosition && (flags & FLAGS_CONTENT_SIZE_DIRTY)) {
|
||||||
|
CCASSERT(_parent, "setNormalizedPosition() doesn't work with orphan nodes");
|
||||||
|
auto s = _parent->getContentSize();
|
||||||
|
_position.x = _normalizedPosition.x * s.width;
|
||||||
|
_position.y = _normalizedPosition.y * s.height;
|
||||||
|
_transformUpdated = _transformDirty = _inverseDirty = true;
|
||||||
|
}
|
||||||
|
|
||||||
|
if(flags & FLAGS_DIRTY_MASK)
|
||||||
|
_modelViewTransform = this->transform(parentTransform);
|
||||||
|
|
||||||
|
_transformUpdated = false;
|
||||||
|
_contentSizeDirty = false;
|
||||||
|
|
||||||
|
return flags;
|
||||||
|
}
|
||||||
|
|
||||||
|
void Node::visit(Renderer* renderer, const Mat4 &parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
// quick return if not visible. children won't be drawn.
|
// quick return if not visible. children won't be drawn.
|
||||||
if (!_visible)
|
if (!_visible)
|
||||||
|
@ -962,17 +1005,12 @@ void Node::visit(Renderer* renderer, const Mat4 &parentTransform, bool parentTra
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool dirty = _transformUpdated || parentTransformUpdated;
|
uint32_t flags = processParentFlags(parentTransform, parentFlags);
|
||||||
if(dirty)
|
|
||||||
_modelViewTransform = this->transform(parentTransform);
|
|
||||||
_transformUpdated = false;
|
|
||||||
|
|
||||||
|
|
||||||
// IMPORTANT:
|
// IMPORTANT:
|
||||||
// To ease the migration to v3.0, we still support the Mat4 stack,
|
// To ease the migration to v3.0, we still support the Mat4 stack,
|
||||||
// but it is deprecated and your code should not rely on it
|
// but it is deprecated and your code should not rely on it
|
||||||
Director* director = Director::getInstance();
|
Director* director = Director::getInstance();
|
||||||
CCASSERT(nullptr != director, "Director is null when seting matrix stack");
|
|
||||||
director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewTransform);
|
director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewTransform);
|
||||||
|
|
||||||
|
@ -987,24 +1025,21 @@ void Node::visit(Renderer* renderer, const Mat4 &parentTransform, bool parentTra
|
||||||
auto node = _children.at(i);
|
auto node = _children.at(i);
|
||||||
|
|
||||||
if ( node && node->_localZOrder < 0 )
|
if ( node && node->_localZOrder < 0 )
|
||||||
node->visit(renderer, _modelViewTransform, dirty);
|
node->visit(renderer, _modelViewTransform, flags);
|
||||||
else
|
else
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
// self draw
|
// self draw
|
||||||
this->draw(renderer, _modelViewTransform, dirty);
|
this->draw(renderer, _modelViewTransform, flags);
|
||||||
|
|
||||||
for(auto it=_children.cbegin()+i; it != _children.cend(); ++it)
|
for(auto it=_children.cbegin()+i; it != _children.cend(); ++it)
|
||||||
(*it)->visit(renderer, _modelViewTransform, dirty);
|
(*it)->visit(renderer, _modelViewTransform, flags);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
this->draw(renderer, _modelViewTransform, dirty);
|
this->draw(renderer, _modelViewTransform, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
// reset for next frame
|
|
||||||
_orderOfArrival = 0;
|
|
||||||
|
|
||||||
director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1640,8 +1675,18 @@ void Node::updatePhysicsBodyRotation(Scene* scene)
|
||||||
|
|
||||||
void Node::setPhysicsBody(PhysicsBody* body)
|
void Node::setPhysicsBody(PhysicsBody* body)
|
||||||
{
|
{
|
||||||
|
if (_physicsBody == body)
|
||||||
|
{
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
if (body != nullptr)
|
if (body != nullptr)
|
||||||
{
|
{
|
||||||
|
if (body->getNode() != nullptr)
|
||||||
|
{
|
||||||
|
body->getNode()->setPhysicsBody(nullptr);
|
||||||
|
}
|
||||||
|
|
||||||
body->_node = this;
|
body->_node = this;
|
||||||
body->retain();
|
body->retain();
|
||||||
|
|
||||||
|
@ -1683,6 +1728,11 @@ void Node::setPhysicsBody(PhysicsBody* body)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (scene != nullptr)
|
||||||
|
{
|
||||||
|
scene->getPhysicsWorld()->addBody(body);
|
||||||
|
}
|
||||||
|
|
||||||
updatePhysicsBodyPosition(scene);
|
updatePhysicsBodyPosition(scene);
|
||||||
updatePhysicsBodyRotation(scene);
|
updatePhysicsBodyRotation(scene);
|
||||||
}
|
}
|
||||||
|
|
|
@ -107,6 +107,12 @@ public:
|
||||||
/// Default tag used for all the nodes
|
/// Default tag used for all the nodes
|
||||||
static const int INVALID_TAG = -1;
|
static const int INVALID_TAG = -1;
|
||||||
|
|
||||||
|
enum {
|
||||||
|
FLAGS_TRANSFORM_DIRTY = (1 << 0),
|
||||||
|
FLAGS_CONTENT_SIZE_DIRTY = (1 << 1),
|
||||||
|
|
||||||
|
FLAGS_DIRTY_MASK = (FLAGS_TRANSFORM_DIRTY | FLAGS_CONTENT_SIZE_DIRTY),
|
||||||
|
};
|
||||||
/// @{
|
/// @{
|
||||||
/// @name Constructor, Destructor and Initializers
|
/// @name Constructor, Destructor and Initializers
|
||||||
|
|
||||||
|
@ -283,6 +289,19 @@ public:
|
||||||
* @param position The position (x,y) of the node in OpenGL coordinates
|
* @param position The position (x,y) of the node in OpenGL coordinates
|
||||||
*/
|
*/
|
||||||
virtual void setPosition(const Vec2 &position);
|
virtual void setPosition(const Vec2 &position);
|
||||||
|
|
||||||
|
/** Sets the position (x,y) using values between 0 and 1.
|
||||||
|
The positions in pixels is calculated like the following:
|
||||||
|
@code
|
||||||
|
// pseudo code
|
||||||
|
void setNormalizedPosition(Vec2 pos) {
|
||||||
|
Size s = getParent()->getContentSize();
|
||||||
|
_position = pos * s;
|
||||||
|
}
|
||||||
|
@endcode
|
||||||
|
*/
|
||||||
|
virtual void setNormalizedPosition(const Vec2 &position);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Gets the position (x,y) of the node in its parent's coordinate system.
|
* Gets the position (x,y) of the node in its parent's coordinate system.
|
||||||
*
|
*
|
||||||
|
@ -294,6 +313,10 @@ public:
|
||||||
* @endcode
|
* @endcode
|
||||||
*/
|
*/
|
||||||
virtual const Vec2& getPosition() const;
|
virtual const Vec2& getPosition() const;
|
||||||
|
|
||||||
|
/** returns the normalized position */
|
||||||
|
virtual const Vec2& getNormalizedPosition() const;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Sets the position (x,y) of the node in its parent's coordinate system.
|
* Sets the position (x,y) of the node in its parent's coordinate system.
|
||||||
*
|
*
|
||||||
|
@ -923,13 +946,13 @@ public:
|
||||||
* AND YOU SHOULD NOT DISABLE THEM AFTER DRAWING YOUR NODE
|
* AND YOU SHOULD NOT DISABLE THEM AFTER DRAWING YOUR NODE
|
||||||
* But if you enable any other GL state, you should disable it after drawing your node.
|
* But if you enable any other GL state, you should disable it after drawing your node.
|
||||||
*/
|
*/
|
||||||
virtual void draw(Renderer *renderer, const Mat4& transform, bool transformUpdated);
|
virtual void draw(Renderer *renderer, const Mat4& transform, uint32_t flags);
|
||||||
virtual void draw() final;
|
virtual void draw() final;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Visits this node's children and draw them recursively.
|
* Visits this node's children and draw them recursively.
|
||||||
*/
|
*/
|
||||||
virtual void visit(Renderer *renderer, const Mat4& parentTransform, bool parentTransformUpdated);
|
virtual void visit(Renderer *renderer, const Mat4& parentTransform, uint32_t parentFlags);
|
||||||
virtual void visit() final;
|
virtual void visit() final;
|
||||||
|
|
||||||
|
|
||||||
|
@ -1362,6 +1385,7 @@ protected:
|
||||||
Vec2 convertToWindowSpace(const Vec2& nodePoint) const;
|
Vec2 convertToWindowSpace(const Vec2& nodePoint) const;
|
||||||
|
|
||||||
Mat4 transform(const Mat4 &parentTransform);
|
Mat4 transform(const Mat4 &parentTransform);
|
||||||
|
uint32_t processParentFlags(const Mat4& parentTransform, uint32_t parentFlags);
|
||||||
|
|
||||||
virtual void updateCascadeOpacity();
|
virtual void updateCascadeOpacity();
|
||||||
virtual void disableCascadeOpacity();
|
virtual void disableCascadeOpacity();
|
||||||
|
@ -1387,6 +1411,8 @@ protected:
|
||||||
|
|
||||||
Vec2 _position; ///< position of the node
|
Vec2 _position; ///< position of the node
|
||||||
float _positionZ; ///< OpenGL real Z position
|
float _positionZ; ///< OpenGL real Z position
|
||||||
|
Vec2 _normalizedPosition;
|
||||||
|
bool _usingNormalizedPosition;
|
||||||
|
|
||||||
float _skewX; ///< skew angle on x-axis
|
float _skewX; ///< skew angle on x-axis
|
||||||
float _skewY; ///< skew angle on y-axis
|
float _skewY; ///< skew angle on y-axis
|
||||||
|
@ -1395,6 +1421,7 @@ protected:
|
||||||
Vec2 _anchorPoint; ///< anchor point normalized (NOT in points)
|
Vec2 _anchorPoint; ///< anchor point normalized (NOT in points)
|
||||||
|
|
||||||
Size _contentSize; ///< untransformed size of the node
|
Size _contentSize; ///< untransformed size of the node
|
||||||
|
bool _contentSizeDirty; ///< whether or not the contentSize is dirty
|
||||||
|
|
||||||
Mat4 _modelViewTransform; ///< ModelView transform of the Node.
|
Mat4 _modelViewTransform; ///< ModelView transform of the Node.
|
||||||
|
|
||||||
|
|
|
@ -82,7 +82,7 @@ void NodeGrid::onGridEndDraw()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void NodeGrid::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated)
|
void NodeGrid::visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
// quick return if not visible. children won't be drawn.
|
// quick return if not visible. children won't be drawn.
|
||||||
if (!_visible)
|
if (!_visible)
|
||||||
|
@ -94,7 +94,7 @@ void NodeGrid::visit(Renderer *renderer, const Mat4 &parentTransform, bool paren
|
||||||
renderer->addCommand(&_groupCommand);
|
renderer->addCommand(&_groupCommand);
|
||||||
renderer->pushGroup(_groupCommand.getRenderQueueID());
|
renderer->pushGroup(_groupCommand.getRenderQueueID());
|
||||||
|
|
||||||
bool dirty = parentTransformUpdated || _transformUpdated;
|
bool dirty = (parentFlags & FLAGS_TRANSFORM_DIRTY) || _transformUpdated;
|
||||||
if(dirty)
|
if(dirty)
|
||||||
_modelViewTransform = this->transform(parentTransform);
|
_modelViewTransform = this->transform(parentTransform);
|
||||||
_transformUpdated = false;
|
_transformUpdated = false;
|
||||||
|
|
|
@ -54,7 +54,7 @@ public:
|
||||||
void setTarget(Node *target);
|
void setTarget(Node *target);
|
||||||
|
|
||||||
// overrides
|
// overrides
|
||||||
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated) override;
|
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags) override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
NodeGrid();
|
NodeGrid();
|
||||||
|
|
|
@ -145,7 +145,7 @@ The positions are updated at visit because:
|
||||||
- using a timer is not guaranteed that it will called after all the positions were updated
|
- using a timer is not guaranteed that it will called after all the positions were updated
|
||||||
- overriding "draw" will only precise if the children have a z > 0
|
- overriding "draw" will only precise if the children have a z > 0
|
||||||
*/
|
*/
|
||||||
void ParallaxNode::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated)
|
void ParallaxNode::visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
// Vec2 pos = position_;
|
// Vec2 pos = position_;
|
||||||
// Vec2 pos = [self convertToWorldSpace:Vec2::ZERO];
|
// Vec2 pos = [self convertToWorldSpace:Vec2::ZERO];
|
||||||
|
@ -161,7 +161,7 @@ void ParallaxNode::visit(Renderer *renderer, const Mat4 &parentTransform, bool p
|
||||||
}
|
}
|
||||||
_lastPosition = pos;
|
_lastPosition = pos;
|
||||||
}
|
}
|
||||||
Node::visit(renderer, parentTransform, parentTransformUpdated);
|
Node::visit(renderer, parentTransform, parentFlags);
|
||||||
}
|
}
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
|
@ -67,7 +67,7 @@ public:
|
||||||
virtual void addChild(Node * child, int zOrder, int tag) override;
|
virtual void addChild(Node * child, int zOrder, int tag) override;
|
||||||
virtual void removeChild(Node* child, bool cleanup) override;
|
virtual void removeChild(Node* child, bool cleanup) override;
|
||||||
virtual void removeAllChildrenWithCleanup(bool cleanup) override;
|
virtual void removeAllChildrenWithCleanup(bool cleanup) override;
|
||||||
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated) override;
|
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags) override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
/** Adds a child to the container with a z-order, a parallax ratio and a position offset
|
/** Adds a child to the container with a z-order, a parallax ratio and a position offset
|
||||||
|
|
|
@ -121,7 +121,7 @@ bool ParticleBatchNode::initWithFile(const std::string& fileImage, int capacity)
|
||||||
|
|
||||||
// override visit.
|
// override visit.
|
||||||
// Don't call visit on it's children
|
// Don't call visit on it's children
|
||||||
void ParticleBatchNode::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated)
|
void ParticleBatchNode::visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
// CAREFUL:
|
// CAREFUL:
|
||||||
// This visit is almost identical to Node#visit
|
// This visit is almost identical to Node#visit
|
||||||
|
@ -135,20 +135,16 @@ void ParticleBatchNode::visit(Renderer *renderer, const Mat4 &parentTransform, b
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool dirty = parentTransformUpdated || _transformUpdated;
|
uint32_t flags = processParentFlags(parentTransform, parentFlags);
|
||||||
if(dirty)
|
|
||||||
_modelViewTransform = transform(parentTransform);
|
|
||||||
_transformUpdated = false;
|
|
||||||
|
|
||||||
// IMPORTANT:
|
// IMPORTANT:
|
||||||
// To ease the migration to v3.0, we still support the Mat4 stack,
|
// To ease the migration to v3.0, we still support the Mat4 stack,
|
||||||
// but it is deprecated and your code should not rely on it
|
// but it is deprecated and your code should not rely on it
|
||||||
Director* director = Director::getInstance();
|
Director* director = Director::getInstance();
|
||||||
CCASSERT(nullptr != director, "Director is null when seting matrix stack");
|
|
||||||
director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewTransform);
|
director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewTransform);
|
||||||
|
|
||||||
draw(renderer, _modelViewTransform, dirty);
|
draw(renderer, _modelViewTransform, flags);
|
||||||
|
|
||||||
director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
}
|
}
|
||||||
|
@ -383,7 +379,7 @@ void ParticleBatchNode::removeAllChildrenWithCleanup(bool doCleanup)
|
||||||
_textureAtlas->removeAllQuads();
|
_textureAtlas->removeAllQuads();
|
||||||
}
|
}
|
||||||
|
|
||||||
void ParticleBatchNode::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void ParticleBatchNode::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
CC_PROFILER_START("CCParticleBatchNode - draw");
|
CC_PROFILER_START("CCParticleBatchNode - draw");
|
||||||
|
|
||||||
|
|
|
@ -91,13 +91,13 @@ public:
|
||||||
inline void setTextureAtlas(TextureAtlas* atlas) { _textureAtlas = atlas; };
|
inline void setTextureAtlas(TextureAtlas* atlas) { _textureAtlas = atlas; };
|
||||||
|
|
||||||
// Overrides
|
// Overrides
|
||||||
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated) override;
|
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags) override;
|
||||||
|
|
||||||
using Node::addChild;
|
using Node::addChild;
|
||||||
virtual void addChild(Node * child, int zOrder, int tag) override;
|
virtual void addChild(Node * child, int zOrder, int tag) override;
|
||||||
virtual void removeChild(Node* child, bool cleanup) override;
|
virtual void removeChild(Node* child, bool cleanup) override;
|
||||||
virtual void reorderChild(Node * child, int zOrder) override;
|
virtual void reorderChild(Node * child, int zOrder) override;
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
virtual Texture2D* getTexture(void) const override;
|
virtual Texture2D* getTexture(void) const override;
|
||||||
virtual void setTexture(Texture2D *texture) override;
|
virtual void setTexture(Texture2D *texture) override;
|
||||||
/**
|
/**
|
||||||
|
|
|
@ -368,7 +368,7 @@ void ParticleSystemQuad::postStep()
|
||||||
}
|
}
|
||||||
|
|
||||||
// overriding draw method
|
// overriding draw method
|
||||||
void ParticleSystemQuad::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void ParticleSystemQuad::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
CCASSERT( _particleIdx == 0 || _particleIdx == _particleCount, "Abnormal error in particle quad");
|
CCASSERT( _particleIdx == 0 || _particleIdx == _particleCount, "Abnormal error in particle quad");
|
||||||
//quad command
|
//quad command
|
||||||
|
|
|
@ -106,7 +106,7 @@ public:
|
||||||
* @js NA
|
* @js NA
|
||||||
* @lua NA
|
* @lua NA
|
||||||
*/
|
*/
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @js NA
|
* @js NA
|
||||||
|
|
|
@ -500,7 +500,7 @@ Vec2 ProgressTimer::boundaryTexCoord(char index)
|
||||||
return Vec2::ZERO;
|
return Vec2::ZERO;
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProgressTimer::onDraw(const Mat4 &transform, bool transformUpdated)
|
void ProgressTimer::onDraw(const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
|
|
||||||
getGLProgram()->use();
|
getGLProgram()->use();
|
||||||
|
@ -551,13 +551,13 @@ void ProgressTimer::onDraw(const Mat4 &transform, bool transformUpdated)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void ProgressTimer::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void ProgressTimer::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
if( ! _vertexData || ! _sprite)
|
if( ! _vertexData || ! _sprite)
|
||||||
return;
|
return;
|
||||||
|
|
||||||
_customCommand.init(_globalZOrder);
|
_customCommand.init(_globalZOrder);
|
||||||
_customCommand.func = CC_CALLBACK_0(ProgressTimer::onDraw, this, transform, transformUpdated);
|
_customCommand.func = CC_CALLBACK_0(ProgressTimer::onDraw, this, transform, flags);
|
||||||
renderer->addCommand(&_customCommand);
|
renderer->addCommand(&_customCommand);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -111,7 +111,7 @@ public:
|
||||||
inline Vec2 getBarChangeRate() const { return _barChangeRate; }
|
inline Vec2 getBarChangeRate() const { return _barChangeRate; }
|
||||||
|
|
||||||
// Overrides
|
// Overrides
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
virtual void setAnchorPoint(const Vec2& anchorPoint) override;
|
virtual void setAnchorPoint(const Vec2& anchorPoint) override;
|
||||||
virtual void setColor(const Color3B &color) override;
|
virtual void setColor(const Color3B &color) override;
|
||||||
virtual const Color3B& getColor() const override;
|
virtual const Color3B& getColor() const override;
|
||||||
|
@ -133,7 +133,7 @@ CC_CONSTRUCTOR_ACCESS:
|
||||||
bool initWithSprite(Sprite* sp);
|
bool initWithSprite(Sprite* sp);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void onDraw(const Mat4 &transform, bool transformUpdated);
|
void onDraw(const Mat4 &transform, uint32_t flags);
|
||||||
|
|
||||||
Tex2F textureCoordFromAlphaPoint(Vec2 alpha);
|
Tex2F textureCoordFromAlphaPoint(Vec2 alpha);
|
||||||
Vec2 vertexFromAlphaPoint(Vec2 alpha);
|
Vec2 vertexFromAlphaPoint(Vec2 alpha);
|
||||||
|
|
|
@ -383,7 +383,7 @@ void RenderTexture::clearStencil(int stencilValue)
|
||||||
glClearStencil(stencilClearValue);
|
glClearStencil(stencilClearValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RenderTexture::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated)
|
void RenderTexture::visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
// override visit.
|
// override visit.
|
||||||
// Don't call visit on its children
|
// Don't call visit on its children
|
||||||
|
@ -392,22 +392,17 @@ void RenderTexture::visit(Renderer *renderer, const Mat4 &parentTransform, bool
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool dirty = parentTransformUpdated || _transformUpdated;
|
uint32_t flags = processParentFlags(parentTransform, parentFlags);
|
||||||
if(dirty)
|
|
||||||
_modelViewTransform = transform(parentTransform);
|
|
||||||
_transformUpdated = false;
|
|
||||||
|
|
||||||
Director* director = Director::getInstance();
|
Director* director = Director::getInstance();
|
||||||
CCASSERT(nullptr != director, "Director is null when seting matrix stack");
|
|
||||||
|
|
||||||
// IMPORTANT:
|
// IMPORTANT:
|
||||||
// To ease the migration to v3.0, we still support the Mat4 stack,
|
// To ease the migration to v3.0, we still support the Mat4 stack,
|
||||||
// but it is deprecated and your code should not rely on it
|
// but it is deprecated and your code should not rely on it
|
||||||
director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewTransform);
|
director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewTransform);
|
||||||
|
|
||||||
_sprite->visit(renderer, _modelViewTransform, dirty);
|
_sprite->visit(renderer, _modelViewTransform, flags);
|
||||||
draw(renderer, _modelViewTransform, dirty);
|
draw(renderer, _modelViewTransform, flags);
|
||||||
|
|
||||||
director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
|
|
||||||
|
@ -654,7 +649,7 @@ void RenderTexture::onClearDepth()
|
||||||
glClearDepth(depthClearValue);
|
glClearDepth(depthClearValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
void RenderTexture::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void RenderTexture::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
if (_autoDraw)
|
if (_autoDraw)
|
||||||
{
|
{
|
||||||
|
@ -672,7 +667,7 @@ void RenderTexture::draw(Renderer *renderer, const Mat4 &transform, bool transfo
|
||||||
for(const auto &child: _children)
|
for(const auto &child: _children)
|
||||||
{
|
{
|
||||||
if (child != _sprite)
|
if (child != _sprite)
|
||||||
child->visit(renderer, transform, transformUpdated);
|
child->visit(renderer, transform, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
//End will pop the current render group
|
//End will pop the current render group
|
||||||
|
|
|
@ -153,8 +153,8 @@ public:
|
||||||
};
|
};
|
||||||
|
|
||||||
// Overrides
|
// Overrides
|
||||||
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated) override;
|
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags) override;
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
|
|
||||||
//flag: use stack matrix computed from scene hierarchy or generate new modelView and projection matrix
|
//flag: use stack matrix computed from scene hierarchy or generate new modelView and projection matrix
|
||||||
void setKeepMatrix(bool keepMatrix);
|
void setKeepMatrix(bool keepMatrix);
|
||||||
|
|
|
@ -53,16 +53,14 @@ Scene::~Scene()
|
||||||
|
|
||||||
bool Scene::init()
|
bool Scene::init()
|
||||||
{
|
{
|
||||||
bool ret = false;
|
auto size = Director::getInstance()->getWinSize();
|
||||||
do
|
return initWithSize(size);
|
||||||
|
}
|
||||||
|
|
||||||
|
bool Scene::initWithSize(const Size& size)
|
||||||
{
|
{
|
||||||
Director * director;
|
setContentSize(size);
|
||||||
CC_BREAK_IF( ! (director = Director::getInstance()) );
|
return true;
|
||||||
this->setContentSize(director->getWinSize());
|
|
||||||
// success
|
|
||||||
ret = true;
|
|
||||||
} while (0);
|
|
||||||
return ret;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
Scene* Scene::create()
|
Scene* Scene::create()
|
||||||
|
@ -80,6 +78,21 @@ Scene *Scene::create()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Scene* Scene::createWithSize(const Size& size)
|
||||||
|
{
|
||||||
|
Scene *ret = new Scene();
|
||||||
|
if (ret && ret->initWithSize(size))
|
||||||
|
{
|
||||||
|
ret->autorelease();
|
||||||
|
return ret;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
CC_SAFE_DELETE(ret);
|
||||||
|
return nullptr;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
std::string Scene::getDescription() const
|
std::string Scene::getDescription() const
|
||||||
{
|
{
|
||||||
return StringUtils::format("<Scene | tag = %d>", _tag);
|
return StringUtils::format("<Scene | tag = %d>", _tag);
|
||||||
|
|
|
@ -54,6 +54,9 @@ public:
|
||||||
/** creates a new Scene object */
|
/** creates a new Scene object */
|
||||||
static Scene *create();
|
static Scene *create();
|
||||||
|
|
||||||
|
/** creates a new Scene object with a predefined Size */
|
||||||
|
static Scene *createWithSize(const Size& size);
|
||||||
|
|
||||||
// Overrides
|
// Overrides
|
||||||
virtual Scene *getScene() override;
|
virtual Scene *getScene() override;
|
||||||
|
|
||||||
|
@ -64,7 +67,8 @@ CC_CONSTRUCTOR_ACCESS:
|
||||||
Scene();
|
Scene();
|
||||||
virtual ~Scene();
|
virtual ~Scene();
|
||||||
|
|
||||||
virtual bool init() override;
|
bool init();
|
||||||
|
bool initWithSize(const Size& size);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
friend class Node;
|
friend class Node;
|
||||||
|
|
|
@ -585,10 +585,10 @@ void Sprite::updateTransform(void)
|
||||||
|
|
||||||
// draw
|
// draw
|
||||||
|
|
||||||
void Sprite::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void Sprite::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
// Don't do calculate the culling if the transform was not updated
|
// Don't do calculate the culling if the transform was not updated
|
||||||
_insideBounds = transformUpdated ? renderer->checkVisibility(transform, _contentSize) : _insideBounds;
|
_insideBounds = (flags & FLAGS_TRANSFORM_DIRTY) ? renderer->checkVisibility(transform, _contentSize) : _insideBounds;
|
||||||
|
|
||||||
if(_insideBounds)
|
if(_insideBounds)
|
||||||
{
|
{
|
||||||
|
|
|
@ -420,7 +420,7 @@ public:
|
||||||
virtual void setAnchorPoint(const Vec2& anchor) override;
|
virtual void setAnchorPoint(const Vec2& anchor) override;
|
||||||
virtual void ignoreAnchorPointForPosition(bool value) override;
|
virtual void ignoreAnchorPointForPosition(bool value) override;
|
||||||
virtual void setVisible(bool bVisible) override;
|
virtual void setVisible(bool bVisible) override;
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
virtual void setOpacityModifyRGB(bool modify) override;
|
virtual void setOpacityModifyRGB(bool modify) override;
|
||||||
virtual bool isOpacityModifyRGB(void) const override;
|
virtual bool isOpacityModifyRGB(void) const override;
|
||||||
/// @}
|
/// @}
|
||||||
|
|
|
@ -132,7 +132,7 @@ SpriteBatchNode::~SpriteBatchNode()
|
||||||
|
|
||||||
// override visit
|
// override visit
|
||||||
// don't call visit on it's children
|
// don't call visit on it's children
|
||||||
void SpriteBatchNode::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated)
|
void SpriteBatchNode::visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
CC_PROFILER_START_CATEGORY(kProfilerCategoryBatchSprite, "CCSpriteBatchNode - visit");
|
CC_PROFILER_START_CATEGORY(kProfilerCategoryBatchSprite, "CCSpriteBatchNode - visit");
|
||||||
|
|
||||||
|
@ -150,20 +150,16 @@ void SpriteBatchNode::visit(Renderer *renderer, const Mat4 &parentTransform, boo
|
||||||
|
|
||||||
sortAllChildren();
|
sortAllChildren();
|
||||||
|
|
||||||
bool dirty = parentTransformUpdated || _transformUpdated;
|
uint32_t flags = processParentFlags(parentTransform, parentFlags);
|
||||||
if(dirty)
|
|
||||||
_modelViewTransform = transform(parentTransform);
|
|
||||||
_transformUpdated = false;
|
|
||||||
|
|
||||||
// IMPORTANT:
|
// IMPORTANT:
|
||||||
// To ease the migration to v3.0, we still support the Mat4 stack,
|
// To ease the migration to v3.0, we still support the Mat4 stack,
|
||||||
// but it is deprecated and your code should not rely on it
|
// but it is deprecated and your code should not rely on it
|
||||||
Director* director = Director::getInstance();
|
Director* director = Director::getInstance();
|
||||||
CCASSERT(nullptr != director, "Director is null when seting matrix stack");
|
|
||||||
director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewTransform);
|
director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewTransform);
|
||||||
|
|
||||||
draw(renderer, _modelViewTransform, dirty);
|
draw(renderer, _modelViewTransform, flags);
|
||||||
|
|
||||||
director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
setOrderOfArrival(0);
|
setOrderOfArrival(0);
|
||||||
|
@ -356,7 +352,7 @@ void SpriteBatchNode::reorderBatch(bool reorder)
|
||||||
_reorderChildDirty=reorder;
|
_reorderChildDirty=reorder;
|
||||||
}
|
}
|
||||||
|
|
||||||
void SpriteBatchNode::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void SpriteBatchNode::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
// Optimization: Fast Dispatch
|
// Optimization: Fast Dispatch
|
||||||
if( _textureAtlas->getTotalQuads() == 0 )
|
if( _textureAtlas->getTotalQuads() == 0 )
|
||||||
|
|
|
@ -134,7 +134,7 @@ public:
|
||||||
*/
|
*/
|
||||||
virtual const BlendFunc& getBlendFunc() const override;
|
virtual const BlendFunc& getBlendFunc() const override;
|
||||||
|
|
||||||
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated) override;
|
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags) override;
|
||||||
|
|
||||||
using Node::addChild;
|
using Node::addChild;
|
||||||
virtual void addChild(Node * child, int zOrder, int tag) override;
|
virtual void addChild(Node * child, int zOrder, int tag) override;
|
||||||
|
@ -143,7 +143,7 @@ public:
|
||||||
virtual void removeChild(Node *child, bool cleanup) override;
|
virtual void removeChild(Node *child, bool cleanup) override;
|
||||||
virtual void removeAllChildrenWithCleanup(bool cleanup) override;
|
virtual void removeAllChildrenWithCleanup(bool cleanup) override;
|
||||||
virtual void sortAllChildren() override;
|
virtual void sortAllChildren() override;
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
virtual std::string getDescription() const override;
|
virtual std::string getDescription() const override;
|
||||||
|
|
||||||
/** Inserts a quad at a certain index into the texture atlas. The Sprite won't be added into the children array.
|
/** Inserts a quad at a certain index into the texture atlas. The Sprite won't be added into the children array.
|
||||||
|
|
|
@ -69,6 +69,13 @@ SpriteFrame* SpriteFrame::create(const std::string& filename, const Rect& rect,
|
||||||
return spriteFrame;
|
return spriteFrame;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SpriteFrame::SpriteFrame(void)
|
||||||
|
: _rotated(false)
|
||||||
|
, _texture(nullptr)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
bool SpriteFrame::initWithTexture(Texture2D* texture, const Rect& rect)
|
bool SpriteFrame::initWithTexture(Texture2D* texture, const Rect& rect)
|
||||||
{
|
{
|
||||||
Rect rectInPixels = CC_RECT_POINTS_TO_PIXELS(rect);
|
Rect rectInPixels = CC_RECT_POINTS_TO_PIXELS(rect);
|
||||||
|
|
|
@ -75,34 +75,6 @@ public:
|
||||||
The originalSize is the size in points of the frame before being trimmed.
|
The originalSize is the size in points of the frame before being trimmed.
|
||||||
*/
|
*/
|
||||||
static SpriteFrame* createWithTexture(Texture2D* pobTexture, const Rect& rect, bool rotated, const Vec2& offset, const Size& originalSize);
|
static SpriteFrame* createWithTexture(Texture2D* pobTexture, const Rect& rect, bool rotated, const Vec2& offset, const Size& originalSize);
|
||||||
/**
|
|
||||||
* @js NA
|
|
||||||
* @lua NA
|
|
||||||
*/
|
|
||||||
virtual ~SpriteFrame(void);
|
|
||||||
|
|
||||||
/** Initializes a SpriteFrame with a texture, rect in points.
|
|
||||||
It is assumed that the frame was not trimmed.
|
|
||||||
*/
|
|
||||||
bool initWithTexture(Texture2D* pobTexture, const Rect& rect);
|
|
||||||
|
|
||||||
/** Initializes a SpriteFrame with a texture filename, rect in points;
|
|
||||||
It is assumed that the frame was not trimmed.
|
|
||||||
*/
|
|
||||||
bool initWithTextureFilename(const std::string& filename, const Rect& rect);
|
|
||||||
|
|
||||||
/** Initializes a SpriteFrame with a texture, rect, rotated, offset and originalSize in pixels.
|
|
||||||
The originalSize is the size in points of the frame before being trimmed.
|
|
||||||
*/
|
|
||||||
bool initWithTexture(Texture2D* pobTexture, const Rect& rect, bool rotated, const Vec2& offset, const Size& originalSize);
|
|
||||||
|
|
||||||
/** Initializes a SpriteFrame with a texture, rect, rotated, offset and originalSize in pixels.
|
|
||||||
The originalSize is the size in pixels of the frame before being trimmed.
|
|
||||||
|
|
||||||
@since v1.1
|
|
||||||
*/
|
|
||||||
bool initWithTextureFilename(const std::string& filename, const Rect& rect, bool rotated, const Vec2& offset, const Size& originalSize);
|
|
||||||
|
|
||||||
|
|
||||||
// attributes
|
// attributes
|
||||||
inline const Rect& getRectInPixels() const { return _rectInPixels; }
|
inline const Rect& getRectInPixels() const { return _rectInPixels; }
|
||||||
|
@ -142,6 +114,39 @@ public:
|
||||||
// Overrides
|
// Overrides
|
||||||
virtual SpriteFrame *clone() const override;
|
virtual SpriteFrame *clone() const override;
|
||||||
|
|
||||||
|
CC_CONSTRUCTOR_ACCESS:
|
||||||
|
/**
|
||||||
|
* @lua NA
|
||||||
|
*/
|
||||||
|
SpriteFrame(void);
|
||||||
|
|
||||||
|
/**
|
||||||
|
* @lua NA
|
||||||
|
*/
|
||||||
|
virtual ~SpriteFrame(void);
|
||||||
|
|
||||||
|
/** Initializes a SpriteFrame with a texture, rect in points.
|
||||||
|
It is assumed that the frame was not trimmed.
|
||||||
|
*/
|
||||||
|
bool initWithTexture(Texture2D* pobTexture, const Rect& rect);
|
||||||
|
|
||||||
|
/** Initializes a SpriteFrame with a texture filename, rect in points;
|
||||||
|
It is assumed that the frame was not trimmed.
|
||||||
|
*/
|
||||||
|
bool initWithTextureFilename(const std::string& filename, const Rect& rect);
|
||||||
|
|
||||||
|
/** Initializes a SpriteFrame with a texture, rect, rotated, offset and originalSize in pixels.
|
||||||
|
The originalSize is the size in points of the frame before being trimmed.
|
||||||
|
*/
|
||||||
|
bool initWithTexture(Texture2D* pobTexture, const Rect& rect, bool rotated, const Vec2& offset, const Size& originalSize);
|
||||||
|
|
||||||
|
/** Initializes a SpriteFrame with a texture, rect, rotated, offset and originalSize in pixels.
|
||||||
|
The originalSize is the size in pixels of the frame before being trimmed.
|
||||||
|
|
||||||
|
@since v1.1
|
||||||
|
*/
|
||||||
|
bool initWithTextureFilename(const std::string& filename, const Rect& rect, bool rotated, const Vec2& offset, const Size& originalSize);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
Vec2 _offset;
|
Vec2 _offset;
|
||||||
Size _originalSize;
|
Size _originalSize;
|
||||||
|
|
|
@ -65,7 +65,7 @@ void SpriteFrameCache::destroyInstance()
|
||||||
CC_SAFE_RELEASE_NULL(_sharedSpriteFrameCache);
|
CC_SAFE_RELEASE_NULL(_sharedSpriteFrameCache);
|
||||||
}
|
}
|
||||||
|
|
||||||
bool SpriteFrameCache::init(void)
|
bool SpriteFrameCache::init()
|
||||||
{
|
{
|
||||||
_spriteFrames.reserve(20);
|
_spriteFrames.reserve(20);
|
||||||
_spriteFramesAliases.reserve(20);
|
_spriteFramesAliases.reserve(20);
|
||||||
|
@ -73,7 +73,7 @@ bool SpriteFrameCache::init(void)
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
SpriteFrameCache::~SpriteFrameCache(void)
|
SpriteFrameCache::~SpriteFrameCache()
|
||||||
{
|
{
|
||||||
CC_SAFE_DELETE(_loadedFileNames);
|
CC_SAFE_DELETE(_loadedFileNames);
|
||||||
}
|
}
|
||||||
|
@ -132,8 +132,7 @@ void SpriteFrameCache::addSpriteFramesWithDictionary(ValueMap& dictionary, Textu
|
||||||
ow = abs(ow);
|
ow = abs(ow);
|
||||||
oh = abs(oh);
|
oh = abs(oh);
|
||||||
// create frame
|
// create frame
|
||||||
spriteFrame = new SpriteFrame();
|
spriteFrame = SpriteFrame::createWithTexture(texture,
|
||||||
spriteFrame->initWithTexture(texture,
|
|
||||||
Rect(x, y, w, h),
|
Rect(x, y, w, h),
|
||||||
false,
|
false,
|
||||||
Vec2(ox, oy),
|
Vec2(ox, oy),
|
||||||
|
@ -155,8 +154,7 @@ void SpriteFrameCache::addSpriteFramesWithDictionary(ValueMap& dictionary, Textu
|
||||||
Size sourceSize = SizeFromString(frameDict["sourceSize"].asString());
|
Size sourceSize = SizeFromString(frameDict["sourceSize"].asString());
|
||||||
|
|
||||||
// create frame
|
// create frame
|
||||||
spriteFrame = new SpriteFrame();
|
spriteFrame = SpriteFrame::createWithTexture(texture,
|
||||||
spriteFrame->initWithTexture(texture,
|
|
||||||
frame,
|
frame,
|
||||||
rotated,
|
rotated,
|
||||||
offset,
|
offset,
|
||||||
|
@ -186,8 +184,7 @@ void SpriteFrameCache::addSpriteFramesWithDictionary(ValueMap& dictionary, Textu
|
||||||
}
|
}
|
||||||
|
|
||||||
// create frame
|
// create frame
|
||||||
spriteFrame = new SpriteFrame();
|
spriteFrame = SpriteFrame::createWithTexture(texture,
|
||||||
spriteFrame->initWithTexture(texture,
|
|
||||||
Rect(textureRect.origin.x, textureRect.origin.y, spriteSize.width, spriteSize.height),
|
Rect(textureRect.origin.x, textureRect.origin.y, spriteSize.width, spriteSize.height),
|
||||||
textureRotated,
|
textureRotated,
|
||||||
spriteOffset,
|
spriteOffset,
|
||||||
|
@ -196,16 +193,21 @@ void SpriteFrameCache::addSpriteFramesWithDictionary(ValueMap& dictionary, Textu
|
||||||
|
|
||||||
// add sprite frame
|
// add sprite frame
|
||||||
_spriteFrames.insert(spriteFrameName, spriteFrame);
|
_spriteFrames.insert(spriteFrameName, spriteFrame);
|
||||||
spriteFrame->release();
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void SpriteFrameCache::addSpriteFramesWithFile(const std::string& pszPlist, Texture2D *pobTexture)
|
void SpriteFrameCache::addSpriteFramesWithFile(const std::string& plist, Texture2D *texture)
|
||||||
{
|
{
|
||||||
std::string fullPath = FileUtils::getInstance()->fullPathForFilename(pszPlist);
|
if (_loadedFileNames->find(plist) != _loadedFileNames->end())
|
||||||
|
{
|
||||||
|
return; // We already added it
|
||||||
|
}
|
||||||
|
|
||||||
|
std::string fullPath = FileUtils::getInstance()->fullPathForFilename(plist);
|
||||||
ValueMap dict = FileUtils::getInstance()->getValueMapFromFile(fullPath);
|
ValueMap dict = FileUtils::getInstance()->getValueMapFromFile(fullPath);
|
||||||
|
|
||||||
addSpriteFramesWithDictionary(dict, pobTexture);
|
addSpriteFramesWithDictionary(dict, texture);
|
||||||
|
_loadedFileNames->insert(plist);
|
||||||
}
|
}
|
||||||
|
|
||||||
void SpriteFrameCache::addSpriteFramesWithFile(const std::string& plist, const std::string& textureFileName)
|
void SpriteFrameCache::addSpriteFramesWithFile(const std::string& plist, const std::string& textureFileName)
|
||||||
|
@ -223,13 +225,13 @@ void SpriteFrameCache::addSpriteFramesWithFile(const std::string& plist, const s
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void SpriteFrameCache::addSpriteFramesWithFile(const std::string& pszPlist)
|
void SpriteFrameCache::addSpriteFramesWithFile(const std::string& plist)
|
||||||
{
|
{
|
||||||
CCASSERT(pszPlist.size()>0, "plist filename should not be nullptr");
|
CCASSERT(plist.size()>0, "plist filename should not be nullptr");
|
||||||
|
|
||||||
if (_loadedFileNames->find(pszPlist) == _loadedFileNames->end())
|
if (_loadedFileNames->find(plist) == _loadedFileNames->end())
|
||||||
{
|
{
|
||||||
std::string fullPath = FileUtils::getInstance()->fullPathForFilename(pszPlist);
|
std::string fullPath = FileUtils::getInstance()->fullPathForFilename(plist);
|
||||||
ValueMap dict = FileUtils::getInstance()->getValueMapFromFile(fullPath);
|
ValueMap dict = FileUtils::getInstance()->getValueMapFromFile(fullPath);
|
||||||
|
|
||||||
string texturePath("");
|
string texturePath("");
|
||||||
|
@ -244,12 +246,12 @@ void SpriteFrameCache::addSpriteFramesWithFile(const std::string& pszPlist)
|
||||||
if (!texturePath.empty())
|
if (!texturePath.empty())
|
||||||
{
|
{
|
||||||
// build texture path relative to plist file
|
// build texture path relative to plist file
|
||||||
texturePath = FileUtils::getInstance()->fullPathFromRelativeFile(texturePath.c_str(), pszPlist);
|
texturePath = FileUtils::getInstance()->fullPathFromRelativeFile(texturePath.c_str(), plist);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
// build texture path by replacing file extension
|
// build texture path by replacing file extension
|
||||||
texturePath = pszPlist;
|
texturePath = plist;
|
||||||
|
|
||||||
// remove .xxx
|
// remove .xxx
|
||||||
size_t startPos = texturePath.find_last_of(".");
|
size_t startPos = texturePath.find_last_of(".");
|
||||||
|
@ -266,7 +268,7 @@ void SpriteFrameCache::addSpriteFramesWithFile(const std::string& pszPlist)
|
||||||
if (texture)
|
if (texture)
|
||||||
{
|
{
|
||||||
addSpriteFramesWithDictionary(dict, texture);
|
addSpriteFramesWithDictionary(dict, texture);
|
||||||
_loadedFileNames->insert(pszPlist);
|
_loadedFileNames->insert(plist);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
|
|
|
@ -61,7 +61,7 @@ class CC_DLL SpriteFrameCache : public Ref
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
/** Returns the shared instance of the Sprite Frame cache */
|
/** Returns the shared instance of the Sprite Frame cache */
|
||||||
static SpriteFrameCache* getInstance(void);
|
static SpriteFrameCache* getInstance();
|
||||||
|
|
||||||
/** @deprecated Use getInstance() instead */
|
/** @deprecated Use getInstance() instead */
|
||||||
CC_DEPRECATED_ATTRIBUTE static SpriteFrameCache* sharedSpriteFrameCache() { return SpriteFrameCache::getInstance(); }
|
CC_DEPRECATED_ATTRIBUTE static SpriteFrameCache* sharedSpriteFrameCache() { return SpriteFrameCache::getInstance(); }
|
||||||
|
@ -82,7 +82,7 @@ public:
|
||||||
* @lua NA
|
* @lua NA
|
||||||
*/
|
*/
|
||||||
virtual ~SpriteFrameCache();
|
virtual ~SpriteFrameCache();
|
||||||
bool init(void);
|
bool init();
|
||||||
|
|
||||||
public:
|
public:
|
||||||
/** Adds multiple Sprite Frames from a plist file.
|
/** Adds multiple Sprite Frames from a plist file.
|
||||||
|
|
|
@ -263,13 +263,13 @@ void TextFieldTTF::setTextColor(const Color4B &color)
|
||||||
Label::setTextColor(_colorText);
|
Label::setTextColor(_colorText);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TextFieldTTF::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated)
|
void TextFieldTTF::visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
if (_delegate && _delegate->onVisit(this,renderer,parentTransform,parentTransformUpdated))
|
if (_delegate && _delegate->onVisit(this,renderer,parentTransform,parentFlags))
|
||||||
{
|
{
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
Label::visit(renderer,parentTransform,parentTransformUpdated);
|
Label::visit(renderer,parentTransform,parentFlags);
|
||||||
}
|
}
|
||||||
|
|
||||||
const Color4B& TextFieldTTF::getColorSpaceHolder()
|
const Color4B& TextFieldTTF::getColorSpaceHolder()
|
||||||
|
|
|
@ -86,7 +86,7 @@ public:
|
||||||
/**
|
/**
|
||||||
@brief If the sender doesn't want to draw, return true.
|
@brief If the sender doesn't want to draw, return true.
|
||||||
*/
|
*/
|
||||||
virtual bool onVisit(TextFieldTTF * sender,Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
virtual bool onVisit(TextFieldTTF * sender,Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
CC_UNUSED_PARAM(sender);
|
CC_UNUSED_PARAM(sender);
|
||||||
return false;
|
return false;
|
||||||
|
@ -165,7 +165,7 @@ public:
|
||||||
virtual void setSecureTextEntry(bool value);
|
virtual void setSecureTextEntry(bool value);
|
||||||
virtual bool isSecureTextEntry();
|
virtual bool isSecureTextEntry();
|
||||||
|
|
||||||
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated) override;
|
virtual void visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags) override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
//////////////////////////////////////////////////////////////////////////
|
//////////////////////////////////////////////////////////////////////////
|
||||||
|
|
|
@ -103,16 +103,16 @@ void TransitionScene::sceneOrder()
|
||||||
_isInSceneOnTop = true;
|
_isInSceneOnTop = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
void TransitionScene::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void TransitionScene::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
Scene::draw(renderer, transform, transformUpdated);
|
Scene::draw(renderer, transform, flags);
|
||||||
|
|
||||||
if( _isInSceneOnTop ) {
|
if( _isInSceneOnTop ) {
|
||||||
_outScene->visit(renderer, transform, transformUpdated);
|
_outScene->visit(renderer, transform, flags);
|
||||||
_inScene->visit(renderer, transform, transformUpdated);
|
_inScene->visit(renderer, transform, flags);
|
||||||
} else {
|
} else {
|
||||||
_inScene->visit(renderer, transform, transformUpdated);
|
_inScene->visit(renderer, transform, flags);
|
||||||
_outScene->visit(renderer, transform, transformUpdated);
|
_outScene->visit(renderer, transform, flags);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1261,7 +1261,7 @@ TransitionCrossFade* TransitionCrossFade::create(float t, Scene* scene)
|
||||||
return nullptr;
|
return nullptr;
|
||||||
}
|
}
|
||||||
|
|
||||||
void TransitionCrossFade::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void TransitionCrossFade::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
// override draw since both scenes (textures) are rendered in 1 scene
|
// override draw since both scenes (textures) are rendered in 1 scene
|
||||||
}
|
}
|
||||||
|
@ -1410,19 +1410,19 @@ void TransitionTurnOffTiles::onExit()
|
||||||
TransitionScene::onExit();
|
TransitionScene::onExit();
|
||||||
}
|
}
|
||||||
|
|
||||||
void TransitionTurnOffTiles::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void TransitionTurnOffTiles::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
Scene::draw(renderer, transform, transformUpdated);
|
Scene::draw(renderer, transform, flags);
|
||||||
|
|
||||||
if( _isInSceneOnTop )
|
if( _isInSceneOnTop )
|
||||||
{
|
{
|
||||||
_outSceneProxy->visit(renderer, transform, transformUpdated);
|
_outSceneProxy->visit(renderer, transform, flags);
|
||||||
_inScene->visit(renderer, transform, transformUpdated);
|
_inScene->visit(renderer, transform, flags);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_inScene->visit(renderer, transform, transformUpdated);
|
_inScene->visit(renderer, transform, flags);
|
||||||
_outSceneProxy->visit(renderer, transform, transformUpdated);
|
_outSceneProxy->visit(renderer, transform, flags);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1490,10 +1490,10 @@ void TransitionSplitCols::switchTargetToInscene()
|
||||||
_gridProxy->setTarget(_inScene);
|
_gridProxy->setTarget(_inScene);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TransitionSplitCols::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void TransitionSplitCols::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
Scene::draw(renderer, transform, transformUpdated);
|
Scene::draw(renderer, transform, flags);
|
||||||
_gridProxy->visit(renderer, transform, transformUpdated);
|
_gridProxy->visit(renderer, transform, flags);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TransitionSplitCols::onExit()
|
void TransitionSplitCols::onExit()
|
||||||
|
@ -1606,19 +1606,19 @@ void TransitionFadeTR::onExit()
|
||||||
TransitionScene::onExit();
|
TransitionScene::onExit();
|
||||||
}
|
}
|
||||||
|
|
||||||
void TransitionFadeTR::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void TransitionFadeTR::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
Scene::draw(renderer, transform, transformUpdated);
|
Scene::draw(renderer, transform, flags);
|
||||||
|
|
||||||
if( _isInSceneOnTop )
|
if( _isInSceneOnTop )
|
||||||
{
|
{
|
||||||
_outSceneProxy->visit(renderer, transform, transformUpdated);
|
_outSceneProxy->visit(renderer, transform, flags);
|
||||||
_inScene->visit(renderer, transform, transformUpdated);
|
_inScene->visit(renderer, transform, flags);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
_inScene->visit(renderer, transform, transformUpdated);
|
_inScene->visit(renderer, transform, flags);
|
||||||
_outSceneProxy->visit(renderer, transform, transformUpdated);
|
_outSceneProxy->visit(renderer, transform, flags);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -91,7 +91,7 @@ public:
|
||||||
//
|
//
|
||||||
// Overrides
|
// Overrides
|
||||||
//
|
//
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
virtual void onEnter() override;
|
virtual void onEnter() override;
|
||||||
virtual void onExit() override;
|
virtual void onExit() override;
|
||||||
virtual void cleanup() override;
|
virtual void cleanup() override;
|
||||||
|
@ -613,7 +613,7 @@ public :
|
||||||
* @js NA
|
* @js NA
|
||||||
* @lua NA
|
* @lua NA
|
||||||
*/
|
*/
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
/**
|
/**
|
||||||
* @js NA
|
* @js NA
|
||||||
* @lua NA
|
* @lua NA
|
||||||
|
@ -651,7 +651,7 @@ public :
|
||||||
virtual void onEnter() override;
|
virtual void onEnter() override;
|
||||||
virtual void onExit() override;
|
virtual void onExit() override;
|
||||||
virtual ActionInterval * easeActionWithAction(ActionInterval * action) override;
|
virtual ActionInterval * easeActionWithAction(ActionInterval * action) override;
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
TransitionTurnOffTiles();
|
TransitionTurnOffTiles();
|
||||||
|
@ -684,7 +684,7 @@ public:
|
||||||
virtual void onEnter() override;
|
virtual void onEnter() override;
|
||||||
virtual ActionInterval * easeActionWithAction(ActionInterval * action) override;
|
virtual ActionInterval * easeActionWithAction(ActionInterval * action) override;
|
||||||
virtual void onExit() override;
|
virtual void onExit() override;
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
protected:
|
protected:
|
||||||
TransitionSplitCols();
|
TransitionSplitCols();
|
||||||
virtual ~TransitionSplitCols();
|
virtual ~TransitionSplitCols();
|
||||||
|
@ -735,7 +735,7 @@ public:
|
||||||
virtual void onEnter() override;
|
virtual void onEnter() override;
|
||||||
virtual ActionInterval* easeActionWithAction(ActionInterval * action) override;
|
virtual ActionInterval* easeActionWithAction(ActionInterval * action) override;
|
||||||
virtual void onExit() override;
|
virtual void onExit() override;
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
protected:
|
protected:
|
||||||
TransitionFadeTR();
|
TransitionFadeTR();
|
||||||
virtual ~TransitionFadeTR();
|
virtual ~TransitionFadeTR();
|
||||||
|
|
|
@ -92,27 +92,27 @@ void TransitionPageTurn::onDisablePolygonOffset()
|
||||||
glPolygonOffset(0, 0);
|
glPolygonOffset(0, 0);
|
||||||
}
|
}
|
||||||
|
|
||||||
void TransitionPageTurn::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void TransitionPageTurn::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
Scene::draw(renderer, transform, transformUpdated);
|
Scene::draw(renderer, transform, flags);
|
||||||
|
|
||||||
if( _isInSceneOnTop ) {
|
if( _isInSceneOnTop ) {
|
||||||
_outSceneProxy->visit(renderer, transform, transformUpdated);
|
_outSceneProxy->visit(renderer, transform, flags);
|
||||||
_enableOffsetCmd.init(_globalZOrder);
|
_enableOffsetCmd.init(_globalZOrder);
|
||||||
_enableOffsetCmd.func = CC_CALLBACK_0(TransitionPageTurn::onEnablePolygonOffset, this);
|
_enableOffsetCmd.func = CC_CALLBACK_0(TransitionPageTurn::onEnablePolygonOffset, this);
|
||||||
renderer->addCommand(&_enableOffsetCmd);
|
renderer->addCommand(&_enableOffsetCmd);
|
||||||
_inSceneProxy->visit(renderer, transform, transformUpdated);
|
_inSceneProxy->visit(renderer, transform, flags);
|
||||||
_disableOffsetCmd.init(_globalZOrder);
|
_disableOffsetCmd.init(_globalZOrder);
|
||||||
_disableOffsetCmd.func = CC_CALLBACK_0(TransitionPageTurn::onDisablePolygonOffset, this);
|
_disableOffsetCmd.func = CC_CALLBACK_0(TransitionPageTurn::onDisablePolygonOffset, this);
|
||||||
renderer->addCommand(&_disableOffsetCmd);
|
renderer->addCommand(&_disableOffsetCmd);
|
||||||
} else {
|
} else {
|
||||||
_inSceneProxy->visit(renderer, transform, transformUpdated);
|
_inSceneProxy->visit(renderer, transform, flags);
|
||||||
|
|
||||||
_enableOffsetCmd.init(_globalZOrder);
|
_enableOffsetCmd.init(_globalZOrder);
|
||||||
_enableOffsetCmd.func = CC_CALLBACK_0(TransitionPageTurn::onEnablePolygonOffset, this);
|
_enableOffsetCmd.func = CC_CALLBACK_0(TransitionPageTurn::onEnablePolygonOffset, this);
|
||||||
renderer->addCommand(&_enableOffsetCmd);
|
renderer->addCommand(&_enableOffsetCmd);
|
||||||
|
|
||||||
_outSceneProxy->visit(renderer, transform, transformUpdated);
|
_outSceneProxy->visit(renderer, transform, flags);
|
||||||
|
|
||||||
_disableOffsetCmd.init(_globalZOrder);
|
_disableOffsetCmd.init(_globalZOrder);
|
||||||
_disableOffsetCmd.func = CC_CALLBACK_0(TransitionPageTurn::onDisablePolygonOffset, this);
|
_disableOffsetCmd.func = CC_CALLBACK_0(TransitionPageTurn::onDisablePolygonOffset, this);
|
||||||
|
|
|
@ -72,7 +72,7 @@ public:
|
||||||
//
|
//
|
||||||
// Overrides
|
// Overrides
|
||||||
//
|
//
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Creates a base transition with duration and incoming scene.
|
* Creates a base transition with duration and incoming scene.
|
||||||
|
|
|
@ -222,6 +222,7 @@ xcopy /Y /Q "$(ProjectDir)..\..\external\win32-specific\gles\prebuilt\*.*" "$(Ou
|
||||||
<ClCompile Include="..\base\ccUtils.cpp" />
|
<ClCompile Include="..\base\ccUtils.cpp" />
|
||||||
<ClCompile Include="..\base\CCValue.cpp" />
|
<ClCompile Include="..\base\CCValue.cpp" />
|
||||||
<ClCompile Include="..\base\etc1.cpp" />
|
<ClCompile Include="..\base\etc1.cpp" />
|
||||||
|
<ClCompile Include="..\base\ObjectFactory.cpp" />
|
||||||
<ClCompile Include="..\base\s3tc.cpp" />
|
<ClCompile Include="..\base\s3tc.cpp" />
|
||||||
<ClCompile Include="..\base\TGAlib.cpp" />
|
<ClCompile Include="..\base\TGAlib.cpp" />
|
||||||
<ClCompile Include="..\base\ZipUtils.cpp" />
|
<ClCompile Include="..\base\ZipUtils.cpp" />
|
||||||
|
@ -354,6 +355,7 @@ xcopy /Y /Q "$(ProjectDir)..\..\external\win32-specific\gles\prebuilt\*.*" "$(Ou
|
||||||
<ClInclude Include="..\3d\CCAnimation3D.h" />
|
<ClInclude Include="..\3d\CCAnimation3D.h" />
|
||||||
<ClInclude Include="..\3d\CCAnimationCurve.h" />
|
<ClInclude Include="..\3d\CCAnimationCurve.h" />
|
||||||
<ClInclude Include="..\3d\CCBundle3D.h" />
|
<ClInclude Include="..\3d\CCBundle3D.h" />
|
||||||
|
<ClInclude Include="..\3d\CCBundle3DData.h" />
|
||||||
<ClInclude Include="..\3d\CCMesh.h" />
|
<ClInclude Include="..\3d\CCMesh.h" />
|
||||||
<ClInclude Include="..\3d\CCMeshSkin.h" />
|
<ClInclude Include="..\3d\CCMeshSkin.h" />
|
||||||
<ClInclude Include="..\3d\CCObjLoader.h" />
|
<ClInclude Include="..\3d\CCObjLoader.h" />
|
||||||
|
@ -408,6 +410,7 @@ xcopy /Y /Q "$(ProjectDir)..\..\external\win32-specific\gles\prebuilt\*.*" "$(Ou
|
||||||
<ClInclude Include="..\base\CCVector.h" />
|
<ClInclude Include="..\base\CCVector.h" />
|
||||||
<ClInclude Include="..\base\etc1.h" />
|
<ClInclude Include="..\base\etc1.h" />
|
||||||
<ClInclude Include="..\base\firePngData.h" />
|
<ClInclude Include="..\base\firePngData.h" />
|
||||||
|
<ClInclude Include="..\base\ObjectFactory.h" />
|
||||||
<ClInclude Include="..\base\s3tc.h" />
|
<ClInclude Include="..\base\s3tc.h" />
|
||||||
<ClInclude Include="..\base\TGAlib.h" />
|
<ClInclude Include="..\base\TGAlib.h" />
|
||||||
<ClInclude Include="..\base\uthash.h" />
|
<ClInclude Include="..\base\uthash.h" />
|
||||||
|
|
|
@ -565,6 +565,9 @@
|
||||||
<ClCompile Include="..\3d\CCSprite3DDataCache.cpp">
|
<ClCompile Include="..\3d\CCSprite3DDataCache.cpp">
|
||||||
<Filter>3d</Filter>
|
<Filter>3d</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
<ClCompile Include="..\base\ObjectFactory.cpp">
|
||||||
|
<Filter>base</Filter>
|
||||||
|
</ClCompile>
|
||||||
<ClCompile Include="..\3d\CCBundle3D.cpp">
|
<ClCompile Include="..\3d\CCBundle3D.cpp">
|
||||||
<Filter>3d</Filter>
|
<Filter>3d</Filter>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
|
@ -1156,6 +1159,9 @@
|
||||||
<ClInclude Include="..\3d\CCSprite3DDataCache.h">
|
<ClInclude Include="..\3d\CCSprite3DDataCache.h">
|
||||||
<Filter>3d</Filter>
|
<Filter>3d</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\base\ObjectFactory.h">
|
||||||
|
<Filter>base</Filter>
|
||||||
|
</ClInclude>
|
||||||
<ClInclude Include="..\3d\CCBundle3D.h">
|
<ClInclude Include="..\3d\CCBundle3D.h">
|
||||||
<Filter>3d</Filter>
|
<Filter>3d</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
@ -1171,6 +1177,9 @@
|
||||||
<ClInclude Include="..\3d\CCAnimation3D.h">
|
<ClInclude Include="..\3d\CCAnimation3D.h">
|
||||||
<Filter>3d</Filter>
|
<Filter>3d</Filter>
|
||||||
</ClInclude>
|
</ClInclude>
|
||||||
|
<ClInclude Include="..\3d\CCBundle3DData.h">
|
||||||
|
<Filter>3d</Filter>
|
||||||
|
</ClInclude>
|
||||||
</ItemGroup>
|
</ItemGroup>
|
||||||
<ItemGroup>
|
<ItemGroup>
|
||||||
<None Include="..\math\Mat4.inl">
|
<None Include="..\math\Mat4.inl">
|
||||||
|
|
|
@ -58,6 +58,11 @@ public:
|
||||||
|
|
||||||
virtual void update(float t) override;
|
virtual void update(float t) override;
|
||||||
|
|
||||||
|
float getSpeed() const { return _speed; }
|
||||||
|
void setSpeed(float speed) { _speed = speed; }
|
||||||
|
|
||||||
|
bool getPlayBack() const { return _playBack; }
|
||||||
|
void setPlayBack(bool playBack) { _playBack = playBack; }
|
||||||
protected:
|
protected:
|
||||||
Animate3D();
|
Animate3D();
|
||||||
virtual ~Animate3D();
|
virtual ~Animate3D();
|
||||||
|
|
|
@ -42,7 +42,7 @@ Animation3D* Animation3D::getOrCreate(const std::string& fileName, const std::st
|
||||||
auto bundle = Bundle3D::getInstance();
|
auto bundle = Bundle3D::getInstance();
|
||||||
if (bundle->load(fullPath))
|
if (bundle->load(fullPath))
|
||||||
{
|
{
|
||||||
Bundle3D::Animation3DData animationdata;
|
Animation3DData animationdata;
|
||||||
animationdata.animation = new Animation3D();
|
animationdata.animation = new Animation3D();
|
||||||
bundle->loadAnimationData(animationName, &animationdata);
|
bundle->loadAnimationData(animationName, &animationdata);
|
||||||
animation = animationdata.animation;
|
animation = animationdata.animation;
|
||||||
|
|
|
@ -21,7 +21,7 @@ void AnimationCurve<componentSize>::evaluate(float time, float* dst, EvaluateTyp
|
||||||
float scale = (_keytime[index + 1] - _keytime[index]);
|
float scale = (_keytime[index + 1] - _keytime[index]);
|
||||||
float t = (time - _keytime[index]) / scale;
|
float t = (time - _keytime[index]) / scale;
|
||||||
|
|
||||||
float* fromValue = &_value[index * _componentSizeByte];
|
float* fromValue = &_value[index * componentSize];
|
||||||
float* toValue = fromValue + componentSize;
|
float* toValue = fromValue + componentSize;
|
||||||
|
|
||||||
switch (type) {
|
switch (type) {
|
||||||
|
|
|
@ -33,38 +33,12 @@
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
Bundle3D* Bundle3D::_instance = nullptr;
|
|
||||||
|
|
||||||
Bundle3D::MeshData::MeshData()
|
void getChildMap(const SkinData* skinData, std::map<int, std::vector<int> >& map, const rapidjson::Value& val, int index)
|
||||||
: vertex(nullptr)
|
|
||||||
, vertexSizeInFloat(0)
|
|
||||||
, indices(nullptr)
|
|
||||||
, numIndex(0)
|
|
||||||
, attribs(nullptr)
|
|
||||||
, attribCount(0)
|
|
||||||
{
|
{
|
||||||
|
if (!skinData)
|
||||||
|
return;
|
||||||
|
|
||||||
}
|
|
||||||
Bundle3D::MeshData::~MeshData()
|
|
||||||
{
|
|
||||||
resetData();
|
|
||||||
}
|
|
||||||
|
|
||||||
int Bundle3D::SkinData::getBoneNameIndex(const std::string& name)
|
|
||||||
{
|
|
||||||
std::vector<std::string>::iterator iter = boneNames.begin();
|
|
||||||
for (int i = 0; iter != boneNames.end(); ++iter, ++i)
|
|
||||||
{
|
|
||||||
if ((*iter) == name)
|
|
||||||
{
|
|
||||||
return i;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
void Bundle3D::SkinData::getChildMap(std::map<int, std::vector<int> >& map, const rapidjson::Value& val, int index)
|
|
||||||
{
|
|
||||||
if (val.HasMember("children"))
|
if (val.HasMember("children"))
|
||||||
{
|
{
|
||||||
const rapidjson::Value& children = val["children"];
|
const rapidjson::Value& children = val["children"];
|
||||||
|
@ -73,26 +47,19 @@ void Bundle3D::SkinData::getChildMap(std::map<int, std::vector<int> >& map, cons
|
||||||
const rapidjson::Value& child = children[i];
|
const rapidjson::Value& child = children[i];
|
||||||
std::string child_name = child["id"].GetString();
|
std::string child_name = child["id"].GetString();
|
||||||
|
|
||||||
int child_name_index = getBoneNameIndex(child_name);
|
int child_name_index = skinData->getBoneNameIndex(child_name);
|
||||||
if (child_name_index < 0)
|
if (child_name_index < 0)
|
||||||
break;
|
break;
|
||||||
|
|
||||||
map[index].push_back(child_name_index);
|
map[index].push_back(child_name_index);
|
||||||
|
|
||||||
getChildMap(map, child, child_name_index);
|
getChildMap(skinData, map, child, child_name_index);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Bundle3D::MeshData::resetData()
|
|
||||||
{
|
Bundle3D* Bundle3D::_instance = nullptr;
|
||||||
CC_SAFE_DELETE_ARRAY(vertex);
|
|
||||||
CC_SAFE_DELETE_ARRAY(indices);
|
|
||||||
CC_SAFE_DELETE_ARRAY(attribs);
|
|
||||||
vertexSizeInFloat = 0;
|
|
||||||
numIndex = 0;
|
|
||||||
attribCount = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
Bundle3D* Bundle3D::getInstance()
|
Bundle3D* Bundle3D::getInstance()
|
||||||
{
|
{
|
||||||
|
@ -210,6 +177,7 @@ bool Bundle3D::loadMeshData(const std::string& id, MeshData* meshdata)
|
||||||
meshdata->attribs[i].size = mesh_vertex_attribute_val["size"].GetUint();
|
meshdata->attribs[i].size = mesh_vertex_attribute_val["size"].GetUint();
|
||||||
meshdata->attribs[i].attribSizeBytes = meshdata->attribs[1].size * parseGLTypeSize(mesh_vertex_attribute_val["type"].GetString());
|
meshdata->attribs[i].attribSizeBytes = meshdata->attribs[1].size * parseGLTypeSize(mesh_vertex_attribute_val["type"].GetString());
|
||||||
meshdata->attribs[i].type = parseGLType(mesh_vertex_attribute_val["type"].GetString());
|
meshdata->attribs[i].type = parseGLType(mesh_vertex_attribute_val["type"].GetString());
|
||||||
|
//assignGLTypeByString(meshdata->attribs[i].type, mesh_vertex_attribute_val["type"].GetString());
|
||||||
meshdata->attribs[i].vertexAttrib = parseGLProgramAttribute(mesh_vertex_attribute_val["vertex_attribute"].GetString());
|
meshdata->attribs[i].vertexAttrib = parseGLProgramAttribute(mesh_vertex_attribute_val["vertex_attribute"].GetString());
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -236,7 +204,7 @@ bool Bundle3D::loadSkinData(const std::string& id, SkinData* skindata)
|
||||||
|
|
||||||
const rapidjson::Value& skin_data_array_val_0 = skin_data_array[(rapidjson::SizeType)0];
|
const rapidjson::Value& skin_data_array_val_0 = skin_data_array[(rapidjson::SizeType)0];
|
||||||
skindata->boneNames.push_back("root");
|
skindata->boneNames.push_back("root");
|
||||||
|
skindata->inverseBindPoseMatrices.push_back(Mat4::IDENTITY);
|
||||||
skindata->rootBoneIndex = 0;
|
skindata->rootBoneIndex = 0;
|
||||||
|
|
||||||
const rapidjson::Value& skin_data_bind_shape = skin_data_array_val_0["bind_shape"];
|
const rapidjson::Value& skin_data_bind_shape = skin_data_array_val_0["bind_shape"];
|
||||||
|
@ -262,7 +230,7 @@ bool Bundle3D::loadSkinData(const std::string& id, SkinData* skindata)
|
||||||
}
|
}
|
||||||
|
|
||||||
const rapidjson::Value& skin_data_array_val_1 = skin_data_array[1];
|
const rapidjson::Value& skin_data_array_val_1 = skin_data_array[1];
|
||||||
skindata->getChildMap(skindata->boneChild, skin_data_array_val_1, 0);
|
getChildMap(skindata, skindata->boneChild, skin_data_array_val_1, 0);
|
||||||
|
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
@ -304,16 +272,16 @@ bool Bundle3D::loadAnimationData(const std::string& id, Animation3DData* animati
|
||||||
float keytime[] = {0.f, 1.f};
|
float keytime[] = {0.f, 1.f};
|
||||||
float pos[] = {0.f, 0.f, 0.f, 20.f, 0.f, 0.f};
|
float pos[] = {0.f, 0.f, 0.f, 20.f, 0.f, 0.f};
|
||||||
|
|
||||||
float keytime1[] = {0.f, 0.25f, 0.5f, 1.f};
|
float keytime1[] = {0.f, 0.333f, 0.667f, 1.f};
|
||||||
float rot[4 * 4];
|
float rot[4 * 4];
|
||||||
Quaternion quat;
|
Quaternion quat;
|
||||||
Quaternion::createFromAxisAngle(Vec3(0.f, 1.f, 0.f), 0, &quat);
|
Quaternion::createFromAxisAngle(Vec3(1.f, 0.f, 0.f), 0, &quat);
|
||||||
rot[0] = quat.x, rot[1] = quat.y, rot[2] = quat.z, rot[3] = quat.w;
|
rot[0] = quat.x, rot[1] = quat.y, rot[2] = quat.z, rot[3] = quat.w;
|
||||||
Quaternion::createFromAxisAngle(Vec3(0.f, 1.f, 0.f), MATH_DEG_TO_RAD(90), &quat);
|
Quaternion::createFromAxisAngle(Vec3(1.f, 0.f, 0.f), MATH_DEG_TO_RAD(90), &quat);
|
||||||
rot[4] = quat.x, rot[5] = quat.y, rot[6] = quat.z, rot[7] = quat.w;
|
rot[4] = quat.x, rot[5] = quat.y, rot[6] = quat.z, rot[7] = quat.w;
|
||||||
Quaternion::createFromAxisAngle(Vec3(0.f, 1.f, 0.f), MATH_DEG_TO_RAD(180), &quat);
|
Quaternion::createFromAxisAngle(Vec3(1.f, 0.f, 0.f), MATH_DEG_TO_RAD(180), &quat);
|
||||||
rot[8] = quat.x, rot[9] = quat.y, rot[10] = quat.z, rot[11] = quat.w;
|
rot[8] = quat.x, rot[9] = quat.y, rot[10] = quat.z, rot[11] = quat.w;
|
||||||
Quaternion::createFromAxisAngle(Vec3(0.f, 1.f, 0.f), MATH_DEG_TO_RAD(270), &quat);
|
Quaternion::createFromAxisAngle(Vec3(1.f, 0.f, 0.f), MATH_DEG_TO_RAD(270), &quat);
|
||||||
rot[12] = quat.x, rot[13] = quat.y, rot[14] = quat.z, rot[15] = quat.w;
|
rot[12] = quat.x, rot[13] = quat.y, rot[14] = quat.z, rot[15] = quat.w;
|
||||||
curve->rotCurve = Animation3D::Curve::AnimationCurveQuat::create(keytime1, rot, 4);
|
curve->rotCurve = Animation3D::Curve::AnimationCurveQuat::create(keytime1, rot, 4);
|
||||||
curve->rotCurve->retain();
|
curve->rotCurve->retain();
|
||||||
|
@ -355,6 +323,7 @@ bool Bundle3D::loadAnimationData(const std::string& id, Animation3DData* animati
|
||||||
}
|
}
|
||||||
|
|
||||||
curve->translateCurve = Animation3D::Curve::AnimationCurveVec3::create(keytime, position, bone_keyframe_position.Size());
|
curve->translateCurve = Animation3D::Curve::AnimationCurveVec3::create(keytime, position, bone_keyframe_position.Size());
|
||||||
|
curve->translateCurve->retain();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( bone_keyframe.HasMember("rotation"))
|
if ( bone_keyframe.HasMember("rotation"))
|
||||||
|
@ -376,6 +345,7 @@ bool Bundle3D::loadAnimationData(const std::string& id, Animation3DData* animati
|
||||||
}
|
}
|
||||||
|
|
||||||
curve->rotCurve = Animation3D::Curve::AnimationCurveQuat::create(keytime, rotate, bone_keyframe_position.Size());
|
curve->rotCurve = Animation3D::Curve::AnimationCurveQuat::create(keytime, rotate, bone_keyframe_position.Size());
|
||||||
|
curve->rotCurve->retain();
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( bone_keyframe.HasMember("scale"))
|
if ( bone_keyframe.HasMember("scale"))
|
||||||
|
@ -397,6 +367,7 @@ bool Bundle3D::loadAnimationData(const std::string& id, Animation3DData* animati
|
||||||
}
|
}
|
||||||
|
|
||||||
curve->scaleCurve = Animation3D::Curve::AnimationCurveVec3::create(keytime, scale, bone_keyframe_position.Size());
|
curve->scaleCurve = Animation3D::Curve::AnimationCurveVec3::create(keytime, scale, bone_keyframe_position.Size());
|
||||||
|
curve->scaleCurve->retain();
|
||||||
}
|
}
|
||||||
|
|
||||||
animation->_boneCurves[bone_name] = curve;
|
animation->_boneCurves[bone_name] = curve;
|
||||||
|
@ -406,6 +377,39 @@ bool Bundle3D::loadAnimationData(const std::string& id, Animation3DData* animati
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
//void Bundle3D::assignGLTypeByString(GLenum& type, std::string str)
|
||||||
|
//{
|
||||||
|
// if (str == "GL_FLOAT")
|
||||||
|
// {
|
||||||
|
// type = GL_FLOAT;
|
||||||
|
// }
|
||||||
|
// else if (str == "GL_UNSIGNED_INT")
|
||||||
|
// {
|
||||||
|
// type = GL_UNSIGNED_INT;
|
||||||
|
// }
|
||||||
|
// else
|
||||||
|
// {
|
||||||
|
// assert(0);
|
||||||
|
// }
|
||||||
|
//}
|
||||||
|
|
||||||
|
GLenum Bundle3D::parseGLType(const std::string& str)
|
||||||
|
{
|
||||||
|
if (str == "GL_FLOAT")
|
||||||
|
{
|
||||||
|
return GL_FLOAT;
|
||||||
|
}
|
||||||
|
else if (str == "GL_UNSIGNED_INT")
|
||||||
|
{
|
||||||
|
return GL_UNSIGNED_INT;
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
assert(0);
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
unsigned int Bundle3D::parseGLTypeSize(const std::string& str)
|
unsigned int Bundle3D::parseGLTypeSize(const std::string& str)
|
||||||
{
|
{
|
||||||
if (str == "GL_FLOAT")
|
if (str == "GL_FLOAT")
|
||||||
|
@ -423,23 +427,6 @@ unsigned int Bundle3D::parseGLTypeSize(const std::string& str)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
unsigned int Bundle3D::parseGLType(const std::string& str)
|
|
||||||
{
|
|
||||||
if (str == "GL_FLOAT")
|
|
||||||
{
|
|
||||||
return GL_FLOAT;
|
|
||||||
}
|
|
||||||
else if (str == "GL_UNSIGNED_INT")
|
|
||||||
{
|
|
||||||
return GL_UNSIGNED_INT;
|
|
||||||
}
|
|
||||||
else
|
|
||||||
{
|
|
||||||
assert(0);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
unsigned int Bundle3D::parseGLProgramAttribute(const std::string& str)
|
unsigned int Bundle3D::parseGLProgramAttribute(const std::string& str)
|
||||||
{
|
{
|
||||||
if (str == "VERTEX_ATTRIB_POSITION")
|
if (str == "VERTEX_ATTRIB_POSITION")
|
||||||
|
|
|
@ -32,57 +32,22 @@
|
||||||
#include "base/ccTypes.h"
|
#include "base/ccTypes.h"
|
||||||
|
|
||||||
#include "3d/CCMesh.h"
|
#include "3d/CCMesh.h"
|
||||||
|
#include "3d/CCBundle3DData.h"
|
||||||
|
|
||||||
#include "document.h"
|
#include "document.h"
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
class Animation3D;
|
class Animation3D;
|
||||||
class Bundle3D
|
|
||||||
{
|
|
||||||
public:
|
|
||||||
struct MeshData
|
|
||||||
{
|
|
||||||
float* vertex;
|
|
||||||
int vertexSizeInFloat;
|
|
||||||
unsigned short* indices;
|
|
||||||
int numIndex;
|
|
||||||
MeshVertexAttrib* attribs;
|
|
||||||
int attribCount;
|
|
||||||
void resetData();
|
|
||||||
MeshData();
|
|
||||||
~MeshData();
|
|
||||||
};
|
|
||||||
struct SkinData
|
|
||||||
{
|
|
||||||
Mat4 bindShape;
|
|
||||||
std::vector<std::string> boneNames;
|
|
||||||
std::vector<Mat4> inverseBindPoseMatrices; //bind pose of bone
|
|
||||||
|
|
||||||
std::map<int, std::vector<int> > boneChild;//key parent, value child
|
|
||||||
int rootBoneIndex;
|
|
||||||
void resetData()
|
|
||||||
{
|
|
||||||
bindShape.setIdentity();
|
|
||||||
boneNames.clear();
|
|
||||||
inverseBindPoseMatrices.clear();
|
|
||||||
boneChild.clear();
|
|
||||||
rootBoneIndex = -1;
|
|
||||||
}
|
|
||||||
|
|
||||||
int getBoneNameIndex(const std::string& name);
|
|
||||||
|
|
||||||
void getChildMap(std::map<int, std::vector<int> >& map, const rapidjson::Value& val, int index);
|
|
||||||
};
|
|
||||||
struct MaterialData
|
|
||||||
{
|
|
||||||
std::string texturePath;
|
|
||||||
};
|
|
||||||
struct Animation3DData
|
struct Animation3DData
|
||||||
{
|
{
|
||||||
Animation3D* animation;
|
Animation3D* animation;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
class Bundle3D
|
||||||
|
{
|
||||||
|
public:
|
||||||
|
|
||||||
static Bundle3D* getInstance();
|
static Bundle3D* getInstance();
|
||||||
|
|
||||||
static void purgeBundle3D();
|
static void purgeBundle3D();
|
||||||
|
@ -117,13 +82,15 @@ public:
|
||||||
bool loadAnimationData(const std::string& id, Animation3DData* animationdata);
|
bool loadAnimationData(const std::string& id, Animation3DData* animationdata);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
|
|
||||||
|
//void assignGLTypeByString(GLenum& type, std::string str);
|
||||||
|
|
||||||
|
GLenum parseGLType(const std::string& str);
|
||||||
|
|
||||||
unsigned int parseGLTypeSize(const std::string& str);
|
unsigned int parseGLTypeSize(const std::string& str);
|
||||||
|
|
||||||
unsigned int parseGLType(const std::string& str);
|
|
||||||
|
|
||||||
unsigned int parseGLProgramAttribute(const std::string& str);
|
unsigned int parseGLProgramAttribute(const std::string& str);
|
||||||
|
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
Bundle3D();
|
Bundle3D();
|
||||||
~Bundle3D();
|
~Bundle3D();
|
||||||
|
|
|
@ -0,0 +1,123 @@
|
||||||
|
/****************************************************************************
|
||||||
|
Copyright (c) 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 __CC_BUNDLE_3D_DATA_H__
|
||||||
|
#define __CC_BUNDLE_3D_DATA_H__
|
||||||
|
|
||||||
|
#include "base/CCRef.h"
|
||||||
|
#include "base/ccTypes.h"
|
||||||
|
#include "math/CCMath.h"
|
||||||
|
|
||||||
|
#include <vector>
|
||||||
|
#include <map>
|
||||||
|
|
||||||
|
NS_CC_BEGIN
|
||||||
|
|
||||||
|
//mesh vertex attribute
|
||||||
|
struct MeshVertexAttrib
|
||||||
|
{
|
||||||
|
//attribute size
|
||||||
|
GLint size;
|
||||||
|
//GL_FLOAT
|
||||||
|
GLenum type;
|
||||||
|
//VERTEX_ATTRIB_POSITION,VERTEX_ATTRIB_COLOR,VERTEX_ATTRIB_TEX_COORD,VERTEX_ATTRIB_NORMAL, VERTEX_ATTRIB_BLEND_WEIGHT, VERTEX_ATTRIB_BLEND_INDEX, GLProgram for detail
|
||||||
|
int vertexAttrib;
|
||||||
|
//size in bytes
|
||||||
|
int attribSizeBytes;
|
||||||
|
};
|
||||||
|
|
||||||
|
struct MeshData
|
||||||
|
{
|
||||||
|
float* vertex;
|
||||||
|
int vertexSizeInFloat;
|
||||||
|
unsigned short* indices;
|
||||||
|
int numIndex;
|
||||||
|
MeshVertexAttrib* attribs;
|
||||||
|
int attribCount;
|
||||||
|
|
||||||
|
public:
|
||||||
|
void resetData()
|
||||||
|
{
|
||||||
|
CC_SAFE_DELETE_ARRAY(vertex);
|
||||||
|
CC_SAFE_DELETE_ARRAY(indices);
|
||||||
|
CC_SAFE_DELETE_ARRAY(attribs);
|
||||||
|
vertexSizeInFloat = 0;
|
||||||
|
numIndex = 0;
|
||||||
|
attribCount = 0;
|
||||||
|
}
|
||||||
|
MeshData()
|
||||||
|
: vertex(nullptr)
|
||||||
|
, vertexSizeInFloat(0)
|
||||||
|
, indices(nullptr)
|
||||||
|
, numIndex(0)
|
||||||
|
, attribs(nullptr)
|
||||||
|
, attribCount(0)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
~MeshData()
|
||||||
|
{
|
||||||
|
resetData();
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
struct SkinData
|
||||||
|
{
|
||||||
|
Mat4 bindShape;
|
||||||
|
std::vector<std::string> boneNames;
|
||||||
|
std::vector<Mat4> inverseBindPoseMatrices; //bind pose of bone
|
||||||
|
|
||||||
|
std::map<int, std::vector<int> > boneChild;//key parent, value child
|
||||||
|
int rootBoneIndex;
|
||||||
|
void resetData()
|
||||||
|
{
|
||||||
|
bindShape.setIdentity();
|
||||||
|
boneNames.clear();
|
||||||
|
inverseBindPoseMatrices.clear();
|
||||||
|
boneChild.clear();
|
||||||
|
rootBoneIndex = -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
int getBoneNameIndex(const std::string& name)const
|
||||||
|
{
|
||||||
|
std::vector<std::string>::const_iterator iter = boneNames.begin();
|
||||||
|
for (int i = 0; iter != boneNames.end(); ++iter, ++i)
|
||||||
|
{
|
||||||
|
if ((*iter) == name)
|
||||||
|
{
|
||||||
|
return i;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
};
|
||||||
|
|
||||||
|
struct MaterialData
|
||||||
|
{
|
||||||
|
std::string texturePath;
|
||||||
|
};
|
||||||
|
|
||||||
|
NS_CC_END
|
||||||
|
|
||||||
|
#endif //__CC_BUNDLE_3D_DATA_H__
|
|
@ -33,20 +33,9 @@
|
||||||
#include "math/CCMath.h"
|
#include "math/CCMath.h"
|
||||||
#include "renderer/CCGLProgram.h"
|
#include "renderer/CCGLProgram.h"
|
||||||
|
|
||||||
NS_CC_BEGIN
|
#include "3d/CCBundle3DData.h"
|
||||||
|
|
||||||
//mesh vertex attribute
|
NS_CC_BEGIN
|
||||||
struct MeshVertexAttrib
|
|
||||||
{
|
|
||||||
//attribute size
|
|
||||||
GLint size;
|
|
||||||
//GL_FLOAT
|
|
||||||
GLenum type;
|
|
||||||
//VERTEX_ATTRIB_POSITION,VERTEX_ATTRIB_COLOR,VERTEX_ATTRIB_TEX_COORD,VERTEX_ATTRIB_NORMAL, VERTEX_ATTRIB_BLEND_WEIGHT, VERTEX_ATTRIB_BLEND_INDEX, GLProgram for detail
|
|
||||||
int vertexAttrib;
|
|
||||||
//size in bytes
|
|
||||||
int attribSizeBytes;
|
|
||||||
};
|
|
||||||
|
|
||||||
class RenderMeshData
|
class RenderMeshData
|
||||||
{
|
{
|
||||||
|
|
|
@ -259,7 +259,7 @@ MeshSkin* MeshSkin::create(const std::string& filename, const std::string& name)
|
||||||
bool ret = instance->load(fullPath);
|
bool ret = instance->load(fullPath);
|
||||||
if (ret)
|
if (ret)
|
||||||
{
|
{
|
||||||
Bundle3D::SkinData skindata;
|
SkinData skindata;
|
||||||
if (instance->loadSkinData(name, &skindata))
|
if (instance->loadSkinData(name, &skindata))
|
||||||
{
|
{
|
||||||
auto skin = new MeshSkin();
|
auto skin = new MeshSkin();
|
||||||
|
|
|
@ -603,7 +603,8 @@ std::string ObjLoader::LoadObj(shapes_t& shapes, const char* filename, const cha
|
||||||
|
|
||||||
std::vector<vertex_index> face;
|
std::vector<vertex_index> face;
|
||||||
while (!isNewLine(token[0])) {
|
while (!isNewLine(token[0])) {
|
||||||
vertex_index vi = parseTriple(token, v.size() / 3, vn.size() / 3, vt.size() / 2);
|
// fix warning, cast to int, i think int is enough
|
||||||
|
vertex_index vi = parseTriple(token, (int)v.size() / 3, (int)vn.size() / 3, (int)vt.size() / 2);
|
||||||
face.push_back(vi);
|
face.push_back(vi);
|
||||||
auto n = strspn(token, " \t\r");
|
auto n = strspn(token, " \t\r");
|
||||||
token += n;
|
token += n;
|
||||||
|
|
|
@ -145,7 +145,7 @@ bool Sprite3D::loadFromC3x(const std::string& path)
|
||||||
if (!bundle->load(fullPath))
|
if (!bundle->load(fullPath))
|
||||||
return false;
|
return false;
|
||||||
|
|
||||||
Bundle3D::MeshData meshdata;
|
MeshData meshdata;
|
||||||
bool ret = bundle->loadMeshData("", &meshdata);
|
bool ret = bundle->loadMeshData("", &meshdata);
|
||||||
if (!ret)
|
if (!ret)
|
||||||
{
|
{
|
||||||
|
@ -158,7 +158,7 @@ bool Sprite3D::loadFromC3x(const std::string& path)
|
||||||
_skin = MeshSkin::create(fullPath, "");
|
_skin = MeshSkin::create(fullPath, "");
|
||||||
CC_SAFE_RETAIN(_skin);
|
CC_SAFE_RETAIN(_skin);
|
||||||
|
|
||||||
Bundle3D::MaterialData materialdata;
|
MaterialData materialdata;
|
||||||
ret = bundle->loadMaterialData("", &materialdata);
|
ret = bundle->loadMaterialData("", &materialdata);
|
||||||
if (ret)
|
if (ret)
|
||||||
{
|
{
|
||||||
|
@ -279,7 +279,7 @@ void Sprite3D::setTexture(Texture2D* texture)
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
void Sprite3D::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void Sprite3D::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
GLProgramState* programstate = getGLProgramState();
|
GLProgramState* programstate = getGLProgramState();
|
||||||
Color4F color(getDisplayedColor());
|
Color4F color(getDisplayedColor());
|
||||||
|
@ -297,7 +297,7 @@ void Sprite3D::draw(Renderer *renderer, const Mat4 &transform, bool transformUpd
|
||||||
_mesh->getIndexCount(),
|
_mesh->getIndexCount(),
|
||||||
transform);
|
transform);
|
||||||
|
|
||||||
_meshCommand.setCullFaceEnabled(true);
|
_meshCommand.setCullFaceEnabled(false);
|
||||||
_meshCommand.setDepthTestEnabled(true);
|
_meshCommand.setDepthTestEnabled(true);
|
||||||
if (_skin)
|
if (_skin)
|
||||||
{
|
{
|
||||||
|
|
|
@ -73,7 +73,7 @@ protected:
|
||||||
//load from .c3b or .c3t
|
//load from .c3b or .c3t
|
||||||
bool loadFromC3x(const std::string& path);
|
bool loadFromC3x(const std::string& path);
|
||||||
|
|
||||||
virtual void draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(Renderer *renderer, const Mat4 &transform, uint32_t flags) override;
|
||||||
|
|
||||||
virtual GLProgram* getDefaultGLProgram(bool textured = true);
|
virtual GLProgram* getDefaultGLProgram(bool textured = true);
|
||||||
|
|
||||||
|
|
|
@ -132,6 +132,7 @@ base/ccUTF8.cpp \
|
||||||
base/ccUtils.cpp \
|
base/ccUtils.cpp \
|
||||||
base/etc1.cpp \
|
base/etc1.cpp \
|
||||||
base/s3tc.cpp \
|
base/s3tc.cpp \
|
||||||
|
base/ObjectFactory.cpp \
|
||||||
renderer/CCBatchCommand.cpp \
|
renderer/CCBatchCommand.cpp \
|
||||||
renderer/CCCustomCommand.cpp \
|
renderer/CCCustomCommand.cpp \
|
||||||
renderer/CCGLProgram.cpp \
|
renderer/CCGLProgram.cpp \
|
||||||
|
|
|
@ -111,8 +111,7 @@ PoolManager* PoolManager::getInstance()
|
||||||
{
|
{
|
||||||
s_singleInstance = new PoolManager();
|
s_singleInstance = new PoolManager();
|
||||||
// Add the first auto release pool
|
// Add the first auto release pool
|
||||||
s_singleInstance->_curReleasePool = new AutoreleasePool("cocos2d autorelease pool");
|
new AutoreleasePool("cocos2d autorelease pool");
|
||||||
s_singleInstance->_releasePoolStack.push_back(s_singleInstance->_curReleasePool);
|
|
||||||
}
|
}
|
||||||
return s_singleInstance;
|
return s_singleInstance;
|
||||||
}
|
}
|
||||||
|
@ -125,6 +124,7 @@ void PoolManager::destroyInstance()
|
||||||
|
|
||||||
PoolManager::PoolManager()
|
PoolManager::PoolManager()
|
||||||
{
|
{
|
||||||
|
_releasePoolStack.reserve(10);
|
||||||
}
|
}
|
||||||
|
|
||||||
PoolManager::~PoolManager()
|
PoolManager::~PoolManager()
|
||||||
|
@ -134,7 +134,6 @@ PoolManager::~PoolManager()
|
||||||
while (!_releasePoolStack.empty())
|
while (!_releasePoolStack.empty())
|
||||||
{
|
{
|
||||||
AutoreleasePool* pool = _releasePoolStack.back();
|
AutoreleasePool* pool = _releasePoolStack.back();
|
||||||
_releasePoolStack.pop_back();
|
|
||||||
|
|
||||||
delete pool;
|
delete pool;
|
||||||
}
|
}
|
||||||
|
@ -143,7 +142,7 @@ PoolManager::~PoolManager()
|
||||||
|
|
||||||
AutoreleasePool* PoolManager::getCurrentPool() const
|
AutoreleasePool* PoolManager::getCurrentPool() const
|
||||||
{
|
{
|
||||||
return _curReleasePool;
|
return _releasePoolStack.back();
|
||||||
}
|
}
|
||||||
|
|
||||||
bool PoolManager::isObjectInPools(Ref* obj) const
|
bool PoolManager::isObjectInPools(Ref* obj) const
|
||||||
|
@ -159,21 +158,12 @@ bool PoolManager::isObjectInPools(Ref* obj) const
|
||||||
void PoolManager::push(AutoreleasePool *pool)
|
void PoolManager::push(AutoreleasePool *pool)
|
||||||
{
|
{
|
||||||
_releasePoolStack.push_back(pool);
|
_releasePoolStack.push_back(pool);
|
||||||
_curReleasePool = pool;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
void PoolManager::pop()
|
void PoolManager::pop()
|
||||||
{
|
{
|
||||||
// Can not pop the pool that created by engine
|
CC_ASSERT(!_releasePoolStack.empty());
|
||||||
CC_ASSERT(_releasePoolStack.size() >= 1);
|
|
||||||
|
|
||||||
_releasePoolStack.pop_back();
|
_releasePoolStack.pop_back();
|
||||||
|
|
||||||
// Should update _curReleasePool if a temple pool is released
|
|
||||||
if (_releasePoolStack.size() > 1)
|
|
||||||
{
|
|
||||||
_curReleasePool = _releasePoolStack.back();
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
|
@ -163,8 +163,7 @@ private:
|
||||||
|
|
||||||
static PoolManager* s_singleInstance;
|
static PoolManager* s_singleInstance;
|
||||||
|
|
||||||
std::deque<AutoreleasePool*> _releasePoolStack;
|
std::vector<AutoreleasePool*> _releasePoolStack;
|
||||||
AutoreleasePool *_curReleasePool;
|
|
||||||
};
|
};
|
||||||
|
|
||||||
// end of base_nodes group
|
// end of base_nodes group
|
||||||
|
|
|
@ -65,6 +65,7 @@
|
||||||
#include "base/base64.h"
|
#include "base/base64.h"
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
|
extern const char* cocos2dVersion(void);
|
||||||
//TODO: these general utils should be in a seperate class
|
//TODO: these general utils should be in a seperate class
|
||||||
//
|
//
|
||||||
// Trimming functions were taken from: http://stackoverflow.com/a/217605
|
// Trimming functions were taken from: http://stackoverflow.com/a/217605
|
||||||
|
@ -295,6 +296,9 @@ Console::Console()
|
||||||
{ "director", "director commands, type -h or [director help] to list supported directives", std::bind(&Console::commandDirector, this, std::placeholders::_1, std::placeholders::_2) },
|
{ "director", "director commands, type -h or [director help] to list supported directives", std::bind(&Console::commandDirector, this, std::placeholders::_1, std::placeholders::_2) },
|
||||||
{ "touch", "simulate touch event via console, type -h or [touch help] to list supported directives", std::bind(&Console::commandTouch, this, std::placeholders::_1, std::placeholders::_2) },
|
{ "touch", "simulate touch event via console, type -h or [touch help] to list supported directives", std::bind(&Console::commandTouch, this, std::placeholders::_1, std::placeholders::_2) },
|
||||||
{ "upload", "upload file. Args: [filename base64_encoded_data]", std::bind(&Console::commandUpload, this, std::placeholders::_1) },
|
{ "upload", "upload file. Args: [filename base64_encoded_data]", std::bind(&Console::commandUpload, this, std::placeholders::_1) },
|
||||||
|
{ "version", "print version string ", [](int fd, const std::string& args) {
|
||||||
|
mydprintf(fd, "%s\n", cocos2dVersion());
|
||||||
|
} },
|
||||||
};
|
};
|
||||||
|
|
||||||
;
|
;
|
||||||
|
|
|
@ -92,7 +92,8 @@ Director* Director::getInstance()
|
||||||
{
|
{
|
||||||
if (!s_SharedDirector)
|
if (!s_SharedDirector)
|
||||||
{
|
{
|
||||||
s_SharedDirector = new DisplayLinkDirector();
|
s_SharedDirector = new (std::nothrow) DisplayLinkDirector();
|
||||||
|
CCASSERT(s_SharedDirector, "FATAL: Not enough memory");
|
||||||
s_SharedDirector->init();
|
s_SharedDirector->init();
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1091,9 +1092,9 @@ void Director::showStats()
|
||||||
|
|
||||||
Mat4 identity = Mat4::IDENTITY;
|
Mat4 identity = Mat4::IDENTITY;
|
||||||
|
|
||||||
_drawnVerticesLabel->visit(_renderer, identity, false);
|
_drawnVerticesLabel->visit(_renderer, identity, 0);
|
||||||
_drawnBatchesLabel->visit(_renderer, identity, false);
|
_drawnBatchesLabel->visit(_renderer, identity, 0);
|
||||||
_FPSLabel->visit(_renderer, identity, false);
|
_FPSLabel->visit(_renderer, identity, 0);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -465,14 +465,29 @@ void Scheduler::schedulePerFrame(const ccSchedulerFunc& callback, void *target,
|
||||||
HASH_FIND_PTR(_hashForUpdates, &target, hashElement);
|
HASH_FIND_PTR(_hashForUpdates, &target, hashElement);
|
||||||
if (hashElement)
|
if (hashElement)
|
||||||
{
|
{
|
||||||
#if COCOS2D_DEBUG >= 1
|
// check if priority has changed
|
||||||
CCASSERT(hashElement->entry->markedForDeletion,"");
|
if ((*hashElement->list)->priority != priority)
|
||||||
#endif
|
{
|
||||||
// TODO: check if priority has changed!
|
if (_updateHashLocked)
|
||||||
|
{
|
||||||
|
CCLOG("warning: you CANNOT change update priority in scheduled function");
|
||||||
hashElement->entry->markedForDeletion = false;
|
hashElement->entry->markedForDeletion = false;
|
||||||
|
hashElement->entry->paused = paused;
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
// will be added again outside if (hashElement).
|
||||||
|
unscheduleUpdate(target);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
hashElement->entry->markedForDeletion = false;
|
||||||
|
hashElement->entry->paused = paused;
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// most of the updates are going to be 0, that's way there
|
// most of the updates are going to be 0, that's way there
|
||||||
// is an special list for updates with priority 0
|
// is an special list for updates with priority 0
|
||||||
|
|
|
@ -28,7 +28,7 @@ THE SOFTWARE.
|
||||||
#include "tinyxml2.h"
|
#include "tinyxml2.h"
|
||||||
#include "base/base64.h"
|
#include "base/base64.h"
|
||||||
|
|
||||||
#if (CC_TARGET_PLATFORM != CC_PLATFORM_IOS && CC_TARGET_PLATFORM != CC_PLATFORM_ANDROID)
|
#if (CC_TARGET_PLATFORM != CC_PLATFORM_IOS && CC_TARGET_PLATFORM != CC_PLATFORM_MAC && CC_TARGET_PLATFORM != CC_PLATFORM_ANDROID)
|
||||||
|
|
||||||
// root name of xml
|
// root name of xml
|
||||||
#define USERDEFAULT_ROOT_NAME "userDefaultRoot"
|
#define USERDEFAULT_ROOT_NAME "userDefaultRoot"
|
||||||
|
|
|
@ -41,4 +41,5 @@ set(COCOS_BASE_SRC
|
||||||
base/ccUtils.cpp
|
base/ccUtils.cpp
|
||||||
base/etc1.cpp
|
base/etc1.cpp
|
||||||
base/s3tc.cpp
|
base/s3tc.cpp
|
||||||
|
base/ObjectFactory.cpp
|
||||||
)
|
)
|
||||||
|
|
|
@ -0,0 +1,107 @@
|
||||||
|
/****************************************************************************
|
||||||
|
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 "ObjectFactory.h"
|
||||||
|
|
||||||
|
|
||||||
|
NS_CC_BEGIN
|
||||||
|
|
||||||
|
ObjectFactory::TInfo::TInfo(void)
|
||||||
|
:_class("")
|
||||||
|
,_fun(nullptr)
|
||||||
|
{
|
||||||
|
}
|
||||||
|
|
||||||
|
ObjectFactory::TInfo::TInfo(const std::string& type, Instance ins)
|
||||||
|
:_class(type)
|
||||||
|
,_fun(ins)
|
||||||
|
{
|
||||||
|
ObjectFactory::getInstance()->registerType(*this);
|
||||||
|
}
|
||||||
|
|
||||||
|
ObjectFactory::TInfo::TInfo(const TInfo &t)
|
||||||
|
{
|
||||||
|
_class = t._class;
|
||||||
|
_fun = t._fun;
|
||||||
|
}
|
||||||
|
|
||||||
|
ObjectFactory::TInfo::~TInfo(void)
|
||||||
|
{
|
||||||
|
_class = "";
|
||||||
|
_fun = nullptr;
|
||||||
|
}
|
||||||
|
|
||||||
|
ObjectFactory::TInfo& ObjectFactory::TInfo::operator= (const TInfo &t)
|
||||||
|
{
|
||||||
|
_class = t._class;
|
||||||
|
_fun = t._fun;
|
||||||
|
return *this;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
ObjectFactory* ObjectFactory::_sharedFactory = nullptr;
|
||||||
|
|
||||||
|
ObjectFactory::ObjectFactory(void)
|
||||||
|
{
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
ObjectFactory::~ObjectFactory(void)
|
||||||
|
{
|
||||||
|
_typeMap.clear();
|
||||||
|
}
|
||||||
|
|
||||||
|
ObjectFactory* ObjectFactory::getInstance()
|
||||||
|
{
|
||||||
|
if ( nullptr == _sharedFactory)
|
||||||
|
{
|
||||||
|
_sharedFactory = new ObjectFactory();
|
||||||
|
}
|
||||||
|
return _sharedFactory;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ObjectFactory::destroyInstance()
|
||||||
|
{
|
||||||
|
CC_SAFE_DELETE(_sharedFactory);
|
||||||
|
}
|
||||||
|
|
||||||
|
Ref* ObjectFactory::createObject(const std::string &name)
|
||||||
|
{
|
||||||
|
Ref *o = nullptr;
|
||||||
|
do
|
||||||
|
{
|
||||||
|
const TInfo t = _typeMap[name];
|
||||||
|
CC_BREAK_IF(t._fun == nullptr);
|
||||||
|
o = t._fun();
|
||||||
|
} while (0);
|
||||||
|
|
||||||
|
return o;
|
||||||
|
}
|
||||||
|
|
||||||
|
void ObjectFactory::registerType(const TInfo &t)
|
||||||
|
{
|
||||||
|
_typeMap.insert(std::make_pair(t._class, t));
|
||||||
|
}
|
||||||
|
|
||||||
|
NS_CC_END
|
|
@ -22,27 +22,47 @@ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
||||||
THE SOFTWARE.
|
THE SOFTWARE.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#ifndef __UISCROLLDELEGATE_H__
|
#ifndef __TRIGGERFACTORY_H__
|
||||||
#define __UISCROLLDELEGATE_H__
|
#define __TRIGGERFACTORY_H__
|
||||||
|
|
||||||
#include "ui/UIWidget.h"
|
#include <string>
|
||||||
|
#include <unordered_map>
|
||||||
|
#include "base/CCRef.h"
|
||||||
|
#include "base/CCPlatformMacros.h"
|
||||||
|
|
||||||
NS_CC_BEGIN
|
NS_CC_BEGIN
|
||||||
|
|
||||||
namespace ui {
|
class ObjectFactory
|
||||||
|
|
||||||
class ScrollViewProtocol
|
|
||||||
{
|
{
|
||||||
public:
|
public:
|
||||||
virtual ~ScrollViewProtocol() {}
|
typedef cocos2d::Ref* (*Instance)(void);
|
||||||
|
struct TInfo
|
||||||
|
{
|
||||||
|
TInfo(void);
|
||||||
|
TInfo(const std::string& type, Instance ins = NULL);
|
||||||
|
TInfo(const TInfo &t);
|
||||||
|
~TInfo(void);
|
||||||
|
TInfo& operator= (const TInfo &t);
|
||||||
|
std::string _class;
|
||||||
|
Instance _fun;
|
||||||
|
};
|
||||||
|
typedef std::unordered_map<std::string, TInfo> FactoryMap;
|
||||||
|
|
||||||
|
static ObjectFactory* getInstance();
|
||||||
|
static void destroyInstance();
|
||||||
|
cocos2d::Ref* createObject(const std::string &name);
|
||||||
|
|
||||||
|
void registerType(const TInfo &t);
|
||||||
|
void removeAll();
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
virtual void handlePressLogic(const Vec2 &touchPoint) = 0;
|
ObjectFactory(void);
|
||||||
virtual void handleMoveLogic(const Vec2 &touchPoint) = 0;
|
virtual ~ObjectFactory(void);
|
||||||
virtual void handleReleaseLogic(const Vec2 &touchPoint) = 0;
|
private:
|
||||||
|
static ObjectFactory *_sharedFactory;
|
||||||
|
FactoryMap _typeMap;
|
||||||
};
|
};
|
||||||
|
|
||||||
}
|
|
||||||
NS_CC_END
|
NS_CC_END
|
||||||
|
|
||||||
#endif /* defined(__UIScrollDelegate__) */
|
#endif
|
|
@ -328,7 +328,7 @@ struct BlendFunc
|
||||||
|
|
||||||
bool operator<(const BlendFunc &a) const
|
bool operator<(const BlendFunc &a) const
|
||||||
{
|
{
|
||||||
return src < a.src || (src < a.src && dst < a.dst);
|
return src < a.src || (src == a.src && dst < a.dst);
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
|
@ -29,8 +29,8 @@ THE SOFTWARE.
|
||||||
#define __COCOS2D_H__
|
#define __COCOS2D_H__
|
||||||
|
|
||||||
// 0x00 HI ME LO
|
// 0x00 HI ME LO
|
||||||
// 00 03 01 00
|
// 00 03 02 00
|
||||||
#define COCOS2D_VERSION 0x00030100
|
#define COCOS2D_VERSION 0x00030200
|
||||||
|
|
||||||
//
|
//
|
||||||
// all cocos2d include files
|
// all cocos2d include files
|
||||||
|
|
|
@ -36,7 +36,6 @@ CCInputDelegate.cpp \
|
||||||
DictionaryHelper.cpp \
|
DictionaryHelper.cpp \
|
||||||
CCSGUIReader.cpp \
|
CCSGUIReader.cpp \
|
||||||
CCSSceneReader.cpp \
|
CCSSceneReader.cpp \
|
||||||
ObjectFactory.cpp \
|
|
||||||
TriggerBase.cpp \
|
TriggerBase.cpp \
|
||||||
TriggerMng.cpp \
|
TriggerMng.cpp \
|
||||||
TriggerObj.cpp \
|
TriggerObj.cpp \
|
||||||
|
|
|
@ -378,7 +378,7 @@ void Armature::update(float dt)
|
||||||
_armatureTransformDirty = false;
|
_armatureTransformDirty = false;
|
||||||
}
|
}
|
||||||
|
|
||||||
void Armature::draw(cocos2d::Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void Armature::draw(cocos2d::Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
if (_parentBone == nullptr && _batchNode == nullptr)
|
if (_parentBone == nullptr && _batchNode == nullptr)
|
||||||
{
|
{
|
||||||
|
@ -408,17 +408,17 @@ void Armature::draw(cocos2d::Renderer *renderer, const Mat4 &transform, bool tra
|
||||||
{
|
{
|
||||||
skin->setBlendFunc(bone->getBlendFunc());
|
skin->setBlendFunc(bone->getBlendFunc());
|
||||||
}
|
}
|
||||||
skin->draw(renderer, transform, transformUpdated);
|
skin->draw(renderer, transform, flags);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
case CS_DISPLAY_ARMATURE:
|
case CS_DISPLAY_ARMATURE:
|
||||||
{
|
{
|
||||||
node->draw(renderer, transform, transformUpdated);
|
node->draw(renderer, transform, flags);
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
default:
|
default:
|
||||||
{
|
{
|
||||||
node->visit(renderer, transform, transformUpdated);
|
node->visit(renderer, transform, flags);
|
||||||
// CC_NODE_DRAW_SETUP();
|
// CC_NODE_DRAW_SETUP();
|
||||||
}
|
}
|
||||||
break;
|
break;
|
||||||
|
@ -426,7 +426,7 @@ void Armature::draw(cocos2d::Renderer *renderer, const Mat4 &transform, bool tra
|
||||||
}
|
}
|
||||||
else if(Node *node = dynamic_cast<Node *>(object))
|
else if(Node *node = dynamic_cast<Node *>(object))
|
||||||
{
|
{
|
||||||
node->visit(renderer, transform, transformUpdated);
|
node->visit(renderer, transform, flags);
|
||||||
// CC_NODE_DRAW_SETUP();
|
// CC_NODE_DRAW_SETUP();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -445,7 +445,7 @@ void Armature::onExit()
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
void Armature::visit(cocos2d::Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated)
|
void Armature::visit(cocos2d::Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
// quick return if not visible. children won't be drawn.
|
// quick return if not visible. children won't be drawn.
|
||||||
if (!_visible)
|
if (!_visible)
|
||||||
|
@ -453,10 +453,7 @@ void Armature::visit(cocos2d::Renderer *renderer, const Mat4 &parentTransform, b
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool dirty = parentTransformUpdated || _transformUpdated;
|
uint32_t flags = processParentFlags(parentTransform, parentFlags);
|
||||||
if(dirty)
|
|
||||||
_modelViewTransform = transform(parentTransform);
|
|
||||||
_transformUpdated = false;
|
|
||||||
|
|
||||||
// IMPORTANT:
|
// IMPORTANT:
|
||||||
// To ease the migration to v3.0, we still support the Mat4 stack,
|
// To ease the migration to v3.0, we still support the Mat4 stack,
|
||||||
|
@ -468,7 +465,7 @@ void Armature::visit(cocos2d::Renderer *renderer, const Mat4 &parentTransform, b
|
||||||
|
|
||||||
|
|
||||||
sortAllChildren();
|
sortAllChildren();
|
||||||
draw(renderer, _modelViewTransform, dirty);
|
draw(renderer, _modelViewTransform, flags);
|
||||||
|
|
||||||
// reset for next frame
|
// reset for next frame
|
||||||
_orderOfArrival = 0;
|
_orderOfArrival = 0;
|
||||||
|
|
|
@ -157,8 +157,8 @@ public:
|
||||||
* @js NA
|
* @js NA
|
||||||
* @lua NA
|
* @lua NA
|
||||||
*/
|
*/
|
||||||
virtual void visit(cocos2d::Renderer *renderer, const cocos2d::Mat4 &parentTransform, bool parentTransformUpdated) override;
|
virtual void visit(cocos2d::Renderer *renderer, const cocos2d::Mat4 &parentTransform, uint32_t parentFlags) override;
|
||||||
virtual void draw(cocos2d::Renderer *renderer, const cocos2d::Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(cocos2d::Renderer *renderer, const cocos2d::Mat4 &transform, uint32_t flags) override;
|
||||||
virtual void update(float dt) override;
|
virtual void update(float dt) override;
|
||||||
|
|
||||||
virtual void onEnter() override;
|
virtual void onEnter() override;
|
||||||
|
|
|
@ -101,7 +101,7 @@ void BatchNode::removeChild(Node* child, bool cleanup)
|
||||||
Node::removeChild(child, cleanup);
|
Node::removeChild(child, cleanup);
|
||||||
}
|
}
|
||||||
|
|
||||||
void BatchNode::visit(Renderer *renderer, const Mat4 &parentTransform, bool parentTransformUpdated)
|
void BatchNode::visit(Renderer *renderer, const Mat4 &parentTransform, uint32_t parentFlags)
|
||||||
{
|
{
|
||||||
// quick return if not visible. children won't be drawn.
|
// quick return if not visible. children won't be drawn.
|
||||||
if (!_visible)
|
if (!_visible)
|
||||||
|
@ -109,21 +109,17 @@ void BatchNode::visit(Renderer *renderer, const Mat4 &parentTransform, bool pare
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
bool dirty = parentTransformUpdated || _transformUpdated;
|
uint32_t flags = processParentFlags(parentTransform, parentFlags);
|
||||||
if(dirty)
|
|
||||||
_modelViewTransform = transform(parentTransform);
|
|
||||||
_transformUpdated = false;
|
|
||||||
|
|
||||||
// IMPORTANT:
|
// IMPORTANT:
|
||||||
// To ease the migration to v3.0, we still support the Mat4 stack,
|
// To ease the migration to v3.0, we still support the Mat4 stack,
|
||||||
// but it is deprecated and your code should not rely on it
|
// but it is deprecated and your code should not rely on it
|
||||||
Director* director = Director::getInstance();
|
Director* director = Director::getInstance();
|
||||||
CCASSERT(nullptr != director, "Director is null when seting matrix stack");
|
|
||||||
director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
director->pushMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewTransform);
|
director->loadMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW, _modelViewTransform);
|
||||||
|
|
||||||
sortAllChildren();
|
sortAllChildren();
|
||||||
draw(renderer, _modelViewTransform, dirty);
|
draw(renderer, _modelViewTransform, flags);
|
||||||
|
|
||||||
// reset for next frame
|
// reset for next frame
|
||||||
_orderOfArrival = 0;
|
_orderOfArrival = 0;
|
||||||
|
@ -131,7 +127,7 @@ void BatchNode::visit(Renderer *renderer, const Mat4 &parentTransform, bool pare
|
||||||
director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
director->popMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
}
|
}
|
||||||
|
|
||||||
void BatchNode::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void BatchNode::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
if (_children.empty())
|
if (_children.empty())
|
||||||
{
|
{
|
||||||
|
@ -152,14 +148,14 @@ void BatchNode::draw(Renderer *renderer, const Mat4 &transform, bool transformUp
|
||||||
pushed = true;
|
pushed = true;
|
||||||
}
|
}
|
||||||
|
|
||||||
armature->visit(renderer, transform, transformUpdated);
|
armature->visit(renderer, transform, flags);
|
||||||
}
|
}
|
||||||
else
|
else
|
||||||
{
|
{
|
||||||
renderer->popGroup();
|
renderer->popGroup();
|
||||||
pushed = false;
|
pushed = false;
|
||||||
|
|
||||||
((Node *)object)->visit(renderer, transform, transformUpdated);
|
((Node *)object)->visit(renderer, transform, flags);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -56,8 +56,8 @@ public:
|
||||||
virtual void addChild(cocos2d::Node *pChild, int zOrder) override;
|
virtual void addChild(cocos2d::Node *pChild, int zOrder) override;
|
||||||
virtual void addChild(cocos2d::Node *pChild, int zOrder, int tag) override;
|
virtual void addChild(cocos2d::Node *pChild, int zOrder, int tag) override;
|
||||||
virtual void removeChild(cocos2d::Node* child, bool cleanup) override;
|
virtual void removeChild(cocos2d::Node* child, bool cleanup) override;
|
||||||
virtual void visit(cocos2d::Renderer *renderer, const cocos2d::Mat4 &parentTransform, bool parentTransformUpdated) override;
|
virtual void visit(cocos2d::Renderer *renderer, const cocos2d::Mat4 &parentTransform, uint32_t parentFlags) override;
|
||||||
virtual void draw(cocos2d::Renderer *renderer, const cocos2d::Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(cocos2d::Renderer *renderer, const cocos2d::Mat4 &transform, uint32_t flags) override;
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
void generateGroupCommand();
|
void generateGroupCommand();
|
||||||
|
|
|
@ -23,6 +23,7 @@ THE SOFTWARE.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "cocostudio/CCComAttribute.h"
|
#include "cocostudio/CCComAttribute.h"
|
||||||
|
#include "platform/CCFileUtils.h"
|
||||||
|
|
||||||
using namespace cocos2d;
|
using namespace cocos2d;
|
||||||
|
|
||||||
|
@ -166,7 +167,7 @@ bool ComAttribute::serialize(void* r)
|
||||||
std::string filePath;
|
std::string filePath;
|
||||||
if (file != nullptr)
|
if (file != nullptr)
|
||||||
{
|
{
|
||||||
filePath.assign(cocos2d::CCFileUtils::getInstance()->fullPathForFilename(file));
|
filePath.assign(cocos2d::FileUtils::getInstance()->fullPathForFilename(file));
|
||||||
}
|
}
|
||||||
int resType = DICTOOL->getIntValue_json(fileData, "resourceType", -1);
|
int resType = DICTOOL->getIntValue_json(fileData, "resourceType", -1);
|
||||||
CC_BREAK_IF(resType != 0);
|
CC_BREAK_IF(resType != 0);
|
||||||
|
|
|
@ -26,6 +26,8 @@ THE SOFTWARE.
|
||||||
#define __CC_EXTENTIONS_CCCOMATTRIBUTE_H__
|
#define __CC_EXTENTIONS_CCCOMATTRIBUTE_H__
|
||||||
|
|
||||||
#include "CCComBase.h"
|
#include "CCComBase.h"
|
||||||
|
#include "2d/CCComponent.h"
|
||||||
|
#include "base/CCValue.h"
|
||||||
|
|
||||||
namespace cocostudio {
|
namespace cocostudio {
|
||||||
|
|
||||||
|
|
|
@ -24,6 +24,7 @@ THE SOFTWARE.
|
||||||
|
|
||||||
#include "cocostudio/CCComAudio.h"
|
#include "cocostudio/CCComAudio.h"
|
||||||
#include "audio/include/SimpleAudioEngine.h"
|
#include "audio/include/SimpleAudioEngine.h"
|
||||||
|
#include "platform/CCFileUtils.h"
|
||||||
|
|
||||||
namespace cocostudio {
|
namespace cocostudio {
|
||||||
|
|
||||||
|
@ -91,7 +92,7 @@ bool ComAudio::serialize(void* r)
|
||||||
std::string filePath;
|
std::string filePath;
|
||||||
if (file != nullptr)
|
if (file != nullptr)
|
||||||
{
|
{
|
||||||
filePath.assign(cocos2d::CCFileUtils::getInstance()->fullPathForFilename(file));
|
filePath.assign(cocos2d::FileUtils::getInstance()->fullPathForFilename(file));
|
||||||
}
|
}
|
||||||
int resType = DICTOOL->getIntValue_json(fileData, "resourceType", -1);
|
int resType = DICTOOL->getIntValue_json(fileData, "resourceType", -1);
|
||||||
CC_BREAK_IF(resType != 0);
|
CC_BREAK_IF(resType != 0);
|
||||||
|
|
|
@ -26,6 +26,7 @@ THE SOFTWARE.
|
||||||
#define __CC_EXTENTIONS_CCCOMAUDIO_H__
|
#define __CC_EXTENTIONS_CCCOMAUDIO_H__
|
||||||
|
|
||||||
#include "CCComBase.h"
|
#include "CCComBase.h"
|
||||||
|
#include "2d/CCComponent.h"
|
||||||
|
|
||||||
namespace cocostudio {
|
namespace cocostudio {
|
||||||
|
|
||||||
|
|
|
@ -25,14 +25,14 @@ THE SOFTWARE.
|
||||||
#ifndef __CC_EXTENTIONS_CCCOMBASE_H__
|
#ifndef __CC_EXTENTIONS_CCCOMBASE_H__
|
||||||
#define __CC_EXTENTIONS_CCCOMBASE_H__
|
#define __CC_EXTENTIONS_CCCOMBASE_H__
|
||||||
|
|
||||||
#include "ObjectFactory.h"
|
|
||||||
#include "DictionaryHelper.h"
|
|
||||||
#include <string>
|
#include <string>
|
||||||
|
#include "DictionaryHelper.h"
|
||||||
|
#include "base/ObjectFactory.h"
|
||||||
|
|
||||||
|
|
||||||
#define DECLARE_CLASS_COMPONENT_INFO \
|
#define DECLARE_CLASS_COMPONENT_INFO \
|
||||||
public: \
|
public: \
|
||||||
static cocostudio::ObjectFactory::TInfo Type; \
|
static cocos2d::ObjectFactory::TInfo Type; \
|
||||||
static cocos2d::Ref* createInstance(void); \
|
static cocos2d::Ref* createInstance(void); \
|
||||||
|
|
||||||
#define IMPLEMENT_CLASS_COMPONENT_INFO(className) \
|
#define IMPLEMENT_CLASS_COMPONENT_INFO(className) \
|
||||||
|
@ -40,10 +40,10 @@ THE SOFTWARE.
|
||||||
{ \
|
{ \
|
||||||
return className::create(); \
|
return className::create(); \
|
||||||
} \
|
} \
|
||||||
cocostudio::ObjectFactory::TInfo className::Type(#className, &className::createInstance); \
|
cocos2d::ObjectFactory::TInfo className::Type(#className, &className::createInstance); \
|
||||||
|
|
||||||
#define CREATE_CLASS_COMPONENT_INFO(className) \
|
#define CREATE_CLASS_COMPONENT_INFO(className) \
|
||||||
cocostudio::ObjectFactory::TInfo(#className, &className::createInstance)
|
cocos2d::ObjectFactory::TInfo(#className, &className::createInstance)
|
||||||
|
|
||||||
|
|
||||||
#endif
|
#endif
|
||||||
|
|
|
@ -23,6 +23,7 @@ THE SOFTWARE.
|
||||||
****************************************************************************/
|
****************************************************************************/
|
||||||
|
|
||||||
#include "cocostudio/CCComController.h"
|
#include "cocostudio/CCComController.h"
|
||||||
|
#include "2d/CCNode.h"
|
||||||
|
|
||||||
namespace cocostudio {
|
namespace cocostudio {
|
||||||
|
|
||||||
|
|
|
@ -27,6 +27,7 @@ THE SOFTWARE.
|
||||||
|
|
||||||
#include "CCComBase.h"
|
#include "CCComBase.h"
|
||||||
#include "cocostudio/CCInputDelegate.h"
|
#include "cocostudio/CCInputDelegate.h"
|
||||||
|
#include "2d/CCComponent.h"
|
||||||
|
|
||||||
namespace cocostudio {
|
namespace cocostudio {
|
||||||
|
|
||||||
|
|
|
@ -26,6 +26,7 @@ THE SOFTWARE.
|
||||||
#define __CC_EXTENTIONS_CCCOMRENDER_H__
|
#define __CC_EXTENTIONS_CCCOMRENDER_H__
|
||||||
|
|
||||||
#include "CCComBase.h"
|
#include "CCComBase.h"
|
||||||
|
#include "2d/CCComponent.h"
|
||||||
|
|
||||||
namespace cocostudio {
|
namespace cocostudio {
|
||||||
|
|
||||||
|
|
|
@ -218,6 +218,58 @@ Widget* GUIReader::widgetFromJsonFile(const char *fileName)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
std::string WidgetPropertiesReader::getGUIClassName(const std::string &name)
|
||||||
|
{
|
||||||
|
std::string convertedClassName = name;
|
||||||
|
if (name == "Panel")
|
||||||
|
{
|
||||||
|
convertedClassName = "Layout";
|
||||||
|
}
|
||||||
|
else if (name == "TextArea")
|
||||||
|
{
|
||||||
|
convertedClassName = "Text";
|
||||||
|
}
|
||||||
|
else if (name == "TextButton")
|
||||||
|
{
|
||||||
|
convertedClassName = "Button";
|
||||||
|
}
|
||||||
|
else if (name == "Label")
|
||||||
|
{
|
||||||
|
convertedClassName = "Text";
|
||||||
|
}
|
||||||
|
else if (name == "LabelAtlas")
|
||||||
|
{
|
||||||
|
convertedClassName = "TextAtlas";
|
||||||
|
}
|
||||||
|
else if (name == "LabelBMFont")
|
||||||
|
{
|
||||||
|
convertedClassName = "TextBMFont";
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
return convertedClassName;
|
||||||
|
}
|
||||||
|
|
||||||
|
cocos2d::ui::Widget* WidgetPropertiesReader::createGUI(const std::string &classname)
|
||||||
|
{
|
||||||
|
std::string name = this->getGUIClassName(classname);
|
||||||
|
|
||||||
|
Ref* object = ObjectFactory::getInstance()->createObject(name);
|
||||||
|
|
||||||
|
return dynamic_cast<ui::Widget*>(object);
|
||||||
|
}
|
||||||
|
|
||||||
|
WidgetReaderProtocol* WidgetPropertiesReader::createWidgetReaderProtocol(const std::string &classname)
|
||||||
|
{
|
||||||
|
Ref* object = ObjectFactory::getInstance()->createObject(classname);
|
||||||
|
|
||||||
|
return dynamic_cast<WidgetReaderProtocol*>(object);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
void WidgetPropertiesReader::setAnchorPointForWidget(cocos2d::ui::Widget *widget, const rapidjson::Value &options)
|
void WidgetPropertiesReader::setAnchorPointForWidget(cocos2d::ui::Widget *widget, const rapidjson::Value &options)
|
||||||
{
|
{
|
||||||
bool isAnchorPointXExists = DICTOOL->checkObjectExist_json(options, "anchorPointX");
|
bool isAnchorPointXExists = DICTOOL->checkObjectExist_json(options, "anchorPointX");
|
||||||
|
@ -1001,7 +1053,7 @@ Widget* WidgetPropertiesReader0300::widgetFromJsonDictionary(const rapidjson::Va
|
||||||
{
|
{
|
||||||
const char* classname = DICTOOL->getStringValue_json(data, "classname");
|
const char* classname = DICTOOL->getStringValue_json(data, "classname");
|
||||||
const rapidjson::Value& uiOptions = DICTOOL->getSubDictionary_json(data, "options");
|
const rapidjson::Value& uiOptions = DICTOOL->getSubDictionary_json(data, "options");
|
||||||
Widget* widget = ObjectFactory::getInstance()->createGUI(classname);
|
Widget* widget = this->createGUI(classname);
|
||||||
|
|
||||||
// create widget reader to parse properties of widget
|
// create widget reader to parse properties of widget
|
||||||
std::string readerName = classname;
|
std::string readerName = classname;
|
||||||
|
@ -1030,7 +1082,8 @@ Widget* WidgetPropertiesReader0300::widgetFromJsonDictionary(const rapidjson::Va
|
||||||
readerName = "TextBMFont";
|
readerName = "TextBMFont";
|
||||||
}
|
}
|
||||||
readerName.append("Reader");
|
readerName.append("Reader");
|
||||||
WidgetReaderProtocol* reader = ObjectFactory::getInstance()->createWidgetReaderProtocol(readerName);
|
|
||||||
|
WidgetReaderProtocol* reader = this->createWidgetReaderProtocol(readerName);
|
||||||
|
|
||||||
if (reader)
|
if (reader)
|
||||||
{
|
{
|
||||||
|
@ -1096,7 +1149,9 @@ Widget* WidgetPropertiesReader0300::widgetFromJsonDictionary(const rapidjson::Va
|
||||||
{
|
{
|
||||||
readerName = "WidgetReader";
|
readerName = "WidgetReader";
|
||||||
}
|
}
|
||||||
reader = ObjectFactory::getInstance()->createWidgetReaderProtocol(readerName);
|
|
||||||
|
reader = dynamic_cast<WidgetReaderProtocol*>(ObjectFactory::getInstance()->createObject(readerName));
|
||||||
|
|
||||||
setPropsForAllWidgetFromJsonDictionary(reader, widget, uiOptions);
|
setPropsForAllWidgetFromJsonDictionary(reader, widget, uiOptions);
|
||||||
|
|
||||||
// 2nd., custom widget parse with custom reader
|
// 2nd., custom widget parse with custom reader
|
||||||
|
|
|
@ -28,10 +28,12 @@ THE SOFTWARE.
|
||||||
#include "ui/UIWidget.h"
|
#include "ui/UIWidget.h"
|
||||||
#include "cocostudio/DictionaryHelper.h"
|
#include "cocostudio/DictionaryHelper.h"
|
||||||
#include "WidgetReader/WidgetReaderProtocol.h"
|
#include "WidgetReader/WidgetReaderProtocol.h"
|
||||||
#include "ObjectFactory.h"
|
#include "base/ObjectFactory.h"
|
||||||
|
|
||||||
|
|
||||||
namespace cocostudio {
|
namespace cocostudio {
|
||||||
|
|
||||||
|
|
||||||
#define kCCSVersion 1.0
|
#define kCCSVersion 1.0
|
||||||
|
|
||||||
typedef void (cocos2d::Ref::*SEL_ParseEvent)(const std::string&, cocos2d::Ref*, const rapidjson::Value&);
|
typedef void (cocos2d::Ref::*SEL_ParseEvent)(const std::string&, cocos2d::Ref*, const rapidjson::Value&);
|
||||||
|
@ -59,7 +61,7 @@ public:
|
||||||
|
|
||||||
const std::string& getFilePath() const { return m_strFilePath; };
|
const std::string& getFilePath() const { return m_strFilePath; };
|
||||||
void registerTypeAndCallBack(const std::string& classType,
|
void registerTypeAndCallBack(const std::string& classType,
|
||||||
ObjectFactory::Instance ins,
|
cocos2d::ObjectFactory::Instance ins,
|
||||||
Ref* object,
|
Ref* object,
|
||||||
SEL_ParseEvent callBack);
|
SEL_ParseEvent callBack);
|
||||||
|
|
||||||
|
@ -94,6 +96,10 @@ public:
|
||||||
protected:
|
protected:
|
||||||
void setAnchorPointForWidget(cocos2d::ui::Widget* widget, const rapidjson::Value&options);
|
void setAnchorPointForWidget(cocos2d::ui::Widget* widget, const rapidjson::Value&options);
|
||||||
|
|
||||||
|
std::string getGUIClassName(const std::string& name);
|
||||||
|
cocos2d::ui::Widget *createGUI(const std::string& classname);
|
||||||
|
WidgetReaderProtocol* createWidgetReaderProtocol(const std::string& classname);
|
||||||
|
|
||||||
protected:
|
protected:
|
||||||
std::string m_strFilePath;
|
std::string m_strFilePath;
|
||||||
};
|
};
|
||||||
|
|
|
@ -111,6 +111,43 @@ Node* SceneReader::nodeByTag(Node *parent, int tag)
|
||||||
return _retNode;
|
return _retNode;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
cocos2d::Component* SceneReader::createComponent(const std::string classname)
|
||||||
|
{
|
||||||
|
std::string name = this->getComponentClassName(classname);
|
||||||
|
Ref *object = ObjectFactory::getInstance()->createObject(name);
|
||||||
|
|
||||||
|
return dynamic_cast<Component*>(object);
|
||||||
|
}
|
||||||
|
std::string SceneReader::getComponentClassName(const std::string &name)
|
||||||
|
{
|
||||||
|
std::string comName;
|
||||||
|
if (name == "CCSprite" || name == "CCTMXTiledMap" || name == "CCParticleSystemQuad" || name == "CCArmature" || name == "GUIComponent")
|
||||||
|
{
|
||||||
|
comName = "ComRender";
|
||||||
|
}
|
||||||
|
else if (name == "CCComAudio" || name == "CCBackgroundAudio")
|
||||||
|
{
|
||||||
|
comName = "ComAudio";
|
||||||
|
}
|
||||||
|
else if (name == "CCComController")
|
||||||
|
{
|
||||||
|
comName = "ComController";
|
||||||
|
}
|
||||||
|
else if (name == "CCComAttribute")
|
||||||
|
{
|
||||||
|
comName = "ComAttribute";
|
||||||
|
}
|
||||||
|
else if (name == "CCScene")
|
||||||
|
{
|
||||||
|
comName = "Scene";
|
||||||
|
}
|
||||||
|
else
|
||||||
|
{
|
||||||
|
CCASSERT(false, "Unregistered Component!");
|
||||||
|
}
|
||||||
|
|
||||||
|
return comName;
|
||||||
|
}
|
||||||
|
|
||||||
Node* SceneReader::createObject(const rapidjson::Value &dict, cocos2d::Node* parent, AttachComponentType attachComponent)
|
Node* SceneReader::createObject(const rapidjson::Value &dict, cocos2d::Node* parent, AttachComponentType attachComponent)
|
||||||
{
|
{
|
||||||
|
@ -134,7 +171,7 @@ Node* SceneReader::createObject(const rapidjson::Value &dict, cocos2d::Node* par
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
const char *comName = DICTOOL->getStringValue_json(subDict, "classname");
|
const char *comName = DICTOOL->getStringValue_json(subDict, "classname");
|
||||||
Component *com = ObjectFactory::getInstance()->createComponent(comName);
|
Component *com = this->createComponent(comName);
|
||||||
if (com != nullptr)
|
if (com != nullptr)
|
||||||
{
|
{
|
||||||
if (com->serialize((void*)(&subDict)))
|
if (com->serialize((void*)(&subDict)))
|
||||||
|
|
|
@ -68,6 +68,10 @@ public:
|
||||||
private:
|
private:
|
||||||
SceneReader(void);
|
SceneReader(void);
|
||||||
virtual ~SceneReader(void);
|
virtual ~SceneReader(void);
|
||||||
|
std::string getComponentClassName(const std::string& name);
|
||||||
|
|
||||||
|
cocos2d::Component* createComponent(const std::string classname);
|
||||||
|
|
||||||
|
|
||||||
cocos2d::Node* createObject(const rapidjson::Value& dict, cocos2d::Node* parent, AttachComponentType attachComponent);
|
cocos2d::Node* createObject(const rapidjson::Value& dict, cocos2d::Node* parent, AttachComponentType attachComponent);
|
||||||
void setPropertyFromJsonDict(const rapidjson::Value& dict, cocos2d::Node *node);
|
void setPropertyFromJsonDict(const rapidjson::Value& dict, cocos2d::Node *node);
|
||||||
|
|
|
@ -219,7 +219,7 @@ Mat4 Skin::getNodeToWorldTransformAR() const
|
||||||
return TransformConcat( _bone->getArmature()->getNodeToWorldTransform(),displayTransform);
|
return TransformConcat( _bone->getArmature()->getNodeToWorldTransform(),displayTransform);
|
||||||
}
|
}
|
||||||
|
|
||||||
void Skin::draw(Renderer *renderer, const Mat4 &transform, bool transformUpdated)
|
void Skin::draw(Renderer *renderer, const Mat4 &transform, uint32_t flags)
|
||||||
{
|
{
|
||||||
Mat4 mv = Director::getInstance()->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
Mat4 mv = Director::getInstance()->getMatrix(MATRIX_STACK_TYPE::MATRIX_STACK_MODELVIEW);
|
||||||
|
|
||||||
|
|
|
@ -54,7 +54,7 @@ public:
|
||||||
cocos2d::Mat4 getNodeToWorldTransform() const override;
|
cocos2d::Mat4 getNodeToWorldTransform() const override;
|
||||||
cocos2d::Mat4 getNodeToWorldTransformAR() const;
|
cocos2d::Mat4 getNodeToWorldTransformAR() const;
|
||||||
|
|
||||||
virtual void draw(cocos2d::Renderer *renderer, const cocos2d::Mat4 &transform, bool transformUpdated) override;
|
virtual void draw(cocos2d::Renderer *renderer, const cocos2d::Mat4 &transform, uint32_t flags) override;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* @js NA
|
* @js NA
|
||||||
|
|
|
@ -30,7 +30,6 @@ set(CS_SRC
|
||||||
DictionaryHelper.cpp
|
DictionaryHelper.cpp
|
||||||
CCSGUIReader.cpp
|
CCSGUIReader.cpp
|
||||||
CCSSceneReader.cpp
|
CCSSceneReader.cpp
|
||||||
ObjectFactory.cpp
|
|
||||||
TriggerBase.cpp
|
TriggerBase.cpp
|
||||||
TriggerMng.cpp
|
TriggerMng.cpp
|
||||||
TriggerObj.cpp
|
TriggerObj.cpp
|
||||||
|
|
|
@ -27,14 +27,14 @@ THE SOFTWARE.
|
||||||
|
|
||||||
#include "cocos2d.h"
|
#include "cocos2d.h"
|
||||||
#include "cocostudio/CocoStudio.h"
|
#include "cocostudio/CocoStudio.h"
|
||||||
#include "ObjectFactory.h"
|
#include "base/ObjectFactory.h"
|
||||||
#include "TriggerObj.h"
|
#include "TriggerObj.h"
|
||||||
#include "TriggerMng.h"
|
#include "TriggerMng.h"
|
||||||
|
|
||||||
|
|
||||||
#define DECLARE_CLASS_INFO \
|
#define DECLARE_CLASS_INFO \
|
||||||
public: \
|
public: \
|
||||||
static cocostudio::ObjectFactory::TInfo Type; \
|
static cocos2d::ObjectFactory::TInfo Type; \
|
||||||
static cocos2d::Ref* createInstance(void); \
|
static cocos2d::Ref* createInstance(void); \
|
||||||
|
|
||||||
#define IMPLEMENT_CLASS_INFO(className) \
|
#define IMPLEMENT_CLASS_INFO(className) \
|
||||||
|
@ -44,7 +44,7 @@ THE SOFTWARE.
|
||||||
ret->autorelease(); \
|
ret->autorelease(); \
|
||||||
return ret; \
|
return ret; \
|
||||||
} \
|
} \
|
||||||
cocostudio::ObjectFactory::TInfo className::Type(#className, &className::createInstance); \
|
cocos2d::ObjectFactory::TInfo className::Type(#className, &className::createInstance); \
|
||||||
|
|
||||||
|
|
||||||
void sendEvent(unsigned int event);
|
void sendEvent(unsigned int event);
|
||||||
|
|
Some files were not shown because too many files have changed in this diff Show More
Loading…
Reference in New Issue