Merge commit '4214ad231ed0b280a41128a4a147dc07d5e914b9' into develop

Conflicts:
	cocos/scripting/auto-generated
This commit is contained in:
bmanGH 2013-12-05 01:17:56 +08:00
commit 5be6ab1986
48 changed files with 4762 additions and 783 deletions

View File

@ -93,6 +93,7 @@ Developers:
martell martell
use tinyxml2 to replace libxml2 use tinyxml2 to replace libxml2
Added Mingw-crt Support without breaking VS SDK Added Mingw-crt Support without breaking VS SDK
CMake support for windows.
mchinen mchinen
fix emulator issue for OpenGL ES 2.0 on Android fix emulator issue for OpenGL ES 2.0 on Android

View File

@ -2,11 +2,15 @@ cocos2d-x-3.0beta0 ?? 2013
[All] [All]
[NEW] Upgrated Box2D to 2.3.0 [NEW] Upgrated Box2D to 2.3.0
[NEW] Added ThreadHelper, ThreadHelper::runOnGLThread() simplify invoking engine codes and OpenGL ES commands in a thread other then gl thread. [NEW] Added ThreadHelper, ThreadHelper::runOnGLThread() simplify invoking engine codes and OpenGL ES commands in a thread other then gl thread.
[NEW] Added tga format support again.
[Android] [Android]
[NEW] build/android-build.sh: add supporting to generate .apk file [NEW] build/android-build.sh: add supporting to generate .apk file
[FIX] XMLHttpRequest receives wrong binary array. [FIX] XMLHttpRequest receives wrong binary array.
[NEW] Bindings-generator supports to bind 'unsigned long'. [NEW] Bindings-generator supports to bind 'unsigned long'.
[FIX] 'Test Frame Event' of TestJavascript/CocoStudioArmatureTest Crashes. [FIX] 'Test Frame Event' of TestJavascript/CocoStudioArmatureTest Crashes.
[Windows]
[NEW] CMake support for windows.
cocos2d-x-3.0alpha1 Nov.19 2013 cocos2d-x-3.0alpha1 Nov.19 2013
[all platforms] [all platforms]
[DOC] Added RELEASE_NOTES and CODING_STYLE.md files [DOC] Added RELEASE_NOTES and CODING_STYLE.md files

View File

