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,41 +105,94 @@ 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}
) )
if(WIN32)
include_directories(
${CMAKE_CURRENT_SOURCE_DIR}/external/${PLATFORM_FOLDER}-specific/gles/include/OGLES
${CMAKE_CURRENT_SOURCE_DIR}/external/${PLATFORM_FOLDER}-specific/icon/include
${CMAKE_CURRENT_SOURCE_DIR}/external/${PLATFORM_FOLDER}-specific/zlib/include
external/curl/include/${PLATFORM_FOLDER}
)
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( link_directories(
/usr/local/lib /usr/local/lib
${CMAKE_SOURCE_DIR}/external/jpeg/prebuilt/linux/${ARCH_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/external/jpeg/prebuilt/${PLATFORM_FOLDER}/${ARCH_DIR}
${CMAKE_SOURCE_DIR}/external/tiff/prebuilt/linux/${ARCH_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/external/tiff/prebuilt/${PLATFORM_FOLDER}/${ARCH_DIR}
${CMAKE_SOURCE_DIR}/external/webp/prebuilt/linux/${ARCH_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/external/webp/prebuilt/${PLATFORM_FOLDER}/${ARCH_DIR}
${CMAKE_SOURCE_DIR}/external/freetype2/prebuilt/linux/${ARCH_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/external/png/prebuilt/${PLATFORM_FOLDER}/${ARCH_DIR}
${CMAKE_SOURCE_DIR}/external/curl/prebuilt/linux/${ARCH_DIR} ${CMAKE_CURRENT_SOURCE_DIR}/external/freetype2/prebuilt/${PLATFORM_FOLDER}/${ARCH_DIR}
${CMAKE_SOURCE_DIR}/external/linux-specific/fmod/prebuilt/${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
add_subdirectory(cocos/math/kazmath) add_subdirectory(cocos/math/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

View File

@ -627,7 +627,7 @@ public:
/** /**
* Sets the parent node * Sets the parent node
* *
* @param parent A pointer to the parnet node * @param parent A pointer to the parent node
*/ */
virtual void setParent(Node* parent); virtual void setParent(Node* parent);
/** /**
@ -635,7 +635,7 @@ public:
* *
* @see `setParent(Node*)` * @see `setParent(Node*)`
* *
* @returns A pointer to the parnet node * @returns A pointer to the parent node
*/ */
virtual Node* getParent() { return _parent; } virtual Node* getParent() { return _parent; }
virtual const Node* getParent() const { return _parent; } virtual const Node* getParent() const { return _parent; }
@ -1386,7 +1386,7 @@ public:
/** /**
* update rotation and position from physics body * update rotation and position from physics body
*/ */
virtual void updatePhysicsTransform(); virtual bool updatePhysicsTransform();
#endif #endif

View File

@ -176,7 +176,7 @@ void ParticleBatchNode::addChild(Node * aChild, int zOrder, int tag)
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);

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 );
@ -192,22 +192,18 @@ void tgaFlipImage( tImageTGA *psInfo )
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,9 +508,23 @@ bool Image::initWithImageData(const unsigned char * data, long dataLen)
ret = initWithATITCData(unpackedData, unpackedLen); ret = initWithATITCData(unpackedData, unpackedLen);
break; break;
default: default:
{
// 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!"); CCAssert(false, "unsupport image format!");
}
free(tgaData);
break; 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()
if(WIN32)
set(AUDIO_SRC
win32/SimpleAudioEngine.cpp
win32/MciPlayer.cpp
)
elseif(APPLE)
else()
set(AUDIO_SRC
linux/SimpleAudioEngineFMOD.cpp
linux/FmodAudioPlayer.cpp
)
include_directories( include_directories(
../../external/linux-specific/fmod/include/${ARCH_DIR} ../../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)))
{ {
@ -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);
} }
@ -279,7 +279,7 @@ 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);
@ -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,20 +307,20 @@ 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;
} }
@ -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,13 +606,13 @@ 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");
@ -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,12 +677,12 @@ 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);
@ -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
@ -395,3 +396,91 @@ _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)
set(SAMPLE_SRC 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 proj.linux/main.cpp
)
endif()
set(SAMPLE_SRC
${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

@ -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);

View File

@ -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;

View File

@ -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)
@ -1238,7 +1238,7 @@ void ParticleBatchHybrid::switchRender(float dt)
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()

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

@ -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
@ -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

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

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 =