2012-02-02 10:37:21 +08:00
|
|
|
/****************************************************************************
|
|
|
|
Copyright (c) 2008-2010 Ricardo Quesada
|
2014-01-07 11:25:07 +08:00
|
|
|
Copyright (c) 2010-2012 cocos2d-x.org
|
2012-02-02 10:37:21 +08:00
|
|
|
Copyright (c) 2011 Zynga Inc.
|
2014-01-07 11:25:07 +08:00
|
|
|
Copyright (c) 2013-2014 Chukong Technologies Inc.
|
2012-02-02 10:37:21 +08:00
|
|
|
|
|
|
|
http://www.cocos2d-x.org
|
|
|
|
|
|
|
|
Permission is hereby granted, free of charge, to any person obtaining a copy
|
|
|
|
of this software and associated documentation files (the "Software"), to deal
|
|
|
|
in the Software without restriction, including without limitation the rights
|
|
|
|
to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
|
|
|
|
copies of the Software, and to permit persons to whom the Software is
|
|
|
|
furnished to do so, subject to the following conditions:
|
|
|
|
|
|
|
|
The above copyright notice and this permission notice shall be included in
|
|
|
|
all copies or substantial portions of the Software.
|
|
|
|
|
|
|
|
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
|
|
|
|
IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
|
|
|
|
FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
|
|
|
|
AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
|
|
|
|
LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
|
|
|
|
OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
|
|
|
|
THE SOFTWARE.
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
#ifndef __CCCONFIG_H__
|
|
|
|
#define __CCCONFIG_H__
|
|
|
|
|
2013-10-14 14:01:00 +08:00
|
|
|
#include "CCPlatformConfig.h"
|
2012-02-02 10:37:21 +08:00
|
|
|
|
2012-03-12 15:22:03 +08:00
|
|
|
/**
|
|
|
|
@file
|
|
|
|
cocos2d (cc) configuration file
|
|
|
|
*/
|
|
|
|
|
2013-02-27 09:38:30 +08:00
|
|
|
/** @def CC_ENABLE_STACKABLE_ACTIONS
|
2013-06-20 14:13:12 +08:00
|
|
|
If enabled, actions that alter the position property (eg: MoveBy, JumpBy, BezierBy, etc..) will be stacked.
|
2013-02-27 09:38:30 +08:00
|
|
|
If you run 2 or more 'position' actions at the same time on a node, then end position will be the sum of all the positions.
|
|
|
|
If disabled, only the last run action will take effect.
|
|
|
|
|
|
|
|
Enabled by default. Disable to be compatible with v2.0 and older versions.
|
|
|
|
|
|
|
|
@since v2.1
|
|
|
|
*/
|
|
|
|
#ifndef CC_ENABLE_STACKABLE_ACTIONS
|
|
|
|
#define CC_ENABLE_STACKABLE_ACTIONS 1
|
|
|
|
#endif
|
|
|
|
|
2012-03-12 15:22:03 +08:00
|
|
|
/** @def CC_ENABLE_GL_STATE_CACHE
|
|
|
|
If enabled, cocos2d will maintain an OpenGL state cache internally to avoid unnecessary switches.
|
2012-09-17 15:02:24 +08:00
|
|
|
In order to use them, you have to use the following functions, instead of the the GL ones:
|
2012-04-19 14:35:52 +08:00
|
|
|
- ccGLUseProgram() instead of glUseProgram()
|
2013-07-26 09:42:53 +08:00
|
|
|
- GL::deleteProgram() instead of glDeleteProgram()
|
|
|
|
- GL::blendFunc() instead of glBlendFunc()
|
2012-03-12 15:22:03 +08:00
|
|
|
|
2013-07-26 09:42:53 +08:00
|
|
|
If this functionality is disabled, then ccGLUseProgram(), GL::deleteProgram(), GL::blendFunc() will call the GL ones, without using the cache.
|
2012-03-12 15:22:03 +08:00
|
|
|
|
2012-09-17 15:02:24 +08:00
|
|
|
It is recommended to enable whenever possible to improve speed.
|
2012-03-12 15:22:03 +08:00
|
|
|
If you are migrating your code from GL ES 1.1, then keep it disabled. Once all your code works as expected, turn it on.
|
2013-02-27 09:38:30 +08:00
|
|
|
|
|
|
|
Default value: Enabled by default
|
|
|
|
|
2012-03-12 15:22:03 +08:00
|
|
|
@since v2.0.0
|
|
|
|
*/
|
|
|
|
#ifndef CC_ENABLE_GL_STATE_CACHE
|
2012-03-28 17:51:26 +08:00
|
|
|
#define CC_ENABLE_GL_STATE_CACHE 1
|
2012-03-12 15:22:03 +08:00
|
|
|
#endif
|
|
|
|
|
2012-02-02 10:37:21 +08:00
|
|
|
/** @def CC_FIX_ARTIFACTS_BY_STRECHING_TEXEL
|
|
|
|
If enabled, the texture coordinates will be calculated by using this formula:
|
|
|
|
- texCoord.left = (rect.origin.x*2+1) / (texture.wide*2);
|
|
|
|
- texCoord.right = texCoord.left + (rect.size.width*2-2)/(texture.wide*2);
|
|
|
|
|
|
|
|
The same for bottom and top.
|
|
|
|
|
|
|
|
This formula prevents artifacts by using 99% of the texture.
|
|
|
|
The "correct" way to prevent artifacts is by using the spritesheet-artifact-fixer.py or a similar tool.
|
|
|
|
|
|
|
|
Affected nodes:
|
2013-06-20 14:13:12 +08:00
|
|
|
- Sprite / SpriteBatchNode and subclasses: LabelBMFont, TMXTiledMap
|
|
|
|
- LabelAtlas
|
|
|
|
- QuadParticleSystem
|
|
|
|
- TileMap
|
2012-02-02 10:37:21 +08:00
|
|
|
|
|
|
|
To enabled set it to 1. Disabled by default.
|
|
|
|
|
|
|
|
@since v0.99.5
|
|
|
|
*/
|
|
|
|
#ifndef CC_FIX_ARTIFACTS_BY_STRECHING_TEXEL
|
|
|
|
#define CC_FIX_ARTIFACTS_BY_STRECHING_TEXEL 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @def CC_DIRECTOR_FPS_INTERVAL
|
2012-09-17 15:02:24 +08:00
|
|
|
Seconds between FPS updates.
|
2012-02-02 10:37:21 +08:00
|
|
|
0.5 seconds, means that the FPS number will be updated every 0.5 seconds.
|
|
|
|
Having a bigger number means a more reliable FPS
|
|
|
|
|
|
|
|
Default value: 0.1f
|
|
|
|
*/
|
2012-04-13 11:22:17 +08:00
|
|
|
#ifndef CC_DIRECTOR_STATS_INTERVAL
|
2013-08-30 11:05:14 +08:00
|
|
|
#define CC_DIRECTOR_STATS_INTERVAL (0.1f)
|
2012-02-02 10:37:21 +08:00
|
|
|
#endif
|
|
|
|
|
2012-03-12 15:22:03 +08:00
|
|
|
/** @def CC_DIRECTOR_FPS_POSITION
|
|
|
|
Position of the FPS
|
|
|
|
|
|
|
|
Default: 0,0 (bottom-left corner)
|
|
|
|
*/
|
|
|
|
#ifndef CC_DIRECTOR_FPS_POSITION
|
2014-04-15 18:08:29 +08:00
|
|
|
#define CC_DIRECTOR_FPS_POSITION Vector2(0,0)
|
2012-03-12 15:22:03 +08:00
|
|
|
#endif
|
|
|
|
|
2012-02-02 10:37:21 +08:00
|
|
|
/** @def CC_DIRECTOR_DISPATCH_FAST_EVENTS
|
2013-06-20 14:13:12 +08:00
|
|
|
If enabled, and only when it is used with FastDirector, the main loop will wait 0.04 seconds to
|
2012-02-02 10:37:21 +08:00
|
|
|
dispatch all the events, even if there are not events to dispatch.
|
|
|
|
If your game uses lot's of events (eg: touches) it might be a good idea to enable this feature.
|
|
|
|
Otherwise, it is safe to leave it disabled.
|
|
|
|
|
|
|
|
To enable set it to 1. Disabled by default.
|
|
|
|
|
|
|
|
@warning This feature is experimental
|
|
|
|
*/
|
|
|
|
#ifndef CC_DIRECTOR_DISPATCH_FAST_EVENTS
|
|
|
|
#define CC_DIRECTOR_DISPATCH_FAST_EVENTS 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @def CC_DIRECTOR_MAC_USE_DISPLAY_LINK_THREAD
|
|
|
|
If enabled, cocos2d-mac will run on the Display Link thread. If disabled cocos2d-mac will run in its own thread.
|
|
|
|
|
|
|
|
If enabled, the images will be drawn at the "correct" time, but the events might not be very responsive.
|
|
|
|
If disabled, some frames might be skipped, but the events will be dispatched as they arrived.
|
|
|
|
|
|
|
|
To enable set it to a 1, to disable it set to 0. Enabled by default.
|
|
|
|
|
|
|
|
Only valid for cocos2d-mac. Not supported on cocos2d-ios.
|
|
|
|
|
|
|
|
*/
|
|
|
|
#ifndef CC_DIRECTOR_MAC_USE_DISPLAY_LINK_THREAD
|
|
|
|
#define CC_DIRECTOR_MAC_USE_DISPLAY_LINK_THREAD 1
|
|
|
|
#endif
|
|
|
|
|
2012-03-26 18:44:28 +08:00
|
|
|
/** @def CC_NODE_RENDER_SUBPIXEL
|
2013-06-20 14:13:12 +08:00
|
|
|
If enabled, the Node objects (Sprite, Label,etc) will be able to render in subpixels.
|
2012-02-02 10:37:21 +08:00
|
|
|
If disabled, integer pixels will be used.
|
|
|
|
|
|
|
|
To enable set it to 1. Enabled by default.
|
|
|
|
*/
|
2012-03-26 18:44:28 +08:00
|
|
|
#ifndef CC_NODE_RENDER_SUBPIXEL
|
|
|
|
#define CC_NODE_RENDER_SUBPIXEL 1
|
2012-02-02 10:37:21 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @def CC_SPRITEBATCHNODE_RENDER_SUBPIXEL
|
2013-06-20 14:13:12 +08:00
|
|
|
If enabled, the Sprite objects rendered with SpriteBatchNode will be able to render in subpixels.
|
2012-02-02 10:37:21 +08:00
|
|
|
If disabled, integer pixels will be used.
|
|
|
|
|
|
|
|
To enable set it to 1. Enabled by default.
|
|
|
|
*/
|
|
|
|
#ifndef CC_SPRITEBATCHNODE_RENDER_SUBPIXEL
|
2012-04-19 14:35:52 +08:00
|
|
|
#define CC_SPRITEBATCHNODE_RENDER_SUBPIXEL 1
|
2012-02-02 10:37:21 +08:00
|
|
|
#endif
|
|
|
|
|
2012-04-13 11:22:17 +08:00
|
|
|
/** @def CC_TEXTURE_ATLAS_USE_VAO
|
2013-06-20 14:13:12 +08:00
|
|
|
By default, TextureAtlas (used by many cocos2d classes) will use VAO (Vertex Array Objects).
|
2012-04-13 11:22:17 +08:00
|
|
|
Apple recommends its usage but they might consume a lot of memory, specially if you use many of them.
|
|
|
|
So for certain cases, where you might need hundreds of VAO objects, it might be a good idea to disable it.
|
|
|
|
|
|
|
|
To disable it set it to 0. Enabled by default.
|
|
|
|
|
|
|
|
*/
|
|
|
|
#ifndef CC_TEXTURE_ATLAS_USE_VAO
|
2012-09-17 17:58:21 +08:00
|
|
|
#if (CC_TARGET_PLATFORM == CC_PLATFORM_IOS) || (CC_TARGET_PLATFORM == CC_PLATFORM_MAC)
|
2012-04-13 18:18:47 +08:00
|
|
|
#define CC_TEXTURE_ATLAS_USE_VAO 1
|
|
|
|
#else
|
2012-09-17 17:58:21 +08:00
|
|
|
/* Some Windows display adapter driver cannot support VAO. */
|
2012-04-13 18:18:47 +08:00
|
|
|
/* Some android devices cannot support VAO very well, so we disable it by default for android platform. */
|
2012-08-20 15:49:02 +08:00
|
|
|
/* Blackberry also doesn't support this feature. */
|
|
|
|
#define CC_TEXTURE_ATLAS_USE_VAO 0
|
2012-04-13 18:18:47 +08:00
|
|
|
#endif
|
2012-03-16 13:42:53 +08:00
|
|
|
#endif
|
|
|
|
|
2012-02-02 10:37:21 +08:00
|
|
|
|
2012-03-16 13:42:53 +08:00
|
|
|
/** @def CC_USE_LA88_LABELS
|
2013-06-20 14:13:12 +08:00
|
|
|
If enabled, it will use LA88 (Luminance Alpha 16-bit textures) for LabelTTF objects.
|
2012-03-16 13:42:53 +08:00
|
|
|
If it is disabled, it will use A8 (Alpha 8-bit textures).
|
|
|
|
LA88 textures are 6% faster than A8 textures, but they will consume 2x memory.
|
2012-02-02 10:37:21 +08:00
|
|
|
|
2012-03-16 13:42:53 +08:00
|
|
|
This feature is enabled by default.
|
2012-02-02 10:37:21 +08:00
|
|
|
|
2012-03-16 13:42:53 +08:00
|
|
|
@since v0.99.5
|
|
|
|
*/
|
|
|
|
#ifndef CC_USE_LA88_LABELS
|
|
|
|
#define CC_USE_LA88_LABELS 1
|
2012-02-02 10:37:21 +08:00
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @def CC_SPRITE_DEBUG_DRAW
|
2013-06-20 14:13:12 +08:00
|
|
|
If enabled, all subclasses of Sprite will draw a bounding box
|
2012-09-17 15:02:24 +08:00
|
|
|
Useful for debugging purposes only. It is recommended to leave it disabled.
|
2012-02-02 10:37:21 +08:00
|
|
|
|
|
|
|
To enable set it to a value different than 0. Disabled by default:
|
|
|
|
0 -- disabled
|
|
|
|
1 -- draw bounding box
|
|
|
|
2 -- draw texture box
|
|
|
|
0 -- disabled
|
|
|
|
1 -- draw bounding box
|
|
|
|
2 -- draw texture box
|
|
|
|
*/
|
|
|
|
#ifndef CC_SPRITE_DEBUG_DRAW
|
|
|
|
#define CC_SPRITE_DEBUG_DRAW 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @def CC_SPRITEBATCHNODE_DEBUG_DRAW
|
2013-06-20 14:13:12 +08:00
|
|
|
If enabled, all subclasses of Sprite that are rendered using an SpriteBatchNode draw a bounding box.
|
2012-09-17 15:02:24 +08:00
|
|
|
Useful for debugging purposes only. It is recommended to leave it disabled.
|
2012-02-02 10:37:21 +08:00
|
|
|
|
|
|
|
To enable set it to a value different than 0. Disabled by default.
|
|
|
|
*/
|
|
|
|
#ifndef CC_SPRITEBATCHNODE_DEBUG_DRAW
|
|
|
|
#define CC_SPRITEBATCHNODE_DEBUG_DRAW 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @def CC_LABELBMFONT_DEBUG_DRAW
|
2013-06-20 14:13:12 +08:00
|
|
|
If enabled, all subclasses of LabelBMFont will draw a bounding box
|
2012-09-17 15:02:24 +08:00
|
|
|
Useful for debugging purposes only. It is recommended to leave it disabled.
|
2012-02-02 10:37:21 +08:00
|
|
|
|
|
|
|
To enable set it to a value different than 0. Disabled by default.
|
|
|
|
*/
|
|
|
|
#ifndef CC_LABELBMFONT_DEBUG_DRAW
|
|
|
|
#define CC_LABELBMFONT_DEBUG_DRAW 0
|
|
|
|
#endif
|
|
|
|
|
|
|
|
/** @def CC_LABELATLAS_DEBUG_DRAW
|
|
|
|
If enabled, all subclasses of LabeltAtlas will draw a bounding box
|
2012-09-17 15:02:24 +08:00
|
|
|
Useful for debugging purposes only. It is recommended to leave it disabled.
|
2012-02-02 10:37:21 +08:00
|
|
|
|
|
|
|
To enable set it to a value different than 0. Disabled by default.
|
|
|
|
*/
|
|
|
|
#ifndef CC_LABELATLAS_DEBUG_DRAW
|
|
|
|
#define CC_LABELATLAS_DEBUG_DRAW 0
|
|
|
|
#endif
|
|
|
|
|
2014-03-28 03:29:28 +08:00
|
|
|
/** @def CC_NODE_DEBUG_VERIFY_EVENT_LISTENERS
|
|
|
|
If enabled (in conjunction with assertion macros) will verify on Node destruction that the node being destroyed has no event
|
|
|
|
listeners still associated with it in the event dispatcher. This can be used to track down problems where the event dispatch
|
|
|
|
system has dangling pointers to destroyed nodes.
|
|
|
|
|
|
|
|
Note: event listener verification will always be disabled in builds where assertions are disabled regardless of this setting.
|
|
|
|
*/
|
|
|
|
#ifndef CC_NODE_DEBUG_VERIFY_EVENT_LISTENERS
|
|
|
|
#define CC_NODE_DEBUG_VERIFY_EVENT_LISTENERS 0
|
|
|
|
#endif
|
|
|
|
|
2012-02-02 10:37:21 +08:00
|
|
|
/** @def CC_ENABLE_PROFILERS
|
2012-09-17 15:02:24 +08:00
|
|
|
If enabled, will activate various profilers within cocos2d. This statistical data will be output to the console
|
2012-02-02 10:37:21 +08:00
|
|
|
once per second showing average time (in milliseconds) required to execute the specific routine(s).
|
2012-09-17 15:02:24 +08:00
|
|
|
Useful for debugging purposes only. It is recommended to leave it disabled.
|
2012-02-02 10:37:21 +08:00
|
|
|
|
|
|
|
To enable set it to a value different than 0. Disabled by default.
|
|
|
|
*/
|
|
|
|
#ifndef CC_ENABLE_PROFILERS
|
|
|
|
#define CC_ENABLE_PROFILERS 0
|
|
|
|
#endif
|
|
|
|
|
2012-02-09 14:07:11 +08:00
|
|
|
/** Enable Lua engine debug log */
|
2012-02-02 10:37:21 +08:00
|
|
|
#ifndef CC_LUA_ENGINE_DEBUG
|
|
|
|
#define CC_LUA_ENGINE_DEBUG 0
|
|
|
|
#endif
|
|
|
|
|
2013-12-04 14:36:32 +08:00
|
|
|
/** Use physics integration API */
|
|
|
|
#ifndef CC_USE_PHYSICS
|
2013-12-27 00:00:50 +08:00
|
|
|
#define CC_USE_PHYSICS 1
|
2013-12-04 14:36:32 +08:00
|
|
|
#endif
|
|
|
|
|
2014-02-20 16:40:46 +08:00
|
|
|
/** Enable Script binding */
|
|
|
|
#ifndef CC_ENABLE_SCRIPT_BINDING
|
2014-02-20 17:02:20 +08:00
|
|
|
#define CC_ENABLE_SCRIPT_BINDING 1
|
2014-02-20 16:40:46 +08:00
|
|
|
#endif
|
|
|
|
|
2014-03-21 13:44:29 +08:00
|
|
|
/** @def CC_CONSTRUCTOR_ACCESS
|
|
|
|
Indicate the init functions access modifier. If value equals to protected, then these functions are protected.
|
|
|
|
If value equals to public, these functions are public
|
|
|
|
|
|
|
|
protected by default.
|
|
|
|
*/
|
|
|
|
#ifndef CC_CONSTRUCTOR_ACCESS
|
|
|
|
#define CC_CONSTRUCTOR_ACCESS protected
|
|
|
|
#endif
|
|
|
|
|
2012-02-02 10:37:21 +08:00
|
|
|
#endif // __CCCONFIG_H__
|