@ -1,4 +1,4 @@
cmake_minimum_required(VERSION 2.6) cmake_minimum_required(VERSION 2.8)
project (Cocos2dx) project (Cocos2dx)
# The version number # The version number
@ -7,6 +7,26 @@ set(Cocos2dxSamples_VERSION_MINOR 0)
include(build/BuildHelpers.CMakeLists.txt) include(build/BuildHelpers.CMakeLists.txt)
if(WIN32 OR APPLE)
option(USE_CHIPMUNK "Use chipmunk for physics library" ON)
option(USE_BOX2D "Use box2d for physics library" OFF)
option(DEBUG_MODE "Debug or release?" ON)
option(BUILD_LIBS_LUA "Build lua libraries" OFF)
option(BUILD_GUI "Build GUI library" OFF)
option(BUILD_NETWORK "Build network library" OFF)
option(BUILD_EXTENSIONS "Build extension library" OFF)
option(BUILD_EDITOR_SPINE "Build editor support for spine" OFF)
option(BUILD_EDITOR_COCOSTUDIO "Build editor support for cocostudio" OFF)
option(BUILD_EDITOR_COCOSBUILDER "Build editor support for cocosbuilder" OFF)
option(BUILD_HelloCpp "Only build HelloCpp sample" ON)
option(BUILD_TestCpp "Only build TestCpp sample" OFF)
option(BUILD_HelloLua "Only build HelloLua sample" OFF)
option(BUILD_TestLua "Only build TestLua sample" OFF)
else()#temp
option(USE_CHIPMUNK "Use chipmunk for physics library" ON) option(USE_CHIPMUNK "Use chipmunk for physics library" ON)
option(USE_BOX2D "Use box2d for physics library" OFF) option(USE_BOX2D "Use box2d for physics library" OFF)
option(DEBUG_MODE "Debug or release?" ON) option(DEBUG_MODE "Debug or release?" ON)
@ -24,6 +44,8 @@ option(BUILD_TestCpp "Only build TestCpp sample" ON)
option(BUILD_HelloLua "Only build HelloLua sample" ON) option(BUILD_HelloLua "Only build HelloLua sample" ON)
option(BUILD_TestLua "Only build TestLua sample" ON) option(BUILD_TestLua "Only build TestLua sample" ON)
endif()#temp
if(DEBUG_MODE) if(DEBUG_MODE)
set(CMAKE_BUILD_TYPE DEBUG) set(CMAKE_BUILD_TYPE DEBUG)
@ -31,18 +53,47 @@ else(DEBUG_MODE)
set(CMAKE_BUILD_TYPE RELEASE) set(CMAKE_BUILD_TYPE RELEASE)
endif(DEBUG_MODE) endif(DEBUG_MODE)
set(CMAKE_C_FLAGS_DEBUG "-g -Wall -DCOCOS2D_DEBUG=1") set(CMAKE_C_FLAGS_DEBUG "-DCOCOS2D_DEBUG=1")
set(CMAKE_CXX_FLAGS_DEBUG ${CMAKE_C_FLAGS_DEBUG}) set(CMAKE_CXX_FLAGS_DEBUG ${CMAKE_C_FLAGS_DEBUG})
if(WIN32)
ADD_DEFINITIONS (-D_USRDLL -DCOCOS2DXWIN32_EXPORTS -D_WINDOWS -DWIN32)
if(MSVC)
ADD_DEFINITIONS(-D_CRT_SECURE_NO_WARNINGS
-D_SCL_SECURE_NO_WARNINGS
-wd4251 -wd4244 -wd4334
-wd4005 -wd4820 -wd4710
-wd4514 -wd4056 -wd4996 -wd4099)
else(MSVC)#MINGW
endif(MSVC)
elseif(APPLE)
else()#Linux
ADD_DEFINITIONS(-DLINUX)
endif()
if(NOT MSVC)# all gcc
set(CMAKE_C_FLAGS_DEBUG "-g -Wall -DCOCOS2D_DEBUG=1")
set(CMAKE_CXX_FLAGS_DEBUG ${CMAKE_C_FLAGS_DEBUG})
set(CMAKE_C_FLAGS ${CMAKE_C_FLAGS} "-std=c99") set(CMAKE_C_FLAGS ${CMAKE_C_FLAGS} "-std=c99")
set(CMAKE_CXX_FLAGS ${CMAKE_CXX_FLAGS} "-std=c++11") set(CMAKE_CXX_FLAGS ${CMAKE_CXX_FLAGS} "-std=c++11")
endif()
if(MINGW)
add_definitions(-DGLEW_STATIC)
endif()
if(USE_CHIPMUNK) if(USE_CHIPMUNK)
message("Using chipmunk ...") message("Using chipmunk ...")
add_definitions(-DLINUX -DCC_ENABLE_CHIPMUNK_INTEGRATION=1) add_definitions(-DCC_ENABLE_CHIPMUNK_INTEGRATION=1)
elseif(USE_BOX2D) elseif(USE_BOX2D)
message("Using box2d ...") message("Using box2d ...")
add_definitions(-DLINUX -DCC_ENABLE_BOX2D_INTEGRATION=1) add_definitions(-DCC_ENABLE_BOX2D_INTEGRATION=1)
else(USE_CHIPMUNK) else(USE_CHIPMUNK)
message(FATAL_ERROR "Must choose a physics library.") message(FATAL_ERROR "Must choose a physics library.")
endif(USE_CHIPMUNK) endif(USE_CHIPMUNK)
@ -54,40 +105,93 @@ else()
set(ARCH_DIR "32-bit") set(ARCH_DIR "32-bit")
endif() endif()
if(WIN32) # Win32
set(PLATFORM_FOLDER win32)
elseif(APPLE)# osx or ios
set(PLATFORM_FOLDER mac)
else() # Assume Linux
set(PLATFORM_FOLDER linux)
endif()
include_directories( include_directories(
. ${CMAKE_CURRENT_SOURCE_DIR}
cocos ${CMAKE_CURRENT_SOURCE_DIR}/cocos
cocos/audio/include ${CMAKE_CURRENT_SOURCE_DIR}/cocos/audio/include
cocos/2d ${CMAKE_CURRENT_SOURCE_DIR}/cocos/2d
cocos/2d/platform ${CMAKE_CURRENT_SOURCE_DIR}/cocos/2d/platform
cocos/2d/platform/linux ${CMAKE_CURRENT_SOURCE_DIR}/cocos/base
cocos/base ${CMAKE_CURRENT_SOURCE_DIR}/cocos/physics
cocos/physics ${CMAKE_CURRENT_SOURCE_DIR}/cocos/editor-support
cocos/editor-support ${CMAKE_CURRENT_SOURCE_DIR}/cocos/math/kazmath/include
cocos/math/kazmath/include ${CMAKE_CURRENT_SOURCE_DIR}/extensions
extensions ${CMAKE_CURRENT_SOURCE_DIR}/external
external ${CMAKE_CURRENT_SOURCE_DIR}/external/tinyxml2
external/jpeg/include/linux ${CMAKE_CURRENT_SOURCE_DIR}/external/unzip
external/tiff/include/linux ${CMAKE_CURRENT_SOURCE_DIR}/external/chipmunk/include/chipmunk
external/webp/include/linux ${CMAKE_CURRENT_SOURCE_DIR}/cocos/2d/platform/${PLATFORM_FOLDER}
external/glfw3/include/linux ${CMAKE_CURRENT_SOURCE_DIR}/external/jpeg/include/${PLATFORM_FOLDER}
external/curl/include/linux/${ARCH_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/external/png/include/${PLATFORM_FOLDER}
external/tinyxml2 ${CMAKE_CURRENT_SOURCE_DIR}/external/tiff/include/${PLATFORM_FOLDER}
external/unzip ${CMAKE_CURRENT_SOURCE_DIR}/external/webp/include/${PLATFORM_FOLDER}
external/chipmunk/include/chipmunk ${CMAKE_CURRENT_SOURCE_DIR}/external/glfw3/include/${PLATFORM_FOLDER}
external/freetype2/include/linux ${CMAKE_CURRENT_SOURCE_DIR}/external/freetype2/include/${PLATFORM_FOLDER}
external/linux-specific/fmod/include/${ARCH_DIR}
) )
link_directories( if(WIN32)
/usr/local/lib include_directories(
${CMAKE_SOURCE_DIR}/external/jpeg/prebuilt/linux/${ARCH_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/external/${PLATFORM_FOLDER}-specific/gles/include/OGLES
${CMAKE_SOURCE_DIR}/external/tiff/prebuilt/linux/${ARCH_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/external/${PLATFORM_FOLDER}-specific/icon/include
${CMAKE_SOURCE_DIR}/external/webp/prebuilt/linux/${ARCH_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/external/${PLATFORM_FOLDER}-specific/zlib/include
${CMAKE_SOURCE_DIR}/external/freetype2/prebuilt/linux/${ARCH_DIR} external/curl/include/${PLATFORM_FOLDER}
${CMAKE_SOURCE_DIR}/external/curl/prebuilt/linux/${ARCH_DIR} )
${CMAKE_SOURCE_DIR}/external/linux-specific/fmod/prebuilt/${ARCH_DIR} elseif(APPLE)
) include_directories(
${CMAKE_CURRENT_SOURCE_DIR}/external/curl/include/${PLATFORM_FOLDER}
)
else()
include_directories(
${CMAKE_CURRENT_SOURCE_DIR}/external/${PLATFORM_FOLDER}-specific/fmod/include/${ARCH_DIR}
${CMAKE_CURRENT_SOURCE_DIR}/external/curl/include/${PLATFORM_FOLDER}/${ARCH_DIR}
)
endif()
if(WIN32)
if(NOT MINGW)
link_directories(
${CMAKE_CURRENT_SOURCE_DIR}/external/jpeg/prebuilt/${PLATFORM_FOLDER}
${CMAKE_CURRENT_SOURCE_DIR}/external/tiff/prebuilt/${PLATFORM_FOLDER}
${CMAKE_CURRENT_SOURCE_DIR}/external/png/prebuilt/${PLATFORM_FOLDER}
${CMAKE_CURRENT_SOURCE_DIR}/external/freetype2/prebuilt/${PLATFORM_FOLDER}
${CMAKE_CURRENT_SOURCE_DIR}/external/curl/prebuilt/${PLATFORM_FOLDER}
${CMAKE_CURRENT_SOURCE_DIR}/external/${PLATFORM_FOLDER}-specific/icon/prebuilt
${CMAKE_CURRENT_SOURCE_DIR}/external/${PLATFORM_FOLDER}-specific/zlib/prebuilt
)
endif()
link_directories(
${CMAKE_CURRENT_SOURCE_DIR}/external/webp/prebuilt/${PLATFORM_FOLDER}
${CMAKE_CURRENT_SOURCE_DIR}/external/glfw3/prebuilt/${PLATFORM_FOLDER}
${CMAKE_CURRENT_SOURCE_DIR}/external/${PLATFORM_FOLDER}-specific/gles/prebuilt
)
elseif(APPLE)
else()
link_directories(
/usr/local/lib
${CMAKE_CURRENT_SOURCE_DIR}/external/jpeg/prebuilt/${PLATFORM_FOLDER}/${ARCH_DIR}
${CMAKE_CURRENT_SOURCE_DIR}/external/tiff/prebuilt/${PLATFORM_FOLDER}/${ARCH_DIR}
${CMAKE_CURRENT_SOURCE_DIR}/external/webp/prebuilt/${PLATFORM_FOLDER}/${ARCH_DIR}
${CMAKE_CURRENT_SOURCE_DIR}/external/png/prebuilt/${PLATFORM_FOLDER}/${ARCH_DIR}
${CMAKE_CURRENT_SOURCE_DIR}/external/freetype2/prebuilt/${PLATFORM_FOLDER}/${ARCH_DIR}
${CMAKE_CURRENT_SOURCE_DIR}/external/curl/prebuilt/${PLATFORM_FOLDER}/${ARCH_DIR}
${CMAKE_CURRENT_SOURCE_DIR}/external/${PLATFORM_FOLDER}-specific/fmod/prebuilt/${ARCH_DIR}
)
endif()
# kazmath # kazmath

View File

@ -0,0 +1,8 @@
@echo off
SETLOCAL
:start
mkdir win32-msvc-vs2010-x86
cd win32-msvc-vs2010-x86
cmake -G "Visual Studio 10" ../..
pause

View File

@ -0,0 +1,8 @@
@echo off
SETLOCAL
:start
mkdir win32-msvc-vs2012-x86
cd win32-msvc-vs2012-x86
cmake -G "Visual Studio 11" ../..
pause

View File

@ -0,0 +1,8 @@
@echo off
SETLOCAL
:start
mkdir win32-msvc-vs2013-x86
cd win32-msvc-vs2013-x86
cmake -G "Visual Studio 12" ../..
pause

View File

@ -1341,14 +1341,17 @@ Point Node::convertTouchToNodeSpaceAR(Touch *touch) const
} }
#ifdef CC_USE_PHYSICS #ifdef CC_USE_PHYSICS
void Node::updatePhysicsTransform() bool Node::updatePhysicsTransform()
{ {
if (_physicsBody) if (_physicsBody != nullptr && _physicsBody->getWorld() != nullptr && !_physicsBody->isResting())
{ {
_position = _physicsBody->getPosition(); _position = _physicsBody->getPosition();
_rotationX = _rotationY = _physicsBody->getRotation(); _rotationX = _rotationY = _physicsBody->getRotation();
_transformDirty = _inverseDirty = true; _transformDirty = _inverseDirty = true;
return true;
} }
return false;
} }
#endif #endif

File diff suppressed because it is too large Load Diff

View File

@ -102,7 +102,7 @@ bool ParticleBatchNode::initWithTexture(Texture2D *tex, int capacity)
_blendFunc = BlendFunc::ALPHA_PREMULTIPLIED; _blendFunc = BlendFunc::ALPHA_PREMULTIPLIED;
setShaderProgram(ShaderCache::getInstance()->getProgram(GLProgram::SHADER_NAME_POSITION_TEXTURE_COLOR)); setShaderProgram(ShaderCache::getInstance()->getProgram(GLProgram::SHADER_NAME_POSITION_TEXTURE_COLOR));
return true; return true;
} }
@ -144,7 +144,7 @@ void ParticleBatchNode::visit()
transform(); transform();
draw(); draw();
if ( _grid && _grid->isActive()) if ( _grid && _grid->isActive())
{ {
_grid->afterDraw(this); _grid->afterDraw(this);
@ -171,12 +171,12 @@ void ParticleBatchNode::addChild(Node * aChild, int zOrder, int tag)
ParticleSystem* child = static_cast<ParticleSystem*>(aChild); ParticleSystem* child = static_cast<ParticleSystem*>(aChild);
CCASSERT( child->getTexture()->getName() == _textureAtlas->getTexture()->getName(), "CCParticleSystem is not using the same texture id"); CCASSERT( child->getTexture()->getName() == _textureAtlas->getTexture()->getName(), "CCParticleSystem is not using the same texture id");
// If this is the 1st children, then copy blending function // If this is the 1st children, then copy blending function
if( _children->count() == 0 ) if( _children->count() == 0 )
{ {
setBlendFunc(child->getBlendFunc()); setBlendFunc(child->getBlendFunc());
} }
CCASSERT( _blendFunc.src == child->getBlendFunc().src && _blendFunc.dst == child->getBlendFunc().dst, "Can't add a PaticleSystem that uses a different blending function"); CCASSERT( _blendFunc.src == child->getBlendFunc().src && _blendFunc.dst == child->getBlendFunc().dst, "Can't add a ParticleSystem that uses a different blending function");
//no lazy sorting, so don't call super addChild, call helper instead //no lazy sorting, so don't call super addChild, call helper instead
unsigned int pos = addChildHelper(child,zOrder,tag); unsigned int pos = addChildHelper(child,zOrder,tag);
@ -184,7 +184,7 @@ void ParticleBatchNode::addChild(Node * aChild, int zOrder, int tag)
//get new atlasIndex //get new atlasIndex
int atlasIndex = 0; int atlasIndex = 0;
if (pos != 0) if (pos != 0)
{ {
ParticleSystem* p = (ParticleSystem*)_children->getObjectAtIndex(pos-1); ParticleSystem* p = (ParticleSystem*)_children->getObjectAtIndex(pos-1);
atlasIndex = p->getAtlasIndex() + p->getTotalParticles(); atlasIndex = p->getAtlasIndex() + p->getTotalParticles();
@ -210,7 +210,7 @@ unsigned int ParticleBatchNode::addChildHelper(ParticleSystem* child, int z, int
CCASSERT( child != NULL, "Argument must be non-nil"); CCASSERT( child != NULL, "Argument must be non-nil");
CCASSERT( child->getParent() == NULL, "child already added. It can't be added again"); CCASSERT( child->getParent() == NULL, "child already added. It can't be added again");
if( ! _children ) if( ! _children )
{ {
_children = new Array(); _children = new Array();
_children->initWithCapacity(4); _children->initWithCapacity(4);
@ -226,7 +226,7 @@ unsigned int ParticleBatchNode::addChildHelper(ParticleSystem* child, int z, int
child->setParent(this); child->setParent(this);
if( _running ) if( _running )
{ {
child->onEnter(); child->onEnter();
child->onEnterTransitionDidFinish(); child->onEnterTransitionDidFinish();
@ -243,7 +243,7 @@ void ParticleBatchNode::reorderChild(Node * aChild, int zOrder)
ParticleSystem* child = static_cast<ParticleSystem*>(aChild); ParticleSystem* child = static_cast<ParticleSystem*>(aChild);
if( zOrder == child->getZOrder() ) if( zOrder == child->getZOrder() )
{ {
return; return;
} }
@ -275,7 +275,7 @@ void ParticleBatchNode::reorderChild(Node * aChild, int zOrder)
for( int i=0;i < _children->count();i++) for( int i=0;i < _children->count();i++)
{ {
ParticleSystem* pNode = (ParticleSystem*)_children->getObjectAtIndex(i); ParticleSystem* pNode = (ParticleSystem*)_children->getObjectAtIndex(i);
if( pNode == child ) if( pNode == child )
{ {
newAtlasIndex = child->getAtlasIndex(); newAtlasIndex = child->getAtlasIndex();
break; break;
@ -300,12 +300,12 @@ void ParticleBatchNode::getCurrentIndex(unsigned int* oldIndex, unsigned int* ne
int minusOne = 0; int minusOne = 0;
unsigned int count = _children->count(); unsigned int count = _children->count();
for( unsigned int i=0; i < count; i++ ) for( unsigned int i=0; i < count; i++ )
{ {
Node* pNode = (Node *)_children->getObjectAtIndex(i); Node* pNode = (Node *)_children->getObjectAtIndex(i);
// new index // new index
if( pNode->getZOrder() > z && ! foundNewIdx ) if( pNode->getZOrder() > z && ! foundNewIdx )
{ {
*newIndex = i; *newIndex = i;
foundNewIdx = true; foundNewIdx = true;
@ -317,7 +317,7 @@ void ParticleBatchNode::getCurrentIndex(unsigned int* oldIndex, unsigned int* ne
} }
// current index // current index
if( child == pNode ) if( child == pNode )
{ {
*oldIndex = i; *oldIndex = i;
foundCurrentIdx = true; foundCurrentIdx = true;
@ -347,7 +347,7 @@ unsigned int ParticleBatchNode::searchNewPositionInChildrenForZ(int z)
{ {
unsigned int count = _children->count(); unsigned int count = _children->count();
for( unsigned int i=0; i < count; i++ ) for( unsigned int i=0; i < count; i++ )
{ {
Node *child = (Node *)_children->getObjectAtIndex(i); Node *child = (Node *)_children->getObjectAtIndex(i);
if (child->getZOrder() > z) if (child->getZOrder() > z)
@ -364,7 +364,7 @@ void ParticleBatchNode::removeChild(Node* aChild, bool cleanup)
// explicit nil handling // explicit nil handling
if (aChild == NULL) if (aChild == NULL)
return; return;
CCASSERT( dynamic_cast<ParticleSystem*>(aChild) != NULL, "CCParticleBatchNode only supports QuadParticleSystems as children"); CCASSERT( dynamic_cast<ParticleSystem*>(aChild) != NULL, "CCParticleBatchNode only supports QuadParticleSystems as children");
CCASSERT(_children->containsObject(aChild), "CCParticleBatchNode doesn't contain the sprite. Can't remove it"); CCASSERT(_children->containsObject(aChild), "CCParticleBatchNode doesn't contain the sprite. Can't remove it");

View File

@ -496,8 +496,10 @@ void Sprite::updateTransform(void)
CCASSERT(_batchNode, "updateTransform is only valid when Sprite is being rendered using an SpriteBatchNode"); CCASSERT(_batchNode, "updateTransform is only valid when Sprite is being rendered using an SpriteBatchNode");
#ifdef CC_USE_PHYSICS #ifdef CC_USE_PHYSICS
updatePhysicsTransform(); if (updatePhysicsTransform())
setDirty(true); {
setDirty(true);
};
#endif #endif
// recalculate matrix only if it is dirty // recalculate matrix only if it is dirty

View File

@ -1,3 +1,34 @@
if(WIN32)
ADD_DEFINITIONS(-DUNICODE -D_UNICODE)
set(PLATFORM_SRC
platform/win32/CCStdC.cpp
platform/win32/CCFileUtilsWin32.cpp
platform/win32/CCCommon.cpp
platform/win32/CCApplication.cpp
platform/win32/CCEGLView.cpp
platform/win32/CCImage.cpp
platform/win32/CCDevice.cpp
)
elseif(APPLE)
else()
set(PLATFORM_SRC
platform/linux/CCStdC.cpp
platform/linux/CCFileUtilsLinux.cpp
platform/linux/CCCommon.cpp
platform/linux/CCApplication.cpp
platform/linux/CCEGLView.cpp
platform/linux/CCImage.cpp
platform/linux/CCDevice.cpp
)
endif()
set(COCOS2D_SRC set(COCOS2D_SRC
CCAction.cpp CCAction.cpp
CCActionCamera.cpp CCActionCamera.cpp
@ -107,27 +138,56 @@ set(COCOS2D_SRC
platform/CCThread.cpp platform/CCThread.cpp
platform/CCEGLViewProtocol.cpp platform/CCEGLViewProtocol.cpp
platform/CCFileUtils.cpp platform/CCFileUtils.cpp
platform/linux/CCStdC.cpp
platform/linux/CCFileUtilsLinux.cpp
platform/linux/CCCommon.cpp
platform/linux/CCApplication.cpp
platform/linux/CCEGLView.cpp
platform/linux/CCImage.cpp
platform/linux/CCDevice.cpp
) )
include(../physics/CMakeLists.txt) include(../physics/CMakeLists.txt)
add_library(cocos2d STATIC add_library(cocos2d STATIC
${COCOS2D_SRC} ${COCOS2D_SRC}
${PLATFORM_SRC}
${COCOS_PHYSICS_SRC} ${COCOS_PHYSICS_SRC}
) )
target_link_libraries(cocos2d
cocosbase if(WIN32)
chipmunk_static
tinyxml2 if(MINGW)
kazmath
unzip set(COCOS_LINK
z
jpeg
png
webp
tiff
glfw3
glew32
opengl32
iconv
freetype
bz2
)
else()
set(COCOS_LINK
libjpeg
libpng
libwebp
libtiff
freetype250
glfw3
glew32
opengl32
libiconv
libzlib
)
endif()
elseif(APPLE)
else()
set(COCOS_LINK
jpeg jpeg
webp webp
tiff tiff
@ -142,6 +202,16 @@ target_link_libraries(cocos2d
rt rt
z z
) )
endif()
target_link_libraries(cocos2d
cocosbase
chipmunk_static
tinyxml2
kazmath
unzip
${COCOS_LINK}
)
set_target_properties(cocos2d set_target_properties(cocos2d
PROPERTIES PROPERTIES

View File

@ -28,7 +28,7 @@ THE SOFTWARE.
#include "TGAlib.h" #include "TGAlib.h"
#include "platform/CCFileUtils.h" #include "platform/CCFileUtils.h"
namespace cocos2d { NS_CC_BEGIN
static bool tgaLoadRLEImageData(unsigned char* Buffer, unsigned long bufSize, tImageTGA *psInfo); static bool tgaLoadRLEImageData(unsigned char* Buffer, unsigned long bufSize, tImageTGA *psInfo);
void tgaFlipImage( tImageTGA *info ); void tgaFlipImage( tImageTGA *info );
@ -191,23 +191,19 @@ void tgaFlipImage( tImageTGA *psInfo )
free(row); free(row);
psInfo->flipped = 0; psInfo->flipped = 0;
} }
// this is the function to call when we want to load an image tImageTGA* tgaLoadBuffer(unsigned char* buffer, long size)
tImageTGA * tgaLoad(const char *filename)
{ {
int mode,total; int mode,total;
tImageTGA *info = NULL; tImageTGA *info = nullptr;
long size = 0;
unsigned char* pBuffer = FileUtils::getInstance()->getFileData(filename, "rb", &size);
do do
{ {
CC_BREAK_IF(! pBuffer); CC_BREAK_IF(! buffer);
info = (tImageTGA *)malloc(sizeof(tImageTGA)); info = (tImageTGA *)malloc(sizeof(tImageTGA));
// get the file header info // get the file header info
if (! tgaLoadHeader(pBuffer, size, info)) if (! tgaLoadHeader(buffer, size, info))
{ {
info->status = TGA_ERROR_MEMORY; info->status = TGA_ERROR_MEMORY;
break; break;
@ -245,11 +241,11 @@ tImageTGA * tgaLoad(const char *filename)
// finally load the image pixels // finally load the image pixels
if ( info->type == 10 ) if ( info->type == 10 )
{ {
bLoadImage = tgaLoadRLEImageData(pBuffer, size, info); bLoadImage = tgaLoadRLEImageData(buffer, size, info);
} }
else else
{ {
bLoadImage = tgaLoadImageData(pBuffer, size, info); bLoadImage = tgaLoadImageData(buffer, size, info);
} }
// check for errors when reading the pixels // check for errors when reading the pixels
@ -270,11 +266,26 @@ tImageTGA * tgaLoad(const char *filename)
} }
} while(0); } while(0);
free(pBuffer);
return info; return info;
} }
// this is the function to call when we want to load an image
tImageTGA * tgaLoad(const char *filename)
{
long size = 0;
unsigned char* buffer = FileUtils::getInstance()->getFileData(filename, "rb", &size);
if (buffer != nullptr)
{
tImageTGA* data = tgaLoadBuffer(buffer, size);
free(buffer);
return data;
}
return nullptr;
}
// converts RGB to grayscale // converts RGB to grayscale
void tgaRGBtogreyscale(tImageTGA *psInfo) { void tgaRGBtogreyscale(tImageTGA *psInfo) {
@ -326,4 +337,4 @@ void tgaDestroy(tImageTGA *psInfo) {
free(psInfo); free(psInfo);
} }
} }
}//namespace cocos2d NS_CC_END

View File

@ -58,6 +58,9 @@ bool tgaLoadHeader(unsigned char *Buffer, unsigned long bufSize, tImageTGA *psIn
/// loads the image pixels. You shouldn't call this function directly /// loads the image pixels. You shouldn't call this function directly
bool tgaLoadImageData(unsigned char *Buffer, unsigned long bufSize, tImageTGA *psInfo); bool tgaLoadImageData(unsigned char *Buffer, unsigned long bufSize, tImageTGA *psInfo);
/// this is the function to call when we want to load an image buffer.
tImageTGA* tgaLoadBuffer(unsigned char* buffer, long size);
/// this is the function to call when we want to load an image /// this is the function to call when we want to load an image
tImageTGA * tgaLoad(const char *filename); tImageTGA * tgaLoad(const char *filename);

View File

@ -85,6 +85,8 @@ public:
S3TC, S3TC,
//! ATITC //! ATITC
ATITC, ATITC,
//! TGA
TGA,
//! Raw Data //! Raw Data
RAW_DATA, RAW_DATA,
//! Unknown format //! Unknown format
@ -206,6 +208,8 @@ protected:
bool initWithETCData(const unsigned char * data, int dataLen); bool initWithETCData(const unsigned char * data, int dataLen);
bool initWithS3TCData(const unsigned char * data, int dataLen); bool initWithS3TCData(const unsigned char * data, int dataLen);
bool initWithATITCData(const unsigned char *data, int dataLen); bool initWithATITCData(const unsigned char *data, int dataLen);
typedef struct sImageTGA tImageTGA;
bool initWithTGAData(tImageTGA* tgaData);
bool saveImageToPNG(const std::string& filePath, bool isToRGB = true); bool saveImageToPNG(const std::string& filePath, bool isToRGB = true);
bool saveImageToJPG(const std::string& filePath); bool saveImageToJPG(const std::string& filePath);
@ -227,6 +231,7 @@ private:
int _numberOfMipmaps; int _numberOfMipmaps;
// false if we cann't auto detect the image is premultiplied or not. // false if we cann't auto detect the image is premultiplied or not.
bool _hasPremultipliedAlpha; bool _hasPremultipliedAlpha;
std::string _filePath;
private: private:

View File

@ -42,6 +42,7 @@ extern "C"
} }
#include "s3tc.h" #include "s3tc.h"
#include "atitc.h" #include "atitc.h"
#include "TGAlib.h"
#include "decode.h" #include "decode.h"
@ -388,13 +389,16 @@ Image::Image()
Image::~Image() Image::~Image()
{ {
CC_SAFE_DELETE_ARRAY(_data); if (_data != nullptr)
{
free(_data);
}
} }
bool Image::initWithImageFile(const char * strPath) bool Image::initWithImageFile(const char * strPath)
{ {
bool bRet = false; bool bRet = false;
std::string fullPath = FileUtils::getInstance()->fullPathForFilename(strPath); _filePath = FileUtils::getInstance()->fullPathForFilename(strPath);
#ifdef EMSCRIPTEN #ifdef EMSCRIPTEN
// Emscripten includes a re-implementation of SDL that uses HTML5 canvas // Emscripten includes a re-implementation of SDL that uses HTML5 canvas
@ -417,7 +421,7 @@ bool Image::initWithImageFile(const char * strPath)
SDL_FreeSurface(iSurf); SDL_FreeSurface(iSurf);
#else #else
long bufferLen = 0; long bufferLen = 0;
unsigned char* buffer = FileUtils::getInstance()->getFileData(fullPath.c_str(), "rb", &bufferLen); unsigned char* buffer = FileUtils::getInstance()->getFileData(_filePath.c_str(), "rb", &bufferLen);
if (buffer != nullptr && bufferLen > 0) if (buffer != nullptr && bufferLen > 0)
{ {
@ -434,6 +438,7 @@ bool Image::initWithImageFileThreadSafe(const char *fullpath)
{ {
bool ret = false; bool ret = false;
long dataLen = 0; long dataLen = 0;
_filePath = fullpath;
#if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID) #if (CC_TARGET_PLATFORM == CC_PLATFORM_ANDROID)
FileUtilsAndroid *fileUitls = (FileUtilsAndroid*)FileUtils::getInstance(); FileUtilsAndroid *fileUitls = (FileUtilsAndroid*)FileUtils::getInstance();
unsigned char *buffer = fileUitls->getFileDataForAsync(fullpath, "rb", &dataLen); unsigned char *buffer = fileUitls->getFileDataForAsync(fullpath, "rb", &dataLen);
@ -503,8 +508,22 @@ bool Image::initWithImageData(const unsigned char * data, long dataLen)
ret = initWithATITCData(unpackedData, unpackedLen); ret = initWithATITCData(unpackedData, unpackedLen);
break; break;
default: default:
CCAssert(false, "unsupport image format!"); {
break; // load and detect image format
tImageTGA* tgaData = tgaLoadBuffer(unpackedData, unpackedLen);
if (tgaData != nullptr && tgaData->status == TGA_OK)
{
ret = initWithTGAData(tgaData);
}
else
{
CCAssert(false, "unsupport image format!");
}
free(tgaData);
break;
}
} }
if(unpackedData != data) if(unpackedData != data)
@ -613,7 +632,6 @@ bool Image::isPvr(const unsigned char * data, int dataLen)
return memcmp(&headerv2->pvrTag, gPVRTexIdentifier, strlen(gPVRTexIdentifier)) == 0 || CC_SWAP_INT32_BIG_TO_HOST(headerv3->version) == 0x50565203; return memcmp(&headerv2->pvrTag, gPVRTexIdentifier, strlen(gPVRTexIdentifier)) == 0 || CC_SWAP_INT32_BIG_TO_HOST(headerv3->version) == 0x50565203;
} }
Image::Format Image::detectFormat(const unsigned char * data, int dataLen) Image::Format Image::detectFormat(const unsigned char * data, int dataLen)
{ {
if (isPng(data, dataLen)) if (isPng(data, dataLen))
@ -787,11 +805,11 @@ bool Image::initWithJpgData(const unsigned char * data, int dataLen)
_width = cinfo.output_width; _width = cinfo.output_width;
_height = cinfo.output_height; _height = cinfo.output_height;
_preMulti = false; _preMulti = false;
row_pointer[0] = new unsigned char[cinfo.output_width*cinfo.output_components]; row_pointer[0] = static_cast<unsigned char*>(malloc(cinfo.output_width*cinfo.output_components * sizeof(unsigned char)));
CC_BREAK_IF(! row_pointer[0]); CC_BREAK_IF(! row_pointer[0]);
_dataLen = cinfo.output_width*cinfo.output_height*cinfo.output_components; _dataLen = cinfo.output_width*cinfo.output_height*cinfo.output_components;
_data = new unsigned char[_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
CC_BREAK_IF(! _data); CC_BREAK_IF(! _data);
/* now actually read the jpeg into the raw buffer */ /* now actually read the jpeg into the raw buffer */
@ -816,7 +834,10 @@ bool Image::initWithJpgData(const unsigned char * data, int dataLen)
bRet = true; bRet = true;
} while (0); } while (0);
CC_SAFE_DELETE_ARRAY(row_pointer[0]); if (row_pointer[0] != nullptr)
{
free(row_pointer[0]);
};
return bRet; return bRet;
} }
@ -926,7 +947,7 @@ bool Image::initWithPngData(const unsigned char * data, int dataLen)
rowbytes = png_get_rowbytes(png_ptr, info_ptr); rowbytes = png_get_rowbytes(png_ptr, info_ptr);
_dataLen = rowbytes * _height; _dataLen = rowbytes * _height;
_data = new unsigned char[_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
CC_BREAK_IF(!_data); CC_BREAK_IF(!_data);
for (unsigned short i = 0; i < _height; ++i) for (unsigned short i = 0; i < _height; ++i)
@ -939,7 +960,10 @@ bool Image::initWithPngData(const unsigned char * data, int dataLen)
_preMulti = false; _preMulti = false;
CC_SAFE_FREE(row_pointers); if (row_pointers != nullptr)
{
free(row_pointers);
};
bRet = true; bRet = true;
} while (0); } while (0);
@ -1097,7 +1121,7 @@ bool Image::initWithTiffData(const unsigned char * data, int dataLen)
_height = h; _height = h;
_dataLen = npixels * sizeof (uint32); _dataLen = npixels * sizeof (uint32);
_data = new unsigned char[_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
uint32* raster = (uint32*) _TIFFmalloc(npixels * sizeof (uint32)); uint32* raster = (uint32*) _TIFFmalloc(npixels * sizeof (uint32));
if (raster != NULL) if (raster != NULL)
@ -1222,7 +1246,7 @@ bool Image::initWithPVRv2Data(const unsigned char * data, int dataLen)
//Move by size of header //Move by size of header
_dataLen = dataLen - sizeof(PVRv2TexHeader); _dataLen = dataLen - sizeof(PVRv2TexHeader);
_data = new unsigned char[_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
memcpy(_data, (unsigned char*)data + sizeof(PVRv2TexHeader), _dataLen); memcpy(_data, (unsigned char*)data + sizeof(PVRv2TexHeader), _dataLen);
// Calculate the data size for each texture level and respect the minimum number of blocks // Calculate the data size for each texture level and respect the minimum number of blocks
@ -1344,7 +1368,7 @@ bool Image::initWithPVRv3Data(const unsigned char * data, int dataLen)
int blockSize = 0, widthBlocks = 0, heightBlocks = 0; int blockSize = 0, widthBlocks = 0, heightBlocks = 0;
_dataLen = dataLen - (sizeof(PVRv3TexHeader) + header->metadataLength); _dataLen = dataLen - (sizeof(PVRv3TexHeader) + header->metadataLength);
_data = new unsigned char[_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
memcpy(_data, static_cast<const unsigned char*>(data) + sizeof(PVRv3TexHeader) + header->metadataLength, _dataLen); memcpy(_data, static_cast<const unsigned char*>(data) + sizeof(PVRv3TexHeader) + header->metadataLength, _dataLen);
_numberOfMipmaps = header->numberOfMipmaps; _numberOfMipmaps = header->numberOfMipmaps;
@ -1431,7 +1455,7 @@ bool Image::initWithETCData(const unsigned char * data, int dataLen)
#ifdef GL_ETC1_RGB8_OES #ifdef GL_ETC1_RGB8_OES
_renderFormat = Texture2D::PixelFormat::ETC; _renderFormat = Texture2D::PixelFormat::ETC;
_dataLen = dataLen - ETC_PKM_HEADER_SIZE; _dataLen = dataLen - ETC_PKM_HEADER_SIZE;
_data = new unsigned char[_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
memcpy(_data, static_cast<const unsigned char*>(data) + ETC_PKM_HEADER_SIZE, _dataLen); memcpy(_data, static_cast<const unsigned char*>(data) + ETC_PKM_HEADER_SIZE, _dataLen);
return true; return true;
#endif #endif
@ -1446,12 +1470,15 @@ bool Image::initWithETCData(const unsigned char * data, int dataLen)
_renderFormat = Texture2D::PixelFormat::RGB888; _renderFormat = Texture2D::PixelFormat::RGB888;
_dataLen = _width * _height * bytePerPixel; _dataLen = _width * _height * bytePerPixel;
_data = new unsigned char[_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
if (etc1_decode_image(static_cast<const unsigned char*>(data) + ETC_PKM_HEADER_SIZE, static_cast<etc1_byte*>(_data), _width, _height, bytePerPixel, stride) != 0) if (etc1_decode_image(static_cast<const unsigned char*>(data) + ETC_PKM_HEADER_SIZE, static_cast<etc1_byte*>(_data), _width, _height, bytePerPixel, stride) != 0)
{ {
_dataLen = 0; _dataLen = 0;
CC_SAFE_DELETE_ARRAY(_data); if (_data != nullptr)
{
free(_data);
}
return false; return false;
} }
@ -1460,6 +1487,85 @@ bool Image::initWithETCData(const unsigned char * data, int dataLen)
return false; return false;
} }
bool Image::initWithTGAData(tImageTGA* tgaData)
{
bool ret = false;
do
{
CC_BREAK_IF(tgaData == nullptr);
// tgaLoadBuffer only support type 2, 3, 10
if (2 == tgaData->type || 10 == tgaData->type)
{
// true color
// unsupport RGB555
if (tgaData->pixelDepth == 16)
{
_renderFormat = Texture2D::PixelFormat::RGB5A1;
}
else if(tgaData->pixelDepth == 24)
{
_renderFormat = Texture2D::PixelFormat::RGB888;
}
else if(tgaData->pixelDepth == 32)
{
_renderFormat = Texture2D::PixelFormat::RGBA8888;
}
else
{
CCLOG("Image WARNING: unsupport true color tga data pixel format. FILE: %s", _filePath.c_str());
break;
}
}
else if(3 == tgaData->type)
{
// gray
if (8 == tgaData->pixelDepth)
{
_renderFormat = Texture2D::PixelFormat::I8;
}
else
{
// actually this won't happen, if it happens, maybe the image file is not a tga
CCLOG("Image WARNING: unsupport gray tga data pixel format. FILE: %s", _filePath.c_str());
break;
}
}
_width = tgaData->width;
_height = tgaData->height;
_data = tgaData->imageData;
_dataLen = _width * _height * tgaData->pixelDepth / 8;
_fileType = Format::TGA;
_preMulti = false;
ret = true;
}while(false);
if (!ret)
{
const unsigned char tgaSuffix[] = ".tga";
for(int i = 0; i < 4; ++i)
{
if (std::tolower(_filePath[_filePath.length() - i - 1]) != tgaSuffix[3 - i])
{
CCLOG("Image WARNING: the image file suffix is not tga, but parsed as a tga image file. FILE: %s", _filePath.c_str());
break;
};
}
}
else
{
if (tgaData->imageData != nullptr)
{
free(tgaData->imageData);
}
}
return ret;
}
namespace namespace
{ {
static const uint32_t makeFourCC(char ch0, char ch1, char ch2, char ch3) static const uint32_t makeFourCC(char ch0, char ch1, char ch2, char ch3)
@ -1479,7 +1585,7 @@ bool Image::initWithS3TCData(const unsigned char * data, int dataLen)
/* load the .dds file */ /* load the .dds file */
S3TCTexHeader *header = (S3TCTexHeader *)data; S3TCTexHeader *header = (S3TCTexHeader *)data;
unsigned char *pixelData = new unsigned char [dataLen - sizeof(S3TCTexHeader)]; unsigned char *pixelData = static_cast<unsigned char*>(malloc((dataLen - sizeof(S3TCTexHeader)) * sizeof(unsigned char)));
memcpy((void *)pixelData, data + sizeof(S3TCTexHeader), dataLen - sizeof(S3TCTexHeader)); memcpy((void *)pixelData, data + sizeof(S3TCTexHeader), dataLen - sizeof(S3TCTexHeader));
_width = header->ddsd.width; _width = header->ddsd.width;
@ -1496,7 +1602,7 @@ bool Image::initWithS3TCData(const unsigned char * data, int dataLen)
if (Configuration::getInstance()->supportsS3TC()) //compressed data length if (Configuration::getInstance()->supportsS3TC()) //compressed data length
{ {
_dataLen = dataLen - sizeof(S3TCTexHeader); _dataLen = dataLen - sizeof(S3TCTexHeader);
_data = new unsigned char [_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
memcpy((void *)_data,(void *)pixelData , _dataLen); memcpy((void *)_data,(void *)pixelData , _dataLen);
} }
else //decompressed data length else //decompressed data length
@ -1511,7 +1617,7 @@ bool Image::initWithS3TCData(const unsigned char * data, int dataLen)
width >>= 1; width >>= 1;
height >>= 1; height >>= 1;
} }
_data = new unsigned char [_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
} }
/* load the mipmaps */ /* load the mipmaps */
@ -1582,7 +1688,10 @@ bool Image::initWithS3TCData(const unsigned char * data, int dataLen)
/* end load the mipmaps */ /* end load the mipmaps */
CC_SAFE_DELETE_ARRAY(pixelData); if (pixelData != nullptr)
{
free(pixelData);
};
return true; return true;
} }
@ -1622,7 +1731,7 @@ bool Image::initWithATITCData(const unsigned char *data, int dataLen)
if (Configuration::getInstance()->supportsATITC()) //compressed data length if (Configuration::getInstance()->supportsATITC()) //compressed data length
{ {
_dataLen = dataLen - sizeof(ATITCTexHeader) - header->bytesOfKeyValueData - 4; _dataLen = dataLen - sizeof(ATITCTexHeader) - header->bytesOfKeyValueData - 4;
_data = new unsigned char [_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
memcpy((void *)_data,(void *)pixelData , _dataLen); memcpy((void *)_data,(void *)pixelData , _dataLen);
} }
else //decompressed data length else //decompressed data length
@ -1637,7 +1746,7 @@ bool Image::initWithATITCData(const unsigned char *data, int dataLen)
width >>= 1; width >>= 1;
height >>= 1; height >>= 1;
} }
_data = new unsigned char [_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
} }
/* load the mipmaps */ /* load the mipmaps */
@ -1738,7 +1847,7 @@ bool Image::initWithWebpData(const unsigned char * data, int dataLen)
_height = config.input.height; _height = config.input.height;
_dataLen = _width * _height * 4; _dataLen = _width * _height * 4;
_data = new unsigned char[_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
config.output.u.RGBA.rgba = static_cast<uint8_t*>(_data); config.output.u.RGBA.rgba = static_cast<uint8_t*>(_data);
config.output.u.RGBA.stride = _width * 4; config.output.u.RGBA.stride = _width * 4;
@ -1747,7 +1856,7 @@ bool Image::initWithWebpData(const unsigned char * data, int dataLen)
if (WebPDecode(static_cast<const uint8_t*>(data), dataLen, &config) != VP8_STATUS_OK) if (WebPDecode(static_cast<const uint8_t*>(data), dataLen, &config) != VP8_STATUS_OK)
{ {
delete []_data; free(_data);
_data = NULL; _data = NULL;
break; break;
} }
@ -1772,7 +1881,7 @@ bool Image::initWithRawData(const unsigned char * data, long dataLen, long width
// only RGBA8888 supported // only RGBA8888 supported
int bytesPerComponent = 4; int bytesPerComponent = 4;
_dataLen = height * width * bytesPerComponent; _dataLen = height * width * bytesPerComponent;
_data = new unsigned char[_dataLen]; _data = static_cast<unsigned char*>(malloc(_dataLen * sizeof(unsigned char)));
CC_BREAK_IF(! _data); CC_BREAK_IF(! _data);
memcpy(_data, data, _dataLen); memcpy(_data, data, _dataLen);
@ -1907,7 +2016,7 @@ bool Image::saveImageToPNG(const std::string& filePath, bool isToRGB)
{ {
if (isToRGB) if (isToRGB)
{ {
unsigned char *pTempData = new unsigned char[_width * _height * 3]; unsigned char *pTempData = static_cast<unsigned char*>(malloc(_width * _height * 3 * sizeof(unsigned char*)));
if (NULL == pTempData) if (NULL == pTempData)
{ {
fclose(fp); fclose(fp);
@ -1935,7 +2044,10 @@ bool Image::saveImageToPNG(const std::string& filePath, bool isToRGB)
free(row_pointers); free(row_pointers);
row_pointers = NULL; row_pointers = NULL;
CC_SAFE_DELETE_ARRAY(pTempData); if (pTempData != nullptr)
{
free(pTempData);
}
} }
else else
{ {
@ -1996,7 +2108,7 @@ bool Image::saveImageToJPG(const std::string& filePath)
if (hasAlpha()) if (hasAlpha())
{ {
unsigned char *pTempData = new unsigned char[_width * _height * 3]; unsigned char *pTempData = static_cast<unsigned char*>(malloc(_width * _height * 3 * sizeof(unsigned char)));
if (NULL == pTempData) if (NULL == pTempData)
{ {
jpeg_finish_compress(&cinfo); jpeg_finish_compress(&cinfo);
@ -2021,7 +2133,10 @@ bool Image::saveImageToJPG(const std::string& filePath)
(void) jpeg_write_scanlines(&cinfo, row_pointer, 1); (void) jpeg_write_scanlines(&cinfo, row_pointer, 1);
} }
CC_SAFE_DELETE_ARRAY(pTempData); if (pTempData != nullptr)
{
free(pTempData);
}
} }
else else
{ {

View File

@ -18,17 +18,17 @@ void Device::setAccelerometerEnabled(bool isEnabled)
{ {
if (isEnabled) if (isEnabled)
{ {
enableAccelerometer(); enableAccelerometerJni();
} }
else else
{ {
disableAccelerometer(); disableAccelerometerJni();
} }
} }
void Device::setAccelerometerInterval(float interval) void Device::setAccelerometerInterval(float interval)
{ {
setAccelerometerInterval(interval); setAccelerometerIntervalJni(interval);
} }
NS_CC_END NS_CC_END

View File

@ -471,8 +471,8 @@ static int32_t engine_handle_input(struct android_app* app, AInputEvent* event)
return 0; return 0;
} }
void enableAccelerometer(void) { void enableAccelerometerJni(void) {
LOGI("enableAccelerometer()"); LOGI("enableAccelerometerJni()");
if (engine.accelerometerSensor != NULL) { if (engine.accelerometerSensor != NULL) {
ASensorEventQueue_enableSensor(engine.sensorEventQueue, ASensorEventQueue_enableSensor(engine.sensorEventQueue,
@ -485,8 +485,8 @@ void enableAccelerometer(void) {
} }
} }
void disableAccelerometer(void) { void disableAccelerometerJni(void) {
LOGI("disableAccelerometer()"); LOGI("disableAccelerometerJni()");
if (engine.accelerometerSensor != NULL) { if (engine.accelerometerSensor != NULL) {
ASensorEventQueue_disableSensor(engine.sensorEventQueue, ASensorEventQueue_disableSensor(engine.sensorEventQueue,
@ -494,8 +494,8 @@ void disableAccelerometer(void) {
} }
} }
void setAccelerometerInterval(float interval) { void setAccelerometerIntervalJni(float interval) {
LOGI("setAccelerometerInterval(%f)", interval); LOGI("setAccelerometerIntervalJni(%f)", interval);
// We'd like to get 60 events per second (in us). // We'd like to get 60 events per second (in us).
ASensorEventQueue_setEventRate(engine.sensorEventQueue, ASensorEventQueue_setEventRate(engine.sensorEventQueue,
engine.accelerometerSensor, interval * 1000000L); engine.accelerometerSensor, interval * 1000000L);

View File

@ -5,8 +5,8 @@
* This is the interface to the Android native activity * This is the interface to the Android native activity
*/ */
void enableAccelerometer(void); void enableAccelerometerJni(void);
void disableAccelerometer(void); void disableAccelerometerJni(void);
void setAccelerometerInterval(float interval); void setAccelerometerIntervalJni(float interval);
#endif // __COCOSNATIVEACTIVITY_H__ #endif // __COCOSNATIVEACTIVITY_H__

View File

@ -413,7 +413,7 @@ EGLView::EGLView()
{ {
g_keyCodeMap.insert(std::make_pair(item.glfwKeyCode, item.keyCode)); g_keyCodeMap.insert(std::make_pair(item.glfwKeyCode, item.keyCode));
} }
strcpy(_viewName, "Cocos2dxWin32"); _viewName = "Cocos2dxWin32";
glfwSetErrorCallback(EGLViewEventHandler::OnGLFWError); glfwSetErrorCallback(EGLViewEventHandler::OnGLFWError);
glfwInit(); glfwInit();
} }
@ -433,7 +433,7 @@ bool EGLView::init(const char* viewName, float width, float height, float frameZ
setFrameZoomFactor(frameZoomFactor); setFrameZoomFactor(frameZoomFactor);
glfwWindowHint(GLFW_RESIZABLE,GL_FALSE); glfwWindowHint(GLFW_RESIZABLE,GL_FALSE);
_mainWindow = glfwCreateWindow(_screenSize.width * _frameZoomFactor, _screenSize.height * _frameZoomFactor, _viewName, nullptr, nullptr); _mainWindow = glfwCreateWindow(_screenSize.width * _frameZoomFactor, _screenSize.height * _frameZoomFactor, _viewName.c_str(), nullptr, nullptr);
glfwMakeContextCurrent(_mainWindow); glfwMakeContextCurrent(_mainWindow);
glfwGetFramebufferSize(_mainWindow, &_frameBufferSize[0], &_frameBufferSize[1]); glfwGetFramebufferSize(_mainWindow, &_frameBufferSize[0], &_frameBufferSize[1]);

View File

@ -1,8 +1,3 @@
set(AUDIO_SRC
linux/SimpleAudioEngineFMOD.cpp
linux/FmodAudioPlayer.cpp
)
# architecture # architecture
if ( CMAKE_SIZEOF_VOID_P EQUAL 8 ) if ( CMAKE_SIZEOF_VOID_P EQUAL 8 )
set(ARCH_DIR "64-bit") set(ARCH_DIR "64-bit")
@ -10,14 +5,31 @@ else()
set(ARCH_DIR "32-bit") set(ARCH_DIR "32-bit")
endif() endif()
include_directories( if(WIN32)
../../external/linux-specific/fmod/include/${ARCH_DIR} set(AUDIO_SRC
) win32/SimpleAudioEngine.cpp
win32/MciPlayer.cpp
)
elseif(APPLE)
else()
set(AUDIO_SRC
linux/SimpleAudioEngineFMOD.cpp
linux/FmodAudioPlayer.cpp
)
include_directories(
../../external/linux-specific/fmod/include/${ARCH_DIR}
)
endif()
add_library(audio STATIC add_library(audio STATIC
${AUDIO_SRC} ${AUDIO_SRC}
) )
if((NOT APPLE) AND (NOT WIN32))
if ( CMAKE_SIZEOF_VOID_P EQUAL 8 ) if ( CMAKE_SIZEOF_VOID_P EQUAL 8 )
set(FMOD_LIB "fmodex64") set(FMOD_LIB "fmodex64")
else() else()
@ -33,4 +45,4 @@ set_target_properties(audio
ARCHIVE_OUTPUT_DIRECTORY "${CMAKE_SOURCE_DIR}/lib" ARCHIVE_OUTPUT_DIRECTORY "${CMAKE_SOURCE_DIR}/lib"
LIBRARY_OUTPUT_DIRECTORY "${CMAKE_SOURCE_DIR}/lib" LIBRARY_OUTPUT_DIRECTORY "${CMAKE_SOURCE_DIR}/lib"
) )
endif()

View File

@ -105,7 +105,7 @@ Array* Array::createWithArray(Array* otherArray)
return otherArray->clone(); return otherArray->clone();
} }
Array* Array::createWithCapacity(long capacity) Array* Array::createWithCapacity(size_t capacity)
{ {
CCASSERT(capacity>=0, "Invalid capacity"); CCASSERT(capacity>=0, "Invalid capacity");
@ -182,7 +182,7 @@ bool Array::initWithObjects(Object* object, ...)
return ret; return ret;
} }
bool Array::initWithCapacity(long capacity) bool Array::initWithCapacity(size_t capacity)
{ {
CCASSERT(capacity>=0, "Invalid capacity"); CCASSERT(capacity>=0, "Invalid capacity");
@ -196,11 +196,11 @@ bool Array::initWithArray(Array* otherArray)
return true; return true;
} }
int Array::getIndexOfObject(Object* object) const size_t Array::getIndexOfObject(Object* object) const
{ {
auto it = data.begin(); auto it = data.begin();
for (long i = 0; it != data.end(); ++it, ++i) for (size_t i = 0; it != data.end(); ++it, ++i)
{ {
if (it->get() == object) if (it->get() == object)
{ {
@ -232,13 +232,13 @@ Object* Array::getRandomObject()
bool Array::containsObject(Object* object) const bool Array::containsObject(Object* object) const
{ {
int i = this->getIndexOfObject(object); auto i = this->getIndexOfObject(object);
return (i >=0); return (i >= 0);
} }
bool Array::isEqualToArray(Array* otherArray) bool Array::isEqualToArray(Array* otherArray)
{ {
for (long i = 0; i< this->count(); i++) for (size_t i = 0; i < this->count(); ++i)
{ {
if (!this->getObjectAtIndex(i)->isEqual(otherArray->getObjectAtIndex(i))) if (!this->getObjectAtIndex(i)->isEqual(otherArray->getObjectAtIndex(i)))
{ {
@ -250,7 +250,7 @@ bool Array::isEqualToArray(Array* otherArray)
void Array::addObject(Object* object) void Array::addObject(Object* object)
{ {
data.push_back( RCPtr<Object>(object) ); data.push_back(RCPtr<Object>(object));
} }
void Array::addObjectsFromArray(Array* otherArray) void Array::addObjectsFromArray(Array* otherArray)
@ -258,12 +258,12 @@ void Array::addObjectsFromArray(Array* otherArray)
data.insert(data.end(), otherArray->data.begin(), otherArray->data.end()); data.insert(data.end(), otherArray->data.begin(), otherArray->data.end());
} }
void Array::insertObject(Object* object, int index) void Array::insertObject(Object* object, size_t index)
{ {
data.insert( std::begin(data) + index, RCPtr<Object>(object) ); data.insert(std::begin(data) + index, RCPtr<Object>(object));
} }
void Array::setObject(Object* object, int index) void Array::setObject(Object* object, size_t index)
{ {
data[index] = RCPtr<Object>(object); data[index] = RCPtr<Object>(object);
} }
@ -276,13 +276,13 @@ void Array::removeLastObject(bool releaseObj)
void Array::removeObject(Object* object, bool releaseObj /* ignored */) void Array::removeObject(Object* object, bool releaseObj /* ignored */)
{ {
data.erase( std::remove( data.begin(), data.end(), object ) ); data.erase(std::remove(data.begin(), data.end(), object));
} }
void Array::removeObjectAtIndex(long index, bool releaseObj /* ignored */) void Array::removeObjectAtIndex(size_t index, bool releaseObj /* ignored */)
{ {
auto obj = data[index]; auto obj = data[index];
data.erase( data.begin() + index ); data.erase(data.begin() + index);
} }
void Array::removeObjectsInArray(Array* otherArray) void Array::removeObjectsInArray(Array* otherArray)
@ -295,7 +295,7 @@ void Array::removeAllObjects()
data.erase(std::begin(data), std::end(data)); data.erase(std::begin(data), std::end(data));
} }
void Array::fastRemoveObjectAtIndex(long index) void Array::fastRemoveObjectAtIndex(size_t index)
{ {
removeObjectAtIndex(index); removeObjectAtIndex(index);
} }
@ -307,27 +307,27 @@ void Array::fastRemoveObject(Object* object)
void Array::exchangeObject(Object* object1, Object* object2) void Array::exchangeObject(Object* object1, Object* object2)
{ {
int idx1 = getIndexOfObject(object1); auto idx1 = getIndexOfObject(object1);
int idx2 = getIndexOfObject(object2); auto idx2 = getIndexOfObject(object2);
CCASSERT(idx1>=0 && idx2>=2, "invalid object index"); CCASSERT(idx1 >= 0 && idx2 >= 2, "invalid object index");
std::swap( data[idx1], data[idx2] ); std::swap(data[idx1], data[idx2]);
} }
void Array::exchangeObjectAtIndex(long index1, long index2) void Array::exchangeObjectAtIndex(size_t index1, size_t index2)
{ {
std::swap( data[index1], data[index2] ); std::swap(data[index1], data[index2]);
} }
void Array::replaceObjectAtIndex(long index, Object* object, bool releaseObject /* ignored */) void Array::replaceObjectAtIndex(size_t index, Object* object, bool releaseObject /* ignored */)
{ {
data[index] = object; data[index] = object;
} }
void Array::reverseObjects() void Array::reverseObjects()
{ {
std::reverse( std::begin(data), std::end(data) ); std::reverse(std::begin(data), std::end(data));
} }
void Array::reduceMemoryFootprint() void Array::reduceMemoryFootprint()
@ -448,7 +448,7 @@ Array* Array::createWithArray(Array* otherArray)
return otherArray->clone(); return otherArray->clone();
} }
Array* Array::createWithCapacity(long capacity) Array* Array::createWithCapacity(size_t capacity)
{ {
CCASSERT(capacity>=0, "Invalid capacity"); CCASSERT(capacity>=0, "Invalid capacity");
@ -531,7 +531,7 @@ bool Array::initWithObjects(Object* object, ...)
return ret; return ret;
} }
bool Array::initWithCapacity(long capacity) bool Array::initWithCapacity(size_t capacity)
{ {
CCASSERT(capacity>=0 && !data, "Array cannot be re-initialized"); CCASSERT(capacity>=0 && !data, "Array cannot be re-initialized");
@ -555,7 +555,7 @@ bool Array::initWithArray(Array* otherArray)
return ret; return ret;
} }
long Array::getIndexOfObject(Object* object) const size_t Array::getIndexOfObject(Object* object) const
{ {
return ccArrayGetIndexOfObject(data, object); return ccArrayGetIndexOfObject(data, object);
} }
@ -574,7 +574,7 @@ Object* Array::getRandomObject()
r = 0; r = 0;
} }
return data->arr[(long)(data->num * r)]; return data->arr[static_cast<size_t>(data->num * r)];
} }
bool Array::containsObject(Object* object) const bool Array::containsObject(Object* object) const
@ -584,7 +584,7 @@ bool Array::containsObject(Object* object) const
bool Array::isEqualToArray(Array* otherArray) bool Array::isEqualToArray(Array* otherArray)
{ {
for (long i = 0; i< this->count(); i++) for (size_t i = 0; i < this->count(); ++i)
{ {
if (!this->getObjectAtIndex(i)->isEqual(otherArray->getObjectAtIndex(i))) if (!this->getObjectAtIndex(i)->isEqual(otherArray->getObjectAtIndex(i)))
{ {
@ -606,15 +606,15 @@ void Array::addObjectsFromArray(Array* otherArray)
ccArrayAppendArrayWithResize(data, otherArray->data); ccArrayAppendArrayWithResize(data, otherArray->data);
} }
void Array::insertObject(Object* object, long index) void Array::insertObject(Object* object, size_t index)
{ {
CCASSERT(data, "Array not initialized"); CCASSERT(data, "Array not initialized");
ccArrayInsertObjectAtIndex(data, object, index); ccArrayInsertObjectAtIndex(data, object, index);
} }
void Array::setObject(Object* object, long index) void Array::setObject(Object* object, size_t index)
{ {
CCASSERT(index>=0 && index < count(), "Invalid index"); CCASSERT(index >= 0 && index < count(), "Invalid index");
if (object != data->arr[index]) if (object != data->arr[index])
{ {
@ -627,7 +627,7 @@ void Array::setObject(Object* object, long index)
void Array::removeLastObject(bool releaseObj) void Array::removeLastObject(bool releaseObj)
{ {
CCASSERT(data->num, "no objects added"); CCASSERT(data->num, "no objects added");
ccArrayRemoveObjectAtIndex(data, data->num-1, releaseObj); ccArrayRemoveObjectAtIndex(data, data->num - 1, releaseObj);
} }
void Array::removeObject(Object* object, bool releaseObj/* = true*/) void Array::removeObject(Object* object, bool releaseObj/* = true*/)
@ -635,7 +635,7 @@ void Array::removeObject(Object* object, bool releaseObj/* = true*/)
ccArrayRemoveObject(data, object, releaseObj); ccArrayRemoveObject(data, object, releaseObj);
} }
void Array::removeObjectAtIndex(long index, bool releaseObj) void Array::removeObjectAtIndex(size_t index, bool releaseObj)
{ {
ccArrayRemoveObjectAtIndex(data, index, releaseObj); ccArrayRemoveObjectAtIndex(data, index, releaseObj);
} }
@ -650,7 +650,7 @@ void Array::removeAllObjects()
ccArrayRemoveAllObjects(data); ccArrayRemoveAllObjects(data);
} }
void Array::fastRemoveObjectAtIndex(long index) void Array::fastRemoveObjectAtIndex(size_t index)
{ {
ccArrayFastRemoveObjectAtIndex(data, index); ccArrayFastRemoveObjectAtIndex(data, index);
} }
@ -662,13 +662,13 @@ void Array::fastRemoveObject(Object* object)
void Array::exchangeObject(Object* object1, Object* object2) void Array::exchangeObject(Object* object1, Object* object2)
{ {
long index1 = ccArrayGetIndexOfObject(data, object1); auto index1 = ccArrayGetIndexOfObject(data, object1);
if (index1 == CC_INVALID_INDEX) if (index1 == CC_INVALID_INDEX)
{ {
return; return;
} }
long index2 = ccArrayGetIndexOfObject(data, object2); auto index2 = ccArrayGetIndexOfObject(data, object2);
if (index2 == CC_INVALID_INDEX) if (index2 == CC_INVALID_INDEX)
{ {
return; return;
@ -677,15 +677,15 @@ void Array::exchangeObject(Object* object1, Object* object2)
ccArraySwapObjectsAtIndexes(data, index1, index2); ccArraySwapObjectsAtIndexes(data, index1, index2);
} }
void Array::exchangeObjectAtIndex(long index1, long index2) void Array::exchangeObjectAtIndex(size_t index1, size_t index2)
{ {
ccArraySwapObjectsAtIndexes(data, index1, index2); ccArraySwapObjectsAtIndexes(data, index1, index2);
} }
void Array::replaceObjectAtIndex(long index, Object* object, bool releaseObject/* = true*/) void Array::replaceObjectAtIndex(size_t index, Object* object, bool releaseObject/* = true*/)
{ {
ccArrayInsertObjectAtIndex(data, object, index); ccArrayInsertObjectAtIndex(data, object, index);
ccArrayRemoveObjectAtIndex(data, index+1); ccArrayRemoveObjectAtIndex(data, index + 1);
} }
void Array::reverseObjects() void Array::reverseObjects()
@ -693,10 +693,10 @@ void Array::reverseObjects()
if (data->num > 1) if (data->num > 1)
{ {
// floorf(), since in the case of an even number, the number of swaps stays the same // floorf(), since in the case of an even number, the number of swaps stays the same
long count = (long) floorf(data->num/2.f); auto count = static_cast<int>(floorf(data->num/2.f));
long maxIndex = data->num - 1; auto maxIndex = data->num - 1;
for (long i = 0; i < count ; i++) for (int i = 0; i < count ; ++i)
{ {
ccArraySwapObjectsAtIndexes(data, i, maxIndex); ccArraySwapObjectsAtIndexes(data, i, maxIndex);
--maxIndex; --maxIndex;

View File

@ -250,7 +250,7 @@ public:
/** Create an array with a default capacity /** Create an array with a default capacity
* @js NA * @js NA
*/ */
static Array* createWithCapacity(long capacity); static Array* createWithCapacity(size_t capacity);
/** Create an array with from an existing array /** Create an array with from an existing array
* @js NA * @js NA
*/ */
@ -295,7 +295,7 @@ public:
* @js NA * @js NA
* @lua NA * @lua NA
*/ */
bool initWithCapacity(long capacity); bool initWithCapacity(size_t capacity);
/** Initializes an array with an existing array /** Initializes an array with an existing array
* @js NA * @js NA
* @lua NA * @lua NA
@ -307,7 +307,7 @@ public:
/** Returns element count of the array /** Returns element count of the array
* @js NA * @js NA
*/ */
long count() const size_t count() const
{ {
#if CC_USE_ARRAY_VECTOR #if CC_USE_ARRAY_VECTOR
return data.size(); return data.size();
@ -318,7 +318,7 @@ public:
/** Returns capacity of the array /** Returns capacity of the array
* @js NA * @js NA
*/ */
long capacity() const size_t capacity() const
{ {
#if CC_USE_ARRAY_VECTOR #if CC_USE_ARRAY_VECTOR
return data.capacity(); return data.capacity();
@ -330,17 +330,17 @@ public:
* @js NA * @js NA
* @lua NA * @lua NA
*/ */
long getIndexOfObject(Object* object) const; size_t getIndexOfObject(Object* object) const;
/** /**
* @js NA * @js NA
*/ */
CC_DEPRECATED_ATTRIBUTE long indexOfObject(Object* object) const { return getIndexOfObject(object); } CC_DEPRECATED_ATTRIBUTE size_t indexOfObject(Object* object) const { return getIndexOfObject(object); }
/** Returns an element with a certain index /** Returns an element with a certain index
* @js NA * @js NA
* @lua NA * @lua NA
*/ */
Object* getObjectAtIndex(long index) Object* getObjectAtIndex(size_t index)
{ {
CCASSERT(index>=0 && index < count(), "index out of range in getObjectAtIndex()"); CCASSERT(index>=0 && index < count(), "index out of range in getObjectAtIndex()");
#if CC_USE_ARRAY_VECTOR #if CC_USE_ARRAY_VECTOR
@ -349,7 +349,7 @@ public:
return data->arr[index]; return data->arr[index];
#endif #endif
} }
CC_DEPRECATED_ATTRIBUTE Object* objectAtIndex(long index) { return getObjectAtIndex(index); } CC_DEPRECATED_ATTRIBUTE Object* objectAtIndex(size_t index) { return getObjectAtIndex(index); }
/** Returns the last element of the array /** Returns the last element of the array
* @js NA * @js NA
*/ */
@ -401,17 +401,17 @@ public:
/** Insert a certain object at a certain index /** Insert a certain object at a certain index
* @js NA * @js NA
*/ */
void insertObject(Object* object, long index); void insertObject(Object* object, size_t index);
/** sets a certain object at a certain index /** sets a certain object at a certain index
* @js NA * @js NA
* @lua NA * @lua NA
*/ */
void setObject(Object* object, long index); void setObject(Object* object, size_t index);
/** sets a certain object at a certain index without retaining. Use it with caution /** sets a certain object at a certain index without retaining. Use it with caution
* @js NA * @js NA
* @lua NA * @lua NA
*/ */
void fastSetObject(Object* object, long index) void fastSetObject(Object* object, size_t index)
{ {
#if CC_USE_ARRAY_VECTOR #if CC_USE_ARRAY_VECTOR
setObject(object, index); setObject(object, index);
@ -424,7 +424,7 @@ public:
* @js NA * @js NA
* @lua NA * @lua NA
*/ */
void swap( long indexOne, long indexTwo ) void swap( size_t indexOne, size_t indexTwo )
{ {
CCASSERT(indexOne >=0 && indexOne < count() && indexTwo >= 0 && indexTwo < count(), "Invalid indices"); CCASSERT(indexOne >=0 && indexOne < count() && indexTwo >= 0 && indexTwo < count(), "Invalid indices");
#if CC_USE_ARRAY_VECTOR #if CC_USE_ARRAY_VECTOR
@ -447,7 +447,7 @@ public:
/** Remove an element with a certain index /** Remove an element with a certain index
* @js NA * @js NA
*/ */
void removeObjectAtIndex(long index, bool releaseObj = true); void removeObjectAtIndex(size_t index, bool releaseObj = true);
/** Remove all elements /** Remove all elements
* @js NA * @js NA
*/ */
@ -463,7 +463,7 @@ public:
/** Fast way to remove an element with a certain index /** Fast way to remove an element with a certain index
* @js NA * @js NA
*/ */
void fastRemoveObjectAtIndex(long index); void fastRemoveObjectAtIndex(size_t index);
// Rearranging Content // Rearranging Content
@ -474,12 +474,12 @@ public:
/** Swap two elements with certain indexes /** Swap two elements with certain indexes
* @js NA * @js NA
*/ */
void exchangeObjectAtIndex(long index1, long index2); void exchangeObjectAtIndex(size_t index1, size_t index2);
/** Replace object at index with another object. /** Replace object at index with another object.
* @js NA * @js NA
*/ */
void replaceObjectAtIndex(long index, Object* object, bool releaseObject = true); void replaceObjectAtIndex(size_t index, Object* object, bool releaseObject = true);
/** Revers the array /** Revers the array
* @js NA * @js NA

View File

@ -237,14 +237,14 @@ public: virtual void set##funName(varType var) \
// A macro to disallow the copy constructor and operator= functions // A macro to disallow the copy constructor and operator= functions
// This should be used in the private: declarations for a class // This should be used in the private: declarations for a class
#if defined(__GNUC__) && ((__GNUC__ >= 5) || ((__GNUG__ == 4) && (__GNUC_MINOR__ >= 4))) \ #if defined(__GNUC__) && ((__GNUC__ >= 5) || ((__GNUG__ == 4) && (__GNUC_MINOR__ >= 4))) \
|| (defined(__clang__) && (__clang_major__ >= 3)) || (defined(__clang__) && (__clang_major__ >= 3)) || (_MSC_VER >= 1800)
#define CC_DISALLOW_COPY_AND_ASSIGN(TypeName) \ #define CC_DISALLOW_COPY_AND_ASSIGN(TypeName) \
TypeName(const TypeName &) = delete; \ TypeName(const TypeName &) = delete; \
TypeName &operator =(const TypeName &) = delete; TypeName &operator =(const TypeName &) = delete;
#else #else
#define CC_DISALLOW_COPY_AND_ASSIGN(TypeName) \ #define CC_DISALLOW_COPY_AND_ASSIGN(TypeName) \
Class(const TypeName &); \ TypeName(const TypeName &); \
Class &operator =(const TypeName &); TypeName &operator =(const TypeName &);
#endif #endif
// A macro to disallow all the implicit constructors, namely the // A macro to disallow all the implicit constructors, namely the

View File

@ -367,7 +367,7 @@ void SIOClientImpl::onOpen(WebSocket* ws)
c->onOpen(); c->onOpen();
} }
Director::getInstance()->getScheduler()->scheduleSelector(schedule_selector(SIOClientImpl::heartbeat), this, (_heartbeat * .9), false); Director::getInstance()->getScheduler()->scheduleSelector(schedule_selector(SIOClientImpl::heartbeat), this, (_heartbeat * .9f), false);
log("SIOClientImpl::onOpen socket connected!"); log("SIOClientImpl::onOpen socket connected!");
} }

View File

@ -26,6 +26,7 @@
#include <climits> #include <climits>
#include <algorithm> #include <algorithm>
#include <cmath>
#include "chipmunk.h" #include "chipmunk.h"
@ -348,7 +349,7 @@ void PhysicsBody::setPosition(Point position)
void PhysicsBody::setRotation(float rotation) void PhysicsBody::setRotation(float rotation)
{ {
cpBodySetAngle(_info->getBody(), PhysicsHelper::float2cpfloat(rotation)); cpBodySetAngle(_info->getBody(), PhysicsHelper::float2cpfloat(rotation * M_PI / 180.0f));
} }
Point PhysicsBody::getPosition() const Point PhysicsBody::getPosition() const
@ -359,7 +360,7 @@ Point PhysicsBody::getPosition() const
float PhysicsBody::getRotation() const float PhysicsBody::getRotation() const
{ {
return -PhysicsHelper::cpfloat2float(cpBodyGetAngle(_info->getBody()) / 3.14f * 180.0f); return -PhysicsHelper::cpfloat2float(cpBodyGetAngle(_info->getBody()) / M_PI * 180.0f);
} }
PhysicsShape* PhysicsBody::addShape(PhysicsShape* shape, bool addMassAndMoment/* = true*/) PhysicsShape* PhysicsBody::addShape(PhysicsShape* shape, bool addMassAndMoment/* = true*/)

View File

@ -97,46 +97,6 @@ void PhysicsJoint::setEnable(bool enable)
} }
} }
PhysicsJointPin::PhysicsJointPin()
{
}
PhysicsJointPin::~PhysicsJointPin()
{
}
PhysicsJointFixed::PhysicsJointFixed()
{
}
PhysicsJointFixed::~PhysicsJointFixed()
{
}
PhysicsJointLimit::PhysicsJointLimit()
{
}
PhysicsJointLimit::~PhysicsJointLimit()
{
}
PhysicsJointDistance::PhysicsJointDistance()
{
}
PhysicsJointDistance::~PhysicsJointDistance()
{
}
PhysicsBodyInfo* PhysicsJoint::getBodyInfo(PhysicsBody* body) const PhysicsBodyInfo* PhysicsJoint::getBodyInfo(PhysicsBody* body) const
{ {
return body->_info; return body->_info;
@ -147,7 +107,6 @@ Node* PhysicsJoint::getBodyNode(PhysicsBody* body) const
return body->_node; return body->_node;
} }
void PhysicsJoint::setCollisionEnable(bool enable) void PhysicsJoint::setCollisionEnable(bool enable)
{ {
if (_collisionEnable != enable) if (_collisionEnable != enable)
@ -190,6 +149,19 @@ void PhysicsJoint::destroy(PhysicsJoint* joint)
} }
} }
void PhysicsJoint::setMaxForce(float force)
{
for (cpConstraint* joint : _info->getJoints())
{
joint->maxForce = PhysicsHelper::float2cpfloat(force);
}
}
float PhysicsJoint::getMaxForce() const
{
return PhysicsHelper::cpfloat2float(_info->getJoints().front()->maxForce);
}
PhysicsJointFixed* PhysicsJointFixed::construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr) PhysicsJointFixed* PhysicsJointFixed::construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr)
{ {
PhysicsJointFixed* joint = new PhysicsJointFixed(); PhysicsJointFixed* joint = new PhysicsJointFixed();
@ -262,21 +234,11 @@ bool PhysicsJointPin::init(PhysicsBody *a, PhysicsBody *b, const Point& anchr)
return false; return false;
} }
void PhysicsJointPin::setMaxForce(float force) PhysicsJointLimit* PhysicsJointLimit::construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2, float min, float max)
{
_info->getJoints().front()->maxForce = PhysicsHelper::float2cpfloat(force);
}
float PhysicsJointPin::getMaxForce() const
{
return PhysicsHelper::cpfloat2float(_info->getJoints().front()->maxForce);
}
PhysicsJointLimit* PhysicsJointLimit::construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2)
{ {
PhysicsJointLimit* joint = new PhysicsJointLimit(); PhysicsJointLimit* joint = new PhysicsJointLimit();
if (joint && joint->init(a, b, anchr1, anchr2)) if (joint && joint->init(a, b, anchr1, anchr2, min, max))
{ {
return joint; return joint;
} }
@ -285,7 +247,12 @@ PhysicsJointLimit* PhysicsJointLimit::construct(PhysicsBody* a, PhysicsBody* b,
return nullptr; return nullptr;
} }
bool PhysicsJointLimit::init(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2) PhysicsJointLimit* PhysicsJointLimit::construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2)
{
return construct(a, b, anchr1, anchr2, 0, b->local2World(anchr1).getDistance(a->local2World(anchr2)));
}
bool PhysicsJointLimit::init(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2, float min, float max)
{ {
do do
{ {
@ -294,8 +261,8 @@ bool PhysicsJointLimit::init(PhysicsBody* a, PhysicsBody* b, const Point& anchr1
cpConstraint* joint = cpSlideJointNew(getBodyInfo(a)->getBody(), getBodyInfo(b)->getBody(), cpConstraint* joint = cpSlideJointNew(getBodyInfo(a)->getBody(), getBodyInfo(b)->getBody(),
PhysicsHelper::point2cpv(anchr1), PhysicsHelper::point2cpv(anchr1),
PhysicsHelper::point2cpv(anchr2), PhysicsHelper::point2cpv(anchr2),
0, PhysicsHelper::float2cpfloat(min),
PhysicsHelper::float2cpfloat(_bodyA->local2World(anchr1).getDistance(_bodyB->local2World(anchr2)))); PhysicsHelper::float2cpfloat(max));
CC_BREAK_IF(joint == nullptr); CC_BREAK_IF(joint == nullptr);
@ -327,6 +294,26 @@ void PhysicsJointLimit::setMax(float max)
cpSlideJointSetMax(_info->getJoints().front(), PhysicsHelper::float2cpfloat(max)); cpSlideJointSetMax(_info->getJoints().front(), PhysicsHelper::float2cpfloat(max));
} }
Point PhysicsJointLimit::getAnchr1() const
{
return PhysicsHelper::cpv2point(cpSlideJointGetAnchr1(_info->getJoints().front()));
}
void PhysicsJointLimit::setAnchr1(const Point& anchr)
{
cpSlideJointSetAnchr1(_info->getJoints().front(), PhysicsHelper::point2cpv(anchr));
}
Point PhysicsJointLimit::getAnchr2() const
{
return PhysicsHelper::cpv2point(cpSlideJointGetAnchr2(_info->getJoints().front()));
}
void PhysicsJointLimit::setAnchr2(const Point& anchr)
{
cpSlideJointSetAnchr1(_info->getJoints().front(), PhysicsHelper::point2cpv(anchr));
}
PhysicsJointDistance* PhysicsJointDistance::construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2) PhysicsJointDistance* PhysicsJointDistance::construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2)
{ {
PhysicsJointDistance* joint = new PhysicsJointDistance(); PhysicsJointDistance* joint = new PhysicsJointDistance();
@ -361,5 +348,449 @@ bool PhysicsJointDistance::init(PhysicsBody* a, PhysicsBody* b, const Point& anc
return false; return false;
} }
float PhysicsJointDistance::getDistance() const
{
return PhysicsHelper::cpfloat2float(cpPinJointGetDist(_info->getJoints().front()));
}
void PhysicsJointDistance::setDistance(float distance)
{
cpPinJointSetDist(_info->getJoints().front(), PhysicsHelper::float2cpfloat(distance));
}
PhysicsJointSpring* PhysicsJointSpring::construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2, float stiffness, float damping)
{
PhysicsJointSpring* joint = new PhysicsJointSpring();
if (joint && joint->init(a, b, anchr1, anchr2, stiffness, damping))
{
return joint;
}
CC_SAFE_DELETE(joint);
return nullptr;
}
bool PhysicsJointSpring::init(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2, float stiffness, float damping)
{
do {
CC_BREAK_IF(!PhysicsJoint::init(a, b));
cpConstraint* joint = cpDampedSpringNew(getBodyInfo(a)->getBody(),
getBodyInfo(b)->getBody(),
PhysicsHelper::point2cpv(anchr1),
PhysicsHelper::point2cpv(anchr2),
PhysicsHelper::float2cpfloat(_bodyB->local2World(anchr1).getDistance(_bodyA->local2World(anchr2))),
PhysicsHelper::float2cpfloat(stiffness),
PhysicsHelper::float2cpfloat(damping));
CC_BREAK_IF(joint == nullptr);
_info->add(joint);
return true;
} while (false);
return false;
}
Point PhysicsJointSpring::getAnchr1() const
{
return PhysicsHelper::cpv2point(cpDampedSpringGetAnchr1(_info->getJoints().front()));
}
void PhysicsJointSpring::setAnchr1(const Point& anchr)
{
cpDampedSpringSetAnchr1(_info->getJoints().front(), PhysicsHelper::point2cpv(anchr));
}
Point PhysicsJointSpring::getAnchr2() const
{
return PhysicsHelper::cpv2point(cpDampedSpringGetAnchr2(_info->getJoints().front()));
}
void PhysicsJointSpring::setAnchr2(const Point& anchr)
{
cpDampedSpringSetAnchr1(_info->getJoints().front(), PhysicsHelper::point2cpv(anchr));
}
float PhysicsJointSpring::getRestLength() const
{
return PhysicsHelper::cpfloat2float(cpDampedSpringGetRestLength(_info->getJoints().front()));
}
void PhysicsJointSpring::setRestLength(float restLength)
{
cpDampedSpringSetRestLength(_info->getJoints().front(), PhysicsHelper::float2cpfloat(restLength));
}
float PhysicsJointSpring::getStiffness() const
{
return PhysicsHelper::cpfloat2float(cpDampedSpringGetStiffness(_info->getJoints().front()));
}
void PhysicsJointSpring::setStiffness(float stiffness)
{
cpDampedSpringSetStiffness(_info->getJoints().front(), PhysicsHelper::float2cpfloat(stiffness));
}
float PhysicsJointSpring::getDamping() const
{
return PhysicsHelper::cpfloat2float(cpDampedSpringGetDamping(_info->getJoints().front()));
}
void PhysicsJointSpring::setDamping(float damping)
{
cpDampedSpringSetDamping(_info->getJoints().front(), PhysicsHelper::float2cpfloat(damping));
}
PhysicsJointGroove* PhysicsJointGroove::construct(PhysicsBody* a, PhysicsBody* b, const Point& grooveA, const Point& grooveB, const Point& anchr2)
{
PhysicsJointGroove* joint = new PhysicsJointGroove();
if (joint && joint->init(a, b, grooveA, grooveB, anchr2))
{
return joint;
}
CC_SAFE_DELETE(joint);
return nullptr;
}
bool PhysicsJointGroove::init(PhysicsBody* a, PhysicsBody* b, const Point& grooveA, const Point& grooveB, const Point& anchr2)
{
do {
CC_BREAK_IF(!PhysicsJoint::init(a, b));
cpConstraint* joint = cpGrooveJointNew(getBodyInfo(a)->getBody(),
getBodyInfo(b)->getBody(),
PhysicsHelper::point2cpv(grooveA),
PhysicsHelper::point2cpv(grooveB),
PhysicsHelper::point2cpv(anchr2));
CC_BREAK_IF(joint == nullptr);
_info->add(joint);
return true;
} while (false);
return false;
}
Point PhysicsJointGroove::getGrooveA() const
{
return PhysicsHelper::cpv2point(cpGrooveJointGetGrooveA(_info->getJoints().front()));
}
void PhysicsJointGroove::setGrooveA(const Point& grooveA)
{
cpGrooveJointSetGrooveA(_info->getJoints().front(), PhysicsHelper::point2cpv(grooveA));
}
Point PhysicsJointGroove::getGrooveB() const
{
return PhysicsHelper::cpv2point(cpGrooveJointGetGrooveB(_info->getJoints().front()));
}
void PhysicsJointGroove::setGrooveB(const Point& grooveB)
{
cpGrooveJointSetGrooveB(_info->getJoints().front(), PhysicsHelper::point2cpv(grooveB));
}
Point PhysicsJointGroove::getAnchr2() const
{
return PhysicsHelper::cpv2point(cpGrooveJointGetAnchr2(_info->getJoints().front()));
}
void PhysicsJointGroove::setAnchr2(const Point& anchr2)
{
cpGrooveJointSetAnchr2(_info->getJoints().front(), PhysicsHelper::point2cpv(anchr2));
}
PhysicsJointRotarySpring* PhysicsJointRotarySpring::construct(PhysicsBody* a, PhysicsBody* b, float stiffness, float damping)
{
PhysicsJointRotarySpring* joint = new PhysicsJointRotarySpring();
if (joint && joint->init(a, b, stiffness, damping))
{
return joint;
}
CC_SAFE_DELETE(joint);
return nullptr;
}
bool PhysicsJointRotarySpring::init(PhysicsBody* a, PhysicsBody* b, float stiffness, float damping)
{
do {
CC_BREAK_IF(!PhysicsJoint::init(a, b));
cpConstraint* joint = cpDampedRotarySpringNew(getBodyInfo(a)->getBody(),
getBodyInfo(b)->getBody(),
PhysicsHelper::float2cpfloat(_bodyB->getRotation() - _bodyA->getRotation()),
PhysicsHelper::float2cpfloat(stiffness),
PhysicsHelper::float2cpfloat(damping));
CC_BREAK_IF(joint == nullptr);
_info->add(joint);
return true;
} while (false);
return false;
}
float PhysicsJointRotarySpring::getRestAngle() const
{
return PhysicsHelper::cpfloat2float(cpDampedRotarySpringGetRestAngle(_info->getJoints().front()));
}
void PhysicsJointRotarySpring::setRestAngle(float restAngle)
{
cpDampedRotarySpringSetRestAngle(_info->getJoints().front(), PhysicsHelper::float2cpfloat(restAngle));
}
float PhysicsJointRotarySpring::getStiffness() const
{
return PhysicsHelper::cpfloat2float(cpDampedRotarySpringGetStiffness(_info->getJoints().front()));
}
void PhysicsJointRotarySpring::setStiffness(float stiffness)
{
cpDampedRotarySpringSetStiffness(_info->getJoints().front(), PhysicsHelper::float2cpfloat(stiffness));
}
float PhysicsJointRotarySpring::getDamping() const
{
return PhysicsHelper::cpfloat2float(cpDampedRotarySpringGetDamping(_info->getJoints().front()));
}
void PhysicsJointRotarySpring::setDamping(float damping)
{
cpDampedRotarySpringSetDamping(_info->getJoints().front(), PhysicsHelper::float2cpfloat(damping));
}
PhysicsJointRotaryLimit* PhysicsJointRotaryLimit::construct(PhysicsBody* a, PhysicsBody* b, float min, float max)
{
PhysicsJointRotaryLimit* joint = new PhysicsJointRotaryLimit();
if (joint && joint->init(a, b, min, max))
{
return joint;
}
CC_SAFE_DELETE(joint);
return nullptr;
}
PhysicsJointRotaryLimit* PhysicsJointRotaryLimit::construct(PhysicsBody* a, PhysicsBody* b)
{
return construct(a, b, 0.0f, 0.0f);
}
bool PhysicsJointRotaryLimit::init(PhysicsBody* a, PhysicsBody* b, float min, float max)
{
do
{
CC_BREAK_IF(!PhysicsJoint::init(a, b));
cpConstraint* joint = cpRotaryLimitJointNew(getBodyInfo(a)->getBody(),
getBodyInfo(b)->getBody(),
PhysicsHelper::float2cpfloat(min),
PhysicsHelper::float2cpfloat(max));
CC_BREAK_IF(joint == nullptr);
_info->add(joint);
return true;
} while (false);
return false;
}
float PhysicsJointRotaryLimit::getMin() const
{
return PhysicsHelper::cpfloat2float(cpRotaryLimitJointGetMin(_info->getJoints().front()));
}
void PhysicsJointRotaryLimit::setMin(float min)
{
cpRotaryLimitJointSetMin(_info->getJoints().front(), PhysicsHelper::float2cpfloat(min));
}
float PhysicsJointRotaryLimit::getMax() const
{
return PhysicsHelper::cpfloat2float(cpRotaryLimitJointGetMax(_info->getJoints().front()));
}
void PhysicsJointRotaryLimit::setMax(float max)
{
cpRotaryLimitJointSetMax(_info->getJoints().front(), PhysicsHelper::float2cpfloat(max));
}
PhysicsJointRatchet* PhysicsJointRatchet::construct(PhysicsBody* a, PhysicsBody* b, float phase, float ratchet)
{
PhysicsJointRatchet* joint = new PhysicsJointRatchet();
if (joint && joint->init(a, b, phase, ratchet))
{
return joint;
}
CC_SAFE_DELETE(joint);
return nullptr;
}
bool PhysicsJointRatchet::init(PhysicsBody* a, PhysicsBody* b, float phase, float ratchet)
{
do
{
CC_BREAK_IF(!PhysicsJoint::init(a, b));
cpConstraint* joint = cpRatchetJointNew(getBodyInfo(a)->getBody(),
getBodyInfo(b)->getBody(),
PhysicsHelper::float2cpfloat(phase),
PhysicsHelper::cpfloat2float(ratchet));
CC_BREAK_IF(joint == nullptr);
_info->add(joint);
return true;
} while (false);
return false;
}
float PhysicsJointRatchet::getAngle() const
{
return PhysicsHelper::cpfloat2float(cpRatchetJointGetAngle(_info->getJoints().front()));
}
void PhysicsJointRatchet::setAngle(float angle)
{
cpRatchetJointSetAngle(_info->getJoints().front(), PhysicsHelper::float2cpfloat(angle));
}
float PhysicsJointRatchet::getPhase() const
{
return PhysicsHelper::cpfloat2float(cpRatchetJointGetPhase(_info->getJoints().front()));
}
void PhysicsJointRatchet::setPhase(float phase)
{
cpRatchetJointSetPhase(_info->getJoints().front(), PhysicsHelper::float2cpfloat(phase));
}
float PhysicsJointRatchet::getRatchet() const
{
return PhysicsHelper::cpfloat2float(cpRatchetJointGetRatchet(_info->getJoints().front()));
}
void PhysicsJointRatchet::setRatchet(float ratchet)
{
cpRatchetJointSetRatchet(_info->getJoints().front(), PhysicsHelper::float2cpfloat(ratchet));
}
PhysicsJointGear* PhysicsJointGear::construct(PhysicsBody* a, PhysicsBody* b, float phase, float ratchet)
{
PhysicsJointGear* joint = new PhysicsJointGear();
if (joint && joint->init(a, b, phase, ratchet))
{
return joint;
}
CC_SAFE_DELETE(joint);
return nullptr;
}
bool PhysicsJointGear::init(PhysicsBody* a, PhysicsBody* b, float phase, float ratio)
{
do
{
CC_BREAK_IF(!PhysicsJoint::init(a, b));
cpConstraint* joint = cpGearJointNew(getBodyInfo(a)->getBody(),
getBodyInfo(b)->getBody(),
PhysicsHelper::float2cpfloat(phase),
PhysicsHelper::float2cpfloat(ratio));
CC_BREAK_IF(joint == nullptr);
_info->add(joint);
return true;
} while (false);
return false;
}
float PhysicsJointGear::getPhase() const
{
return PhysicsHelper::cpfloat2float(cpGearJointGetPhase(_info->getJoints().front()));
}
void PhysicsJointGear::setPhase(float phase)
{
cpGearJointSetPhase(_info->getJoints().front(), PhysicsHelper::float2cpfloat(phase));
}
float PhysicsJointGear::getRatio() const
{
return PhysicsHelper::cpfloat2float(cpGearJointGetRatio(_info->getJoints().front()));
}
void PhysicsJointGear::setRatio(float ratio)
{
cpGearJointSetRatio(_info->getJoints().front(), PhysicsHelper::float2cpfloat(ratio));
}
PhysicsJointMotor* PhysicsJointMotor::construct(PhysicsBody* a, PhysicsBody* b, float rate)
{
PhysicsJointMotor* joint = new PhysicsJointMotor();
if (joint && joint->init(a, b, rate))
{
return joint;
}
CC_SAFE_DELETE(joint);
return nullptr;
}
bool PhysicsJointMotor::init(PhysicsBody* a, PhysicsBody* b, float rate)
{
do
{
CC_BREAK_IF(!PhysicsJoint::init(a, b));
cpConstraint* joint = cpSimpleMotorNew(getBodyInfo(a)->getBody(),
getBodyInfo(b)->getBody(),
PhysicsHelper::float2cpfloat(rate));
CC_BREAK_IF(joint == nullptr);
_info->add(joint);
return true;
} while (false);
return false;
}
float PhysicsJointMotor::getRate() const
{
return PhysicsHelper::cpfloat2float(cpSimpleMotorGetRate(_info->getJoints().front()));
}
void PhysicsJointMotor::setRate(float rate)
{
cpSimpleMotorSetRate(_info->getJoints().front(), PhysicsHelper::float2cpfloat(rate));
}
NS_CC_END NS_CC_END
#endif // CC_USE_PHYSICS #endif // CC_USE_PHYSICS

View File

@ -59,6 +59,9 @@ public:
void removeFormWorld(); void removeFormWorld();
static void destroy(PhysicsJoint* joint); static void destroy(PhysicsJoint* joint);
void setMaxForce(float force);
float getMaxForce() const;
protected: protected:
bool init(PhysicsBody* a, PhysicsBody* b); bool init(PhysicsBody* a, PhysicsBody* b);
@ -95,8 +98,8 @@ protected:
bool init(PhysicsBody* a, PhysicsBody* b, const Point& anchr); bool init(PhysicsBody* a, PhysicsBody* b, const Point& anchr);
protected: protected:
PhysicsJointFixed(); PhysicsJointFixed() {}
virtual ~PhysicsJointFixed(); virtual ~PhysicsJointFixed() {}
}; };
/* /*
@ -106,18 +109,23 @@ class PhysicsJointLimit : public PhysicsJoint
{ {
public: public:
static PhysicsJointLimit* construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2); static PhysicsJointLimit* construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2);
static PhysicsJointLimit* construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2, float min, float max);
Point getAnchr1() const;
void setAnchr1(const Point& anchr1);
Point getAnchr2() const;
void setAnchr2(const Point& anchr2);
float getMin() const; float getMin() const;
void setMin(float min); void setMin(float min);
float getMax() const; float getMax() const;
void setMax(float max); void setMax(float max);
protected: protected:
bool init(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2); bool init(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2, float min, float max);
protected: protected:
PhysicsJointLimit(); PhysicsJointLimit() {}
virtual ~PhysicsJointLimit(); virtual ~PhysicsJointLimit() {}
}; };
/* /*
@ -128,15 +136,12 @@ class PhysicsJointPin : public PhysicsJoint
public: public:
static PhysicsJointPin* construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr); static PhysicsJointPin* construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr);
void setMaxForce(float force);
float getMaxForce() const;
protected: protected:
bool init(PhysicsBody* a, PhysicsBody* b, const Point& anchr); bool init(PhysicsBody* a, PhysicsBody* b, const Point& anchr);
protected: protected:
PhysicsJointPin(); PhysicsJointPin() {}
virtual ~PhysicsJointPin(); virtual ~PhysicsJointPin() {}
}; };
class PhysicsJointDistance : public PhysicsJoint class PhysicsJointDistance : public PhysicsJoint
@ -144,12 +149,151 @@ class PhysicsJointDistance : public PhysicsJoint
public: public:
static PhysicsJointDistance* construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2); static PhysicsJointDistance* construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2);
float getDistance() const;
void setDistance(float distance);
protected: protected:
bool init(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2); bool init(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2);
protected: protected:
PhysicsJointDistance(); PhysicsJointDistance() {}
virtual ~PhysicsJointDistance(); virtual ~PhysicsJointDistance() {}
};
class PhysicsJointSpring : public PhysicsJoint
{
public:
static PhysicsJointSpring* construct(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2, float stiffness, float damping);
Point getAnchr1() const;
void setAnchr1(const Point& anchr1);
Point getAnchr2() const;
void setAnchr2(const Point& anchr2);
float getRestLength() const;
void setRestLength(float restLength);
float getStiffness() const;
void setStiffness(float stiffness);
float getDamping() const;
void setDamping(float damping);
protected:
bool init(PhysicsBody* a, PhysicsBody* b, const Point& anchr1, const Point& anchr2, float stiffness, float damping);
protected:
PhysicsJointSpring() {}
virtual ~PhysicsJointSpring() {}
};
class PhysicsJointGroove : public PhysicsJoint
{
public:
static PhysicsJointGroove* construct(PhysicsBody* a, PhysicsBody* b, const Point& grooveA, const Point& grooveB, const Point& anchr2);
Point getGrooveA() const;
void setGrooveA(const Point& grooveA);
Point getGrooveB() const;
void setGrooveB(const Point& grooveB);
Point getAnchr2() const;
void setAnchr2(const Point& anchr2);
protected:
bool init(PhysicsBody* a, PhysicsBody* b, const Point& grooveA, const Point& grooveB, const Point& anchr);
protected:
PhysicsJointGroove() {}
virtual ~PhysicsJointGroove() {}
};
class PhysicsJointRotarySpring : public PhysicsJoint
{
public:
static PhysicsJointRotarySpring* construct(PhysicsBody* a, PhysicsBody* b, float stiffness, float damping);
float getRestAngle() const;
void setRestAngle(float restAngle);
float getStiffness() const;
void setStiffness(float stiffness);
float getDamping() const;
void setDamping(float damping);
protected:
bool init(PhysicsBody* a, PhysicsBody* b, float stiffness, float damping);
protected:
PhysicsJointRotarySpring() {}
virtual ~PhysicsJointRotarySpring() {}
};
class PhysicsJointRotaryLimit : public PhysicsJoint
{
public:
static PhysicsJointRotaryLimit* construct(PhysicsBody* a, PhysicsBody* b, float min, float max);
static PhysicsJointRotaryLimit* construct(PhysicsBody* a, PhysicsBody* b);
float getMin() const;
void setMin(float min);
float getMax() const;
void setMax(float max);
protected:
bool init(PhysicsBody* a, PhysicsBody* b, float min, float max);
protected:
PhysicsJointRotaryLimit() {}
virtual ~PhysicsJointRotaryLimit() {}
};
class PhysicsJointRatchet : public PhysicsJoint
{
public:
static PhysicsJointRatchet* construct(PhysicsBody* a, PhysicsBody* b, float phase, float ratchet);
float getAngle() const;
void setAngle(float angle);
float getPhase() const;
void setPhase(float phase);
float getRatchet() const;
void setRatchet(float ratchet);
protected:
bool init(PhysicsBody* a, PhysicsBody* b, float phase, float ratchet);
protected:
PhysicsJointRatchet() {}
virtual ~PhysicsJointRatchet() {}
};
class PhysicsJointGear : public PhysicsJoint
{
public:
static PhysicsJointGear* construct(PhysicsBody* a, PhysicsBody* b, float phase, float ratio);
float getPhase() const;
void setPhase(float phase);
float getRatio() const;
void setRatio(float ratchet);
protected:
bool init(PhysicsBody* a, PhysicsBody* b, float phase, float ratio);
protected:
PhysicsJointGear() {}
virtual ~PhysicsJointGear() {}
};
class PhysicsJointMotor : public PhysicsJoint
{
public:
static PhysicsJointMotor* construct(PhysicsBody* a, PhysicsBody* b, float rate);
float getRate() const;
void setRate(float rate);
protected:
bool init(PhysicsBody* a, PhysicsBody* b, float rate);
protected:
PhysicsJointMotor() {}
virtual ~PhysicsJointMotor() {}
}; };
NS_CC_END NS_CC_END

View File

@ -519,6 +519,19 @@ void PhysicsDebugDraw::drawJoint(PhysicsJoint& joint)
_drawNode->drawSegment(PhysicsHelper::cpv2point(a), PhysicsHelper::cpv2point(b), 1, Color4F(0.0f, 0.0f, 1.0f, 1.0f)); _drawNode->drawSegment(PhysicsHelper::cpv2point(a), PhysicsHelper::cpv2point(b), 1, Color4F(0.0f, 0.0f, 1.0f, 1.0f));
_drawNode->drawDot(PhysicsHelper::cpv2point(c), 2, Color4F(0.0f, 1.0f, 0.0f, 1.0f)); _drawNode->drawDot(PhysicsHelper::cpv2point(c), 2, Color4F(0.0f, 1.0f, 0.0f, 1.0f));
} }
else if(klass == cpDampedSpringGetClass())
{
cpDampedSpring *subJoint = (cpDampedSpring *)constraint;
cpVect a = cpvadd(body_a->p, cpvrotate(subJoint->anchr1, body_a->rot));
cpVect b = cpvadd(body_b->p, cpvrotate(subJoint->anchr2, body_b->rot));
_drawNode->drawSegment(PhysicsHelper::cpv2point(a), PhysicsHelper::cpv2point(b), 1, Color4F(0.0f, 0.0f, 1.0f, 1.0f));
_drawNode->drawDot(PhysicsHelper::cpv2point(a), 2, Color4F(0.0f, 1.0f, 0.0f, 1.0f));
_drawNode->drawDot(PhysicsHelper::cpv2point(b), 2, Color4F(0.0f, 1.0f, 0.0f, 1.0f));
}
} }
} }

File diff suppressed because it is too large Load Diff

View File

@ -1 +0,0 @@
e70a68a07977b12b3f233641ac8d558e48c5517c

View File

@ -112,3 +112,10 @@ function CCBReaderLoad(strFilePath,proxy,owner)
return node return node
end end
local function CCBuilderReaderLoad(strFilePath,proxy,owner)
print("\n********** \n".."CCBuilderReaderLoad(strFilePath,proxy,owner)".." was deprecated please use ".. "CCBReaderLoad(strFilePath,proxy,owner)" .. " instead.\n**********")
return CCBReaderLoad(strFilePath,proxy,owner)
end
rawset(_G,"CCBuilderReaderLoad",CCBuilderReaderLoad)

View File

@ -291,4 +291,72 @@ function cc.c4f( _r,_g,_b,_a )
return { r = _r, g = _g, b = _b, a = _a } return { r = _r, g = _g, b = _b, a = _a }
end end
--Vertex2F
function cc.vertex2F(_x,_y)
return { x = _x, y = _y }
end
--Vertex3F
function cc.Vertex3F(_x,_y,_z)
return { x = _x, y = _y, z = _z }
end
--Tex2F
function cc.tex2F(_u,_v)
return { u = _u, v = _v }
end
--PointSprite
function cc.PointSprite(_pos,_color,_size)
return { pos = _pos, color = _color, size = _size }
end
--Quad2
function cc.Quad2(_tl,_tr,_bl,_br)
return { tl = _tl, tr = _tr, bl = _bl, br = _br }
end
--Quad3
function cc.Quad3(_tl, _tr, _bl, _br)
return { tl = _tl, tr = _tr, bl = _bl, br = _br }
end
--V2F_C4B_T2F
function cc.V2F_C4B_T2F(_vertices, _colors, _texCoords)
return { vertices = _vertices, colors = _colors, texCoords = _texCoords }
end
--V2F_C4F_T2F
function cc.V2F_C4F_T2F(_vertices, _colors, _texCoords)
return { vertices = _vertices, colors = _colors, texCoords = _texCoords }
end
--V3F_C4B_T2F
function cc.V3F_C4B_T2F(_vertices, _colors, _texCoords)
return { vertices = _vertices, colors = _colors, texCoords = _texCoords }
end
--V2F_C4B_T2F_Quad
function cc.V2F_C4B_T2F_Quad(_bl, _br, _tl, _tr)
return { bl = _bl, br = _br, tl = _tl, tr = _tr }
end
--V3F_C4B_T2F_Quad
function cc.V3F_C4B_T2F_Quad(_tl, _bl, _tr, _br)
return { tl = _tl, bl = _bl, tr = _tr, br = _br }
end
--V2F_C4F_T2F_Quad
function cc.V2F_C4F_T2F_Quad(_bl, _br, _tl, _tr)
return { bl = _bl, br = _br, tl = _tl, tr = _tr }
end
--T2F_Quad
function cc.T2F_Quad(_bl, _br, _tl, _tr)
return { bl = _bl, br = _br, tl = _tl, tr = _tr }
end
--AnimationFrameData
function cc.AnimationFrameData( _texCoords, _delay, _size)
return { texCoords = _texCoords, delay = _delay, size = _size }
end

View File

@ -591,20 +591,20 @@ rawset(_G,"ccpIntersectPoint",ccpIntersectPoint)
local function vertex2(x,y) local function vertex2(x,y)
deprecatedTip("vertex2(x,y)","Vertex2F(x,y)") deprecatedTip("vertex2(x,y)","cc.vertex2F(x,y)")
return Vertex2F(x,y) return cc.vertex2F(x,y)
end end
rawset(_G,"vertex2",vertex2) rawset(_G,"vertex2",vertex2)
local function vertex3(x,y,z) local function vertex3(x,y,z)
deprecatedTip("vertex3(x,y,z)","Vertex3F(x,y,z)") deprecatedTip("vertex3(x,y,z)","cc.Vertex3F(x,y,z)")
return Vertex3F(x,y,z) return cc.Vertex3F(x,y,z)
end end
rawset(_G,"vertex3",vertex3) rawset(_G,"vertex3",vertex3)
local function tex2(u,v) local function tex2(u,v)
deprecatedTip("tex2(u,v)","Tex2F(u,v)") deprecatedTip("tex2(u,v)","cc.tex2f(u,v)")
return Tex2F(u,v) return cc.tex2f(u,v)
end end
rawset(_G,"tex2",tex2) rawset(_G,"tex2",tex2)
@ -615,109 +615,116 @@ end
rawset(_G,"ccc4BFromccc4F",ccc4BFromccc4F) rawset(_G,"ccc4BFromccc4F",ccc4BFromccc4F)
local function ccColor3BDeprecated() local function ccColor3BDeprecated()
deprecatedTip("ccColor3B","Color3B") deprecatedTip("ccColor3B","cc.c3b(0,0,0)")
return Color3B return cc.c3b(0,0,0)
end end
_G["ccColor3B"] = ccColor3BDeprecated() _G["ccColor3B"] = ccColor3BDeprecated
local function ccColor4BDeprecated() local function ccColor4BDeprecated()
deprecatedTip("ccColor4B","Color4B") deprecatedTip("ccColor4B","cc.c4b(0,0,0,0)")
return Color4B return cc.c4b(0,0,0,0)
end end
_G["ccColor4B"] = ccColor4BDeprecated() _G["ccColor4B"] = ccColor4BDeprecated
local function ccColor4FDeprecated() local function ccColor4FDeprecated()
deprecatedTip("ccColor4F","Color4F") deprecatedTip("ccColor4F","cc.c4f(0.0,0.0,0.0,0.0)")
return Color4F return cc.c4f(0.0,0.0,0.0,0.0)
end end
_G["ccColor4F"] = ccColor4FDeprecated() _G["ccColor4F"] = ccColor4FDeprecated
local function ccVertex2FDeprecated() local function ccVertex2FDeprecated()
deprecatedTip("ccVertex2F","Vertex2F") deprecatedTip("ccVertex2F","cc.vertex2F(0.0,0.0)")
return Vertex2F return cc.vertex2F(0.0,0.0)
end end
_G["ccVertex2F"] = ccVertex2FDeprecated() _G["ccVertex2F"] = ccVertex2FDeprecated
local function ccVertex3FDeprecated() local function ccVertex3FDeprecated()
deprecatedTip("ccVertex3F","Vertex3F") deprecatedTip("ccVertex3F","cc.Vertex3F(0.0, 0.0, 0.0)")
return Vertex3F return cc.Vertex3F(0.0, 0.0, 0.0)
end end
_G["ccVertex3F"] = ccVertex3FDeprecated() _G["ccVertex3F"] = ccVertex3FDeprecated
local function ccTex2FDeprecated() local function ccTex2FDeprecated()
deprecatedTip("ccTex2F","Tex2F") deprecatedTip("ccTex2F","cc.tex2F(0.0, 0.0)")
return Tex2F return cc.tex2F(0.0, 0.0)
end end
_G["ccTex2F"] = ccTex2FDeprecated() _G["ccTex2F"] = ccTex2FDeprecated
local function ccPointSpriteDeprecated() local function ccPointSpriteDeprecated()
deprecatedTip("ccPointSprite","PointSprite") deprecatedTip("ccPointSprite","cc.PointSprite(cc.vertex2F(0.0, 0.0),cc.c4b(0.0, 0.0, 0.0),0)")
return PointSprite return cc.PointSprite(cc.vertex2F(0.0, 0.0),cc.c4b(0.0, 0.0, 0.0),0)
end end
_G["ccPointSprite"] = ccPointSpriteDeprecated() _G["ccPointSprite"] = ccPointSpriteDeprecated
local function ccQuad2Deprecated() local function ccQuad2Deprecated()
deprecatedTip("ccQuad2","Quad2") deprecatedTip("ccQuad2","cc.Quad2(cc.vertex2F(0.0, 0.0), cc.vertex2F(0.0, 0.0), cc.vertex2F(0.0, 0.0), cc.vertex2F(0.0, 0.0))")
return Quad2 return cc.Quad2(cc.vertex2F(0.0, 0.0), cc.vertex2F(0.0, 0.0), cc.vertex2F(0.0, 0.0), cc.vertex2F(0.0, 0.0))
end end
_G["ccQuad2"] = ccQuad2Deprecated() _G["ccQuad2"] = ccQuad2Deprecated
local function ccQuad3Deprecated() local function ccQuad3Deprecated()
deprecatedTip("ccQuad3","Quad3") deprecatedTip("ccQuad3","cc.Quad3(cc.Vertex3F(0.0, 0.0 ,0.0), cc.Vertex3F(0.0, 0.0 ,0.0), cc.Vertex3F(0.0, 0.0 ,0.0), cc.Vertex3F(0.0, 0.0 ,0.0))")
return Quad3 return cc.Quad3(cc.Vertex3F(0.0, 0.0 ,0.0), cc.Vertex3F(0.0, 0.0 ,0.0), cc.Vertex3F(0.0, 0.0 ,0.0), cc.Vertex3F(0.0, 0.0 ,0.0))
end end
_G["ccQuad3"] = ccQuad3Deprecated() _G["ccQuad3"] = ccQuad3Deprecated
local function ccV2FC4BT2FDeprecated() local function ccV2FC4BT2FDeprecated()
deprecatedTip("ccV2F_C4B_T2F","V2F_C4B_T2F") deprecatedTip("ccV2F_C4B_T2F","cc.V2F_C4B_T2F(cc.vertex2F(0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0))")
return V2F_C4B_T2F return cc.V2F_C4B_T2F(cc.vertex2F(0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0))
end end
_G["ccV2F_C4B_T2F"] = ccV2FC4BT2FDeprecated() _G["ccV2F_C4B_T2F"] = ccV2FC4BT2FDeprecated
local function ccV2FC4FT2FDeprecated() local function ccV2FC4FT2FDeprecated()
deprecatedTip("ccV2F_C4F_T2F","V2F_C4F_T2F") deprecatedTip("ccV2F_C4F_T2F","cc.V2F_C4F_T2F(cc.vertex2F(0.0, 0.0), cc.c4f(0.0 , 0.0 , 0.0 , 0.0 ), cc.tex2F(0.0, 0.0))")
return V2F_C4F_T2F return cc.V2F_C4F_T2F(cc.vertex2F(0.0, 0.0), cc.c4f(0.0 , 0.0 , 0.0 , 0.0), cc.tex2F(0.0, 0.0))
end end
_G["ccV2F_C4F_T2F"] = ccV2FC4FT2FDeprecated() _G["ccV2F_C4F_T2F"] = ccV2FC4FT2FDeprecated
local function ccV3FC4BT2FDeprecated() local function ccV3FC4BT2FDeprecated()
deprecatedTip("ccV3F_C4B_T2F","V3F_C4B_T2F") deprecatedTip("ccV3F_C4B_T2F","cc.V3F_C4B_T2F(cc.vertex3F(0.0, 0.0, 0.0), cc.c4b(0 , 0 , 0, 0 ), cc.tex2F(0.0, 0.0))")
return V3F_C4B_T2F return cc.V3F_C4B_T2F(cc.vertex3F(0.0, 0.0, 0.0), cc.c4b(0 , 0 , 0, 0 ), cc.tex2F(0.0, 0.0))
end end
_G["ccV3F_C4B_T2F"] = ccV3FC4BT2FDeprecated() _G["ccV3F_C4B_T2F"] = ccV3FC4BT2FDeprecated
local function ccV2FC4BT2FQuadDeprecated() local function ccV2FC4BT2FQuadDeprecated()
deprecatedTip("ccV2F_C4B_T2F_Quad","V2F_C4B_T2F_Quad") deprecatedTip("ccV2F_C4B_T2F_Quad","cc.V2F_C4B_T2F_Quad(cc.V2F_C4B_T2F(cc.vertex2F(0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0)), cc.V2F_C4B_T2F(cc.vertex2F(0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0)), cc.V2F_C4B_T2F(cc.vertex2F(0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0)), cc.V2F_C4B_T2F(cc.vertex2F(0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0)))")
return V2F_C4B_T2F_Quad return cc.V2F_C4B_T2F_Quad(cc.V2F_C4B_T2F(cc.vertex2F(0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0)), cc.V2F_C4B_T2F(cc.vertex2F(0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0)), cc.V2F_C4B_T2F(cc.vertex2F(0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0)), cc.V2F_C4B_T2F(cc.vertex2F(0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0)))
end end
_G["ccV2F_C4B_T2F_Quad"] = ccV2FC4BT2FQuadDeprecated() _G["ccV2F_C4B_T2F_Quad"] = ccV2FC4BT2FQuadDeprecated
local function ccV3FC4BT2FQuadDeprecated() local function ccV3FC4BT2FQuadDeprecated()
deprecatedTip("ccV3F_C4B_T2F_Quad","V3F_C4B_T2F_Quad") deprecatedTip("ccV3F_C4B_T2F_Quad","cc.V3F_C4B_T2F_Quad(_tl, _bl, _tr, _br)")
return V3F_C4B_T2F_Quad return cc.V3F_C4B_T2F_Quad(cc.V3F_C4B_T2F(cc.vertex3F(0.0, 0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0)), cc.V3F_C4B_T2F(cc.vertex3F(0.0, 0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0)), cc.V3F_C4B_T2F(cc.vertex3F(0.0, 0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0)), cc.V3F_C4B_T2F(cc.vertex3F(0.0, 0.0, 0.0), cc.c4b(0 , 0, 0, 0 ), cc.tex2F(0.0, 0.0)))
end end
_G["ccV3F_C4B_T2F_Quad"] = ccV3FC4BT2FQuadDeprecated() _G["ccV3F_C4B_T2F_Quad"] = ccV3FC4BT2FQuadDeprecated
local function ccV2FC4FT2FQuadDeprecated() local function ccV2FC4FT2FQuadDeprecated()
deprecatedTip("ccV2F_C4F_T2F_Quad","V2F_C4F_T2F_Quad") deprecatedTip("ccV2F_C4F_T2F_Quad","cc.V2F_C4F_T2F_Quad(_bl, _br, _tl, _tr)")
return V2F_C4F_T2F_Quad return cc.V2F_C4F_T2F_Quad(cc.V2F_C4F_T2F(cc.vertex2F(0.0, 0.0), cc.c4f(0.0 , 0.0, 0.0, 0.0 ), cc.tex2F(0.0, 0.0)), cc.V2F_C4F_T2F(cc.vertex2F(0.0, 0.0), cc.c4f(0.0 , 0.0, 0.0, 0.0 ), cc.tex2F(0.0, 0.0)), cc.V3F_C4B_T2F(cc.vertex2F(0.0, 0.0), cc.c4f(0.0 , 0.0, 0.0, 0.0 ), cc.tex2F(0.0, 0.0)), cc.V2F_C4F_T2F(cc.vertex2F(0.0, 0.0), cc.c4f(0.0 , 0.0, 0.0, 0.0 ), cc.tex2F(0.0, 0.0)))
end end
_G["ccV2F_C4F_T2F_Quad"] = ccV2FC4FT2FQuadDeprecated() _G["ccV2F_C4F_T2F_Quad"] = ccV2FC4FT2FQuadDeprecated
local function ccT2FQuadDeprecated() local function ccT2FQuadDeprecated()
deprecatedTip("ccT2F_Quad","T2F_Quad") deprecatedTip("ccT2F_Quad","cc.T2F_Quad(_bl, _br, _tl, _tr)")
return T2F_Quad return cc.T2F_Quad(cc.tex2F(0.0,0.0), cc.tex2F(0.0,0.0), cc.tex2F(0.0,0.0), cc.tex2F(0.0,0.0))
end end
_G["ccT2F_Quad"] = ccT2FQuadDeprecated() _G["ccT2F_Quad"] = ccT2FQuadDeprecated
local function ccAnimationFrameDataDeprecated() local function ccAnimationFrameDataDeprecated()
deprecatedTip("ccAnimationFrameData","AnimationFrameData") deprecatedTip("ccAnimationFrameData","cc.AnimationFrameData( _texCoords, _delay, _size)")
return AnimationFrameData return cc.AnimationFrameData(cc.T2F_Quad(cc.tex2F(0.0,0.0), cc.tex2F(0.0,0.0), cc.tex2F(0.0,0.0), cc.tex2F(0.0,0.0)), 0, cc.size(0,0))
end end
_G["ccAnimationFrameData"] = ccAnimationFrameDataDeprecated() _G["ccAnimationFrameData"] = ccAnimationFrameDataDeprecated
local function tex2(u,v)
deprecatedTip("tex2(u,v)","cc.tex2f(u,v)")
return cc.tex2f(u,v)
end
rawset(_G,"tex2",tex2)
--functions of CCControl will be deprecated end --functions of CCControl will be deprecated end
local CCControlDeprecated = { } local CCControlDeprecated = { }
function CCControlDeprecated.addHandleOfControlEvent(self,func,controlEvent) function CCControlDeprecated.addHandleOfControlEvent(self,func,controlEvent)
@ -1047,3 +1054,114 @@ function CCLayerDeprecated.isKeypadEnabled(self)
end end
rawset(cc.Layer, "isKeypadEnabled", CCLayerDeprecated.isKeypadEnabled ) rawset(cc.Layer, "isKeypadEnabled", CCLayerDeprecated.isKeypadEnabled )
--functions of Layer will be deprecated end --functions of Layer will be deprecated end
--functions of ccs.GUIReader will be deprecated begin
local CCSGUIReaderDeprecated = { }
function CCSGUIReaderDeprecated.purgeGUIReader()
deprecatedTip("ccs.GUIReader:purgeGUIReader","ccs.GUIReader:destroyInstance")
return ccs.GUIReader:destroyInstance()
end
rawset(ccs.GUIReader,"purgeGUIReader",CCSGUIReaderDeprecated.purgeGUIReader)
--functions of ccs.GUIReader will be deprecated end
--functions of ccs.ActionManagerEx will be deprecated begin
local CCSActionManagerExDeprecated = { }
function CCSActionManagerExDeprecated.destroyActionManager()
deprecatedTip("ccs.ActionManagerEx:destroyActionManager","ccs.ActionManagerEx:destroyInstance")
return ccs.ActionManagerEx:destroyInstance()
end
rawset(ccs.ActionManagerEx,"destroyActionManager",CCSActionManagerExDeprecated.destroyActionManager)
--functions of ccs.ActionManagerEx will be deprecated end
--functions of ccs.SceneReader will be deprecated begin
local CCSSceneReaderDeprecated = { }
function CCSSceneReaderDeprecated.destroySceneReader(self)
deprecatedTip("ccs.SceneReader:destroySceneReader","ccs.SceneReader:destroyInstance")
return self:destroyInstance()
end
rawset(ccs.SceneReader,"destroySceneReader",CCSSceneReaderDeprecated.destroySceneReader)
--functions of ccs.SceneReader will be deprecated end
--functions of CCArmatureDataManager will be deprecated begin
local CCArmatureDataManagerDeprecated = { }
function CCArmatureDataManagerDeprecated.sharedArmatureDataManager()
deprecatedTip("CCArmatureDataManager:sharedArmatureDataManager","ccs.ArmatureDataManager:getInstance")
return ccs.ArmatureDataManager:getInstance()
end
rawset(CCArmatureDataManager,"sharedArmatureDataManager",CCArmatureDataManagerDeprecated.sharedArmatureDataManager)
function CCArmatureDataManagerDeprecated.purge()
deprecatedTip("CCArmatureDataManager:purge","ccs.ArmatureDataManager:destoryInstance")
return ccs.ArmatureDataManager:destoryInstance()
end
rawset(CCArmatureDataManager,"purge",CCArmatureDataManagerDeprecated.purge)
--functions of CCArmatureDataManager will be deprecated end
--functions of GUIReader will be deprecated begin
local GUIReaderDeprecated = { }
function GUIReaderDeprecated.shareReader()
deprecatedTip("GUIReader:shareReader","ccs.GUIReader:getInstance")
return ccs.GUIReader:getInstance()
end
rawset(GUIReader,"shareReader",GUIReaderDeprecated.shareReader)
function GUIReaderDeprecated.purgeGUIReader()
deprecatedTip("GUIReader:purgeGUIReader","ccs.GUIReader:destroyInstance")
return ccs.GUIReader:destroyInstance()
end
rawset(GUIReader,"purgeGUIReader",GUIReaderDeprecated.purgeGUIReader)
--functions of GUIReader will be deprecated end
--functions of SceneReader will be deprecated begin
local SceneReaderDeprecated = { }
function SceneReaderDeprecated.sharedSceneReader()
deprecatedTip("SceneReader:sharedSceneReader","ccs.SceneReader:getInstance")
return ccs.SceneReader:getInstance()
end
rawset(SceneReader,"sharedSceneReader",SceneReaderDeprecated.sharedSceneReader)
function SceneReaderDeprecated.purgeSceneReader(self)
deprecatedTip("SceneReader:purgeSceneReader","ccs.SceneReader:destroyInstance")
return self:destroyInstance()
end
rawset(SceneReader,"purgeSceneReader",SceneReaderDeprecated.purgeSceneReader)
--functions of SceneReader will be deprecated end
--functions of ActionManager will be deprecated begin
local ActionManagerDeprecated = { }
function ActionManagerDeprecated.shareManager()
deprecatedTip("ActionManager:shareManager","ccs.ActionManagerEx:getInstance")
return ccs.ActionManagerEx:getInstance()
end
rawset(ActionManager,"shareManager",ActionManagerDeprecated.shareManager)
function ActionManagerDeprecated.purgeActionManager()
deprecatedTip("ActionManager:purgeActionManager","ccs.ActionManagerEx:destroyActionManager")
return ccs.ActionManagerEx:destroyActionManager()
end
rawset(ActionManager,"purgeActionManager",ActionManagerDeprecated.purgeActionManager)
--functions of ActionManager will be deprecated end
--functions of CCEGLView will be deprecated begin
local CCEGLViewDeprecated = { }
function CCEGLViewDeprecated.sharedOpenGLView()
deprecatedTip("CCEGLView:sharedOpenGLView","cc.EGLView:getInstance")
return cc.EGLView:getInstance()
end
rawset(CCEGLView,"sharedOpenGLView",CCEGLViewDeprecated.sharedOpenGLView)
--functions of CCEGLView will be deprecated end
--Enums of CCTableView will be deprecated begin
rawset(CCTableView, "kTableViewScroll",cc.SCROLLVIEW_SCRIPT_SCROLL)
rawset(CCTableView,"kTableViewZoom",cc.SCROLLVIEW_SCRIPT_ZOOM)
rawset(CCTableView,"kTableCellTouched",cc.TABLECELL_TOUCHED)
rawset(CCTableView,"kTableCellSizeForIndex",cc.TABLECELL_SIZE_FOR_INDEX)
rawset(CCTableView,"kTableCellSizeAtIndex",cc.TABLECELL_SIZE_AT_INDEX)
rawset(CCTableView,"kNumberOfCellsInTableView",cc.NUMBER_OF_CELLS_IN_TABLEVIEW)
--Enums of CCTableView will be deprecated end
--Enums of CCScrollView will be deprecated begin
rawset(CCScrollView, "kScrollViewScroll",cc.SCROLLVIEW_SCRIPT_SCROLL)
rawset(CCScrollView,"kScrollViewZoom",cc.SCROLLVIEW_SCRIPT_ZOOM)
--Enums of CCScrollView will be deprecated end

View File

@ -1815,13 +1815,324 @@ end
_G["CCCallFuncN"] = DeprecatedClass.CCCallFuncN() _G["CCCallFuncN"] = DeprecatedClass.CCCallFuncN()
--CCCallFuncN class will be Deprecated,end --CCCallFuncN class will be Deprecated,end
--ccBlendFunc class will be Deprecated,begin --CCArmature class will be Deprecated,begin
function DeprecatedClass.ccBlendFunc() function DeprecatedClass.CCArmature()
deprecatedTip("ccBlendFunc","BlendFunc") deprecatedTip("CCArmature","ccs.Armature")
return BlendFunc return ccs.Armature
end end
_G["ccBlendFunc"] = DeprecatedClass.ccBlendFunc() _G["CCArmature"] = DeprecatedClass.CCArmature()
--ccBlendFunc class will be Deprecated,end --CCArmature class will be Deprecated,end
--CCArmatureAnimation class will be Deprecated,begin
function DeprecatedClass.CCArmatureAnimation()
deprecatedTip("CCArmatureAnimation","ccs.ArmatureAnimation")
return ccs.ArmatureAnimation
end
_G["CCArmatureAnimation"] = DeprecatedClass.CCArmatureAnimation()
--CCArmatureAnimation class will be Deprecated,end
--CCSkin class will be Deprecated,begin
function DeprecatedClass.CCSkin()
deprecatedTip("CCSkin","ccs.Skin")
return ccs.Skin
end
_G["CCSkin"] = DeprecatedClass.CCSkin()
--CCSkin class will be Deprecated,end
--CCBone class will be Deprecated,begin
function DeprecatedClass.CCBone()
deprecatedTip("CCBone","ccs.Bone")
return ccs.Bone
end
_G["CCBone"] = DeprecatedClass.CCBone()
--CCBone class will be Deprecated,end
--CCArmatureDataManager class will be Deprecated,begin
function DeprecatedClass.CCArmatureDataManager()
deprecatedTip("CCArmatureDataManager","ccs.ArmatureDataManager")
return ccs.ArmatureDataManager
end
_G["CCArmatureDataManager"] = DeprecatedClass.CCArmatureDataManager()
--CCArmatureDataManager class will be Deprecated,end
--CCBatchNode class will be Deprecated,begin
function DeprecatedClass.CCBatchNode()
deprecatedTip("CCBatchNode","ccs.BatchNode")
return ccs.BatchNode
end
_G["CCBatchNode"] = DeprecatedClass.CCBatchNode()
--CCBatchNode class will be Deprecated,end
--CCTween class will be Deprecated,begin
function DeprecatedClass.CCTween()
deprecatedTip("CCTween","ccs.Tween")
return ccs.Tween
end
_G["CCTween"] = DeprecatedClass.CCTween()
--CCTween class will be Deprecated,end
--CCBaseData class will be Deprecated,begin
function DeprecatedClass.CCBaseData()
deprecatedTip("CCBaseData","ccs.BaseData")
return ccs.BaseData
end
_G["CCBaseData"] = DeprecatedClass.CCBaseData()
--CCBaseData class will be Deprecated,end
--CCDisplayManager class will be Deprecated,begin
function DeprecatedClass.CCDisplayManager()
deprecatedTip("CCDisplayManager","ccs.DisplayManager")
return ccs.DisplayManager
end
_G["CCDisplayManager"] = DeprecatedClass.CCDisplayManager()
--CCDisplayManager class will be Deprecated,end
--UIHelper class will be Deprecated,begin
function DeprecatedClass.UIHelper()
deprecatedTip("UIHelper","ccs.UIHelper")
return ccs.UIHelper
end
_G["UIHelper"] = DeprecatedClass.UIHelper()
--UIHelper class will be Deprecated,end
--UILayout class will be Deprecated,begin
function DeprecatedClass.UILayout()
deprecatedTip("UILayout","ccs.UILayout")
return ccs.UILayout
end
_G["UILayout"] = DeprecatedClass.UILayout()
--UILayout class will be Deprecated,end
--UIWidget class will be Deprecated,begin
function DeprecatedClass.UIWidget()
deprecatedTip("UIWidget","ccs.UIWidget")
return ccs.UIWidget
end
_G["UIWidget"] = DeprecatedClass.UIWidget()
--UIWidget class will be Deprecated,end
--UILayer class will be Deprecated,begin
function DeprecatedClass.UILayer()
deprecatedTip("UILayer","ccs.UILayer")
return ccs.UILayer
end
_G["UILayer"] = DeprecatedClass.UILayer()
--UILayer class will be Deprecated,end
--UIButton class will be Deprecated,begin
function DeprecatedClass.UIButton()
deprecatedTip("UIButton","ccs.UIButton")
return ccs.UIButton
end
_G["UIButton"] = DeprecatedClass.UIButton()
--UIButton class will be Deprecated,end
--UICheckBox class will be Deprecated,begin
function DeprecatedClass.UICheckBox()
deprecatedTip("UICheckBox","ccs.UICheckBox")
return ccs.UICheckBox
end
_G["UICheckBox"] = DeprecatedClass.UICheckBox()
--UICheckBox class will be Deprecated,end
--UIImageView class will be Deprecated,begin
function DeprecatedClass.UIImageView()
deprecatedTip("UIImageView","ccs.UIImageView")
return ccs.UIImageView
end
_G["UIImageView"] = DeprecatedClass.UIImageView()
--UIImageView class will be Deprecated,end
--UILabel class will be Deprecated,begin
function DeprecatedClass.UILabel()
deprecatedTip("UILabel","ccs.UILabel")
return ccs.UILabel
end
_G["UILabel"] = DeprecatedClass.UILabel()
--UILabel class will be Deprecated,end
--UILabelAtlas class will be Deprecated,begin
function DeprecatedClass.UILabelAtlas()
deprecatedTip("UILabelAtlas","ccs.UILabelAtlas")
return ccs.UILabelAtlas
end
_G["UILabelAtlas"] = DeprecatedClass.UILabelAtlas()
--UILabelAtlas class will be Deprecated,end
--UILabelBMFont class will be Deprecated,begin
function DeprecatedClass.UILabelBMFont()
deprecatedTip("UILabelBMFont","ccs.UILabelBMFont")
return ccs.UILabelBMFont
end
_G["UILabelBMFont"] = DeprecatedClass.UILabelBMFont()
--UILabelBMFont class will be Deprecated,end
--UILoadingBar class will be Deprecated,begin
function DeprecatedClass.UILoadingBar()
deprecatedTip("UILoadingBar","ccs.UILoadingBar")
return ccs.UILoadingBar
end
_G["UILoadingBar"] = DeprecatedClass.UILoadingBar()
--UILoadingBar class will be Deprecated,end
--UISlider class will be Deprecated,begin
function DeprecatedClass.UISlider()
deprecatedTip("UISlider","ccs.UISlider")
return ccs.UISlider
end
_G["UISlider"] = DeprecatedClass.UISlider()
--UISlider class will be Deprecated,end
--UITextField class will be Deprecated,begin
function DeprecatedClass.UITextField()
deprecatedTip("UITextField","ccs.UITextField")
return ccs.UITextField
end
_G["UITextField"] = DeprecatedClass.UITextField()
--UITextField class will be Deprecated,end
--UIScrollView class will be Deprecated,begin
function DeprecatedClass.UIScrollView()
deprecatedTip("UIScrollView","ccs.UIScrollView")
return ccs.UIScrollView
end
_G["UIScrollView"] = DeprecatedClass.UIScrollView()
--UIScrollView class will be Deprecated,end
--UIPageView class will be Deprecated,begin
function DeprecatedClass.UIPageView()
deprecatedTip("UIPageView","ccs.UIPageView")
return ccs.UIPageView
end
_G["UIPageView"] = DeprecatedClass.UIPageView()
--UIPageView class will be Deprecated,end
--UIListView class will be Deprecated,begin
function DeprecatedClass.UIListView()
deprecatedTip("UIListView","ccs.UIListView")
return ccs.UIListView
end
_G["UIListView"] = DeprecatedClass.UIListView()
--UIListView class will be Deprecated,end
--UILayoutParameter class will be Deprecated,begin
function DeprecatedClass.UILayoutParameter()
deprecatedTip("UILayoutParameter","ccs.UILayoutParameter")
return ccs.UILayoutParameter
end
_G["UILayoutParameter"] = DeprecatedClass.UILayoutParameter()
--UILayoutParameter class will be Deprecated,end
--UILinearLayoutParameter class will be Deprecated,begin
function DeprecatedClass.UILinearLayoutParameter()
deprecatedTip("UILinearLayoutParameter","ccs.UILinearLayoutParameter")
return ccs.UILinearLayoutParameter
end
_G["UILinearLayoutParameter"] = DeprecatedClass.UILinearLayoutParameter()
--UILinearLayoutParameter class will be Deprecated,end
--UIRelativeLayoutParameter class will be Deprecated,begin
function DeprecatedClass.UIRelativeLayoutParameter()
deprecatedTip("UIRelativeLayoutParameter","ccs.UIRelativeLayoutParameter")
return ccs.UIRelativeLayoutParameter
end
_G["UIRelativeLayoutParameter"] = DeprecatedClass.UIRelativeLayoutParameter()
--UIRelativeLayoutParameter class will be Deprecated,end
--CCComController class will be Deprecated,begin
function DeprecatedClass.CCComController()
deprecatedTip("CCComController","ccs.ComController")
return ccs.CCComController
end
_G["CCComController"] = DeprecatedClass.CCComController()
--CCComController class will be Deprecated,end
--CCComAudio class will be Deprecated,begin
function DeprecatedClass.CCComAudio()
deprecatedTip("CCComAudio","ccs.ComAudio")
return ccs.ComAudio
end
_G["CCComAudio"] = DeprecatedClass.CCComAudio()
--CCComAudio class will be Deprecated,end
--CCComAttribute class will be Deprecated,begin
function DeprecatedClass.CCComAttribute()
deprecatedTip("CCComAttribute","ccs.ComAttribute")
return ccs.ComAttribute
end
_G["CCComAttribute"] = DeprecatedClass.CCComAttribute()
--CCComAttribute class will be Deprecated,end
--CCComRender class will be Deprecated,begin
function DeprecatedClass.CCComRender()
deprecatedTip("CCComRender","ccs.ComRender")
return ccs.ComRender
end
_G["CCComRender"] = DeprecatedClass.CCComRender()
--CCComRender class will be Deprecated,end
--ActionManager class will be Deprecated,begin
function DeprecatedClass.ActionManager()
deprecatedTip("ActionManager","ccs.ActionManagerEx")
return ccs.ActionManagerEx
end
_G["ActionManager"] = DeprecatedClass.ActionManager()
--CCComRender class will be Deprecated,end
--SceneReader class will be Deprecated,begin
function DeprecatedClass.SceneReader()
deprecatedTip("SceneReader","ccs.SceneReader")
return ccs.SceneReader
end
_G["SceneReader"] = DeprecatedClass.SceneReader()
--SceneReader class will be Deprecated,end
--GUIReader class will be Deprecated,begin
function DeprecatedClass.GUIReader()
deprecatedTip("GUIReader","ccs.GUIReader")
return ccs.GUIReader
end
_G["GUIReader"] = DeprecatedClass.GUIReader()
--GUIReader class will be Deprecated,end
--UIRootWidget class will be Deprecated,begin
function DeprecatedClass.UIRootWidget()
deprecatedTip("UIRootWidget","ccs.UIRootWidget")
return ccs.UIRootWidget
end
_G["UIRootWidget"] = DeprecatedClass.UIRootWidget()
--UIRootWidget class will be Deprecated,end
--ActionObject class will be Deprecated,begin
function DeprecatedClass.ActionObject()
deprecatedTip("ActionObject","ccs.ActionObject")
return ccs.ActionObject
end
_G["ActionObject"] = DeprecatedClass.ActionObject()
--ActionObject class will be Deprecated,end
--CCEGLViewProtocol class will be Deprecated,begin
function DeprecatedClass.CCEGLViewProtocol()
deprecatedTip("CCEGLViewProtocol","cc.EGLViewProtocol")
return cc.EGLViewProtocol
end
_G["CCEGLViewProtocol"] = DeprecatedClass.CCEGLViewProtocol()
--CCEGLViewProtocol class will be Deprecated,end
--CCEGLView class will be Deprecated,begin
function DeprecatedClass.CCEGLView()
deprecatedTip("CCEGLView","cc.EGLView")
return cc.EGLView
end
_G["CCEGLView"] = DeprecatedClass.CCEGLView()
--CCEGLView class will be Deprecated,end
--CCBProxy class will be Deprecated,begin
function DeprecatedClass.CCBProxy()
deprecatedTip("CCBProxy","cc.CCBProxy")
return cc.CCBProxy
end
_G["CCBProxy"] = DeprecatedClass.CCBProxy()
--CCBProxy class will be Deprecated,end

View File

@ -1,5 +1,6 @@
require "Cocos2dConstants.lua" require "Cocos2dConstants.lua"
require "OpenglConstants.lua" require "OpenglConstants.lua"
require "StudioConstants.lua"
--Enums will be deprecated,begin --Enums will be deprecated,begin
_G.kCCTextAlignmentLeft = cc.TEXT_ALIGNMENT_LEFT _G.kCCTextAlignmentLeft = cc.TEXT_ALIGNMENT_LEFT
_G.kCCTextAlignmentRight = cc.TEXT_ALIGNMENT_RIGHT _G.kCCTextAlignmentRight = cc.TEXT_ALIGNMENT_RIGHT
@ -394,4 +395,92 @@ _G.kWebSocketScriptHandlerError = cc.WEBSOCKET_ERROR
_G.kStateConnecting = cc.WEBSOCKET_STATE_CONNECTING _G.kStateConnecting = cc.WEBSOCKET_STATE_CONNECTING
_G.kStateOpen = cc.WEBSOCKET_STATE_OPEN _G.kStateOpen = cc.WEBSOCKET_STATE_OPEN
_G.kStateClosing = cc.WEBSOCKET_STATE_CLOSING _G.kStateClosing = cc.WEBSOCKET_STATE_CLOSING
_G.kStateClosed = cc.WEBSOCKET_STATE_CLOSED _G.kStateClosed = cc.WEBSOCKET_STATE_CLOSED
_G.LAYOUT_COLOR_NONE = ccs.LayoutBackGroundColorType.none
_G.LAYOUT_COLOR_SOLID = ccs.LayoutBackGroundColorType.solid
_G.LAYOUT_COLOR_GRADIENT = ccs.LayoutBackGroundColorType.gradient
_G.LAYOUT_ABSOLUTE = ccs.LayoutType.absolute
_G.LAYOUT_LINEAR_VERTICAL = ccs.LayoutType.linearVertical
_G.LAYOUT_LINEAR_HORIZONTAL = ccs.LayoutType.linearHorizontal
_G.LAYOUT_RELATIVE = ccs.LayoutType.relative
_G.BRIGHT_NONE = ccs.BrightStyle.none
_G.BRIGHT_NORMAL = ccs.BrightStyle.normal
_G.BRIGHT_HIGHLIGHT = ccs.BrightStyle.highlight
_G.WidgetTypeWidget = ccs.WidgetType.widget
_G.WidgetTypeContainer = ccs.WidgetType.container
_G.UI_TEX_TYPE_LOCAL = ccs.TextureResType.UI_TEX_TYPE_LOCAL
_G.UI_TEX_TYPE_PLIST = ccs.TextureResType.UI_TEX_TYPE_PLIST
_G.TOUCH_EVENT_BEGAN = ccs.TouchEventType.began
_G.TOUCH_EVENT_MOVED = ccs.TouchEventType.moved
_G.TOUCH_EVENT_ENDED = ccs.TouchEventType.ended
_G.TOUCH_EVENT_CANCELED = ccs.TouchEventType.canceled
_G.SIZE_ABSOLUTE = ccs.SizeType.absolute
_G.SIZE_PERCENT = ccs.SizeType.percent
_G.POSITION_ABSOLUTE = ccs.PositionType.absolute
_G.POSITION_PERCENT = ccs.PositionType.percent
_G.CHECKBOX_STATE_EVENT_SELECTED = ccs.CheckBoxEventType.selected
_G.CHECKBOX_STATE_EVENT_UNSELECTED = ccs.CheckBoxEventType.unselected
_G.CHECKBOX_STATE_EVENT_SELECTED = ccs.CheckBoxEventType.selected
_G.CHECKBOX_STATE_EVENT_UNSELECTED = ccs.CheckBoxEventType.unselected
_G.LoadingBarTypeLeft = ccs.LoadingBarType.left
_G.LoadingBarTypeRight = ccs.LoadingBarType.right
_G.LoadingBarTypeRight = ccs.SliderEventType.percent_changed
_G.TEXTFIELD_EVENT_ATTACH_WITH_IME = ccs.TextFiledEventType.attach_with_ime
_G.TEXTFIELD_EVENT_DETACH_WITH_IME = ccs.TextFiledEventType.detach_with_ime
_G.TEXTFIELD_EVENT_INSERT_TEXT = ccs.TextFiledEventType.insert_text
_G.TEXTFIELD_EVENT_DELETE_BACKWARD = ccs.TextFiledEventType.delete_backward
_G.SCROLLVIEW_EVENT_SCROLL_TO_TOP = ccs.SCROLLVIEW_DIR.none
_G.SCROLLVIEW_DIR_VERTICAL = ccs.SCROLLVIEW_DIR.vertical
_G.SCROLLVIEW_DIR_HORIZONTAL = ccs.SCROLLVIEW_DIR.horizontal
_G.SCROLLVIEW_DIR_BOTH = ccs.SCROLLVIEW_DIR.both
_G.SCROLLVIEW_EVENT_SCROLL_TO_TOP = ccs.ScrollviewEventType.SCROLL_TO_TOP
_G.SCROLLVIEW_EVENT_SCROLL_TO_BOTTOM = ccs.ScrollviewEventType.SCROLL_TO_BOTTOM
_G.SCROLLVIEW_EVENT_SCROLL_TO_LEFT = ccs.ScrollviewEventType.SCROLL_TO_LEFT
_G.SCROLLVIEW_EVENT_SCROLL_TO_RIGHT = ccs.ScrollviewEventType.SCROLL_TO_RIGHT
_G.SCROLLVIEW_EVENT_SCROLLING = ccs.ScrollviewEventType.SCROLLING
_G.SCROLLVIEW_EVENT_BOUNCE_TOP = ccs.ScrollviewEventType.BOUNCE_TOP
_G.SCROLLVIEW_EVENT_BOUNCE_BOTTOM = ccs.ScrollviewEventType.BOUNCE_BOTTOM
_G.SCROLLVIEW_EVENT_BOUNCE_LEFT = ccs.ScrollviewEventType.BOUNCE_LEFT
_G.SCROLLVIEW_EVENT_BOUNCE_RIGHT = ccs.ScrollviewEventType.BOUNCE_RIGHT
_G.PAGEVIEW_EVENT_TURNING = ccs.PageViewEventType.turning
_G.PAGEVIEW_TOUCHLEFT = ccs.PVTouchDir.touch_left
_G.PAGEVIEW_TOUCHRIGHT = ccs.PVTouchDir.touch_right
_G.LISTVIEW_DIR_NONE = ccs.ListViewDirection.none
_G.LISTVIEW_DIR_VERTICAL = ccs.ListViewDirection.vertical
_G.LISTVIEW_DIR_HORIZONTAL = ccs.ListViewDirection.horizontal
_G.LISTVIEW_MOVE_DIR_NONE = ccs.ListViewMoveDirection.none
_G.LISTVIEW_MOVE_DIR_UP = ccs.ListViewMoveDirection.up
_G.LISTVIEW_MOVE_DIR_DOWN = ccs.ListViewMoveDirection.down
_G.LISTVIEW_MOVE_DIR_LEFT = ccs.ListViewMoveDirection.left
_G.LISTVIEW_MOVE_DIR_RIGHT = ccs.ListViewMoveDirection.right
_G.LISTVIEW_EVENT_INIT_CHILD = ccs.ListViewEventType.init_child
_G.LISTVIEW_EVENT_UPDATE_CHILD = ccs.ListViewEventType.update_child
_G.LAYOUT_PARAMETER_NONE = ccs.UILayoutParameterType.none
_G.LAYOUT_PARAMETER_LINEAR = ccs.UILayoutParameterType.linear
_G.LAYOUT_PARAMETER_RELATIVE = ccs.UILayoutParameterType.relative
_G.kCCScrollViewDirectionHorizontal = cc.SCROLLVIEW_DIRECTION_HORIZONTAL
_G.kCCScrollViewDirectionVertical = cc.SCROLLVIEW_DIRECTION_VERTICAL
_G.kCCTableViewFillTopDown = cc.TABLEVIEW_FILL_TOPDOWN
_G.kCCTableViewFillBottomUp = cc.TABLEVIEW_FILL_BOTTOMUP

View File

@ -20,11 +20,11 @@ ccs.WidgetType =
container = 1, --container container = 1, --container
} }
-- ccs.TextureResType = ccs.TextureResType =
-- { {
-- "local" = 0, UI_TEX_TYPE_LOCAL = 0,
-- "plist" = 1, UI_TEX_TYPE_PLIST = 1,
-- } }
ccs.TouchEventType = ccs.TouchEventType =
{ {
@ -138,10 +138,15 @@ ccs.SCROLLVIEW_MOVE_DIR = {
} }
ccs.ScrollviewEventType = { ccs.ScrollviewEventType = {
top = 0, SCROLL_TO_TOP = 0,
bottom = 1, SCROLL_TO_BOTTOM = 1,
left = 2, SCROLL_TO_LEFT = 2,
right = 3, SCROLL_TO_RIGHT = 3,
SCROLLING = 4,
BOUNCE_TOP = 5,
BOUNCE_BOTTOM = 6,
BOUNCE_LEFT = 7,
BOUNCE_RIGHT = 8,
} }
ccs.ListViewDirection = { ccs.ListViewDirection = {

View File

@ -1,7 +1,37 @@
set(APP_NAME hellocpp) set(APP_NAME hellocpp)
if(QT)
set(PLATFORM_SRC
proj.qt/main.cpp
)
elseif(ANDROID)
set(PLATFORM_SRC
proj.android/jni/hellocpp/main.cpp
)
elseif(WIN32)
set(PLATFORM_SRC
proj.win32/main.cpp
)
elseif(APPLE)
if(IOS)
set(PLATFORM_SRC
proj.ios/main.m
proj.ios/AppController.mm
proj.ios/RootViewController.mm
)
else()
set(PLATFORM_SRC
proj.mac/main.m
)
endif()
else()
set(PLATFORM_SRC
proj.linux/main.cpp
)
endif()
set(SAMPLE_SRC set(SAMPLE_SRC
proj.linux/main.cpp ${PLATFORM_SRC}
Classes/AppDelegate.cpp Classes/AppDelegate.cpp
Classes/HelloWorldScene.cpp Classes/HelloWorldScene.cpp
) )
@ -11,15 +41,27 @@ add_executable(${APP_NAME}
${SAMPLE_SRC} ${SAMPLE_SRC}
) )
#get our resources
add_custom_command(TARGET ${APP_NAME} PRE_BUILD
COMMAND ${CMAKE_COMMAND} -E copy_directory
${CMAKE_CURRENT_SOURCE_DIR}/Resources ${CMAKE_CURRENT_BINARY_DIR})
if(WIN32 AND MSVC)
#get our dlls
add_custom_command(TARGET ${APP_NAME} PRE_BUILD
COMMAND ${CMAKE_COMMAND} -E copy
${CMAKE_CURRENT_SOURCE_DIR}/../../../external/win32-specific/gles/prebuilt/glew32.dll
${CMAKE_CURRENT_BINARY_DIR})
add_custom_command(TARGET ${APP_NAME} PRE_BUILD
COMMAND ${CMAKE_COMMAND} -E copy
${CMAKE_CURRENT_SOURCE_DIR}/../../../external/win32-specific/zlib/prebuilt/zlib1.dll
${CMAKE_CURRENT_BINARY_DIR}/Debug)
#Visual Studio Defaults to wrong type
set_target_properties(${APP_NAME} PROPERTIES LINK_FLAGS_DEBUG "/SUBSYSTEM:WINDOWS")
set_target_properties(${APP_NAME} PROPERTIES LINK_FLAGS_RELEASE "/SUBSYSTEM:WINDOWS")
endif()
target_link_libraries(${APP_NAME} audio cocos2d) target_link_libraries(${APP_NAME} audio cocos2d)
set(APP_BIN_DIR "${CMAKE_SOURCE_DIR}/bin/${APP_NAME}")
set_target_properties(${APP_NAME} PROPERTIES
RUNTIME_OUTPUT_DIRECTORY "${APP_BIN_DIR}")
pre_build(${APP_NAME}
COMMAND ${CMAKE_COMMAND} -E remove_directory ${APP_BIN_DIR}/Resources
COMMAND ${CMAKE_COMMAND} -E copy_directory ${CMAKE_CURRENT_SOURCE_DIR}/Resources ${APP_BIN_DIR}/Resources
)

View File

@ -184,7 +184,7 @@ void ArmatureTestLayer::onExit()
removeAllChildren(); removeAllChildren();
backItem = restartItem = nextItem = nullptr; backItem = restartItem = nextItem = nullptr;
Layer::onExit(); Layer::onExit();
} }
@ -371,7 +371,7 @@ void TestPerformance::onEnter()
decrease->setColor(Color3B(0,200,20)); decrease->setColor(Color3B(0,200,20));
MenuItemFont *increase = MenuItemFont::create(" + ", CC_CALLBACK_1(TestPerformance::onIncrease, this)); MenuItemFont *increase = MenuItemFont::create(" + ", CC_CALLBACK_1(TestPerformance::onIncrease, this));
increase->setColor(Color3B(0,200,20)); increase->setColor(Color3B(0,200,20));
Menu *menu = Menu::create(decrease, increase, nullptr); Menu *menu = Menu::create(decrease, increase, nullptr);
menu->alignItemsHorizontally(); menu->alignItemsHorizontally();
menu->setPosition(Point(VisibleRect::getVisibleRect().size.width/2, VisibleRect::getVisibleRect().size.height-100)); menu->setPosition(Point(VisibleRect::getVisibleRect().size.width/2, VisibleRect::getVisibleRect().size.height-100));
@ -404,7 +404,7 @@ void TestPerformance::onDecrease(Object* pSender)
{ {
removeArmatureFromParent(ArmaturePerformanceTag + armatureCount); removeArmatureFromParent(ArmaturePerformanceTag + armatureCount);
armatureCount --; armatureCount --;
refreshTitile(); refreshTitle();
} }
} }
void TestPerformance::addArmature(int number) void TestPerformance::addArmature(int number)
@ -423,7 +423,7 @@ void TestPerformance::addArmature(int number)
armature->release(); armature->release();
} }
refreshTitile(); refreshTitle();
} }
void TestPerformance::addArmatureToParent(cocostudio::Armature *armature) void TestPerformance::addArmatureToParent(cocostudio::Armature *armature)
{ {
@ -433,7 +433,7 @@ void TestPerformance::removeArmatureFromParent(int tag)
{ {
removeChildByTag(ArmaturePerformanceTag + armatureCount); removeChildByTag(ArmaturePerformanceTag + armatureCount);
} }
void TestPerformance::refreshTitile() void TestPerformance::refreshTitle()
{ {
char pszCount[255]; char pszCount[255];
sprintf(pszCount, "%s %i", subtitle().c_str(), armatureCount); sprintf(pszCount, "%s %i", subtitle().c_str(), armatureCount);
@ -601,7 +601,7 @@ void TestFrameEvent::onFrameEvent(Bone *bone, const char *evt, int originFrameIn
{ {
this->stopAllActions(); this->stopAllActions();
ActionInterval *action = ShatteredTiles3D::create(0.2f, Size(16,12), 5, false); ActionInterval *action = ShatteredTiles3D::create(0.2f, Size(16,12), 5, false);
action->setTag(FRAME_EVENT_ACTION_TAG); action->setTag(FRAME_EVENT_ACTION_TAG);
this->runAction(action); this->runAction(action);
} }
@ -617,7 +617,7 @@ void TestFrameEvent::checkAction(float dt)
void TestParticleDisplay::onEnter() void TestParticleDisplay::onEnter()
{ {
ArmatureTestLayer::onEnter(); ArmatureTestLayer::onEnter();
auto listener = EventListenerTouchAllAtOnce::create(); auto listener = EventListenerTouchAllAtOnce::create();
listener->onTouchesEnded = CC_CALLBACK_2(TestParticleDisplay::onTouchesEnded, this); listener->onTouchesEnded = CC_CALLBACK_2(TestParticleDisplay::onTouchesEnded, this);
_eventDispatcher->addEventListenerWithSceneGraphPriority(listener, this); _eventDispatcher->addEventListenerWithSceneGraphPriority(listener, this);
@ -681,7 +681,7 @@ void TestUseMutiplePicture::onEnter()
auto listener = EventListenerTouchAllAtOnce::create(); auto listener = EventListenerTouchAllAtOnce::create();
listener->onTouchesEnded = CC_CALLBACK_2(TestUseMutiplePicture::onTouchesEnded, this); listener->onTouchesEnded = CC_CALLBACK_2(TestUseMutiplePicture::onTouchesEnded, this);
_eventDispatcher->addEventListenerWithSceneGraphPriority(listener, this); _eventDispatcher->addEventListenerWithSceneGraphPriority(listener, this);
displayIndex = 0; displayIndex = 0;
armature = Armature::create("Knight_f/Knight"); armature = Armature::create("Knight_f/Knight");
@ -1076,7 +1076,7 @@ std::string TestAnchorPoint::title()
void TestArmatureNesting::onEnter() void TestArmatureNesting::onEnter()
{ {
ArmatureTestLayer::onEnter(); ArmatureTestLayer::onEnter();
auto listener = EventListenerTouchAllAtOnce::create(); auto listener = EventListenerTouchAllAtOnce::create();
listener->onTouchesEnded = CC_CALLBACK_2(TestArmatureNesting::onTouchesEnded, this); listener->onTouchesEnded = CC_CALLBACK_2(TestArmatureNesting::onTouchesEnded, this);
_eventDispatcher->addEventListenerWithSceneGraphPriority(listener, this); _eventDispatcher->addEventListenerWithSceneGraphPriority(listener, this);
@ -1241,7 +1241,7 @@ void TestArmatureNesting2::onTouchesEnded(const std::vector<Touch*>& touches, Ev
{ {
Point point = touches[0]->getLocation(); Point point = touches[0]->getLocation();
Armature *armature = hero->getMount() == nullptr ? hero : hero->getMount(); Armature *armature = hero->getMount() == nullptr ? hero : hero->getMount();
//Set armature direction //Set armature direction
if (point.x < armature->getPositionX()) if (point.x < armature->getPositionX())

View File

@ -16,7 +16,7 @@
class ArmatureTestScene : public TestScene class ArmatureTestScene : public TestScene
{ {
public: public:
ArmatureTestScene(bool bPortrait = false); ArmatureTestScene(bool bPortrait = false);
virtual void runThisTest(); virtual void runThisTest();
@ -114,7 +114,7 @@ public:
virtual void addArmature(int number); virtual void addArmature(int number);
virtual void addArmatureToParent(cocostudio::Armature *armature); virtual void addArmatureToParent(cocostudio::Armature *armature);
virtual void removeArmatureFromParent(int tag); virtual void removeArmatureFromParent(int tag);
virtual void refreshTitile(); virtual void refreshTitle();
int armatureCount; int armatureCount;
@ -327,4 +327,4 @@ public:
bool touchedMenu; bool touchedMenu;
}; };
#endif // __HELLOWORLD_SCENE_H__ #endif // __HELLOWORLD_SCENE_H__

View File

@ -21,9 +21,9 @@ void DemoFirework::onEnter()
_emitter = ParticleFireworks::create(); _emitter = ParticleFireworks::create();
_emitter->retain(); _emitter->retain();
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_stars1) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_stars1) );
setEmitterPosition(); setEmitterPosition();
} }
@ -45,11 +45,11 @@ void DemoFire::onEnter()
_emitter = ParticleFire::create(); _emitter = ParticleFire::create();
_emitter->retain(); _emitter->retain();
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) );//.pvr"); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) );//.pvr");
auto p = _emitter->getPosition(); auto p = _emitter->getPosition();
_emitter->setPosition( Point(p.x, 100) ); _emitter->setPosition( Point(p.x, 100) );
setEmitterPosition(); setEmitterPosition();
} }
@ -72,7 +72,7 @@ void DemoSun::onEnter()
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) );
setEmitterPosition(); setEmitterPosition();
} }
@ -93,10 +93,10 @@ void DemoGalaxy::onEnter()
_emitter = ParticleGalaxy::create(); _emitter = ParticleGalaxy::create();
_emitter->retain(); _emitter->retain();
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) );
setEmitterPosition(); setEmitterPosition();
} }
std::string DemoGalaxy::title() std::string DemoGalaxy::title()
@ -117,7 +117,7 @@ void DemoFlower::onEnter()
_emitter->retain(); _emitter->retain();
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_stars1) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_stars1) );
setEmitterPosition(); setEmitterPosition();
} }
@ -143,61 +143,61 @@ void DemoBigFlower::onEnter()
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_stars1) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_stars1) );
_emitter->setDuration(-1); _emitter->setDuration(-1);
// gravity // gravity
_emitter->setGravity(Point::ZERO); _emitter->setGravity(Point::ZERO);
// angle // angle
_emitter->setAngle(90); _emitter->setAngle(90);
_emitter->setAngleVar(360); _emitter->setAngleVar(360);
// speed of particles // speed of particles
_emitter->setSpeed(160); _emitter->setSpeed(160);
_emitter->setSpeedVar(20); _emitter->setSpeedVar(20);
// radial // radial
_emitter->setRadialAccel(-120); _emitter->setRadialAccel(-120);
_emitter->setRadialAccelVar(0); _emitter->setRadialAccelVar(0);
// tagential // tagential
_emitter->setTangentialAccel(30); _emitter->setTangentialAccel(30);
_emitter->setTangentialAccelVar(0); _emitter->setTangentialAccelVar(0);
// emitter position // emitter position
_emitter->setPosition( Point(160,240) ); _emitter->setPosition( Point(160,240) );
_emitter->setPosVar(Point::ZERO); _emitter->setPosVar(Point::ZERO);
// life of particles // life of particles
_emitter->setLife(4); _emitter->setLife(4);
_emitter->setLifeVar(1); _emitter->setLifeVar(1);
// spin of particles // spin of particles
_emitter->setStartSpin(0); _emitter->setStartSpin(0);
_emitter->setStartSizeVar(0); _emitter->setStartSizeVar(0);
_emitter->setEndSpin(0); _emitter->setEndSpin(0);
_emitter->setEndSpinVar(0); _emitter->setEndSpinVar(0);
// color of particles // color of particles
Color4F startColor(0.5f, 0.5f, 0.5f, 1.0f); Color4F startColor(0.5f, 0.5f, 0.5f, 1.0f);
_emitter->setStartColor(startColor); _emitter->setStartColor(startColor);
Color4F startColorVar(0.5f, 0.5f, 0.5f, 1.0f); Color4F startColorVar(0.5f, 0.5f, 0.5f, 1.0f);
_emitter->setStartColorVar(startColorVar); _emitter->setStartColorVar(startColorVar);
Color4F endColor(0.1f, 0.1f, 0.1f, 0.2f); Color4F endColor(0.1f, 0.1f, 0.1f, 0.2f);
_emitter->setEndColor(endColor); _emitter->setEndColor(endColor);
Color4F endColorVar(0.1f, 0.1f, 0.1f, 0.2f); Color4F endColorVar(0.1f, 0.1f, 0.1f, 0.2f);
_emitter->setEndColorVar(endColorVar); _emitter->setEndColorVar(endColorVar);
// size, in pixels // size, in pixels
_emitter->setStartSize(80.0f); _emitter->setStartSize(80.0f);
_emitter->setStartSizeVar(40.0f); _emitter->setStartSizeVar(40.0f);
_emitter->setEndSize(ParticleSystem::START_SIZE_EQUAL_TO_END_SIZE); _emitter->setEndSize(ParticleSystem::START_SIZE_EQUAL_TO_END_SIZE);
// emits per second // emits per second
_emitter->setEmissionRate(_emitter->getTotalParticles()/_emitter->getLife()); _emitter->setEmissionRate(_emitter->getTotalParticles()/_emitter->getLife());
// additive // additive
_emitter->setBlendAdditive(true); _emitter->setBlendAdditive(true);
@ -224,33 +224,33 @@ void DemoRotFlower::onEnter()
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
////_emitter->release(); // win32 : Remove this line ////_emitter->release(); // win32 : Remove this line
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_stars2) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_stars2) );
// duration // duration
_emitter->setDuration(-1); _emitter->setDuration(-1);
// gravity // gravity
_emitter->setGravity(Point::ZERO); _emitter->setGravity(Point::ZERO);
// angle // angle
_emitter->setAngle(90); _emitter->setAngle(90);
_emitter->setAngleVar(360); _emitter->setAngleVar(360);
// speed of particles // speed of particles
_emitter->setSpeed(160); _emitter->setSpeed(160);
_emitter->setSpeedVar(20); _emitter->setSpeedVar(20);
// radial // radial
_emitter->setRadialAccel(-120); _emitter->setRadialAccel(-120);
_emitter->setRadialAccelVar(0); _emitter->setRadialAccelVar(0);
// tagential // tagential
_emitter->setTangentialAccel(30); _emitter->setTangentialAccel(30);
_emitter->setTangentialAccelVar(0); _emitter->setTangentialAccelVar(0);
// emitter position // emitter position
_emitter->setPosition( Point(160,240) ); _emitter->setPosition( Point(160,240) );
_emitter->setPosVar(Point::ZERO); _emitter->setPosVar(Point::ZERO);
// life of particles // life of particles
_emitter->setLife(3); _emitter->setLife(3);
_emitter->setLifeVar(1); _emitter->setLifeVar(1);
@ -260,31 +260,31 @@ void DemoRotFlower::onEnter()
_emitter->setStartSpinVar(0); _emitter->setStartSpinVar(0);
_emitter->setEndSpin(0); _emitter->setEndSpin(0);
_emitter->setEndSpinVar(2000); _emitter->setEndSpinVar(2000);
// color of particles // color of particles
Color4F startColor(0.5f, 0.5f, 0.5f, 1.0f); Color4F startColor(0.5f, 0.5f, 0.5f, 1.0f);
_emitter->setStartColor(startColor); _emitter->setStartColor(startColor);
Color4F startColorVar(0.5f, 0.5f, 0.5f, 1.0f); Color4F startColorVar(0.5f, 0.5f, 0.5f, 1.0f);
_emitter->setStartColorVar(startColorVar); _emitter->setStartColorVar(startColorVar);
Color4F endColor(0.1f, 0.1f, 0.1f, 0.2f); Color4F endColor(0.1f, 0.1f, 0.1f, 0.2f);
_emitter->setEndColor(endColor); _emitter->setEndColor(endColor);
Color4F endColorVar(0.1f, 0.1f, 0.1f, 0.2f); Color4F endColorVar(0.1f, 0.1f, 0.1f, 0.2f);
_emitter->setEndColorVar(endColorVar); _emitter->setEndColorVar(endColorVar);
// size, in pixels // size, in pixels
_emitter->setStartSize(30.0f); _emitter->setStartSize(30.0f);
_emitter->setStartSizeVar(00.0f); _emitter->setStartSizeVar(00.0f);
_emitter->setEndSize(ParticleSystem::START_SIZE_EQUAL_TO_END_SIZE); _emitter->setEndSize(ParticleSystem::START_SIZE_EQUAL_TO_END_SIZE);
// emits per second // emits per second
_emitter->setEmissionRate(_emitter->getTotalParticles()/_emitter->getLife()); _emitter->setEmissionRate(_emitter->getTotalParticles()/_emitter->getLife());
// additive // additive
_emitter->setBlendAdditive(false); _emitter->setBlendAdditive(false);
setEmitterPosition(); setEmitterPosition();
} }
@ -305,9 +305,9 @@ void DemoMeteor::onEnter()
_emitter = ParticleMeteor::create(); _emitter = ParticleMeteor::create();
_emitter->retain(); _emitter->retain();
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) );
setEmitterPosition(); setEmitterPosition();
} }
@ -328,9 +328,9 @@ void DemoSpiral::onEnter()
_emitter = ParticleSpiral::create(); _emitter = ParticleSpiral::create();
_emitter->retain(); _emitter->retain();
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) );
setEmitterPosition(); setEmitterPosition();
} }
@ -351,11 +351,11 @@ void DemoExplosion::onEnter()
_emitter = ParticleExplosion::create(); _emitter = ParticleExplosion::create();
_emitter->retain(); _emitter->retain();
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_stars1) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_stars1) );
_emitter->setAutoRemoveOnFinish(true); _emitter->setAutoRemoveOnFinish(true);
setEmitterPosition(); setEmitterPosition();
} }
@ -377,10 +377,10 @@ void DemoSmoke::onEnter()
_emitter->retain(); _emitter->retain();
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) );
auto p = _emitter->getPosition(); auto p = _emitter->getPosition();
_emitter->setPosition( Point( p.x, 100) ); _emitter->setPosition( Point( p.x, 100) );
setEmitterPosition(); setEmitterPosition();
} }
@ -401,34 +401,34 @@ void DemoSnow::onEnter()
_emitter = ParticleSnow::create(); _emitter = ParticleSnow::create();
_emitter->retain(); _emitter->retain();
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
auto p = _emitter->getPosition(); auto p = _emitter->getPosition();
_emitter->setPosition( Point( p.x, p.y-110) ); _emitter->setPosition( Point( p.x, p.y-110) );
_emitter->setLife(3); _emitter->setLife(3);
_emitter->setLifeVar(1); _emitter->setLifeVar(1);
// gravity // gravity
_emitter->setGravity(Point(0,-10)); _emitter->setGravity(Point(0,-10));
// speed of particles // speed of particles
_emitter->setSpeed(130); _emitter->setSpeed(130);
_emitter->setSpeedVar(30); _emitter->setSpeedVar(30);
Color4F startColor = _emitter->getStartColor(); Color4F startColor = _emitter->getStartColor();
startColor.r = 0.9f; startColor.r = 0.9f;
startColor.g = 0.9f; startColor.g = 0.9f;
startColor.b = 0.9f; startColor.b = 0.9f;
_emitter->setStartColor(startColor); _emitter->setStartColor(startColor);
Color4F startColorVar = _emitter->getStartColorVar(); Color4F startColorVar = _emitter->getStartColorVar();
startColorVar.b = 0.1f; startColorVar.b = 0.1f;
_emitter->setStartColorVar(startColorVar); _emitter->setStartColorVar(startColorVar);
_emitter->setEmissionRate(_emitter->getTotalParticles()/_emitter->getLife()); _emitter->setEmissionRate(_emitter->getTotalParticles()/_emitter->getLife());
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_snow) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_snow) );
setEmitterPosition(); setEmitterPosition();
} }
@ -449,13 +449,13 @@ void DemoRain::onEnter()
_emitter = ParticleRain::create(); _emitter = ParticleRain::create();
_emitter->retain(); _emitter->retain();
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
auto p = _emitter->getPosition(); auto p = _emitter->getPosition();
_emitter->setPosition( Point( p.x, p.y-100) ); _emitter->setPosition( Point( p.x, p.y-100) );
_emitter->setLife(4); _emitter->setLife(4);
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) );
setEmitterPosition(); setEmitterPosition();
} }
@ -473,74 +473,74 @@ void DemoModernArt::onEnter()
{ {
ParticleDemo::onEnter(); ParticleDemo::onEnter();
//FIXME: If use ParticleSystemPoint, bada 1.0 device will crash. //FIXME: If use ParticleSystemPoint, bada 1.0 device will crash.
// Crash place: ParticleSystemPoint.cpp Line 149, function: glDrawArrays(GL_POINTS, 0, _particleIdx); // Crash place: ParticleSystemPoint.cpp Line 149, function: glDrawArrays(GL_POINTS, 0, _particleIdx);
_emitter = ParticleSystemQuad::createWithTotalParticles(1000); _emitter = ParticleSystemQuad::createWithTotalParticles(1000);
_emitter->retain(); _emitter->retain();
_background->addChild(_emitter, 10); _background->addChild(_emitter, 10);
////_emitter->release(); ////_emitter->release();
auto s = Director::getInstance()->getWinSize(); auto s = Director::getInstance()->getWinSize();
// duration // duration
_emitter->setDuration(-1); _emitter->setDuration(-1);
// gravity // gravity
_emitter->setGravity(Point(0,0)); _emitter->setGravity(Point(0,0));
// angle // angle
_emitter->setAngle(0); _emitter->setAngle(0);
_emitter->setAngleVar(360); _emitter->setAngleVar(360);
// radial // radial
_emitter->setRadialAccel(70); _emitter->setRadialAccel(70);
_emitter->setRadialAccelVar(10); _emitter->setRadialAccelVar(10);
// tagential // tagential
_emitter->setTangentialAccel(80); _emitter->setTangentialAccel(80);
_emitter->setTangentialAccelVar(0); _emitter->setTangentialAccelVar(0);
// speed of particles // speed of particles
_emitter->setSpeed(50); _emitter->setSpeed(50);
_emitter->setSpeedVar(10); _emitter->setSpeedVar(10);
// emitter position // emitter position
_emitter->setPosition( Point( s.width/2, s.height/2) ); _emitter->setPosition( Point( s.width/2, s.height/2) );
_emitter->setPosVar(Point::ZERO); _emitter->setPosVar(Point::ZERO);
// life of particles // life of particles
_emitter->setLife(2.0f); _emitter->setLife(2.0f);
_emitter->setLifeVar(0.3f); _emitter->setLifeVar(0.3f);
// emits per frame // emits per frame
_emitter->setEmissionRate(_emitter->getTotalParticles()/_emitter->getLife()); _emitter->setEmissionRate(_emitter->getTotalParticles()/_emitter->getLife());
// color of particles // color of particles
Color4F startColor(0.5f, 0.5f, 0.5f, 1.0f); Color4F startColor(0.5f, 0.5f, 0.5f, 1.0f);
_emitter->setStartColor(startColor); _emitter->setStartColor(startColor);
Color4F startColorVar(0.5f, 0.5f, 0.5f, 1.0f); Color4F startColorVar(0.5f, 0.5f, 0.5f, 1.0f);
_emitter->setStartColorVar(startColorVar); _emitter->setStartColorVar(startColorVar);
Color4F endColor(0.1f, 0.1f, 0.1f, 0.2f); Color4F endColor(0.1f, 0.1f, 0.1f, 0.2f);
_emitter->setEndColor(endColor); _emitter->setEndColor(endColor);
Color4F endColorVar(0.1f, 0.1f, 0.1f, 0.2f); Color4F endColorVar(0.1f, 0.1f, 0.1f, 0.2f);
_emitter->setEndColorVar(endColorVar); _emitter->setEndColorVar(endColorVar);
// size, in pixels // size, in pixels
_emitter->setStartSize(1.0f); _emitter->setStartSize(1.0f);
_emitter->setStartSizeVar(1.0f); _emitter->setStartSizeVar(1.0f);
_emitter->setEndSize(32.0f); _emitter->setEndSize(32.0f);
_emitter->setEndSizeVar(8.0f); _emitter->setEndSizeVar(8.0f);
// texture // texture
_emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) ); _emitter->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) );
// additive // additive
_emitter->setBlendAdditive(false); _emitter->setBlendAdditive(false);
setEmitterPosition(); setEmitterPosition();
} }
@ -551,7 +551,7 @@ std::string DemoModernArt::title()
//------------------------------------------------------------------ //------------------------------------------------------------------
// //
// DemoRing // DemoRing
// //
//------------------------------------------------------------------ //------------------------------------------------------------------
void DemoRing::onEnter() void DemoRing::onEnter()
@ -569,7 +569,7 @@ void DemoRing::onEnter()
_emitter->setSpeed(100); _emitter->setSpeed(100);
_emitter->setSpeedVar(0); _emitter->setSpeedVar(0);
_emitter->setEmissionRate(10000); _emitter->setEmissionRate(10000);
setEmitterPosition(); setEmitterPosition();
} }
@ -586,16 +586,16 @@ std::string DemoRing::title()
void ParallaxParticle::onEnter() void ParallaxParticle::onEnter()
{ {
ParticleDemo::onEnter(); ParticleDemo::onEnter();
_background->getParent()->removeChild(_background, true); _background->getParent()->removeChild(_background, true);
_background = NULL; _background = NULL;
auto p = ParallaxNode::create(); auto p = ParallaxNode::create();
addChild(p, 5); addChild(p, 5);
auto p1 = Sprite::create(s_back3); auto p1 = Sprite::create(s_back3);
auto p2 = Sprite::create(s_back3); auto p2 = Sprite::create(s_back3);
p->addChild( p1, 1, Point(0.5f,1), Point(0,250) ); p->addChild( p1, 1, Point(0.5f,1), Point(0,250) );
p->addChild(p2, 2, Point(1.5f,1), Point(0,50) ); p->addChild(p2, 2, Point(1.5f,1), Point(0,50) );
@ -605,15 +605,15 @@ void ParallaxParticle::onEnter()
p1->addChild(_emitter, 10); p1->addChild(_emitter, 10);
_emitter->setPosition( Point(250,200) ); _emitter->setPosition( Point(250,200) );
auto par = ParticleSun::create(); auto par = ParticleSun::create();
p2->addChild(par, 10); p2->addChild(par, 10);
par->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) ); par->setTexture( Director::getInstance()->getTextureCache()->addImage(s_fire) );
auto move = MoveBy::create(4, Point(300,0)); auto move = MoveBy::create(4, Point(300,0));
auto move_back = move->reverse(); auto move_back = move->reverse();
auto seq = Sequence::create( move, move_back, NULL); auto seq = Sequence::create( move, move_back, NULL);
p->runAction(RepeatForever::create(seq)); p->runAction(RepeatForever::create(seq));
} }
std::string ParallaxParticle::title() std::string ParallaxParticle::title()
@ -685,7 +685,7 @@ void RadiusMode1::onEnter()
Color4F endColor(0.1f, 0.1f, 0.1f, 0.2f); Color4F endColor(0.1f, 0.1f, 0.1f, 0.2f);
_emitter->setEndColor(endColor); _emitter->setEndColor(endColor);
Color4F endColorVar(0.1f, 0.1f, 0.1f, 0.2f); Color4F endColorVar(0.1f, 0.1f, 0.1f, 0.2f);
_emitter->setEndColorVar(endColorVar); _emitter->setEndColorVar(endColorVar);
// size, in pixels // size, in pixels
@ -769,7 +769,7 @@ void RadiusMode2::onEnter()
Color4F endColor(0.1f, 0.1f, 0.1f, 0.2f); Color4F endColor(0.1f, 0.1f, 0.1f, 0.2f);
_emitter->setEndColor(endColor); _emitter->setEndColor(endColor);
Color4F endColorVar(0.1f, 0.1f, 0.1f, 0.2f); Color4F endColorVar(0.1f, 0.1f, 0.1f, 0.2f);
_emitter->setEndColorVar(endColorVar); _emitter->setEndColorVar(endColorVar);
// size, in pixels // size, in pixels
@ -853,7 +853,7 @@ void Issue704::onEnter()
Color4F endColor(0.1f, 0.1f, 0.1f, 0.2f); Color4F endColor(0.1f, 0.1f, 0.1f, 0.2f);
_emitter->setEndColor(endColor); _emitter->setEndColor(endColor);
Color4F endColorVar(0.1f, 0.1f, 0.1f, 0.2f); Color4F endColorVar(0.1f, 0.1f, 0.1f, 0.2f);
_emitter->setEndColorVar(endColorVar); _emitter->setEndColorVar(endColorVar);
// size, in pixels // size, in pixels
@ -956,7 +956,7 @@ enum
IDC_TOGGLE IDC_TOGGLE
}; };
static int sceneIdx = -1; static int sceneIdx = -1;
#define MAX_LAYER 44 #define MAX_LAYER 44
@ -1033,8 +1033,8 @@ Layer* backParticleAction()
sceneIdx--; sceneIdx--;
int total = MAX_LAYER; int total = MAX_LAYER;
if( sceneIdx < 0 ) if( sceneIdx < 0 )
sceneIdx += total; sceneIdx += total;
auto layer = createParticleLayer(sceneIdx); auto layer = createParticleLayer(sceneIdx);
layer->autorelease(); layer->autorelease();
@ -1047,7 +1047,7 @@ Layer* restartParticleAction()
layer->autorelease(); layer->autorelease();
return layer; return layer;
} }
ParticleDemo::~ParticleDemo(void) ParticleDemo::~ParticleDemo(void)
{ {
@ -1060,46 +1060,46 @@ void ParticleDemo::onEnter(void)
_color = LayerColor::create( Color4B(127,127,127,255) ); _color = LayerColor::create( Color4B(127,127,127,255) );
this->addChild(_color); this->addChild(_color);
_emitter = NULL; _emitter = NULL;
auto listener = EventListenerTouchAllAtOnce::create(); auto listener = EventListenerTouchAllAtOnce::create();
listener->onTouchesBegan = CC_CALLBACK_2(ParticleDemo::onTouchesBegan, this); listener->onTouchesBegan = CC_CALLBACK_2(ParticleDemo::onTouchesBegan, this);
listener->onTouchesMoved = CC_CALLBACK_2(ParticleDemo::onTouchesMoved, this); listener->onTouchesMoved = CC_CALLBACK_2(ParticleDemo::onTouchesMoved, this);
listener->onTouchesEnded = CC_CALLBACK_2(ParticleDemo::onTouchesEnded, this); listener->onTouchesEnded = CC_CALLBACK_2(ParticleDemo::onTouchesEnded, this);
_eventDispatcher->addEventListenerWithSceneGraphPriority(listener, this); _eventDispatcher->addEventListenerWithSceneGraphPriority(listener, this);
auto s = Director::getInstance()->getWinSize(); auto s = Director::getInstance()->getWinSize();
auto item4 = MenuItemToggle::createWithCallback( CC_CALLBACK_1(ParticleDemo::toggleCallback, this), auto item4 = MenuItemToggle::createWithCallback( CC_CALLBACK_1(ParticleDemo::toggleCallback, this),
MenuItemFont::create( "Free Movement" ), MenuItemFont::create( "Free Movement" ),
MenuItemFont::create( "Relative Movement" ), MenuItemFont::create( "Relative Movement" ),
MenuItemFont::create( "Grouped Movement" ), MenuItemFont::create( "Grouped Movement" ),
NULL ); NULL );
auto menu = Menu::create(item4, NULL); auto menu = Menu::create(item4, NULL);
menu->setPosition( Point::ZERO ); menu->setPosition( Point::ZERO );
item4->setPosition( Point( VisibleRect::left().x, VisibleRect::bottom().y+ 100) ); item4->setPosition( Point( VisibleRect::left().x, VisibleRect::bottom().y+ 100) );
item4->setAnchorPoint( Point(0,0) ); item4->setAnchorPoint( Point(0,0) );
addChild( menu, 100 ); addChild( menu, 100 );
auto labelAtlas = LabelAtlas::create("0000", "fps_images.png", 12, 32, '.'); auto labelAtlas = LabelAtlas::create("0000", "fps_images.png", 12, 32, '.');
addChild(labelAtlas, 100, kTagParticleCount); addChild(labelAtlas, 100, kTagParticleCount);
labelAtlas->setPosition(Point(s.width-66,50)); labelAtlas->setPosition(Point(s.width-66,50));
// moving background // moving background
_background = Sprite::create(s_back3); _background = Sprite::create(s_back3);
addChild(_background, 5); addChild(_background, 5);
_background->setPosition( Point(s.width/2, s.height-180) ); _background->setPosition( Point(s.width/2, s.height-180) );
auto move = MoveBy::create(4, Point(300,0) ); auto move = MoveBy::create(4, Point(300,0) );
auto move_back = move->reverse(); auto move_back = move->reverse();
auto seq = Sequence::create( move, move_back, NULL); auto seq = Sequence::create( move, move_back, NULL);
_background->runAction( RepeatForever::create(seq) ); _background->runAction( RepeatForever::create(seq) );
scheduleUpdate(); scheduleUpdate();
} }
@ -1110,7 +1110,7 @@ std::string ParticleDemo::title()
std::string ParticleDemo::subtitle() std::string ParticleDemo::subtitle()
{ {
return "No titile"; return "No title";
} }
void ParticleDemo::onTouchesBegan(const std::vector<Touch*>& touches, Event *event) void ParticleDemo::onTouchesBegan(const std::vector<Touch*>& touches, Event *event)
@ -1126,7 +1126,7 @@ void ParticleDemo::onTouchesMoved(const std::vector<Touch*>& touches, Event *ev
void ParticleDemo::onTouchesEnded(const std::vector<Touch*>& touches, Event *event) void ParticleDemo::onTouchesEnded(const std::vector<Touch*>& touches, Event *event)
{ {
auto touch = touches[0]; auto touch = touches[0];
auto location = touch->getLocation(); auto location = touch->getLocation();
auto pos = Point::ZERO; auto pos = Point::ZERO;
@ -1169,7 +1169,7 @@ void ParticleDemo::restartCallback(Object* sender)
{ {
if (_emitter != NULL) if (_emitter != NULL)
{ {
_emitter->resetSystem(); _emitter->resetSystem();
} }
} }
@ -1187,7 +1187,7 @@ void ParticleDemo::backCallback(Object* sender)
s->addChild( backParticleAction() ); s->addChild( backParticleAction() );
Director::getInstance()->replaceScene(s); Director::getInstance()->replaceScene(s);
s->release(); s->release();
} }
void ParticleDemo::setEmitterPosition() void ParticleDemo::setEmitterPosition()
{ {
@ -1217,10 +1217,10 @@ void ParticleBatchHybrid::onEnter()
addChild(batch, 10); addChild(batch, 10);
schedule(schedule_selector(ParticleBatchHybrid::switchRender), 2.0f); schedule(schedule_selector(ParticleBatchHybrid::switchRender), 2.0f);
auto node = Node::create(); auto node = Node::create();
addChild(node); addChild(node);
_parent1 = batch; _parent1 = batch;
_parent2 = node; _parent2 = node;
} }
@ -1229,16 +1229,16 @@ void ParticleBatchHybrid::switchRender(float dt)
{ {
bool usingBatch = ( _emitter->getBatchNode() != NULL ); bool usingBatch = ( _emitter->getBatchNode() != NULL );
_emitter->removeFromParentAndCleanup(false); _emitter->removeFromParentAndCleanup(false);
auto newParent = (usingBatch ? _parent2 : _parent1 ); auto newParent = (usingBatch ? _parent2 : _parent1 );
newParent->addChild(_emitter); newParent->addChild(_emitter);
log("Particle: Using new parent: %s", usingBatch ? "CCNode" : "CCParticleBatchNode"); log("Particle: Using new parent: %s", usingBatch ? "CCNode" : "CCParticleBatchNode");
} }
std::string ParticleBatchHybrid::title() std::string ParticleBatchHybrid::title()
{ {
return "Paticle Batch"; return "Particle Batch";
} }
std::string ParticleBatchHybrid::subtitle() std::string ParticleBatchHybrid::subtitle()
@ -1280,7 +1280,7 @@ void ParticleBatchMultipleEmitters::onEnter()
std::string ParticleBatchMultipleEmitters::title() std::string ParticleBatchMultipleEmitters::title()
{ {
return "Paticle Batch"; return "Particle Batch";
} }
std::string ParticleBatchMultipleEmitters::subtitle() std::string ParticleBatchMultipleEmitters::subtitle()
@ -1304,7 +1304,7 @@ void ParticleReorder::onEnter()
auto parent2 = ParticleBatchNode::createWithTexture(ignore->getTexture()); auto parent2 = ParticleBatchNode::createWithTexture(ignore->getTexture());
ignore->unscheduleUpdate(); ignore->unscheduleUpdate();
for( unsigned int i=0; i<2;i++) for( unsigned int i=0; i<2;i++)
{ {
auto parent = ( i==0 ? parent1 : parent2 ); auto parent = ( i==0 ? parent1 : parent2 );
@ -1499,7 +1499,7 @@ void MultipleParticleSystems::onEnter()
removeChild(_background, true); removeChild(_background, true);
_background = NULL; _background = NULL;
Director::getInstance()->getTextureCache()->addImage("Images/particles.png"); Director::getInstance()->getTextureCache()->addImage("Images/particles.png");
for (int i = 0; i<5; i++) { for (int i = 0; i<5; i++) {
auto particleSystem = ParticleSystemQuad::create("Particles/SpinningPeas.plist"); auto particleSystem = ParticleSystemQuad::create("Particles/SpinningPeas.plist");
@ -1528,15 +1528,15 @@ void MultipleParticleSystems::update(float dt)
{ {
auto atlas = (LabelAtlas*) getChildByTag(kTagParticleCount); auto atlas = (LabelAtlas*) getChildByTag(kTagParticleCount);
unsigned int count = 0; unsigned int count = 0;
Object* pObj = NULL; Object* pObj = NULL;
CCARRAY_FOREACH(getChildren(), pObj) CCARRAY_FOREACH(getChildren(), pObj)
{ {
auto item = dynamic_cast<ParticleSystem*>(pObj); auto item = dynamic_cast<ParticleSystem*>(pObj);
if (item != NULL) if (item != NULL)
{ {
count += item->getParticleCount(); count += item->getParticleCount();
} }
} }
char str[100] = {0}; char str[100] = {0};
@ -1579,8 +1579,8 @@ void MultipleParticleSystemsBatched::update(float dt)
{ {
auto atlas = (LabelAtlas*) getChildByTag(kTagParticleCount); auto atlas = (LabelAtlas*) getChildByTag(kTagParticleCount);
unsigned count = 0; unsigned count = 0;
auto batchNode = getChildByTag(2); auto batchNode = getChildByTag(2);
Object* pObj = NULL; Object* pObj = NULL;
CCARRAY_FOREACH(batchNode->getChildren(), pObj) CCARRAY_FOREACH(batchNode->getChildren(), pObj)
@ -1588,7 +1588,7 @@ void MultipleParticleSystemsBatched::update(float dt)
auto item = dynamic_cast<ParticleSystem*>(pObj); auto item = dynamic_cast<ParticleSystem*>(pObj);
if (item != NULL) if (item != NULL)
{ {
count += item->getParticleCount(); count += item->getParticleCount();
} }
} }
char str[50] = {0}; char str[50] = {0};
@ -1631,7 +1631,7 @@ void AddAndDeleteParticleSystems::onEnter()
particleSystem->setPosition(Point(i*15 +100,i*15+100)); particleSystem->setPosition(Point(i*15 +100,i*15+100));
unsigned int randZ = rand() % 100; unsigned int randZ = rand() % 100;
_batchNode->addChild(particleSystem, randZ, -1); _batchNode->addChild(particleSystem, randZ, -1);
} }
@ -1644,7 +1644,7 @@ void AddAndDeleteParticleSystems::onEnter()
void AddAndDeleteParticleSystems::removeSystem(float dt) void AddAndDeleteParticleSystems::removeSystem(float dt)
{ {
int nChildrenCount = _batchNode->getChildren()->count(); int nChildrenCount = _batchNode->getChildren()->count();
if (nChildrenCount > 0) if (nChildrenCount > 0)
{ {
CCLOG("remove random system"); CCLOG("remove random system");
unsigned int uRand = rand() % (nChildrenCount - 1); unsigned int uRand = rand() % (nChildrenCount - 1);
@ -1659,7 +1659,7 @@ void AddAndDeleteParticleSystems::removeSystem(float dt)
particleSystem->setPosition(Point(rand() % 300 ,rand() % 400)); particleSystem->setPosition(Point(rand() % 300 ,rand() % 400));
CCLOG("add a new system"); CCLOG("add a new system");
unsigned int randZ = rand() % 100; unsigned int randZ = rand() % 100;
_batchNode->addChild(particleSystem, randZ, -1); _batchNode->addChild(particleSystem, randZ, -1);
} }
} }
@ -1668,8 +1668,8 @@ void AddAndDeleteParticleSystems::update(float dt)
{ {
auto atlas = (LabelAtlas*) getChildByTag(kTagParticleCount); auto atlas = (LabelAtlas*) getChildByTag(kTagParticleCount);
unsigned int count = 0; unsigned int count = 0;
auto batchNode = getChildByTag(2); auto batchNode = getChildByTag(2);
Object* pObj = NULL; Object* pObj = NULL;
CCARRAY_FOREACH(batchNode->getChildren(), pObj) CCARRAY_FOREACH(batchNode->getChildren(), pObj)
@ -1677,7 +1677,7 @@ void AddAndDeleteParticleSystems::update(float dt)
auto item = dynamic_cast<ParticleSystem*>(pObj); auto item = dynamic_cast<ParticleSystem*>(pObj);
if (item != NULL) if (item != NULL)
{ {
count += item->getParticleCount(); count += item->getParticleCount();
} }
} }
char str[100] = {0}; char str[100] = {0};
@ -1796,7 +1796,7 @@ void ReorderParticleSystems::onEnter()
void ReorderParticleSystems::reorderSystem(float time) void ReorderParticleSystems::reorderSystem(float time)
{ {
auto system = (ParticleSystem*)_batchNode->getChildren()->getObjectAtIndex(1); auto system = (ParticleSystem*)_batchNode->getChildren()->getObjectAtIndex(1);
_batchNode->reorderChild(system, system->getZOrder() - 1); _batchNode->reorderChild(system, system->getZOrder() - 1);
} }
@ -1804,8 +1804,8 @@ void ReorderParticleSystems::update(float dt)
{ {
auto atlas = (LabelAtlas*) getChildByTag(kTagParticleCount); auto atlas = (LabelAtlas*) getChildByTag(kTagParticleCount);
unsigned int count = 0; unsigned int count = 0;
auto batchNode = getChildByTag(2); auto batchNode = getChildByTag(2);
Object* pObj = NULL; Object* pObj = NULL;
CCARRAY_FOREACH(batchNode->getChildren(), pObj) CCARRAY_FOREACH(batchNode->getChildren(), pObj)
@ -1813,7 +1813,7 @@ void ReorderParticleSystems::update(float dt)
auto item = dynamic_cast<ParticleSystem*>(pObj); auto item = dynamic_cast<ParticleSystem*>(pObj);
if (item != NULL) if (item != NULL)
{ {
count += item->getParticleCount(); count += item->getParticleCount();
} }
} }
char str[100] = {0}; char str[100] = {0};

View File

@ -519,7 +519,7 @@ void SpriteMainScene::onEnter()
auto director = Director::getInstance(); auto director = Director::getInstance();
auto sched = director->getScheduler(); auto sched = director->getScheduler();
sched->scheduleSelector(SEL_SCHEDULE(&SpriteMainScene::updateAutoTest), this, 0.2, false); sched->scheduleSelector(SEL_SCHEDULE(&SpriteMainScene::updateAutoTest), this, 0.2f, false);
} }
} }

View File

@ -686,7 +686,6 @@ void PhysicsDemoJoints::onEnter()
node->setPhysicsBody(box); node->setPhysicsBody(box);
box->setDynamic(false); box->setDynamic(false);
node->setPosition(Point::ZERO); node->setPosition(Point::ZERO);
this->addChild(node); this->addChild(node);
for (int i = 0; i < 4; ++i) for (int i = 0; i < 4; ++i)
@ -749,9 +748,115 @@ void PhysicsDemoJoints::onEnter()
auto sp2 = makeBox(offset + Point(30, 0), Size(30, 10)); auto sp2 = makeBox(offset + Point(30, 0), Size(30, 10));
sp2->getPhysicsBody()->setTag(DRAG_BODYS_TAG); sp2->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
PhysicsJointLimit* joint = PhysicsJointLimit::construct(sp1->getPhysicsBody(), sp2->getPhysicsBody(), Point::ZERO, Point::ZERO); PhysicsJointLimit* joint = PhysicsJointLimit::construct(sp1->getPhysicsBody(), sp2->getPhysicsBody(), Point::ZERO, Point::ZERO, 30.0f, 60.0f);
joint->setMin(30.0f); _scene->getPhysicsWorld()->addJoint(joint);
joint->setMax(60.0f);
this->addChild(sp1);
this->addChild(sp2);
break;
}
case 4:
{
auto sp1 = makeBall(offset - Point(30, 0), 10);
sp1->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
auto sp2 = makeBox(offset + Point(30, 0), Size(30, 10));
sp2->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
PhysicsJointSpring* joint = PhysicsJointSpring::construct(sp1->getPhysicsBody(), sp2->getPhysicsBody(), Point::ZERO, Point::ZERO, 500.0f, 0.3f);
_scene->getPhysicsWorld()->addJoint(joint);
this->addChild(sp1);
this->addChild(sp2);
break;
}
case 5:
{
auto sp1 = makeBall(offset - Point(30, 0), 10);
sp1->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
auto sp2 = makeBox(offset + Point(30, 0), Size(30, 10));
sp2->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
PhysicsJointGroove* joint = PhysicsJointGroove::construct(sp1->getPhysicsBody(), sp2->getPhysicsBody(), Point(30, 15), Point(30, -15), Point(-30, 0));
_scene->getPhysicsWorld()->addJoint(joint);
this->addChild(sp1);
this->addChild(sp2);
break;
}
case 6:
{
auto sp1 = makeBox(offset - Point(30, 0), Size(30, 10));
sp1->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
auto sp2 = makeBox(offset + Point(30, 0), Size(30, 10));
sp2->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
_scene->getPhysicsWorld()->addJoint(PhysicsJointPin::construct(sp1->getPhysicsBody(), box, sp1->getPosition()));
_scene->getPhysicsWorld()->addJoint(PhysicsJointPin::construct(sp2->getPhysicsBody(), box, sp2->getPosition()));
PhysicsJointRotarySpring* joint = PhysicsJointRotarySpring::construct(sp1->getPhysicsBody(), sp2->getPhysicsBody(), 3000.0f, 60.0f);
_scene->getPhysicsWorld()->addJoint(joint);
this->addChild(sp1);
this->addChild(sp2);
break;
}
case 7:
{
auto sp1 = makeBox(offset - Point(30, 0), Size(30, 10));
sp1->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
auto sp2 = makeBox(offset + Point(30, 0), Size(30, 10));
sp2->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
_scene->getPhysicsWorld()->addJoint(PhysicsJointPin::construct(sp1->getPhysicsBody(), box, sp1->getPosition()));
_scene->getPhysicsWorld()->addJoint(PhysicsJointPin::construct(sp2->getPhysicsBody(), box, sp2->getPosition()));
PhysicsJointRotaryLimit* joint = PhysicsJointRotaryLimit::construct(sp1->getPhysicsBody(), sp2->getPhysicsBody(), 0.0f, M_PI_2);
_scene->getPhysicsWorld()->addJoint(joint);
this->addChild(sp1);
this->addChild(sp2);
break;
}
case 8:
{
auto sp1 = makeBox(offset - Point(30, 0), Size(30, 10));
sp1->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
auto sp2 = makeBox(offset + Point(30, 0), Size(30, 10));
sp2->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
_scene->getPhysicsWorld()->addJoint(PhysicsJointPin::construct(sp1->getPhysicsBody(), box, sp1->getPosition()));
_scene->getPhysicsWorld()->addJoint(PhysicsJointPin::construct(sp2->getPhysicsBody(), box, sp2->getPosition()));
PhysicsJointRatchet* joint = PhysicsJointRatchet::construct(sp1->getPhysicsBody(), sp2->getPhysicsBody(), 0.0f, M_PI_2);
_scene->getPhysicsWorld()->addJoint(joint);
this->addChild(sp1);
this->addChild(sp2);
break;
}
case 9:
{
auto sp1 = makeBox(offset - Point(30, 0), Size(30, 10));
sp1->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
auto sp2 = makeBox(offset + Point(30, 0), Size(30, 10));
sp2->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
_scene->getPhysicsWorld()->addJoint(PhysicsJointPin::construct(sp1->getPhysicsBody(), box, sp1->getPosition()));
_scene->getPhysicsWorld()->addJoint(PhysicsJointPin::construct(sp2->getPhysicsBody(), box, sp2->getPosition()));
PhysicsJointGear* joint = PhysicsJointGear::construct(sp1->getPhysicsBody(), sp2->getPhysicsBody(), 0.0f, 2.0f);
_scene->getPhysicsWorld()->addJoint(joint);
this->addChild(sp1);
this->addChild(sp2);
break;
}
case 10:
{
auto sp1 = makeBox(offset - Point(30, 0), Size(30, 10));
sp1->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
auto sp2 = makeBox(offset + Point(30, 0), Size(30, 10));
sp2->getPhysicsBody()->setTag(DRAG_BODYS_TAG);
_scene->getPhysicsWorld()->addJoint(PhysicsJointPin::construct(sp1->getPhysicsBody(), box, sp1->getPosition()));
_scene->getPhysicsWorld()->addJoint(PhysicsJointPin::construct(sp2->getPhysicsBody(), box, sp2->getPosition()));
PhysicsJointMotor* joint = PhysicsJointMotor::construct(sp1->getPhysicsBody(), sp2->getPhysicsBody(), M_PI_2);
_scene->getPhysicsWorld()->addJoint(joint); _scene->getPhysicsWorld()->addJoint(joint);
this->addChild(sp1); this->addChild(sp1);

View File

@ -52,6 +52,7 @@ static std::function<Layer*()> createFunctions[] =
CL(TexturePNG), CL(TexturePNG),
CL(TextureJPEG), CL(TextureJPEG),
CL(TextureTIFF), CL(TextureTIFF),
CL(TextureTGA),
CL(TextureWEBP), CL(TextureWEBP),
CL(TexturePixelFormat), CL(TexturePixelFormat),
CL(TextureBlend), CL(TextureBlend),
@ -190,6 +191,29 @@ std::string TextureTIFF::title()
return "TIFF Test"; return "TIFF Test";
} }
//------------------------------------------------------------------
//
// TextureTGA
//
//------------------------------------------------------------------
void TextureTGA::onEnter()
{
TextureDemo::onEnter();
auto s = Director::getInstance()->getWinSize();
auto img = Sprite::create("TileMaps/levelmap.tga");
img->setPosition(Point( s.width/2.0f, s.height/2.0f));
this->addChild(img);
Director::getInstance()->getTextureCache()->dumpCachedTextureInfo();
}
std::string TextureTGA::title()
{
return "TGA Test";
}
//------------------------------------------------------------------ //------------------------------------------------------------------
// //
// TexturePNG // TexturePNG

View File

@ -26,6 +26,15 @@ public:
virtual void onEnter(); virtual void onEnter();
}; };
class TextureTGA : public TextureDemo
{
public:
CREATE_FUNC(TextureTGA);
virtual std::string title();
virtual void onEnter();
};
class TexturePNG : public TextureDemo class TexturePNG : public TextureDemo
{ {
public: public:

View File

@ -3,7 +3,7 @@ local armaturePerformanceTag = 20000
local frameEventActionTag = 10000 local frameEventActionTag = 10000
local winSize = cc.Director:getInstance():getWinSize() local winSize = cc.Director:getInstance():getWinSize()
local scheduler = cc.Director:getInstance():getScheduler() local scheduler = cc.Director:getInstance():getScheduler()
local ArmatureTestIndex = local ArmatureTestIndex =
{ {
TEST_ASYNCHRONOUS_LOADING = 1, TEST_ASYNCHRONOUS_LOADING = 1,
TEST_DIRECT_LOADING = 2, TEST_DIRECT_LOADING = 2,
@ -52,7 +52,7 @@ function ArmatureTestScene.create()
bg:setScaleY(scaleY) bg:setScaleY(scaleY)
scene:addChild(bg) scene:addChild(bg)
return scene return scene
end end
function ArmatureTestScene.toMainMenuCallback() function ArmatureTestScene.toMainMenuCallback()
@ -66,7 +66,7 @@ ArmatureTestLayer._restarItem = nil
ArmatureTestLayer._nextItem = nil ArmatureTestLayer._nextItem = nil
function ArmatureTestLayer:onEnter() function ArmatureTestLayer:onEnter()
end end
function ArmatureTestLayer.title(idx) function ArmatureTestLayer.title(idx)
@ -97,7 +97,7 @@ function ArmatureTestLayer.title(idx)
elseif ArmatureTestIndex.TEST_ARMATURE_NESTING == idx then elseif ArmatureTestIndex.TEST_ARMATURE_NESTING == idx then
return "Test Armature Nesting" return "Test Armature Nesting"
elseif ArmatureTestIndex.TEST_ARMATURE_NESTING_2 == idx then elseif ArmatureTestIndex.TEST_ARMATURE_NESTING_2 == idx then
return "Test Armature Nesting 2" return "Test Armature Nesting 2"
end end
end end
@ -127,7 +127,7 @@ function ArmatureTestLayer.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:onEnter() layer:onEnter()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
end end
return layer return layer
end end
@ -152,7 +152,7 @@ end
function ArmatureTestLayer:createMenu() function ArmatureTestLayer:createMenu()
local menu = cc.Menu:create() local menu = cc.Menu:create()
self._backItem = cc.MenuItemImage:create(s_pPathB1, s_pPathB2) self._backItem = cc.MenuItemImage:create(s_pPathB1, s_pPathB2)
self._backItem:registerScriptTapHandler(self.backCallback) self._backItem:registerScriptTapHandler(self.backCallback)
menu:addChild(self._backItem,itemTagBasic) menu:addChild(self._backItem,itemTagBasic)
@ -160,14 +160,14 @@ function ArmatureTestLayer:createMenu()
self._restarItem:registerScriptTapHandler(self.restartCallback) self._restarItem:registerScriptTapHandler(self.restartCallback)
menu:addChild(self._restarItem,itemTagBasic) menu:addChild(self._restarItem,itemTagBasic)
self._nextItem = cc.MenuItemImage:create(s_pPathF1, s_pPathF2) self._nextItem = cc.MenuItemImage:create(s_pPathF1, s_pPathF2)
menu:addChild(self._nextItem,itemTagBasic) menu:addChild(self._nextItem,itemTagBasic)
self._nextItem:registerScriptTapHandler(self.nextCallback) self._nextItem:registerScriptTapHandler(self.nextCallback)
local size = cc.Director:getInstance():getWinSize() local size = cc.Director:getInstance():getWinSize()
self._backItem:setPosition(cc.p(size.width / 2 - self._restarItem:getContentSize().width * 2, self._restarItem:getContentSize().height / 2)) self._backItem:setPosition(cc.p(size.width / 2 - self._restarItem:getContentSize().width * 2, self._restarItem:getContentSize().height / 2))
self._restarItem:setPosition(cc.p(size.width / 2, self._restarItem:getContentSize().height / 2)) self._restarItem:setPosition(cc.p(size.width / 2, self._restarItem:getContentSize().height / 2))
self._nextItem:setPosition(cc.p(size.width / 2 + self._restarItem:getContentSize().width * 2, self._restarItem:getContentSize().height / 2)) self._nextItem:setPosition(cc.p(size.width / 2 + self._restarItem:getContentSize().width * 2, self._restarItem:getContentSize().height / 2))
menu:setPosition(cc.p(0, 0)) menu:setPosition(cc.p(0, 0))
self:addChild(menu) self:addChild(menu)
@ -181,7 +181,7 @@ function ArmatureTestLayer.toExtensionMenu()
end end
end end
function ArmatureTestLayer:createToExtensionMenu() function ArmatureTestLayer:createToExtensionMenu()
cc.MenuItemFont:setFontName("Arial") cc.MenuItemFont:setFontName("Arial")
cc.MenuItemFont:setFontSize(24) cc.MenuItemFont:setFontSize(24)
local menuItemFont = cc.MenuItemFont:create("Back") local menuItemFont = cc.MenuItemFont:create("Back")
@ -279,7 +279,7 @@ function TestAsynchronousLoading.create()
layer:createMenu() layer:createMenu()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:onEnter() layer:onEnter()
end end
return layer return layer
end end
@ -313,7 +313,7 @@ function TestDirectLoading.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:onEnter() layer:onEnter()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
end end
return layer return layer
end end
@ -348,7 +348,7 @@ function TestCSWithSkeleton.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:onEnter() layer:onEnter()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
end end
return layer return layer
end end
@ -366,7 +366,7 @@ function TestDragonBones20.extend(target)
return target return target
end end
function TestDragonBones20:onEnter() function TestDragonBones20:onEnter()
local armature = ccs.Armature:create("Dragon") local armature = ccs.Armature:create("Dragon")
armature:getAnimation():playByIndex(1) armature:getAnimation():playByIndex(1)
armature:getAnimation():setSpeedScale(0.4) armature:getAnimation():setSpeedScale(0.4)
@ -383,8 +383,8 @@ function TestDragonBones20.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:onEnter() layer:onEnter()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
end end
return layer return layer
end end
local TestPerformance = class("TestPerformance",ArmatureTestLayer) local TestPerformance = class("TestPerformance",ArmatureTestLayer)
@ -405,7 +405,7 @@ function TestPerformance.extend(target)
return target return target
end end
function TestPerformance:refreshTitile() function TestPerformance:refreshTitle()
local subTitleInfo = ArmatureTestLayer.subTitle(5) .. self._armatureCount local subTitleInfo = ArmatureTestLayer.subTitle(5) .. self._armatureCount
local label = tolua.cast(self:getChildByTag(10001),"LabelTTF") local label = tolua.cast(self:getChildByTag(10001),"LabelTTF")
label:setString(subTitleInfo) label:setString(subTitleInfo)
@ -429,7 +429,7 @@ function TestPerformance:addArmature(num)
self:addArmatureToParent(armature) self:addArmatureToParent(armature)
end end
self:refreshTitile() self:refreshTitle()
end end
function TestPerformance:onEnter() function TestPerformance:onEnter()
@ -446,7 +446,7 @@ function TestPerformance:onEnter()
for i = 1, 20 do for i = 1, 20 do
self:removeArmatureFromParent(armaturePerformanceTag + self._armatureCount) self:removeArmatureFromParent(armaturePerformanceTag + self._armatureCount)
self._armatureCount = self._armatureCount - 1 self._armatureCount = self._armatureCount - 1
self:refreshTitile() self:refreshTitle()
end end
end end
@ -458,7 +458,7 @@ function TestPerformance:onEnter()
local increase = cc.MenuItemFont:create(" + ") local increase = cc.MenuItemFont:create(" + ")
increase:setColor(cc.c3b(0,200,20)) increase:setColor(cc.c3b(0,200,20))
increase:registerScriptTapHandler(onIncrease) increase:registerScriptTapHandler(onIncrease)
local menu = cc.Menu:create(decrease, increase ) local menu = cc.Menu:create(decrease, increase )
menu:alignItemsHorizontally() menu:alignItemsHorizontally()
menu:setPosition(cc.p(VisibleRect:getVisibleRect().width/2, VisibleRect:getVisibleRect().height-100)) menu:setPosition(cc.p(VisibleRect:getVisibleRect().width/2, VisibleRect:getVisibleRect().height-100))
@ -481,8 +481,8 @@ function TestPerformance.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
layer:onEnter() layer:onEnter()
end end
return layer return layer
end end
local TestPerformanceBatchNode = class("TestPerformanceBatchNode",TestPerformance) local TestPerformanceBatchNode = class("TestPerformanceBatchNode",TestPerformance)
@ -507,7 +507,7 @@ function TestPerformanceBatchNode:removeArmatureFromParent(tag)
self._batchNode:removeChildByTag(armaturePerformanceTag + self._armatureCount, true) self._batchNode:removeChildByTag(armaturePerformanceTag + self._armatureCount, true)
end end
function TestPerformanceBatchNode:onEnter() function TestPerformanceBatchNode:onEnter()
self._batchNode = ccs.BatchNode:create() self._batchNode = ccs.BatchNode:create()
self:addChild(self._batchNode) self:addChild(self._batchNode)
@ -523,7 +523,7 @@ function TestPerformanceBatchNode:onEnter()
for i = 1, 20 do for i = 1, 20 do
self:removeArmatureFromParent(armaturePerformanceTag + self._armatureCount) self:removeArmatureFromParent(armaturePerformanceTag + self._armatureCount)
self._armatureCount = self._armatureCount - 1 self._armatureCount = self._armatureCount - 1
self:refreshTitile() self:refreshTitle()
end end
end end
@ -535,7 +535,7 @@ function TestPerformanceBatchNode:onEnter()
local increase = cc.MenuItemFont:create(" + ") local increase = cc.MenuItemFont:create(" + ")
increase:setColor(cc.c3b(0,200,20)) increase:setColor(cc.c3b(0,200,20))
increase:registerScriptTapHandler(onIncrease) increase:registerScriptTapHandler(onIncrease)
local menu = cc.Menu:create(decrease, increase ) local menu = cc.Menu:create(decrease, increase )
menu:alignItemsHorizontally() menu:alignItemsHorizontally()
menu:setPosition(cc.p(VisibleRect:getVisibleRect().width/2, VisibleRect:getVisibleRect().height-100)) menu:setPosition(cc.p(VisibleRect:getVisibleRect().width/2, VisibleRect:getVisibleRect().height-100))
@ -558,8 +558,8 @@ function TestPerformanceBatchNode.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
layer:onEnter() layer:onEnter()
end end
return layer return layer
end end
local TestChangeZorder = class("TestChangeZorder",ArmatureTestLayer) local TestChangeZorder = class("TestChangeZorder",ArmatureTestLayer)
@ -576,7 +576,7 @@ function TestChangeZorder.extend(target)
return target return target
end end
function TestChangeZorder:onEnter() function TestChangeZorder:onEnter()
self.currentTag = -1 self.currentTag = -1
local armature = ccs.Armature:create("Knight_f/Knight") local armature = ccs.Armature:create("Knight_f/Knight")
@ -617,8 +617,8 @@ function TestChangeZorder.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:onEnter() layer:onEnter()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
end end
return layer return layer
end end
--UNDO callback --UNDO callback
@ -635,7 +635,7 @@ function TestAnimationEvent.extend(target)
return target return target
end end
function TestAnimationEvent:onEnter() function TestAnimationEvent:onEnter()
local armature = ccs.Armature:create("Cowboy") local armature = ccs.Armature:create("Cowboy")
armature:getAnimation():play("Fire") armature:getAnimation():play("Fire")
armature:setScaleX(-0.24) armature:setScaleX(-0.24)
@ -682,8 +682,8 @@ function TestAnimationEvent.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:onEnter() layer:onEnter()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
end end
return layer return layer
end end
local TestFrameEvent = class("TestFrameEvent",ArmatureTestLayer) local TestFrameEvent = class("TestFrameEvent",ArmatureTestLayer)
@ -699,7 +699,7 @@ function TestFrameEvent.extend(target)
return target return target
end end
function TestFrameEvent:onEnter() function TestFrameEvent:onEnter()
local armature = ccs.Armature:create("HeroAnimation") local armature = ccs.Armature:create("HeroAnimation")
armature:getAnimation():play("attack") armature:getAnimation():play("attack")
armature:getAnimation():setSpeedScale(0.5) armature:getAnimation():setSpeedScale(0.5)
@ -708,7 +708,7 @@ function TestFrameEvent:onEnter()
local function onFrameEvent( bone,evt,originFrameIndex,currentFrameIndex) local function onFrameEvent( bone,evt,originFrameIndex,currentFrameIndex)
if (not self:getActionByTag(frameEventActionTag)) or (not self:getActionByTag(frameEventActionTag):isDone()) then if (not self:getActionByTag(frameEventActionTag)) or (not self:getActionByTag(frameEventActionTag):isDone()) then
self:stopAllActions() self:stopAllActions()
local action = cc.ShatteredTiles3D:create(0.2, cc.size(16,12), 5, false) local action = cc.ShatteredTiles3D:create(0.2, cc.size(16,12), 5, false)
action:setTag(frameEventActionTag) action:setTag(frameEventActionTag)
self:runAction(action) self:runAction(action)
end end
@ -741,8 +741,8 @@ function TestFrameEvent.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
layer:onEnter() layer:onEnter()
end end
return layer return layer
end end
local TestParticleDisplay = class("TestParticleDisplay",ArmatureTestLayer) local TestParticleDisplay = class("TestParticleDisplay",ArmatureTestLayer)
@ -760,8 +760,8 @@ function TestParticleDisplay.extend(target)
return target return target
end end
function TestParticleDisplay:onEnter() function TestParticleDisplay:onEnter()
self:setTouchEnabled(true) self:setTouchEnabled(true)
self.animationID = 0 self.animationID = 0
self.armature = ccs.Armature:create("robot") self.armature = ccs.Armature:create("robot")
@ -780,7 +780,7 @@ function TestParticleDisplay:onEnter()
bone:setZOrder(100) bone:setZOrder(100)
bone:setScale(1.2) bone:setScale(1.2)
self.armature:addBone(bone, "bady-a3") self.armature:addBone(bone, "bady-a3")
bone = ccs.Bone:create("p2") bone = ccs.Bone:create("p2")
bone:addDisplay(p2, 0) bone:addDisplay(p2, 0)
bone:changeDisplayByIndex(0, true) bone:changeDisplayByIndex(0, true)
@ -812,9 +812,9 @@ function TestParticleDisplay.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:onEnter() layer:onEnter()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
end end
return layer return layer
end end
local TestUseMutiplePicture = class("TestUseMutiplePicture",ArmatureTestLayer) local TestUseMutiplePicture = class("TestUseMutiplePicture",ArmatureTestLayer)
@ -832,8 +832,8 @@ function TestUseMutiplePicture.extend(target)
return target return target
end end
function TestUseMutiplePicture:onEnter() function TestUseMutiplePicture:onEnter()
self:setTouchEnabled(true) self:setTouchEnabled(true)
self.displayIndex = 1 self.displayIndex = 1
self.armature = ccs.Armature:create("Knight_f/Knight") self.armature = ccs.Armature:create("Knight_f/Knight")
@ -842,14 +842,14 @@ function TestUseMutiplePicture:onEnter()
self.armature:setScale(1.2) self.armature:setScale(1.2)
self:addChild(self.armature) self:addChild(self.armature)
local weapon = local weapon =
{ {
"weapon_f-sword.png", "weapon_f-sword.png",
"weapon_f-sword2.png", "weapon_f-sword2.png",
"weapon_f-sword3.png", "weapon_f-sword3.png",
"weapon_f-sword4.png", "weapon_f-sword4.png",
"weapon_f-sword5.png", "weapon_f-sword5.png",
"weapon_f-knife.png", "weapon_f-knife.png",
"weapon_f-hammer.png", "weapon_f-hammer.png",
} }
@ -882,9 +882,9 @@ function TestUseMutiplePicture.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:onEnter() layer:onEnter()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
end end
return layer return layer
end end
local TestAnchorPoint = class("TestAnchorPoint",ArmatureTestLayer) local TestAnchorPoint = class("TestAnchorPoint",ArmatureTestLayer)
@ -925,7 +925,7 @@ function TestAnchorPoint.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:onEnter() layer:onEnter()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
end end
return layer return layer
end end
@ -946,7 +946,7 @@ function TestArmatureNesting.extend(target)
end end
function TestArmatureNesting:onEnter() function TestArmatureNesting:onEnter()
self:setTouchEnabled(true) self:setTouchEnabled(true)
self.weaponIndex = 0 self.weaponIndex = 0
self.armature = ccs.Armature:create("cyborg") self.armature = ccs.Armature:create("cyborg")
@ -980,9 +980,9 @@ function TestArmatureNesting.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:onEnter() layer:onEnter()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
end end
return layer return layer
end end
local Hero = class("Hero") local Hero = class("Hero")
@ -1140,9 +1140,9 @@ function TestArmatureNesting2.create()
layer:createToExtensionMenu() layer:createToExtensionMenu()
layer:creatTitleAndSubTitle(armatureSceneIdx) layer:creatTitleAndSubTitle(armatureSceneIdx)
layer:onEnter() layer:onEnter()
end end
return layer return layer
end end
@ -1173,7 +1173,7 @@ function nextArmatureTest()
return armatureSceneArr[armatureSceneIdx]() return armatureSceneArr[armatureSceneIdx]()
end end
function backArmatureTest() function backArmatureTest()
armatureSceneIdx = armatureSceneIdx - 1 armatureSceneIdx = armatureSceneIdx - 1
if armatureSceneIdx <= 0 then if armatureSceneIdx <= 0 then
armatureSceneIdx = armatureSceneIdx + table.getn(armatureSceneArr) armatureSceneIdx = armatureSceneIdx + table.getn(armatureSceneArr)
@ -1187,7 +1187,7 @@ function restartArmatureTest()
end end
local function addFileInfo() local function addFileInfo()
end end
function runArmatureTestScene() function runArmatureTestScene()

View File

@ -330,7 +330,7 @@ local function ParticleBatchHybrid()
layer:registerScriptHandler(ParticleBatchHybrid_onEnterOrExit) layer:registerScriptHandler(ParticleBatchHybrid_onEnterOrExit)
titleLabel:setString("Paticle Batch") titleLabel:setString("Particle Batch")
subtitleLabel:setString("Hybrid: batched and non batched every 2 seconds") subtitleLabel:setString("Hybrid: batched and non batched every 2 seconds")
return layer return layer
end end
@ -364,7 +364,7 @@ local function ParticleBatchMultipleEmitters()
layer:addChild(batch, 10) layer:addChild(batch, 10)
titleLabel:setString("Paticle Batch") titleLabel:setString("Particle Batch")
subtitleLabel:setString("Multiple emitters. One Batch") subtitleLabel:setString("Multiple emitters. One Batch")
return layer return layer
end end
@ -900,7 +900,7 @@ local function RadiusMode1()
emitter:setTexture(cc.TextureCache:getInstance():addImage("Images/stars-grayscale.png")) emitter:setTexture(cc.TextureCache:getInstance():addImage("Images/stars-grayscale.png"))
-- duration -- duration
emitter:setDuration(cc.PARTICLE_DURATION_INFINITY) emitter:setDuration(cc.PARTICLE_DURATION_INFINITY)
-- radius mode -- radius mode
emitter:setEmitterMode(cc.PARTICLE_MODE_RADIUS) emitter:setEmitterMode(cc.PARTICLE_MODE_RADIUS)

View File

@ -26,7 +26,7 @@ headers = %(cocosdir)s/cocos/2d/cocos2d.h %(cocosdir)s/cocos/audio/include/Simpl
# what classes to produce code for. You can use regular expressions here. When testing the regular # what classes to produce code for. You can use regular expressions here. When testing the regular
# expression, it will be enclosed in "^$", like this: "^Menu*$". # expression, it will be enclosed in "^$", like this: "^Menu*$".
classes = Sprite.* Scene Node.* Director Layer.* Menu.* Touch .*Action.* Move.* Rotate.* Blink.* Tint.* Sequence Repeat.* Fade.* Ease.* Scale.* Transition.* Spawn Animat.* Flip.* Delay.* Skew.* Jump.* Place.* Show.* Progress.* PointArray ToggleVisibility.* RemoveSelf Hide Particle.* Label.* Atlas.* TextureCache.* Texture2D Cardinal.* CatmullRom.* ParallaxNode TileMap.* TMX.* CallFunc RenderTexture GridAction Grid3DAction GridBase$ .+Grid Shaky3D Waves3D FlipX3D FlipY3D Speed ActionManager Set Data SimpleAudioEngine Scheduler Timer Orbit.* Follow.* Bezier.* CardinalSpline.* Camera.* DrawNode .*3D$ Liquid$ Waves$ ShuffleTiles$ TurnOffTiles$ Split.* Twirl$ FileUtils$ GLProgram ShaderCache Application ClippingNode MotionStreak ^Object$ UserDefault Image classes = Sprite.* Scene Node.* Director Layer.* Menu.* Touch .*Action.* Move.* Rotate.* Blink.* Tint.* Sequence Repeat.* Fade.* Ease.* Scale.* Transition.* Spawn Animat.* Flip.* Delay.* Skew.* Jump.* Place.* Show.* Progress.* PointArray ToggleVisibility.* RemoveSelf Hide Particle.* Label.* Atlas.* TextureCache.* Texture2D Cardinal.* CatmullRom.* ParallaxNode TileMap.* TMX.* CallFunc RenderTexture GridAction Grid3DAction GridBase$ .+Grid Shaky3D Waves3D FlipX3D FlipY3D Speed ActionManager Set Data SimpleAudioEngine Scheduler Timer Orbit.* Follow.* Bezier.* CardinalSpline.* Camera.* DrawNode .*3D$ Liquid$ Waves$ ShuffleTiles$ TurnOffTiles$ Split.* Twirl$ FileUtils$ GLProgram ShaderCache Application ClippingNode MotionStreak ^Object$ UserDefault EGLViewProtocol EGLView Image
# what should we skip? in the format ClassName::[function function] # what should we skip? in the format ClassName::[function function]
# ClassName is a regular expression, but will be used like this: "^ClassName$" functions are also # ClassName is a regular expression, but will be used like this: "^ClassName$" functions are also
@ -50,7 +50,8 @@ skip = Node::[setGLServerState description getUserObject .*UserData getGLServerS
MenuItem.*::[create setCallback initWithCallback], MenuItem.*::[create setCallback initWithCallback],
Label::[getLettersInfo], Label::[getLettersInfo],
Copying::[*], Copying::[*],
.*Protocol::[*], LabelProtocol::[*],
LabelTextFormatProtocol::[*],
.*Delegate::[*], .*Delegate::[*],
PoolManager::[*], PoolManager::[*],
Texture2D::[initWithPVRTCData addPVRTCImage releaseData setTexParameters initWithData keepData], Texture2D::[initWithPVRTCData addPVRTCImage releaseData setTexParameters initWithData keepData],
@ -68,7 +69,6 @@ skip = Node::[setGLServerState description getUserObject .*UserData getGLServerS
ScriptEngineManager::[*], ScriptEngineManager::[*],
KeypadHandler::[*], KeypadHandler::[*],
Invocation::[*], Invocation::[*],
EGLView::[*],
SchedulerScriptHandlerEntry::[*], SchedulerScriptHandlerEntry::[*],
Size::[*], Size::[*],
Point::[*], Point::[*],
@ -105,7 +105,9 @@ skip = Node::[setGLServerState description getUserObject .*UserData getGLServerS
ccFontDefinition::[*], ccFontDefinition::[*],
Object::[autorelease isEqual acceptVisitor update], Object::[autorelease isEqual acceptVisitor update],
UserDefault::[getInstance (s|g)etDataForKey], UserDefault::[getInstance (s|g)etDataForKey],
Label::[getLettersInfo] Label::[getLettersInfo],
EGLViewProtocol::[setTouchDelegate],
EGLView::[end swapBuffers]
rename_functions = SpriteFrameCache::[addSpriteFramesWithFile=addSpriteFrames getSpriteFrameByName=getSpriteFrame], rename_functions = SpriteFrameCache::[addSpriteFramesWithFile=addSpriteFrames getSpriteFrameByName=getSpriteFrame],
ProgressTimer::[setReverseProgress=setReverseDirection], ProgressTimer::[setReverseProgress=setReverseDirection],
@ -136,7 +138,7 @@ base_classes_to_skip = Clonable
# classes that create no constructor # classes that create no constructor
# Set is special and we will use a hand-written constructor # Set is special and we will use a hand-written constructor
abstract_classes = Action FiniteTimeAction ActionInterval ActionEase EaseRateAction EaseElastic EaseBounce ActionInstant GridAction Grid3DAction TiledGrid3DAction Director SpriteFrameCache TransitionEaseScene Set SimpleAudioEngine FileUtils Application ClippingNode Label abstract_classes = Action FiniteTimeAction ActionInterval ActionEase EaseRateAction EaseElastic EaseBounce ActionInstant GridAction Grid3DAction TiledGrid3DAction Director SpriteFrameCache TransitionEaseScene Set SimpleAudioEngine FileUtils Application ClippingNode Label EGLViewProtocol EGLView
# Determining whether to use script object(js object) to control the lifecycle of native(cpp) object or the other way around. Supported values are 'yes' or 'no'. # Determining whether to use script object(js object) to control the lifecycle of native(cpp) object or the other way around. Supported values are 'yes' or 'no'.
script_control_cpp = no script_control_cpp = no

View File

@ -49,11 +49,9 @@ skip = *::[^visit$ copyWith.* onEnter.* onExit.* ^description$ getObjectType .*
UIWidget::[(s|g)etUserObject], UIWidget::[(s|g)etUserObject],
UIImageView::[doubleClickEvent] UIImageView::[doubleClickEvent]
rename_functions = UIHelper::[instance=getInstance], rename_functions = GUIReader::[shareReader=getInstance purgeGUIReader=destroyInstance],
ArmatureDataManager::[sharedArmatureDataManager=getInstance], ActionManagerEx::[shareManager=getInstance purgeActionManager=destroyInstance],
GUIReader::[shareReader=getInstance], SceneReader::[purgeSceneReader=destroyInstance]
ActionManagerEx::[shareManager=getInstance purgeActionManager=destroyActionManager],
SceneReader::[purgeSceneReader=destroySceneReader]
rename_classes = rename_classes =