Merge pull request #17 from cocos2d/develop

update coco2d-x
This commit is contained in:
chuanweizhang2013 2014-03-15 10:05:46 +08:00
commit 59011f86a0
91 changed files with 829 additions and 352 deletions

View File

@ -1 +1 @@
0b50d2b1b4ed3b031417b663cca76662bdf97fc8 874372f8d3779318a2f70b74984575e632ff0dc8

View File

@ -31,42 +31,41 @@ Example:
$ cd cocos2d-x $ cd cocos2d-x
$ ./setup.py $ ./setup.py
$ source FILE_TO_SAVE_SYSTEM_VARIABLE $ source FILE_TO_SAVE_SYSTEM_VARIABLE
$ cocos new mygame -p com.your_company.mygame -l cpp -d /home/mygame $ cocos new MyGame -p com.your_company.mygame -l cpp -d /home
$ cd /home/mygame $ cd /home/MyGame
### Build new project for android ### ### Build and run new project for android ###
$ cd proj.android $ cocos run -p -j 4 android
$ ./build_native.py
### Build new project for ios & osx ### ### Build and run new project for iOS ###
* Enter *proj.ios_mac* folder, open *mygame.xcodeproj* $ cocos run -p ios
* Select ios or osx targets in scheme toolbar
### Build and run new project for OSX ###
### Build new project for linux ### $ cocos run -p mac
### Build and run new project for linux ###
if you never run cocos2d-x on linux, you need to install all dependences by the if you never run cocos2d-x on linux, you need to install all dependences by the
script in **cocos2d/build/install-deps-linux.sh** script in **cocos2d/build/install-deps-linux.sh**
$ cd cocos2d/build $ cd cocos2d-x/build
$ ./install-deps-linux.sh $ ./install-deps-linux.sh
$ ../..
Then Then
$ mkdir build $ cd /home/MyGame
$ cd build $ cocos run -p linux
$ cmake ..
$ make -j4
Run Run
$ bin/mygame $ bin/MyGame
### Build new project for win32 ### ### Build and run new project for win32 ###
* Enter *proj.win32*, open *mygame.sln* by vs2012 $ cocos run -p win32
Main features Main features
@ -107,6 +106,7 @@ Build Requirements
* Mac OS X 10.7+, Xcode 4.6+ * Mac OS X 10.7+, Xcode 4.6+
* or Ubuntu 12.10+, CMake 2.6+ * or Ubuntu 12.10+, CMake 2.6+
* or Windows 7+, VS 2012+ * or Windows 7+, VS 2012+
* Python 2.7.5
Runtime Requirements Runtime Requirements
@ -127,7 +127,7 @@ Select the test you want from Xcode Scheme chooser.
``` ```
$ cd cocos2d-x/build $ cd cocos2d-x/build
$ open samples.xcodeproj $ open cocos_tests.xcodeproj
``` ```
* For Linux * For Linux
@ -142,9 +142,9 @@ $ make
Run Samples Run Samples
``` ```
$ bin/hellocpp/hellocpp $ bin/cpp-empty-test/cpp-empty-test
or or
$ bin/testlua/testlua $ bin/lua-empty-test/lua-empty-test
``` ```
You may meet building errors when building libGLFW.so. It is because libGL.so directs to an error target, You may meet building errors when building libGLFW.so. It is because libGL.so directs to an error target,
@ -158,10 +158,11 @@ Open the `cocos2d-x/build/cocos2d-win32.vc2012.sln`
``` ```
$ cd cocos2d-x/build $ cd cocos2d-x/build
$ python ./android-build.py hellocpp $ python ./android-build.py cpp-empty-test -p 10
$ adb install ../tests/cpp-empty-tst/proj.android/bin/CppEmptyTest-debug.apk
``` ```
Import HelloCpp Android project using Eclipse(released with Android SDK). The path to be imported is `cocos2d-x/samples/Cpp/HelloCpp/proj.android`. Then click item on Android device to run tests. Available value of `-p` is the API level, cocos2d-x supports from level 10.
Contributing to the Project Contributing to the Project

View File

@ -1,6 +1,6 @@
#!/usr/bin/python #!/usr/bin/python
# android-build.py # android-build.py
# Build android # Build android
import sys import sys
import os, os.path import os, os.path
@ -12,21 +12,21 @@ LUA_SAMPLES = ['lua-empty-test', 'lua-tests']
ALL_SAMPLES = CPP_SAMPLES + LUA_SAMPLES ALL_SAMPLES = CPP_SAMPLES + LUA_SAMPLES
def get_num_of_cpu(): def get_num_of_cpu():
''' The build process can be accelerated by running multiple concurrent job processes using the -j-option. ''' The build process can be accelerated by running multiple concurrent job processes using the -j-option.
''' '''
try: try:
platform = sys.platform platform = sys.platform
if platform == 'win32': if platform == 'win32':
if 'NUMBER_OF_PROCESSORS' in os.environ: if 'NUMBER_OF_PROCESSORS' in os.environ:
return int(os.environ['NUMBER_OF_PROCESSORS']) return int(os.environ['NUMBER_OF_PROCESSORS'])
else: else:
return 1 return 1
else: else:
from numpy.distutils import cpuinfo from numpy.distutils import cpuinfo
return cpuinfo.cpu._getNCPUs() return cpuinfo.cpu._getNCPUs()
except Exception: except Exception:
print "Can't know cpuinfo, use default 1 cpu" print "Can't know cpuinfo, use default 1 cpu"
return 1 return 1
def check_environment_variables(): def check_environment_variables():
''' Checking the environment NDK_ROOT, which will be used for building ''' Checking the environment NDK_ROOT, which will be used for building
@ -39,7 +39,7 @@ def check_environment_variables():
sys.exit(1) sys.exit(1)
return NDK_ROOT return NDK_ROOT
def check_environment_variables_sdk(): def check_environment_variables_sdk():
''' Checking the environment ANDROID_SDK_ROOT, which will be used for building ''' Checking the environment ANDROID_SDK_ROOT, which will be used for building
''' '''
@ -74,7 +74,7 @@ def select_toolchain_version():
def caculate_built_samples(args): def caculate_built_samples(args):
''' Compute the sampels to be built ''' Compute the sampels to be built
'cpp' for short of all cpp tests 'cpp' for short of all cpp tests
'lua' for short of all lua tests 'lua' for short of all lua tests
''' '''
if 'all' in args: if 'all' in args:
@ -115,17 +115,17 @@ def do_build(cocos_root, ndk_root, app_android_root, ndk_build_param,sdk_root,an
if os.system(command) != 0: if os.system(command) != 0:
raise Exception("Build dynamic library for project [ " + app_android_root + " ] fails!") raise Exception("Build dynamic library for project [ " + app_android_root + " ] fails!")
elif android_platform is not None: elif android_platform is not None:
sdk_tool_path = os.path.join(sdk_root, "tools/android") sdk_tool_path = os.path.join(sdk_root, "tools/android")
cocoslib_path = os.path.join(cocos_root, "cocos/2d/platform/android/java") cocoslib_path = os.path.join(cocos_root, "cocos/2d/platform/android/java")
command = '%s update lib-project -t %s -p %s' % (sdk_tool_path,android_platform,cocoslib_path) command = '%s update lib-project -t %s -p %s' % (sdk_tool_path,android_platform,cocoslib_path)
if os.system(command) != 0: if os.system(command) != 0:
raise Exception("update cocos lib-project [ " + cocoslib_path + " ] fails!") raise Exception("update cocos lib-project [ " + cocoslib_path + " ] fails!")
command = '%s update project -t %s -p %s -s' % (sdk_tool_path,android_platform,app_android_root) command = '%s update project -t %s -p %s -s' % (sdk_tool_path,android_platform,app_android_root)
if os.system(command) != 0: if os.system(command) != 0:
raise Exception("update project [ " + app_android_root + " ] fails!") raise Exception("update project [ " + app_android_root + " ] fails!")
buildfile_path = os.path.join(app_android_root, "build.xml") buildfile_path = os.path.join(app_android_root, "build.xml")
command = 'ant clean %s -f %s -Dsdk.dir=%s' % (build_mode,buildfile_path,sdk_root) command = 'ant clean %s -f %s -Dsdk.dir=%s' % (build_mode,buildfile_path,sdk_root)
os.system(command) os.system(command)
def copy_files(src, dst): def copy_files(src, dst):
@ -166,7 +166,7 @@ def copy_resources(target, app_android_root):
assets_src_dir = os.path.join(assets_dir, "src"); assets_src_dir = os.path.join(assets_dir, "src");
os.mkdir(assets_src_dir) os.mkdir(assets_src_dir)
copy_files(resources_dir, assets_src_dir) copy_files(resources_dir, assets_src_dir)
resources_dir = os.path.join(app_android_root, "../../../../cocos/scripting/lua-bindings/script") resources_dir = os.path.join(app_android_root, "../../../../cocos/scripting/lua-bindings/script")
copy_files(resources_dir, assets_dir) copy_files(resources_dir, assets_dir)
@ -184,20 +184,20 @@ def build_samples(target,ndk_build_param,android_platform,build_mode):
current_dir = os.path.dirname(os.path.realpath(__file__)) current_dir = os.path.dirname(os.path.realpath(__file__))
cocos_root = os.path.join(current_dir, "..") cocos_root = os.path.join(current_dir, "..")
if android_platform is not None: if android_platform is not None:
sdk_root = check_environment_variables_sdk() sdk_root = check_environment_variables_sdk()
if android_platform.isdigit(): if android_platform.isdigit():
android_platform = 'android-'+android_platform android_platform = 'android-'+android_platform
else: else:
print 'please use vaild android platform' print 'please use vaild android platform'
exit(1) exit(1)
if build_mode is None: if build_mode is None:
build_mode = 'debug' build_mode = 'debug'
elif build_mode != 'release': elif build_mode != 'release':
build_mode = 'debug' build_mode = 'debug'
app_android_root = '' app_android_root = ''
target_proj_path_map = { target_proj_path_map = {
@ -214,8 +214,8 @@ def build_samples(target,ndk_build_param,android_platform,build_mode):
print 'unknown target: %s' % target print 'unknown target: %s' % target
continue continue
copy_resources(target, app_android_root) copy_resources(target, app_android_root)
do_build(cocos_root, ndk_root, app_android_root, ndk_build_param,sdk_root,android_platform,build_mode) do_build(cocos_root, ndk_root, app_android_root, ndk_build_param,sdk_root,android_platform,build_mode)
# -------------- main -------------- # -------------- main --------------
if __name__ == '__main__': if __name__ == '__main__':
@ -223,8 +223,8 @@ if __name__ == '__main__':
#parse the params #parse the params
usage = """ usage = """
This script is mainy used for building tests built-in with cocos2d-x. This script is mainy used for building tests built-in with cocos2d-x.
Usage: %prog [options] [cpp-empty-test|cpp-tests|lua-empty-test|lua-tests] Usage: %prog [options] [cpp-empty-test|cpp-tests|lua-empty-test|lua-tests|cpp|lua|all]
If you are new to cocos2d-x, I recommend you start with cpp-empty-test, lua-empty-test. If you are new to cocos2d-x, I recommend you start with cpp-empty-test, lua-empty-test.
@ -237,16 +237,17 @@ if __name__ == '__main__':
""" """
parser = OptionParser(usage=usage) parser = OptionParser(usage=usage)
parser.add_option("-n", "--ndk", dest="ndk_build_param", parser.add_option("-n", "--ndk", dest="ndk_build_param",
help='Parameter for ndk-build') help='Parameter for ndk-build')
parser.add_option("-p", "--platform", dest="android_platform", parser.add_option("-p", "--platform", dest="android_platform",
help='Parameter for android-update. Without the parameter,the script just build dynamic library for the projects. Valid android-platform are:[10|11|12|13|14|15|16|17|18|19]') help='Parameter for android-update. Without the parameter,the script just build dynamic library for the projects. Valid android-platform are:[10|11|12|13|14|15|16|17|18|19]')
parser.add_option("-b", "--build", dest="build_mode", parser.add_option("-b", "--build", dest="build_mode",
help='The build mode for java project,debug[default] or release. Get more information,please refer to http://developer.android.com/tools/building/building-cmdline.html') help='The build mode for java project,debug[default] or release. Get more information,please refer to http://developer.android.com/tools/building/building-cmdline.html')
(opts, args) = parser.parse_args() (opts, args) = parser.parse_args()
if len(args) == 0: if len(args) == 0:
parser.print_help() parser.print_help()
sys.exit(1)
else: else:
try: try:
build_samples(args, opts.ndk_build_param,opts.android_platform,opts.build_mode) build_samples(args, opts.ndk_build_param,opts.android_platform,opts.build_mode)

View File

@ -1 +1 @@
bbf0323293cba3d7ee58ef36706831a8761692d8 b8986c04c89d3861f82fb99b0df633ac2cc4a13c

View File

@ -1 +1 @@
66526d30a3e76bb1b54c7615a18c467845798e78 2c5a07d179e9514618036dfb7cfedd3f9cf4c506

View File

@ -27,16 +27,22 @@
#include "CCFontFreeType.h" #include "CCFontFreeType.h"
#include "ccUTF8.h" #include "ccUTF8.h"
#include "CCDirector.h" #include "CCDirector.h"
#include "CCEventListenerCustom.h"
#include "CCEventDispatcher.h"
#include "CCEventType.h"
NS_CC_BEGIN NS_CC_BEGIN
const int FontAtlas::CacheTextureWidth = 1024; const int FontAtlas::CacheTextureWidth = 1024;
const int FontAtlas::CacheTextureHeight = 1024; const int FontAtlas::CacheTextureHeight = 1024;
const char* FontAtlas::EVENT_PURGE_TEXTURES = "__cc_FontAtlasPurgeTextures";
FontAtlas::FontAtlas(Font &theFont) FontAtlas::FontAtlas(Font &theFont)
: _font(&theFont) : _font(&theFont)
, _currentPageData(nullptr) , _currentPageData(nullptr)
, _fontAscender(0) , _fontAscender(0)
, _toForegroundListener(nullptr)
, _toBackgroundListener(nullptr)
{ {
_font->retain(); _font->retain();
@ -61,15 +67,40 @@ FontAtlas::FontAtlas(Font &theFont)
_currentPageDataSize *= 2; _currentPageDataSize *= 2;
} }
_currentPageData = new unsigned char[_currentPageDataSize]; _currentPageData = new unsigned char[_currentPageDataSize];
memset(_currentPageData, 0, _currentPageDataSize); memset(_currentPageData, 0, _currentPageDataSize);
addTexture(texture,0); addTexture(texture,0);
texture->release(); texture->release();
#if CC_ENABLE_CACHE_TEXTURE_DATA
auto eventDispatcher = Director::getInstance()->getEventDispatcher();
_toBackgroundListener = EventListenerCustom::create(EVENT_COME_TO_BACKGROUND, CC_CALLBACK_1(FontAtlas::listenToBackground, this));
eventDispatcher->addEventListenerWithFixedPriority(_toBackgroundListener, 1);
_toForegroundListener = EventListenerCustom::create(EVENT_COME_TO_FOREGROUND, CC_CALLBACK_1(FontAtlas::listenToForeground, this));
eventDispatcher->addEventListenerWithFixedPriority(_toForegroundListener, 1);
#endif
} }
} }
FontAtlas::~FontAtlas() FontAtlas::~FontAtlas()
{ {
#if CC_ENABLE_CACHE_TEXTURE_DATA
FontFreeType* fontTTf = dynamic_cast<FontFreeType*>(_font);
if (fontTTf)
{
auto eventDispatcher = Director::getInstance()->getEventDispatcher();
if (_toForegroundListener)
{
eventDispatcher->removeEventListener(_toForegroundListener);
_toForegroundListener = nullptr;
}
if (_toBackgroundListener)
{
eventDispatcher->removeEventListener(_toBackgroundListener);
_toBackgroundListener = nullptr;
}
}
#endif
_font->release(); _font->release();
relaseTextures(); relaseTextures();
@ -82,6 +113,82 @@ void FontAtlas::relaseTextures()
{ {
item.second->release(); item.second->release();
} }
_atlasTextures.clear();
}
void FontAtlas::purgeTexturesAtlas()
{
FontFreeType* fontTTf = dynamic_cast<FontFreeType*>(_font);
if (fontTTf && _atlasTextures.size() > 1)
{
for( auto &item: _atlasTextures)
{
if (item.first != 0)
{
item.second->release();
}
}
auto temp = _atlasTextures[0];
_atlasTextures.clear();
_atlasTextures[0] = temp;
_fontLetterDefinitions.clear();
memset(_currentPageData,0,_currentPageDataSize);
_currentPage = 0;
_currentPageOrigX = 0;
_currentPageOrigY = 0;
auto eventDispatcher = Director::getInstance()->getEventDispatcher();
eventDispatcher->dispatchCustomEvent(EVENT_PURGE_TEXTURES,this);
}
}
void FontAtlas::listenToBackground(EventCustom *event)
{
#if CC_ENABLE_CACHE_TEXTURE_DATA
FontFreeType* fontTTf = dynamic_cast<FontFreeType*>(_font);
if (fontTTf && _atlasTextures.size() > 1)
{
for( auto &item: _atlasTextures)
{
if (item.first != 0)
{
item.second->release();
}
}
auto temp = _atlasTextures[0];
_atlasTextures.clear();
_atlasTextures[0] = temp;
_fontLetterDefinitions.clear();
memset(_currentPageData,0,_currentPageDataSize);
_currentPage = 0;
_currentPageOrigX = 0;
_currentPageOrigY = 0;
}
#endif
}
void FontAtlas::listenToForeground(EventCustom *event)
{
#if CC_ENABLE_CACHE_TEXTURE_DATA
FontFreeType* fontTTf = dynamic_cast<FontFreeType*>(_font);
if (fontTTf)
{
if (_currentPageOrigX == 0 && _currentPageOrigY == 0)
{
auto eventDispatcher = Director::getInstance()->getEventDispatcher();
eventDispatcher->dispatchCustomEvent(EVENT_PURGE_TEXTURES,this);
}
else
{
auto contentSize = Size(CacheTextureWidth,CacheTextureHeight);
auto pixelFormat = fontTTf->getOutlineSize() > 0 ? Texture2D::PixelFormat::AI88 : Texture2D::PixelFormat::A8;
_atlasTextures[_currentPage]->initWithData(_currentPageData, _currentPageDataSize, pixelFormat, CacheTextureWidth, CacheTextureHeight, contentSize );
}
}
#endif
} }
void FontAtlas::addLetterDefinition(const FontLetterDefinition &letterDefinition) void FontAtlas::addLetterDefinition(const FontLetterDefinition &letterDefinition)
@ -107,10 +214,10 @@ bool FontAtlas::getLetterDefinitionForChar(unsigned short letteCharUTF16, FontL
bool FontAtlas::prepareLetterDefinitions(unsigned short *utf16String) bool FontAtlas::prepareLetterDefinitions(unsigned short *utf16String)
{ {
if(_currentPageData == nullptr) FontFreeType* fontTTf = dynamic_cast<FontFreeType*>(_font);
if(fontTTf == nullptr)
return false; return false;
FontFreeType* fontTTf = (FontFreeType*)_font;
int length = cc_wcslen(utf16String); int length = cc_wcslen(utf16String);
float offsetAdjust = _letterPadding / 2; float offsetAdjust = _letterPadding / 2;
@ -150,11 +257,6 @@ bool FontAtlas::prepareLetterDefinitions(unsigned short *utf16String)
{ {
_atlasTextures[_currentPage]->initWithData(_currentPageData, _currentPageDataSize, pixelFormat, CacheTextureWidth, CacheTextureHeight, contentSize ); _atlasTextures[_currentPage]->initWithData(_currentPageData, _currentPageDataSize, pixelFormat, CacheTextureWidth, CacheTextureHeight, contentSize );
_currentPageOrigY = 0; _currentPageOrigY = 0;
delete []_currentPageData;
_currentPageData = new unsigned char[_currentPageDataSize];
if(_currentPageData == nullptr)
return false;
memset(_currentPageData, 0, _currentPageDataSize); memset(_currentPageData, 0, _currentPageDataSize);
_currentPage++; _currentPage++;
auto tex = new Texture2D; auto tex = new Texture2D;

View File

@ -34,6 +34,8 @@ NS_CC_BEGIN
//fwd //fwd
class Font; class Font;
class Texture2D; class Texture2D;
class EventCustom;
class EventListenerCustom;
struct FontLetterDefinition struct FontLetterDefinition
{ {
@ -54,6 +56,7 @@ class CC_DLL FontAtlas : public Ref
public: public:
static const int CacheTextureWidth; static const int CacheTextureWidth;
static const int CacheTextureHeight; static const int CacheTextureHeight;
static const char* EVENT_PURGE_TEXTURES;
/** /**
* @js ctor * @js ctor
*/ */
@ -76,7 +79,22 @@ public:
Texture2D* getTexture(int slot); Texture2D* getTexture(int slot);
const Font* getFont() const; const Font* getFont() const;
/** Listen "come to background" message, and clear the texture atlas.
It only has effect on Android.
*/
void listenToBackground(EventCustom *event);
/** Listen "come to foreground" message and restore the texture atlas.
It only has effect on Android.
*/
void listenToForeground(EventCustom *event);
/** Removes textures atlas.
It will purge the textures atlas and if multiple texture exist in the FontAtlas.
*/
void purgeTexturesAtlas();
private: private:
void relaseTextures(); void relaseTextures();
@ -95,6 +113,8 @@ private:
bool _makeDistanceMap; bool _makeDistanceMap;
int _fontAscender; int _fontAscender;
EventListenerCustom* _toBackgroundListener;
EventListenerCustom* _toForegroundListener;
}; };

View File

@ -36,6 +36,14 @@ NS_CC_BEGIN
std::unordered_map<std::string, FontAtlas *> FontAtlasCache::_atlasMap; std::unordered_map<std::string, FontAtlas *> FontAtlasCache::_atlasMap;
void FontAtlasCache::purgeCachedData()
{
for (auto & atlas:_atlasMap)
{
atlas.second->purgeTexturesAtlas();
}
}
FontAtlas * FontAtlasCache::getFontAtlasTTF(const TTFConfig & config) FontAtlas * FontAtlasCache::getFontAtlasTTF(const TTFConfig & config)
{ {
bool useDistanceField = config.distanceFieldEnabled; bool useDistanceField = config.distanceFieldEnabled;
@ -46,7 +54,7 @@ FontAtlas * FontAtlasCache::getFontAtlasTTF(const TTFConfig & config)
int fontSize = config.fontSize; int fontSize = config.fontSize;
if (useDistanceField) if (useDistanceField)
{ {
fontSize = Label::DistanceFieldFontSize; fontSize = Label::DistanceFieldFontSize / CC_CONTENT_SCALE_FACTOR();
} }
std::string atlasName = generateFontName(config.fontFilePath, fontSize, GlyphCollection::DYNAMIC, useDistanceField); std::string atlasName = generateFontName(config.fontFilePath, fontSize, GlyphCollection::DYNAMIC, useDistanceField);

View File

@ -45,6 +45,11 @@ public:
static FontAtlas * getFontAtlasCharMap(const std::string& plistFile); static FontAtlas * getFontAtlasCharMap(const std::string& plistFile);
static bool releaseFontAtlas(FontAtlas *atlas); static bool releaseFontAtlas(FontAtlas *atlas);
/** Removes cached data.
It will purge the textures atlas and if multiple texture exist in one FontAtlas.
*/
static void purgeCachedData();
private: private:
static std::string generateFontName(const std::string& fontFileName, int size, GlyphCollection theGlyphs, bool useDistanceField); static std::string generateFontName(const std::string& fontFileName, int size, GlyphCollection theGlyphs, bool useDistanceField);

View File

@ -33,6 +33,10 @@
#include "CCDirector.h" #include "CCDirector.h"
#include "renderer/CCRenderer.h" #include "renderer/CCRenderer.h"
#include "CCFont.h" #include "CCFont.h"
#include "CCEventListenerCustom.h"
#include "CCEventDispatcher.h"
#include "CCEventType.h"
#include "CCEventCustom.h"
NS_CC_BEGIN NS_CC_BEGIN
@ -278,6 +282,14 @@ Label::Label(FontAtlas *atlas /* = nullptr */, TextHAlignment hAlignment /* = Te
_cascadeColorEnabled = true; _cascadeColorEnabled = true;
reset(); reset();
#if CC_ENABLE_CACHE_TEXTURE_DATA
auto toBackgroundListener = EventListenerCustom::create(EVENT_COME_TO_BACKGROUND, CC_CALLBACK_1(Label::listenToBackground, this));
_eventDispatcher->addEventListenerWithSceneGraphPriority(toBackgroundListener, this);
#endif
auto purgeTextureListener = EventListenerCustom::create(FontAtlas::EVENT_PURGE_TEXTURES, CC_CALLBACK_1(Label::listenToFontAtlasPurge, this));
_eventDispatcher->addEventListenerWithSceneGraphPriority(purgeTextureListener, this);
} }
Label::~Label() Label::~Label()
@ -404,6 +416,8 @@ bool Label::setTTFConfig(const TTFConfig& ttfConfig)
return false; return false;
} }
setFontAtlas(newAtlas,ttfConfig.distanceFieldEnabled,true);
_fontConfig = ttfConfig; _fontConfig = ttfConfig;
if (_fontConfig.outlineSize > 0) if (_fontConfig.outlineSize > 0)
{ {
@ -418,8 +432,6 @@ bool Label::setTTFConfig(const TTFConfig& ttfConfig)
this->setFontScale(1.0f * ttfConfig.fontSize / DistanceFieldFontSize); this->setFontScale(1.0f * ttfConfig.fontSize / DistanceFieldFontSize);
} }
setFontAtlas(newAtlas,ttfConfig.distanceFieldEnabled,true);
_currentLabelType = LabelType::TTF; _currentLabelType = LabelType::TTF;
return true; return true;
@ -813,7 +825,7 @@ void Label::disableEffect()
void Label::setFontScale(float fontScale) void Label::setFontScale(float fontScale)
{ {
_fontScale = fontScale; _fontScale = fontScale * CC_CONTENT_SCALE_FACTOR();
Node::setScale(_fontScale); Node::setScale(_fontScale);
} }
@ -1024,13 +1036,7 @@ void Label::setFontName(const std::string& fontName)
const std::string& Label::getFontName() const const std::string& Label::getFontName() const
{ {
switch (_currentLabelType) return _fontName;
{
case LabelType::TTF:
return _fontConfig.fontFilePath;
default:
return _fontDefinition._fontName;
}
} }
void Label::setFontSize(int fontSize) void Label::setFontSize(int fontSize)
@ -1044,15 +1050,7 @@ void Label::setFontSize(int fontSize)
int Label::getFontSize() const int Label::getFontSize() const
{ {
switch (_currentLabelType) return _fontSize;
{
case LabelType::TTF:
return _fontConfig.fontSize;
case LabelType::STRING_TEXTURE:
return _fontDefinition._fontSize;
default:
return 0;
}
} }
///// PROTOCOL STUFF ///// PROTOCOL STUFF
@ -1215,4 +1213,24 @@ const Size& Label::getContentSize() const
return Node::getContentSize(); return Node::getContentSize();
} }
void Label::listenToBackground(EventCustom *event)
{
#if CC_ENABLE_CACHE_TEXTURE_DATA
if (_fontAtlas && _currentLabelType == LabelType::TTF)
{
_batchNodes.clear();
_batchNodes.push_back(this);
Node::removeAllChildrenWithCleanup(true);
}
#endif
}
void Label::listenToFontAtlasPurge(EventCustom *event)
{
if (_fontAtlas && _currentLabelType == LabelType::TTF && event->getUserData() == _fontAtlas)
{
alignText();
}
}
NS_CC_END NS_CC_END

View File

@ -230,6 +230,15 @@ public:
virtual const Size& getContentSize() const override; virtual const Size& getContentSize() const override;
/** Listen "come to background" message
It only has effect on Android.
*/
void listenToBackground(EventCustom *event);
/** Listen "FontAtlas purge textures" message
*/
void listenToFontAtlasPurge(EventCustom *event);
protected: protected:
void onDraw(const kmMat4& transform, bool transformUpdated); void onDraw(const kmMat4& transform, bool transformUpdated);

View File

@ -226,6 +226,24 @@ const std::string& LabelAtlas::getString(void) const
return _string; return _string;
} }
void LabelAtlas::updateColor()
{
if (_textureAtlas)
{
Color4B color4( _displayedColor.r, _displayedColor.g, _displayedColor.b, _displayedOpacity );
auto quads = _textureAtlas->getQuads();
ssize_t length = _string.length();
for (int index = 0; index < length; index++)
{
quads[index].bl.colors = color4;
quads[index].br.colors = color4;
quads[index].tl.colors = color4;
quads[index].tr.colors = color4;
_textureAtlas->updateQuad(&quads[index], index);
}
}
}
//CCLabelAtlas - draw //CCLabelAtlas - draw
#if CC_LABELATLAS_DEBUG_DRAW #if CC_LABELATLAS_DEBUG_DRAW

View File

@ -94,7 +94,8 @@ protected:
{ {
_string.clear(); _string.clear();
} }
virtual void updateColor() override;
// string to render // string to render
std::string _string; std::string _string;
// the first char in the charmap // the first char in the charmap

View File

@ -29,7 +29,7 @@ THE SOFTWARE.
#include "CCActionInterval.h" #include "CCActionInterval.h"
#include "CCSprite.h" #include "CCSprite.h"
#include "CCLabelAtlas.h" #include "CCLabelAtlas.h"
#include "CCLabelTTF.h" #include "CCLabel.h"
#include "CCScriptSupport.h" #include "CCScriptSupport.h"
#include <stdarg.h> #include <stdarg.h>
#include <cstring> #include <cstring>
@ -301,12 +301,12 @@ void MenuItemLabel::setEnabled(bool enabled)
{ {
if(enabled == false) if(enabled == false)
{ {
_colorBackup = _label->getColor(); _colorBackup = this->getColor();
_label->setColor(_disabledColor); this->setColor(_disabledColor);
} }
else else
{ {
_label->setColor(_colorBackup); this->setColor(_colorBackup);
} }
} }
MenuItem::setEnabled(enabled); MenuItem::setEnabled(enabled);
@ -439,7 +439,7 @@ bool MenuItemFont::initWithString(const std::string& value, const ccMenuCallback
_fontName = _globalFontName; _fontName = _globalFontName;
_fontSize = _globalFontSize; _fontSize = _globalFontSize;
LabelTTF *label = LabelTTF::create(value, _fontName, (float)_fontSize); Label *label = Label::create(value, _fontName, _fontSize);
if (MenuItemLabel::initWithLabel(label, callback)) if (MenuItemLabel::initWithLabel(label, callback))
{ {
// do something ? // do something ?
@ -447,17 +447,11 @@ bool MenuItemFont::initWithString(const std::string& value, const ccMenuCallback
return true; return true;
} }
void MenuItemFont::recreateLabel()
{
LabelTTF *label = LabelTTF::create(dynamic_cast<LabelProtocol*>(_label)->getString(),
_fontName.c_str(), (float)_fontSize);
this->setLabel(label);
}
void MenuItemFont::setFontSizeObj(int s) void MenuItemFont::setFontSizeObj(int s)
{ {
_fontSize = s; _fontSize = s;
recreateLabel(); dynamic_cast<Label*>(_label)->setFontSize(_fontSize);
this->setContentSize(dynamic_cast<Label*>(_label)->getContentSize());
} }
int MenuItemFont::getFontSizeObj() const int MenuItemFont::getFontSizeObj() const
@ -468,7 +462,8 @@ int MenuItemFont::getFontSizeObj() const
void MenuItemFont::setFontNameObj(const std::string& name) void MenuItemFont::setFontNameObj(const std::string& name)
{ {
_fontName = name; _fontName = name;
recreateLabel(); dynamic_cast<Label*>(_label)->setFontName(_fontName);
this->setContentSize(dynamic_cast<Label*>(_label)->getContentSize());
} }
const std::string& MenuItemFont::getFontNameObj() const const std::string& MenuItemFont::getFontNameObj() const

View File

@ -40,7 +40,7 @@ NS_CC_BEGIN
typedef std::function<void(Ref*)> ccMenuCallback; typedef std::function<void(Ref*)> ccMenuCallback;
class LabelTTF; class Label;
class LabelAtlas; class LabelAtlas;
class Sprite; class Sprite;
class SpriteFrame; class SpriteFrame;
@ -142,6 +142,7 @@ private:
- BitmapFontAtlas - BitmapFontAtlas
- LabelAtlas - LabelAtlas
- LabelTTF - LabelTTF
- Label
*/ */
class CC_DLL MenuItemLabel : public MenuItem class CC_DLL MenuItemLabel : public MenuItem
{ {
@ -310,8 +311,6 @@ protected:
CC_DEPRECATED_ATTRIBUTE bool initWithString(const std::string& value, Ref* target, SEL_MenuHandler selector); CC_DEPRECATED_ATTRIBUTE bool initWithString(const std::string& value, Ref* target, SEL_MenuHandler selector);
/** initializes a menu item from a string with a target/selector */ /** initializes a menu item from a string with a target/selector */
bool initWithString(const std::string& value, const ccMenuCallback& callback); bool initWithString(const std::string& value, const ccMenuCallback& callback);
void recreateLabel();
int _fontSize; int _fontSize;
std::string _fontName; std::string _fontName;

View File

@ -224,7 +224,7 @@ void TMXLayer::parseInternalProperties()
void TMXLayer::setupTileSprite(Sprite* sprite, Point pos, int gid) void TMXLayer::setupTileSprite(Sprite* sprite, Point pos, int gid)
{ {
sprite->setPosition(getPositionAt(pos)); sprite->setPosition(getPositionAt(pos));
sprite->setVertexZ((float)getVertexZForPos(pos)); sprite->setPositionZ((float)getVertexZForPos(pos));
sprite->setAnchorPoint(Point::ZERO); sprite->setAnchorPoint(Point::ZERO);
sprite->setOpacity(_opacity); sprite->setOpacity(_opacity);
@ -326,7 +326,7 @@ Sprite * TMXLayer::getTileAt(const Point& pos)
tile = Sprite::createWithTexture(this->getTexture(), rect); tile = Sprite::createWithTexture(this->getTexture(), rect);
tile->setBatchNode(this); tile->setBatchNode(this);
tile->setPosition(getPositionAt(pos)); tile->setPosition(getPositionAt(pos));
tile->setVertexZ((float)getVertexZForPos(pos)); tile->setPositionZ((float)getVertexZForPos(pos));
tile->setAnchorPoint(Point::ZERO); tile->setAnchorPoint(Point::ZERO);
tile->setOpacity(_opacity); tile->setOpacity(_opacity);

View File

@ -500,11 +500,9 @@ void TextureCache::waitForQuit()
std::string TextureCache::getCachedTextureInfo() const std::string TextureCache::getCachedTextureInfo() const
{ {
char buffer[16386]; std::string buffer;
char buftmp[4096]; char buftmp[4096];
memset(buffer,0,sizeof(buffer));
unsigned int count = 0; unsigned int count = 0;
unsigned int totalBytes = 0; unsigned int totalBytes = 0;
@ -527,13 +525,14 @@ std::string TextureCache::getCachedTextureInfo() const
(long)tex->getPixelsHigh(), (long)tex->getPixelsHigh(),
(long)bpp, (long)bpp,
(long)bytes / 1024); (long)bytes / 1024);
strcat(buffer, buftmp);
buffer += buftmp;
} }
snprintf(buftmp, sizeof(buftmp)-1, "TextureCache dumpDebugInfo: %ld textures, for %lu KB (%.2f MB)\n", (long)count, (long)totalBytes / 1024, totalBytes / (1024.0f*1024.0f)); snprintf(buftmp, sizeof(buftmp)-1, "TextureCache dumpDebugInfo: %ld textures, for %lu KB (%.2f MB)\n", (long)count, (long)totalBytes / 1024, totalBytes / (1024.0f*1024.0f));
strcat(buffer, buftmp); buffer += buftmp;
return std::string(buffer); return buffer;
} }
#if CC_ENABLE_CACHE_TEXTURE_DATA #if CC_ENABLE_CACHE_TEXTURE_DATA

View File

@ -84,6 +84,7 @@
<DebugInformationFormat>OldStyle</DebugInformationFormat> <DebugInformationFormat>OldStyle</DebugInformationFormat>
<DisableSpecificWarnings>4267;4251;4244;%(DisableSpecificWarnings)</DisableSpecificWarnings> <DisableSpecificWarnings>4267;4251;4244;%(DisableSpecificWarnings)</DisableSpecificWarnings>
<MultiProcessorCompilation>true</MultiProcessorCompilation> <MultiProcessorCompilation>true</MultiProcessorCompilation>
<CompileAs>CompileAsCpp</CompileAs>
</ClCompile> </ClCompile>
<PreLinkEvent> <PreLinkEvent>
<Command>if not exist "$(OutDir)" mkdir "$(OutDir)" <Command>if not exist "$(OutDir)" mkdir "$(OutDir)"
@ -129,6 +130,7 @@ xcopy /Y /Q "$(ProjectDir)..\..\external\win32-specific\gles\prebuilt\*.*" "$(Ou
<DebugInformationFormat>ProgramDatabase</DebugInformationFormat> <DebugInformationFormat>ProgramDatabase</DebugInformationFormat>
<DisableSpecificWarnings>4267;4251;4244;%(DisableSpecificWarnings)</DisableSpecificWarnings> <DisableSpecificWarnings>4267;4251;4244;%(DisableSpecificWarnings)</DisableSpecificWarnings>
<MultiProcessorCompilation>true</MultiProcessorCompilation> <MultiProcessorCompilation>true</MultiProcessorCompilation>
<CompileAs>CompileAsCpp</CompileAs>
</ClCompile> </ClCompile>
<PreLinkEvent> <PreLinkEvent>
<Command>if not exist "$(OutDir)" mkdir "$(OutDir)" <Command>if not exist "$(OutDir)" mkdir "$(OutDir)"
@ -182,42 +184,20 @@ xcopy /Y /Q "$(ProjectDir)..\..\external\win32-specific\gles\prebuilt\*.*" "$(Ou
<ClCompile Include="..\base\CCValue.cpp" /> <ClCompile Include="..\base\CCValue.cpp" />
<ClCompile Include="..\base\etc1.cpp" /> <ClCompile Include="..\base\etc1.cpp" />
<ClCompile Include="..\base\s3tc.cpp" /> <ClCompile Include="..\base\s3tc.cpp" />
<ClCompile Include="..\math\kazmath\kazmath\aabb.c"> <ClCompile Include="..\math\kazmath\kazmath\aabb.c" />
<CompileAs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">CompileAsCpp</CompileAs>
</ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\GL\mat4stack.c" /> <ClCompile Include="..\math\kazmath\kazmath\GL\mat4stack.c" />
<ClCompile Include="..\math\kazmath\kazmath\GL\matrix.c" /> <ClCompile Include="..\math\kazmath\kazmath\GL\matrix.c" />
<ClCompile Include="..\math\kazmath\kazmath\mat3.c"> <ClCompile Include="..\math\kazmath\kazmath\mat3.c" />
<CompileAs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">CompileAsCpp</CompileAs> <ClCompile Include="..\math\kazmath\kazmath\mat4.c" />
</ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\mat4.c">
<CompileAs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">CompileAsCpp</CompileAs>
</ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\neon_matrix_impl.c" /> <ClCompile Include="..\math\kazmath\kazmath\neon_matrix_impl.c" />
<ClCompile Include="..\math\kazmath\kazmath\plane.c"> <ClCompile Include="..\math\kazmath\kazmath\plane.c" />
<CompileAs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">CompileAsCpp</CompileAs> <ClCompile Include="..\math\kazmath\kazmath\quaternion.c" />
</ClCompile> <ClCompile Include="..\math\kazmath\kazmath\ray2.c" />
<ClCompile Include="..\math\kazmath\kazmath\quaternion.c"> <ClCompile Include="..\math\kazmath\kazmath\ray3.c" />
<CompileAs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">CompileAsCpp</CompileAs> <ClCompile Include="..\math\kazmath\kazmath\utility.c" />
</ClCompile> <ClCompile Include="..\math\kazmath\kazmath\vec2.c" />
<ClCompile Include="..\math\kazmath\kazmath\ray2.c"> <ClCompile Include="..\math\kazmath\kazmath\vec3.c" />
<CompileAs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">CompileAsCpp</CompileAs> <ClCompile Include="..\math\kazmath\kazmath\vec4.c" />
</ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\ray3.c">
<CompileAs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">CompileAsCpp</CompileAs>
</ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\utility.c">
<CompileAs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">CompileAsCpp</CompileAs>
</ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\vec2.c">
<CompileAs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">CompileAsCpp</CompileAs>
</ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\vec3.c">
<CompileAs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">CompileAsCpp</CompileAs>
</ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\vec4.c">
<CompileAs Condition="'$(Configuration)|$(Platform)'=='Debug|Win32'">CompileAsCpp</CompileAs>
</ClCompile>
<ClCompile Include="..\physics\CCPhysicsBody.cpp" /> <ClCompile Include="..\physics\CCPhysicsBody.cpp" />
<ClCompile Include="..\physics\CCPhysicsContact.cpp" /> <ClCompile Include="..\physics\CCPhysicsContact.cpp" />
<ClCompile Include="..\physics\CCPhysicsJoint.cpp" /> <ClCompile Include="..\physics\CCPhysicsJoint.cpp" />
@ -558,6 +538,9 @@ xcopy /Y /Q "$(ProjectDir)..\..\external\win32-specific\gles\prebuilt\*.*" "$(Ou
<ClInclude Include="utlist.h" /> <ClInclude Include="utlist.h" />
<ClInclude Include="ZipUtils.h" /> <ClInclude Include="ZipUtils.h" />
</ItemGroup> </ItemGroup>
<ItemGroup>
<Text Include="..\math\kazmath\kazmath\CMakeLists.txt" />
</ItemGroup>
<Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" /> <Import Project="$(VCTargetsPath)\Microsoft.Cpp.targets" />
<ImportGroup Label="ExtensionTargets"> <ImportGroup Label="ExtensionTargets">
</ImportGroup> </ImportGroup>

View File

@ -91,21 +91,6 @@
<Filter Include="physics\chipmunk"> <Filter Include="physics\chipmunk">
<UniqueIdentifier>{aeadfa95-9c89-4212-98ae-89ad57db596a}</UniqueIdentifier> <UniqueIdentifier>{aeadfa95-9c89-4212-98ae-89ad57db596a}</UniqueIdentifier>
</Filter> </Filter>
<Filter Include="kazmath\include">
<UniqueIdentifier>{05e27e68-7574-4a8b-af68-553dd3bafdfa}</UniqueIdentifier>
</Filter>
<Filter Include="kazmath\src">
<UniqueIdentifier>{b797075f-7437-46d5-b4ee-2aa2c108e98f}</UniqueIdentifier>
</Filter>
<Filter Include="kazmath\src\GL">
<UniqueIdentifier>{c755509d-1610-4e6c-b01b-e01d4d0de46e}</UniqueIdentifier>
</Filter>
<Filter Include="kazmath\include\kazmath">
<UniqueIdentifier>{e1b64497-c099-4f06-8d61-9d4c6b7a215a}</UniqueIdentifier>
</Filter>
<Filter Include="kazmath\include\kazmath\GL">
<UniqueIdentifier>{7c71abeb-8b4b-4be8-a23c-e32fedc65fc9}</UniqueIdentifier>
</Filter>
<Filter Include="base"> <Filter Include="base">
<UniqueIdentifier>{aec8225f-81a7-4213-b97b-7004d5535398}</UniqueIdentifier> <UniqueIdentifier>{aec8225f-81a7-4213-b97b-7004d5535398}</UniqueIdentifier>
</Filter> </Filter>
@ -115,6 +100,9 @@
<Filter Include="platform\desktop"> <Filter Include="platform\desktop">
<UniqueIdentifier>{32373f63-2c2d-4eab-bc4a-21745ba0b3fb}</UniqueIdentifier> <UniqueIdentifier>{32373f63-2c2d-4eab-bc4a-21745ba0b3fb}</UniqueIdentifier>
</Filter> </Filter>
<Filter Include="kazmath\GL">
<UniqueIdentifier>{465965df-dc31-471a-887f-e430125b8ba0}</UniqueIdentifier>
</Filter>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
<ClCompile Include="..\physics\CCPhysicsBody.cpp"> <ClCompile Include="..\physics\CCPhysicsBody.cpp">
@ -561,46 +549,46 @@
</ClCompile> </ClCompile>
<ClCompile Include="CCTweenFunction.cpp" /> <ClCompile Include="CCTweenFunction.cpp" />
<ClCompile Include="..\math\kazmath\kazmath\GL\mat4stack.c"> <ClCompile Include="..\math\kazmath\kazmath\GL\mat4stack.c">
<Filter>kazmath\src\GL</Filter> <Filter>kazmath\GL</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\GL\matrix.c"> <ClCompile Include="..\math\kazmath\kazmath\GL\matrix.c">
<Filter>kazmath\src\GL</Filter> <Filter>kazmath\GL</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\aabb.c"> <ClCompile Include="..\math\kazmath\kazmath\aabb.c">
<Filter>kazmath\src</Filter> <Filter>kazmath</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\mat3.c"> <ClCompile Include="..\math\kazmath\kazmath\mat3.c">
<Filter>kazmath\src</Filter> <Filter>kazmath</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\mat4.c"> <ClCompile Include="..\math\kazmath\kazmath\mat4.c">
<Filter>kazmath\src</Filter> <Filter>kazmath</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\neon_matrix_impl.c"> <ClCompile Include="..\math\kazmath\kazmath\neon_matrix_impl.c">
<Filter>kazmath\src</Filter> <Filter>kazmath</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\plane.c"> <ClCompile Include="..\math\kazmath\kazmath\plane.c">
<Filter>kazmath\src</Filter> <Filter>kazmath</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\quaternion.c"> <ClCompile Include="..\math\kazmath\kazmath\quaternion.c">
<Filter>kazmath\src</Filter> <Filter>kazmath</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\ray2.c"> <ClCompile Include="..\math\kazmath\kazmath\ray2.c">
<Filter>kazmath\src</Filter> <Filter>kazmath</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\ray3.c"> <ClCompile Include="..\math\kazmath\kazmath\ray3.c">
<Filter>kazmath\src</Filter> <Filter>kazmath</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\utility.c"> <ClCompile Include="..\math\kazmath\kazmath\utility.c">
<Filter>kazmath\src</Filter> <Filter>kazmath</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\vec2.c"> <ClCompile Include="..\math\kazmath\kazmath\vec2.c">
<Filter>kazmath\src</Filter> <Filter>kazmath</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\vec3.c"> <ClCompile Include="..\math\kazmath\kazmath\vec3.c">
<Filter>kazmath\src</Filter> <Filter>kazmath</Filter>
</ClCompile> </ClCompile>
<ClCompile Include="..\math\kazmath\kazmath\vec4.c"> <ClCompile Include="..\math\kazmath\kazmath\vec4.c">
<Filter>kazmath\src</Filter> <Filter>kazmath</Filter>
</ClCompile> </ClCompile>
</ItemGroup> </ItemGroup>
<ItemGroup> <ItemGroup>
@ -1162,49 +1150,54 @@
</ClInclude> </ClInclude>
<ClInclude Include="CCTweenFunction.h" /> <ClInclude Include="CCTweenFunction.h" />
<ClInclude Include="..\math\kazmath\kazmath\GL\mat4stack.h"> <ClInclude Include="..\math\kazmath\kazmath\GL\mat4stack.h">
<Filter>kazmath\include\kazmath\GL</Filter> <Filter>kazmath\GL</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\GL\matrix.h"> <ClInclude Include="..\math\kazmath\kazmath\GL\matrix.h">
<Filter>kazmath\include\kazmath\GL</Filter> <Filter>kazmath\GL</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\aabb.h"> <ClInclude Include="..\math\kazmath\kazmath\aabb.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\kazmath.h"> <ClInclude Include="..\math\kazmath\kazmath\kazmath.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\mat3.h"> <ClInclude Include="..\math\kazmath\kazmath\mat3.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\mat4.h"> <ClInclude Include="..\math\kazmath\kazmath\mat4.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\neon_matrix_impl.h"> <ClInclude Include="..\math\kazmath\kazmath\neon_matrix_impl.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\plane.h"> <ClInclude Include="..\math\kazmath\kazmath\plane.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\quaternion.h"> <ClInclude Include="..\math\kazmath\kazmath\quaternion.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\ray2.h"> <ClInclude Include="..\math\kazmath\kazmath\ray2.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\ray3.h"> <ClInclude Include="..\math\kazmath\kazmath\ray3.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\utility.h"> <ClInclude Include="..\math\kazmath\kazmath\utility.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\vec2.h"> <ClInclude Include="..\math\kazmath\kazmath\vec2.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\vec3.h"> <ClInclude Include="..\math\kazmath\kazmath\vec3.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
<ClInclude Include="..\math\kazmath\kazmath\vec4.h"> <ClInclude Include="..\math\kazmath\kazmath\vec4.h">
<Filter>kazmath\include\kazmath</Filter> <Filter>kazmath</Filter>
</ClInclude> </ClInclude>
</ItemGroup> </ItemGroup>
<ItemGroup>
<Text Include="..\math\kazmath\kazmath\CMakeLists.txt">
<Filter>kazmath</Filter>
</Text>
</ItemGroup>
</Project> </Project>

View File

@ -399,7 +399,7 @@ void GLView::swapBuffers()
bool GLView::windowShouldClose() bool GLView::windowShouldClose()
{ {
if(_mainWindow) if(_mainWindow)
return glfwWindowShouldClose(_mainWindow); return glfwWindowShouldClose(_mainWindow) ? true : false;
else else
return true; return true;
} }

View File

@ -70,17 +70,26 @@ int Application::run()
return 0; return 0;
} }
long lastTime = 0L;
long curTime = 0L;
auto director = Director::getInstance(); auto director = Director::getInstance();
auto glview = director->getOpenGLView(); auto glview = director->getOpenGLView();
// Retain glview to avoid glview being released in the while loop
glview->retain();
while (!glview->windowShouldClose()) while (!glview->windowShouldClose())
{ {
long iLastTime = getCurrentMillSecond(); lastTime = getCurrentMillSecond();
director->mainLoop(); director->mainLoop();
glview->pollEvents(); glview->pollEvents();
long iCurTime = getCurrentMillSecond();
if (iCurTime-iLastTime<_animationInterval){ curTime = getCurrentMillSecond();
usleep((_animationInterval - iCurTime+iLastTime)*1000); if (curTime - lastTime < _animationInterval)
{
usleep((_animationInterval - curTime + lastTime)*1000);
} }
} }
/* Only work on Desktop /* Only work on Desktop
@ -88,8 +97,13 @@ int Application::run()
* when we want to close the window, we should call Director::end(); * when we want to close the window, we should call Director::end();
* then call Director::mainLoop to do release of internal resources * then call Director::mainLoop to do release of internal resources
*/ */
director->end(); if (glview->isOpenGLReady())
director->mainLoop(); {
director->end();
director->mainLoop();
director = nullptr;
}
glview->release();
return -1; return -1;
} }

View File

@ -68,16 +68,27 @@ int Application::run()
{ {
return 0; return 0;
} }
GLView* glview = Director::getInstance()->getOpenGLView();
long lastTime = 0L;
long curTime = 0L;
auto director = Director::getInstance();
auto glview = director->getOpenGLView();
// Retain glview to avoid glview being released in the while loop
glview->retain();
while (!glview->windowShouldClose()) while (!glview->windowShouldClose())
{ {
long iLastTime = getCurrentMillSecond(); lastTime = getCurrentMillSecond();
Director::getInstance()->mainLoop();
director->mainLoop();
glview->pollEvents(); glview->pollEvents();
long iCurTime = getCurrentMillSecond();
if (iCurTime-iLastTime<_animationInterval){ curTime = getCurrentMillSecond();
usleep(static_cast<useconds_t>((_animationInterval - iCurTime+iLastTime)*1000)); if (curTime - lastTime < _animationInterval)
{
usleep(static_cast<useconds_t>((_animationInterval - curTime + lastTime)*1000));
} }
} }
@ -86,8 +97,14 @@ int Application::run()
* when we want to close the window, we should call Director::end(); * when we want to close the window, we should call Director::end();
* then call Director::mainLoop to do release of internal resources * then call Director::mainLoop to do release of internal resources
*/ */
Director::getInstance()->end(); if (glview->isOpenGLReady())
Director::getInstance()->mainLoop(); {
director->end();
director->mainLoop();
}
glview->release();
return true; return true;
} }

View File

@ -79,12 +79,16 @@ int Application::run()
auto director = Director::getInstance(); auto director = Director::getInstance();
auto glview = director->getOpenGLView(); auto glview = director->getOpenGLView();
// Retain glview to avoid glview being released in the while loop
glview->retain();
while(!glview->windowShouldClose()) while(!glview->windowShouldClose())
{ {
QueryPerformanceCounter(&nNow); QueryPerformanceCounter(&nNow);
if (nNow.QuadPart - nLast.QuadPart > _animationInterval.QuadPart) if (nNow.QuadPart - nLast.QuadPart > _animationInterval.QuadPart)
{ {
nLast.QuadPart = nNow.QuadPart; nLast.QuadPart = nNow.QuadPart;
director->mainLoop(); director->mainLoop();
glview->pollEvents(); glview->pollEvents();
} }
@ -101,6 +105,7 @@ int Application::run()
director->mainLoop(); director->mainLoop();
director = nullptr; director = nullptr;
} }
glview->release();
return true; return true;
} }

View File

@ -110,7 +110,7 @@ bool FileUtilsWin32::isFileExist(const std::string& strFilePath) const
} }
WCHAR utf16Buf[CC_MAX_PATH] = {0}; WCHAR utf16Buf[CC_MAX_PATH] = {0};
MultiByteToWideChar(CP_UTF8, 0, strPath.c_str(), -1, utf16Buf, sizeof(utf16Buf)); MultiByteToWideChar(CP_UTF8, 0, strPath.c_str(), -1, utf16Buf, sizeof(utf16Buf)/sizeof(utf16Buf[0]));
return GetFileAttributesW(utf16Buf) != -1 ? true : false; return GetFileAttributesW(utf16Buf) != -1 ? true : false;
} }
@ -137,7 +137,7 @@ static Data getData(const std::string& filename, bool forString)
std::string fullPath = FileUtils::getInstance()->fullPathForFilename(filename); std::string fullPath = FileUtils::getInstance()->fullPathForFilename(filename);
WCHAR wszBuf[CC_MAX_PATH] = {0}; WCHAR wszBuf[CC_MAX_PATH] = {0};
MultiByteToWideChar(CP_UTF8, 0, fullPath.c_str(), -1, wszBuf, sizeof(wszBuf)); MultiByteToWideChar(CP_UTF8, 0, fullPath.c_str(), -1, wszBuf, sizeof(wszBuf)/sizeof(wszBuf[0]));
HANDLE fileHandle = ::CreateFileW(wszBuf, GENERIC_READ, 0, NULL, OPEN_EXISTING, NULL, NULL); HANDLE fileHandle = ::CreateFileW(wszBuf, GENERIC_READ, 0, NULL, OPEN_EXISTING, NULL, NULL);
CC_BREAK_IF(fileHandle == INVALID_HANDLE_VALUE); CC_BREAK_IF(fileHandle == INVALID_HANDLE_VALUE);
@ -211,7 +211,7 @@ unsigned char* FileUtilsWin32::getFileData(const std::string& filename, const ch
std::string fullPath = fullPathForFilename(filename); std::string fullPath = fullPathForFilename(filename);
WCHAR wszBuf[CC_MAX_PATH] = {0}; WCHAR wszBuf[CC_MAX_PATH] = {0};
MultiByteToWideChar(CP_UTF8, 0, fullPath.c_str(), -1, wszBuf, sizeof(wszBuf)); MultiByteToWideChar(CP_UTF8, 0, fullPath.c_str(), -1, wszBuf, sizeof(wszBuf)/sizeof(wszBuf[0]));
HANDLE fileHandle = ::CreateFileW(wszBuf, GENERIC_READ, 0, NULL, OPEN_EXISTING, NULL, NULL); HANDLE fileHandle = ::CreateFileW(wszBuf, GENERIC_READ, 0, NULL, OPEN_EXISTING, NULL, NULL);
CC_BREAK_IF(fileHandle == INVALID_HANDLE_VALUE); CC_BREAK_IF(fileHandle == INVALID_HANDLE_VALUE);

View File

@ -214,7 +214,7 @@ static void _log(const char *format, va_list args)
WCHAR wszBuf[MAX_LOG_LENGTH] = {0}; WCHAR wszBuf[MAX_LOG_LENGTH] = {0};
MultiByteToWideChar(CP_UTF8, 0, buf, -1, wszBuf, sizeof(wszBuf)); MultiByteToWideChar(CP_UTF8, 0, buf, -1, wszBuf, sizeof(wszBuf));
OutputDebugStringW(wszBuf); OutputDebugStringW(wszBuf);
WideCharToMultiByte(CP_ACP, 0, wszBuf, sizeof(wszBuf), buf, sizeof(buf), NULL, FALSE); WideCharToMultiByte(CP_ACP, 0, wszBuf, -1, buf, sizeof(buf), NULL, FALSE);
printf("%s", buf); printf("%s", buf);
#else #else

View File

@ -488,11 +488,11 @@ void CCBAnimationManager::setAnimatedProperty(const std::string& propName, Node
} else if(propName == "rotationX") } else if(propName == "rotationX")
{ {
float rotate = value.asFloat(); float rotate = value.asFloat();
pNode->setRotationX(rotate); pNode->setRotationSkewX(rotate);
}else if(propName == "rotationY") }else if(propName == "rotationY")
{ {
float rotate = value.asFloat(); float rotate = value.asFloat();
pNode->setRotationY(rotate); pNode->setRotationSkewY(rotate);
} }
else if (propName == "opacity") else if (propName == "opacity")
{ {
@ -1169,7 +1169,7 @@ void CCBRotateXTo::startWithTarget(Node *pNode)
_target = pNode; _target = pNode;
_elapsed = 0.0f; _elapsed = 0.0f;
_firstTick = true; _firstTick = true;
_startAngle = _target->getRotationX(); _startAngle = _target->getRotationSkewX();
_diffAngle = _dstAngle - _startAngle; _diffAngle = _dstAngle - _startAngle;
} }
@ -1190,8 +1190,7 @@ CCBRotateXTo* CCBRotateXTo::reverse() const
void CCBRotateXTo::update(float time) void CCBRotateXTo::update(float time)
{ {
_target->setRotationX(_startAngle + (_diffAngle * time)) _target->setRotationSkewX(_startAngle + (_diffAngle * time));
;
} }
@ -1257,14 +1256,13 @@ void CCBRotateYTo::startWithTarget(Node *pNode)
_target = pNode; _target = pNode;
_elapsed = 0.0f; _elapsed = 0.0f;
_firstTick = true; _firstTick = true;
_startAngle = _target->getRotationY(); _startAngle = _target->getRotationSkewY();
_diffAngle = _dstAngle - _startAngle; _diffAngle = _dstAngle - _startAngle;
} }
void CCBRotateYTo::update(float time) void CCBRotateYTo::update(float time)
{ {
_target->setRotationY(_startAngle + (_diffAngle * time)) _target->setRotationSkewY(_startAngle + (_diffAngle * time));
;
} }

View File

@ -79,7 +79,7 @@ void NodeLoader::parseProperties(Node * pNode, Node * pParent, CCBReader * ccbRe
pNode = ccbNode->getCCBFileNode(); pNode = ccbNode->getCCBFileNode();
// Skip properties that doesn't have a value to override // Skip properties that doesn't have a value to override
Array *extraPropsNames = (Array*)pNode->getUserObject(); __Array *extraPropsNames = (__Array*)pNode->getUserObject();
Ref* pObj = NULL; Ref* pObj = NULL;
bool bFound = false; bool bFound = false;
CCARRAY_FOREACH(extraPropsNames, pObj) CCARRAY_FOREACH(extraPropsNames, pObj)
@ -1055,9 +1055,9 @@ void NodeLoader::onHandlePropTypeDegrees(Node * pNode, Node * pParent, const cha
if(strcmp(pPropertyName, PROPERTY_ROTATION) == 0) { if(strcmp(pPropertyName, PROPERTY_ROTATION) == 0) {
pNode->setRotation(pDegrees); pNode->setRotation(pDegrees);
} else if(strcmp(pPropertyName, PROPERTY_ROTATIONX) == 0) { } else if(strcmp(pPropertyName, PROPERTY_ROTATIONX) == 0) {
pNode->setRotationX(pDegrees); pNode->setRotationSkewX(pDegrees);
} else if(strcmp(pPropertyName, PROPERTY_ROTATIONY) == 0) { } else if(strcmp(pPropertyName, PROPERTY_ROTATIONY) == 0) {
pNode->setRotationY(pDegrees); pNode->setRotationSkewY(pDegrees);
} }
else { else {
ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName); ASSERT_FAIL_UNEXPECTED_PROPERTY(pPropertyName);

View File

@ -157,7 +157,7 @@ const cocos2d::Size GUIReader::getFileDesignSize(const char* fileName) const
void GUIReader::registerTypeAndCallBack(const std::string& classType, void GUIReader::registerTypeAndCallBack(const std::string& classType,
ObjectFactory::Instance ins, ObjectFactory::Instance ins,
Object *object, Ref *object,
SEL_ParseEvent callBack) SEL_ParseEvent callBack)
{ {
ObjectFactory* factoryCreate = ObjectFactory::getInstance(); ObjectFactory* factoryCreate = ObjectFactory::getInstance();
@ -2030,8 +2030,8 @@ void WidgetPropertiesReader0300::setPropsForAllCustomWidgetFromJsonDictionary(co
{ {
GUIReader* guiReader = GUIReader::getInstance(); GUIReader* guiReader = GUIReader::getInstance();
std::map<std::string, Object*> object_map = GUIReader::getInstance()->getParseObjectMap(); std::map<std::string, Ref*> object_map = GUIReader::getInstance()->getParseObjectMap();
Object* object = object_map[classType]; Ref* object = object_map[classType];
std::map<std::string, SEL_ParseEvent> selector_map = guiReader->getParseCallBackMap(); std::map<std::string, SEL_ParseEvent> selector_map = guiReader->getParseCallBackMap();
SEL_ParseEvent selector = selector_map[classType]; SEL_ParseEvent selector = selector_map[classType];

View File

@ -143,7 +143,7 @@ Component* ObjectFactory::createComponent(const std::string &name)
ui::Widget* ObjectFactory::createGUI(std::string name) ui::Widget* ObjectFactory::createGUI(std::string name)
{ {
Object* object = NULL; Ref* object = nullptr;
if (name == "Panel") if (name == "Panel")
{ {
@ -182,7 +182,7 @@ ui::Widget* ObjectFactory::createGUI(std::string name)
WidgetReaderProtocol* ObjectFactory::createWidgetReaderProtocol(std::string name) WidgetReaderProtocol* ObjectFactory::createWidgetReaderProtocol(std::string name)
{ {
Object* object = NULL; Ref* object = NULL;
do do
{ {

View File

@ -932,7 +932,12 @@
); );
HEADER_SEARCH_PATHS = ""; HEADER_SEARCH_PATHS = "";
IPHONEOS_DEPLOYMENT_TARGET = 5.1; IPHONEOS_DEPLOYMENT_TARGET = 5.1;
LIBRARY_SEARCH_PATHS = "$(SRCROOT)/../../../../external/lua/luajit/prebuilt/ios"; LIBRARY_SEARCH_PATHS = (
"$(SRCROOT)/../../../../external/lua/luajit/prebuilt/ios",
"$(SRCROOT)/../../../../external/lua/lua/prebuilt/ios",
);
"OTHER_LDFLAGS[arch=arm64]" = "-llua";
"OTHER_LDFLAGS[sdk=iphonesimulator7.1]" = "-llua";
SDKROOT = iphoneos; SDKROOT = iphoneos;
TARGETED_DEVICE_FAMILY = "1,2"; TARGETED_DEVICE_FAMILY = "1,2";
USER_HEADER_SEARCH_PATHS = "$(inherited) $(SRCROOT)/../../../2d/platform/ios"; USER_HEADER_SEARCH_PATHS = "$(inherited) $(SRCROOT)/../../../2d/platform/ios";
@ -952,7 +957,12 @@
); );
HEADER_SEARCH_PATHS = ""; HEADER_SEARCH_PATHS = "";
IPHONEOS_DEPLOYMENT_TARGET = 5.1; IPHONEOS_DEPLOYMENT_TARGET = 5.1;
LIBRARY_SEARCH_PATHS = "$(SRCROOT)/../../../../external/lua/luajit/prebuilt/ios"; LIBRARY_SEARCH_PATHS = (
"$(SRCROOT)/../../../../external/lua/luajit/prebuilt/ios",
"$(SRCROOT)/../../../../external/lua/lua/prebuilt/ios",
);
"OTHER_LDFLAGS[arch=arm64]" = "-llua";
"OTHER_LDFLAGS[sdk=iphonesimulator7.1]" = "-llua";
SDKROOT = iphoneos; SDKROOT = iphoneos;
TARGETED_DEVICE_FAMILY = "1,2"; TARGETED_DEVICE_FAMILY = "1,2";
USER_HEADER_SEARCH_PATHS = "$(inherited) $(SRCROOT)/../../../2d/platform/ios"; USER_HEADER_SEARCH_PATHS = "$(inherited) $(SRCROOT)/../../../2d/platform/ios";

View File

@ -30,9 +30,9 @@
#include <string> #include <string>
#include "cocostudio/ObjectFactory.h" #include "cocostudio/ObjectFactory.h"
#pragma mark - //#pragma mark -
#pragma mark Widget macro //#pragma mark Widget macro
#pragma mark - //#pragma mark -
#define DECLARE_CLASS_GUI_INFO \ #define DECLARE_CLASS_GUI_INFO \
public: \ public: \
@ -50,9 +50,9 @@
cocostudio::ObjectFactory::TInfo(#className, &className::createInstance) \ cocostudio::ObjectFactory::TInfo(#className, &className::createInstance) \
#pragma mark - //#pragma mark -
#pragma mark Reader macro //#pragma mark Reader macro
#pragma mark - //#pragma mark -
#define DECLARE_CLASS_WIDGET_READER_INFO \ #define DECLARE_CLASS_WIDGET_READER_INFO \
public: \ public: \

View File

@ -436,7 +436,7 @@ void Button::updateFlippedX()
_titleRenderer->setFlippedX(_flippedX); _titleRenderer->setFlippedX(_flippedX);
if (_scale9Enabled) if (_scale9Enabled)
{ {
int flip = _flippedX ? -1 : 1; float flip = _flippedX ? -1.0f : 1.0f;
_buttonNormalRenderer->setScaleX(flip); _buttonNormalRenderer->setScaleX(flip);
_buttonClickedRenderer->setScaleX(flip); _buttonClickedRenderer->setScaleX(flip);
_buttonDisableRenderer->setScaleX(flip); _buttonDisableRenderer->setScaleX(flip);
@ -454,7 +454,7 @@ void Button::updateFlippedY()
_titleRenderer->setFlippedY(_flippedY); _titleRenderer->setFlippedY(_flippedY);
if (_scale9Enabled) if (_scale9Enabled)
{ {
int flip = _flippedY ? -1 : 1; float flip = _flippedY ? -1.0f : 1.0f;
_buttonNormalRenderer->setScaleY(flip); _buttonNormalRenderer->setScaleY(flip);
_buttonClickedRenderer->setScaleY(flip); _buttonClickedRenderer->setScaleY(flip);
_buttonDisableRenderer->setScaleY(flip); _buttonDisableRenderer->setScaleY(flip);

View File

@ -154,11 +154,11 @@ public:
const Point& getBackGroundColorVector(); const Point& getBackGroundColorVector();
void setBackGroundImageColor(const ccColor3B& color); void setBackGroundImageColor(const Color3B& color);
void setBackGroundImageOpacity(GLubyte opacity); void setBackGroundImageOpacity(GLubyte opacity);
const ccColor3B& getBackGroundImageColor(); const Color3B& getBackGroundImageColor();
GLubyte getBackGroundImageOpacity(); GLubyte getBackGroundImageOpacity();

View File

@ -340,7 +340,7 @@ void RichText::formarRenderers()
float newContentSizeHeight = 0.0f; float newContentSizeHeight = 0.0f;
float *maxHeights = new float[_elementRenders.size()]; float *maxHeights = new float[_elementRenders.size()];
for (int i=0; i<_elementRenders.size(); i++) for (size_t i=0; i<_elementRenders.size(); i++)
{ {
Vector<Node*>* row = (_elementRenders[i]); Vector<Node*>* row = (_elementRenders[i]);
float maxHeight = 0.0f; float maxHeight = 0.0f;
@ -355,7 +355,7 @@ void RichText::formarRenderers()
float nextPosY = _customSize.height; float nextPosY = _customSize.height;
for (int i=0; i<_elementRenders.size(); i++) for (size_t i=0; i<_elementRenders.size(); i++)
{ {
Vector<Node*>* row = (_elementRenders[i]); Vector<Node*>* row = (_elementRenders[i]);
float nextPosX = 0.0f; float nextPosX = 0.0f;
@ -374,7 +374,7 @@ void RichText::formarRenderers()
delete [] maxHeights; delete [] maxHeights;
} }
int length = _elementRenders.size(); size_t length = _elementRenders.size();
for (size_t i = 0; i<length; i++) for (size_t i = 0; i<length; i++)
{ {
Vector<Node*>* l = _elementRenders[i]; Vector<Node*>* l = _elementRenders[i];

View File

@ -1020,8 +1020,8 @@ void Widget::copyProperties(Widget *widget)
setScaleX(widget->getScaleX()); setScaleX(widget->getScaleX());
setScaleY(widget->getScaleY()); setScaleY(widget->getScaleY());
setRotation(widget->getRotation()); setRotation(widget->getRotation());
setRotationX(widget->getRotationX()); setRotationSkewX(widget->getRotationSkewX());
setRotationY(widget->getRotationY()); setRotationSkewY(widget->getRotationSkewY());
setFlippedX(widget->isFlippedX()); setFlippedX(widget->isFlippedX());
setFlippedY(widget->isFlippedY()); setFlippedY(widget->isFlippedY());
setColor(widget->getColor()); setColor(widget->getColor());

View File

@ -91,8 +91,8 @@ You can run the samples...
$ cd cocos2d-x $ cd cocos2d-x
$ ./setup.py $ ./setup.py
$ cd build $ cd build
$ ./android-build.py -p 10 $ ./android-build.py cpp-empty-test -p 10
$ adb install cocos2d-x/tests/proj.android/bin/TestDemo-debug.apk $ adb install cocos2d-x/tests/cpp-empty-test/proj.android/bin/CppEmptyTest-debug.apk
Then click item on Android device to run tests. Available value of `-p` is the API level, cocos2d-x supports from level 10. Then click item on Android device to run tests. Available value of `-p` is the API level, cocos2d-x supports from level 10.
@ -101,18 +101,18 @@ Then click item on Android device to run tests. Available value of `-p` is the A
$ cd cocos2d-x $ cd cocos2d-x
$ ./setup.py $ ./setup.py
$ cd build $ cd build
$ ./android-build.py $ ./android-build.py cpp-empty-test -p 10
Then Then
* Import cocos2d-x Android project into Eclipse, the path used to import is `cocos/2d/platform/android` * Import cocos2d-x Android project into Eclipse, the path used to import is `cocos/2d/platform/android`
* Import `tests` Android project into Eclipse, the path used to import is `tests/proj.android` * Import `cpp-empty-test` Android project into Eclipse, the path used to import is `tests/cpp-empty-test/proj.android`
* Build `tests` Android project and run * Build `cpp-empty-test` Android project and run
### Windows ### Windows
* Enter `cocos2d-x/build`, and open `cocos2d-win32.vs2012.sln` * Enter `cocos2d-x/build`, and open `cocos2d-win32.vs2012.sln`
* Select `TestCpp` as running target * Select `cpp-empty-test` as running target
* Click run button * Click run button
@ -126,23 +126,17 @@ Then
$ mkdir build $ mkdir build
$ cd build $ cd build
$ cmake .. $ cmake ../cocos2d-x
$ make -j4 $ make -j4
Run Run
$ cd bin/testcpp $ cd bin/cpp-empty-test
$ ./testcpp $ ./cpp-empty-test
## How to start a new game ## How to start a new game
$ cd cocos2d-x Please refer to [ReadMe](../README.md)
$ ./setup.py
$ source FILE_TO_RECORD_SYSTEM_VARIABLE
`FILE_TO_RECORD_SYSTEM_VARIABLE` may be `~/.bash_profile`, `~/.bash_login` or `~./.profile`
$ cocos new MyGame -p com.MyCompany.MyGame -l cpp -d directory_to_save
Because `cocos run` command is not ready, so you should do it manually as running `TestCpp`. After `cocos run` command is finished, can just run `cocos run` to run the new game on demand target.
# Highlights of v3.0 # Highlights of v3.0

View File

@ -171,13 +171,13 @@ typedef CURL_TYPEOF_CURL_SOCKLEN_T curl_socklen_t;
typedef CURL_TYPEOF_CURL_OFF_T curl_off_t; typedef CURL_TYPEOF_CURL_OFF_T curl_off_t;
/* curl_off_t formatting string directive without "%" conversion specifier. */ /* curl_off_t formatting string directive without "%" conversion specifier. */
#define CURL_FORMAT_CURL_OFF_T "lld" #define CURL_FORMAT_CURL_OFF_T PRId64
/* unsigned curl_off_t formatting string without "%" conversion specifier. */ /* unsigned curl_off_t formatting string without "%" conversion specifier. */
#define CURL_FORMAT_CURL_OFF_TU "llu" #define CURL_FORMAT_CURL_OFF_TU PRIu64
/* curl_off_t formatting string directive with "%" conversion specifier. */ /* curl_off_t formatting string directive with "%" conversion specifier. */
#define CURL_FORMAT_OFF_T "%lld" #define CURL_FORMAT_OFF_T "%" PRId64
/* The size of `curl_off_t', as computed by sizeof. */ /* The size of `curl_off_t', as computed by sizeof. */
#define CURL_SIZEOF_CURL_OFF_T 8 #define CURL_SIZEOF_CURL_OFF_T 8

View File

@ -1 +1 @@
c135286e812602cc184684b59b4d074f723ef4a5 dc1d98e73cda98024add3420a06fa29651c863d0

View File

@ -0,0 +1 @@
9b09288998b6198388456c41ccbdd5596622abe5

View File

@ -1 +1 @@
3303f759eb8c682843322ffa9f8c69563d241ca5 81b071fde15c160fb96e2b28a22142e903fdf5a4

View File

@ -0,0 +1 @@
690402fd689da9d29621e7665db2f40ac4e947eb

View File

@ -1 +1 @@
39c4d5970691b3a3ca47be0f7d2a0b5c72e9e2ee e8281e5ccfc438a1d097b9704010312801ea192e

View File

@ -0,0 +1 @@
dd93f7d77c23392642750b58fb0f41eda9218b69

View File

@ -1 +1 @@
fc2d13f253f62b28ad1d37a4a24da1e977acba20 d8eeb3fe1c71ca56139f7e31f0b502da876c692b

View File

@ -631,7 +631,7 @@ static void base_open (lua_State *L) {
luaL_register(L, "_G", base_funcs); luaL_register(L, "_G", base_funcs);
lua_pushliteral(L, LUA_VERSION); lua_pushliteral(L, LUA_VERSION);
lua_setglobal(L, "_VERSION"); /* set global _VERSION */ lua_setglobal(L, "_VERSION"); /* set global _VERSION */
/* `ipairs' and `pairs' need auxiliary functions as upvalues */ /* `ipairs' and `pairs' need auxliliary functions as upvalues */
auxopen(L, "ipairs", luaB_ipairs, ipairsaux); auxopen(L, "ipairs", luaB_ipairs, ipairsaux);
auxopen(L, "pairs", luaB_pairs, luaB_next); auxopen(L, "pairs", luaB_pairs, luaB_next);
/* `newproxy' needs a weaktable as upvalue */ /* `newproxy' needs a weaktable as upvalue */

View File

@ -1,5 +1,5 @@
/* /*
** $Id: lcode.c,v 2.25.1.5 2011/01/31 14:53:16 roberto Exp $ ** $Id: lcode.c,v 2.25.1.3 2007/12/28 15:32:23 roberto Exp $
** Code generator for Lua ** Code generator for Lua
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -544,6 +544,10 @@ void luaK_goiftrue (FuncState *fs, expdesc *e) {
pc = NO_JUMP; /* always true; do nothing */ pc = NO_JUMP; /* always true; do nothing */
break; break;
} }
case VFALSE: {
pc = luaK_jump(fs); /* always jump */
break;
}
case VJMP: { case VJMP: {
invertjump(fs, e); invertjump(fs, e);
pc = e->u.s.info; pc = e->u.s.info;
@ -568,6 +572,10 @@ static void luaK_goiffalse (FuncState *fs, expdesc *e) {
pc = NO_JUMP; /* always false; do nothing */ pc = NO_JUMP; /* always false; do nothing */
break; break;
} }
case VTRUE: {
pc = luaK_jump(fs); /* always jump */
break;
}
case VJMP: { case VJMP: {
pc = e->u.s.info; pc = e->u.s.info;
break; break;

View File

@ -1,5 +1,5 @@
/* /*
** $Id: ldblib.c,v 1.104.1.4 2009/08/04 18:50:18 roberto Exp $ ** $Id: ldblib.c,v 1.104.1.3 2008/01/21 13:11:21 roberto Exp $
** Interface from Lua to its debug API ** Interface from Lua to its debug API
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -45,7 +45,6 @@ static int db_setmetatable (lua_State *L) {
static int db_getfenv (lua_State *L) { static int db_getfenv (lua_State *L) {
luaL_checkany(L, 1);
lua_getfenv(L, 1); lua_getfenv(L, 1);
return 1; return 1;
} }

View File

@ -1,5 +1,5 @@
/* /*
** $Id: ldo.c,v 2.38.1.4 2012/01/18 02:27:10 roberto Exp $ ** $Id: ldo.c,v 2.38.1.3 2008/01/18 22:31:22 roberto Exp $
** Stack and Call structure of Lua ** Stack and Call structure of Lua
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -217,7 +217,6 @@ static StkId adjust_varargs (lua_State *L, Proto *p, int actual) {
int nvar = actual - nfixargs; /* number of extra arguments */ int nvar = actual - nfixargs; /* number of extra arguments */
lua_assert(p->is_vararg & VARARG_HASARG); lua_assert(p->is_vararg & VARARG_HASARG);
luaC_checkGC(L); luaC_checkGC(L);
luaD_checkstack(L, p->maxstacksize);
htab = luaH_new(L, nvar, 1); /* create `arg' table */ htab = luaH_new(L, nvar, 1); /* create `arg' table */
for (i=0; i<nvar; i++) /* put extra arguments into `arg' table */ for (i=0; i<nvar; i++) /* put extra arguments into `arg' table */
setobj2n(L, luaH_setnum(L, htab, i+1), L->top - nvar + i); setobj2n(L, luaH_setnum(L, htab, i+1), L->top - nvar + i);

View File

@ -1,5 +1,5 @@
/* /*
** $Id: lgc.c,v 2.38.1.2 2011/03/18 18:05:38 roberto Exp $ ** $Id: lgc.c,v 2.38.1.1 2007/12/27 13:02:25 roberto Exp $
** Garbage Collector ** Garbage Collector
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -627,6 +627,7 @@ void luaC_step (lua_State *L) {
} }
} }
else { else {
lua_assert(g->totalbytes >= g->estimate);
setthreshold(g); setthreshold(g);
} }
} }

View File

@ -1,5 +1,5 @@
/* /*
** $Id: liolib.c,v 2.73.1.4 2010/05/14 15:33:51 roberto Exp $ ** $Id: liolib.c,v 2.73.1.3 2008/01/18 17:47:43 roberto Exp $
** Standard I/O (and system) library ** Standard I/O (and system) library
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -180,13 +180,11 @@ static int io_popen (lua_State *L) {
} }
#ifndef __native_client__
static int io_tmpfile (lua_State *L) { static int io_tmpfile (lua_State *L) {
FILE **pf = newfile(L); FILE **pf = newfile(L);
*pf = tmpfile(); *pf = tmpfile();
return (*pf == NULL) ? pushresult(L, 0, NULL) : 1; return (*pf == NULL) ? pushresult(L, 0, NULL) : 1;
} }
#endif
static FILE *getiofile (lua_State *L, int findex) { static FILE *getiofile (lua_State *L, int findex) {
@ -278,10 +276,7 @@ static int read_number (lua_State *L, FILE *f) {
lua_pushnumber(L, d); lua_pushnumber(L, d);
return 1; return 1;
} }
else { else return 0; /* read fails */
lua_pushnil(L); /* "result" to be removed */
return 0; /* read fails */
}
} }
@ -488,9 +483,7 @@ static const luaL_Reg iolib[] = {
{"output", io_output}, {"output", io_output},
{"popen", io_popen}, {"popen", io_popen},
{"read", io_read}, {"read", io_read},
#ifndef __native_client__
{"tmpfile", io_tmpfile}, {"tmpfile", io_tmpfile},
#endif
{"type", io_type}, {"type", io_type},
{"write", io_write}, {"write", io_write},
{NULL, NULL} {NULL, NULL}

View File

@ -1,5 +1,5 @@
/* /*
** $Id: llex.c,v 2.20.1.2 2009/11/23 14:58:22 roberto Exp $ ** $Id: llex.c,v 2.20.1.1 2007/12/27 13:02:25 roberto Exp $
** Lexical Analyzer ** Lexical Analyzer
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -118,10 +118,8 @@ TString *luaX_newstring (LexState *ls, const char *str, size_t l) {
lua_State *L = ls->L; lua_State *L = ls->L;
TString *ts = luaS_newlstr(L, str, l); TString *ts = luaS_newlstr(L, str, l);
TValue *o = luaH_setstr(L, ls->fs->h, ts); /* entry for `str' */ TValue *o = luaH_setstr(L, ls->fs->h, ts); /* entry for `str' */
if (ttisnil(o)) { if (ttisnil(o))
setbvalue(o, 1); /* make sure `str' will not be collected */ setbvalue(o, 1); /* make sure `str' will not be collected */
luaC_checkGC(L);
}
return ts; return ts;
} }
@ -178,9 +176,9 @@ static void buffreplace (LexState *ls, char from, char to) {
static void trydecpoint (LexState *ls, SemInfo *seminfo) { static void trydecpoint (LexState *ls, SemInfo *seminfo) {
/* format error: try to update decimal point separator */ /* format error: try to update decimal point separator */
/* struct lconv *cv = localeconv(); removed for android ndk */ struct lconv *cv = localeconv();
char old = ls->decpoint; char old = ls->decpoint;
ls->decpoint = '.'; /* (cv ? cv->decimal_point[0] : '.'); removed for android ndk */ ls->decpoint = (cv ? cv->decimal_point[0] : '.');
buffreplace(ls, old, ls->decpoint); /* try updated decimal separator */ buffreplace(ls, old, ls->decpoint); /* try updated decimal separator */
if (!luaO_str2d(luaZ_buffer(ls->buff), &seminfo->r)) { if (!luaO_str2d(luaZ_buffer(ls->buff), &seminfo->r)) {
/* format error with correct decimal point: no more options */ /* format error with correct decimal point: no more options */

View File

@ -1,5 +1,5 @@
/* /*
** $Id: loadlib.c,v 1.52.1.4 2009/09/09 13:17:16 roberto Exp $ ** $Id: loadlib.c,v 1.52.1.3 2008/08/06 13:29:28 roberto Exp $
** Dynamic library loader for Lua ** Dynamic library loader for Lua
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
** **
@ -639,7 +639,7 @@ LUALIB_API int luaopen_package (lua_State *L) {
lua_pushvalue(L, -1); lua_pushvalue(L, -1);
lua_replace(L, LUA_ENVIRONINDEX); lua_replace(L, LUA_ENVIRONINDEX);
/* create `loaders' table */ /* create `loaders' table */
lua_createtable(L, sizeof(loaders)/sizeof(loaders[0]) - 1, 0); lua_createtable(L, 0, sizeof(loaders)/sizeof(loaders[0]) - 1);
/* fill it with pre-defined loaders */ /* fill it with pre-defined loaders */
for (i=0; loaders[i] != NULL; i++) { for (i=0; loaders[i] != NULL; i++) {
lua_pushcfunction(L, loaders[i]); lua_pushcfunction(L, loaders[i]);

View File

@ -35,12 +35,10 @@ static int os_pushresult (lua_State *L, int i, const char *filename) {
} }
#ifndef __native_client__
static int os_execute (lua_State *L) { static int os_execute (lua_State *L) {
lua_pushinteger(L, system(luaL_optstring(L, 1, NULL))); lua_pushinteger(L, system(luaL_optstring(L, 1, NULL)));
return 1; return 1;
} }
#endif
static int os_remove (lua_State *L) { static int os_remove (lua_State *L) {
@ -223,9 +221,7 @@ static const luaL_Reg syslib[] = {
{"clock", os_clock}, {"clock", os_clock},
{"date", os_date}, {"date", os_date},
{"difftime", os_difftime}, {"difftime", os_difftime},
#ifndef __native_client__
{"execute", os_execute}, {"execute", os_execute},
#endif
{"exit", os_exit}, {"exit", os_exit},
{"getenv", os_getenv}, {"getenv", os_getenv},
{"remove", os_remove}, {"remove", os_remove},

View File

@ -1,5 +1,5 @@
/* /*
** $Id: lparser.c,v 2.42.1.4 2011/10/21 19:31:42 roberto Exp $ ** $Id: lparser.c,v 2.42.1.3 2007/12/28 15:32:23 roberto Exp $
** Lua Parser ** Lua Parser
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -374,9 +374,9 @@ static void close_func (LexState *ls) {
lua_assert(luaG_checkcode(f)); lua_assert(luaG_checkcode(f));
lua_assert(fs->bl == NULL); lua_assert(fs->bl == NULL);
ls->fs = fs->prev; ls->fs = fs->prev;
L->top -= 2; /* remove table and prototype from the stack */
/* last token read was anchored in defunct function; must reanchor it */ /* last token read was anchored in defunct function; must reanchor it */
if (fs) anchor_token(ls); if (fs) anchor_token(ls);
L->top -= 2; /* remove table and prototype from the stack */
} }

View File

@ -1,5 +1,5 @@
/* /*
** $Id: lstrlib.c,v 1.132.1.5 2010/05/14 15:34:19 roberto Exp $ ** $Id: lstrlib.c,v 1.132.1.4 2008/07/11 17:27:21 roberto Exp $
** Standard library for string operations and pattern-matching ** Standard library for string operations and pattern-matching
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -754,7 +754,6 @@ static void addintlen (char *form) {
static int str_format (lua_State *L) { static int str_format (lua_State *L) {
int top = lua_gettop(L);
int arg = 1; int arg = 1;
size_t sfl; size_t sfl;
const char *strfrmt = luaL_checklstring(L, arg, &sfl); const char *strfrmt = luaL_checklstring(L, arg, &sfl);
@ -769,8 +768,7 @@ static int str_format (lua_State *L) {
else { /* format item */ else { /* format item */
char form[MAX_FORMAT]; /* to store the format (`%...') */ char form[MAX_FORMAT]; /* to store the format (`%...') */
char buff[MAX_ITEM]; /* to store the formatted item */ char buff[MAX_ITEM]; /* to store the formatted item */
if (++arg > top) arg++;
luaL_argerror(L, arg, "no value");
strfrmt = scanformat(L, strfrmt, form); strfrmt = scanformat(L, strfrmt, form);
switch (*strfrmt++) { switch (*strfrmt++) {
case 'c': { case 'c': {

View File

@ -336,3 +336,57 @@ struct Smain {
int status; int status;
}; };
static int pmain (lua_State *L) {
struct Smain *s = (struct Smain *)lua_touserdata(L, 1);
char **argv = s->argv;
int script;
int has_i = 0, has_v = 0, has_e = 0;
globalL = L;
if (argv[0] && argv[0][0]) progname = argv[0];
lua_gc(L, LUA_GCSTOP, 0); /* stop collector during initialization */
luaL_openlibs(L); /* open libraries */
lua_gc(L, LUA_GCRESTART, 0);
s->status = handle_luainit(L);
if (s->status != 0) return 0;
script = collectargs(argv, &has_i, &has_v, &has_e);
if (script < 0) { /* invalid args? */
print_usage();
s->status = 1;
return 0;
}
if (has_v) print_version();
s->status = runargs(L, argv, (script > 0) ? script : s->argc);
if (s->status != 0) return 0;
if (script)
s->status = handle_script(L, argv, script);
if (s->status != 0) return 0;
if (has_i)
dotty(L);
else if (script == 0 && !has_e && !has_v) {
if (lua_stdin_is_tty()) {
print_version();
dotty(L);
}
else dofile(L, NULL); /* executes stdin as a file */
}
return 0;
}
int main (int argc, char **argv) {
int status;
struct Smain s;
lua_State *L = lua_open(); /* create state */
if (L == NULL) {
l_message(argv[0], "cannot create state: not enough memory");
return EXIT_FAILURE;
}
s.argc = argc;
s.argv = argv;
status = lua_cpcall(L, &pmain, &s);
report(L, status);
lua_close(L);
return (status || s.status) ? EXIT_FAILURE : EXIT_SUCCESS;
}

View File

@ -1,5 +1,5 @@
/* /*
** $Id: lua.h,v 1.218.1.7 2012/01/13 20:36:20 roberto Exp $ ** $Id: lua.h,v 1.218.1.5 2008/08/06 13:30:12 roberto Exp $
** Lua - An Extensible Extension Language ** Lua - An Extensible Extension Language
** Lua.org, PUC-Rio, Brazil (http://www.lua.org) ** Lua.org, PUC-Rio, Brazil (http://www.lua.org)
** See Copyright Notice at the end of this file ** See Copyright Notice at the end of this file
@ -17,9 +17,9 @@
#define LUA_VERSION "Lua 5.1" #define LUA_VERSION "Lua 5.1"
#define LUA_RELEASE "Lua 5.1.5" #define LUA_RELEASE "Lua 5.1.4"
#define LUA_VERSION_NUM 501 #define LUA_VERSION_NUM 501
#define LUA_COPYRIGHT "Copyright (C) 1994-2012 Lua.org, PUC-Rio" #define LUA_COPYRIGHT "Copyright (C) 1994-2008 Lua.org, PUC-Rio"
#define LUA_AUTHORS "R. Ierusalimschy, L. H. de Figueiredo & W. Celes" #define LUA_AUTHORS "R. Ierusalimschy, L. H. de Figueiredo & W. Celes"
@ -362,7 +362,7 @@ struct lua_Debug {
/****************************************************************************** /******************************************************************************
* Copyright (C) 1994-2012 Lua.org, PUC-Rio. All rights reserved. * Copyright (C) 1994-2008 Lua.org, PUC-Rio. All rights reserved.
* *
* Permission is hereby granted, free of charge, to any person obtaining * Permission is hereby granted, free of charge, to any person obtaining
* a copy of this software and associated documentation files (the * a copy of this software and associated documentation files (the

View File

@ -1,5 +1,5 @@
/* /*
** $Id: lvm.c,v 2.63.1.5 2011/08/17 20:43:11 roberto Exp $ ** $Id: lvm.c,v 2.63.1.3 2007/12/28 15:32:23 roberto Exp $
** Lua virtual machine ** Lua virtual machine
** See Copyright Notice in lua.h ** See Copyright Notice in lua.h
*/ */
@ -133,7 +133,6 @@ void luaV_gettable (lua_State *L, const TValue *t, TValue *key, StkId val) {
void luaV_settable (lua_State *L, const TValue *t, TValue *key, StkId val) { void luaV_settable (lua_State *L, const TValue *t, TValue *key, StkId val) {
int loop; int loop;
TValue temp;
for (loop = 0; loop < MAXTAGLOOP; loop++) { for (loop = 0; loop < MAXTAGLOOP; loop++) {
const TValue *tm; const TValue *tm;
if (ttistable(t)) { /* `t' is a table? */ if (ttistable(t)) { /* `t' is a table? */
@ -142,7 +141,6 @@ void luaV_settable (lua_State *L, const TValue *t, TValue *key, StkId val) {
if (!ttisnil(oldval) || /* result is no nil? */ if (!ttisnil(oldval) || /* result is no nil? */
(tm = fasttm(L, h->metatable, TM_NEWINDEX)) == NULL) { /* or no TM? */ (tm = fasttm(L, h->metatable, TM_NEWINDEX)) == NULL) { /* or no TM? */
setobj2t(L, oldval, val); setobj2t(L, oldval, val);
h->flags = 0;
luaC_barriert(L, h, val); luaC_barriert(L, h, val);
return; return;
} }
@ -154,9 +152,7 @@ void luaV_settable (lua_State *L, const TValue *t, TValue *key, StkId val) {
callTM(L, tm, t, key, val); callTM(L, tm, t, key, val);
return; return;
} }
/* else repeat with `tm' */ t = tm; /* else repeat with `tm' */
setobj(L, &temp, tm); /* avoid pointing inside table (may rehash) */
t = &temp;
} }
luaG_runerror(L, "loop in settable"); luaG_runerror(L, "loop in settable");
} }

View File

@ -0,0 +1 @@
a064ce4dee79c042cebd3ab706673cd2a7bc4a4e

View File

@ -1 +1 @@
2a8128e7d552dc8b2d79c1cbd8c84c21ad578672 c4decf3cb39b46189df24c54868f46e985b15de2

View File

@ -0,0 +1 @@
13d38a8f7cf04ee464b3eaf5fd7464853499390e

View File

@ -1 +1 @@
fb78024e2f81c33d196af83e7740de7c7f4ea021 373f86ef034bf18f5d52588747c02d7896884730

View File

@ -15,7 +15,7 @@
#define TIFF_INT32_T signed int #define TIFF_INT32_T signed int
/* Signed 64-bit type */ /* Signed 64-bit type */
#define TIFF_INT64_T signed long long #define TIFF_INT64_T int64_t
/* Signed 8-bit type */ /* Signed 8-bit type */
#define TIFF_INT8_T signed char #define TIFF_INT8_T signed char
@ -27,7 +27,7 @@
#define TIFF_UINT32_T unsigned int #define TIFF_UINT32_T unsigned int
/* Unsigned 64-bit type */ /* Unsigned 64-bit type */
#define TIFF_UINT64_T unsigned long long #define TIFF_UINT64_T uint64_t
/* Unsigned 8-bit type */ /* Unsigned 8-bit type */
#define TIFF_UINT8_T unsigned char #define TIFF_UINT8_T unsigned char

View File

@ -1 +1 @@
60433133a48054eb884d9e6a0cee95fe4ba22b1c 286c39ddabb05b91c81ee5d7ec0a1301d0be3108

View File

@ -0,0 +1 @@
39aa0b352df6cb1adf2390cf199910b21a3b3c12

View File

@ -1 +1 @@
5fe8aca7e0bfa91c79b4b6b0a562f88a6653c452 e5cd88ead5723950d6f69e8bd72b4b18b2f9d893

9
external/version.txt vendored Normal file
View File

@ -0,0 +1,9 @@
libs version
———————————————————
freetype 2.5.0
curl 7.26.0
jpeg 9.0
png 1.6.2
tiff 4.0.3
webp 0.2.1
websockets v1.23-chrome32-firefox24

View File

@ -1 +1 @@
c26c3c22887023d322926dcbbd0f69377deedaf8 7f9f32e81cbd068ab7a9c408a26eedfdcc8d6e30

View File

@ -0,0 +1 @@
904e2e16f2f4846b4550b9ba25e8b709f6c4337e

View File

@ -1 +1 @@
4c5c7d34a90f5fcac954f6d44803173224d8ead2 6b5decfe3f5b19bacfbd9778cb58843a7161a6a9

View File

@ -1 +1 @@
ee4ee6cc26274f6d3138d08d429d6ba49b629f53 5c60f0b27edd2650caee8a96948272604a8098d5

View File

@ -1 +1 @@
5d0743ce07a9c865d4367d8e3db161148676f2c8 36c2d4cb652d9a93fa2a285cb8c73f237612bb46

View File

@ -351,7 +351,7 @@ class SetEnvVar(object):
ndk_root = self._get_input_value() ndk_root = self._get_input_value()
if ndk_root and not self._is_ndk_root_valid(ndk_root) and not ndk_root_found: if ndk_root and not self._is_ndk_root_valid(ndk_root) and not ndk_root_found:
print 'Error: %s is not a valid path of NDK_ROOT. Ignoring it.' % ndk_root print 'Error: "%s" is not a valid path of NDK_ROOT. Ignoring it.' % ndk_root
if ndk_root_found: if ndk_root_found:
print 'FOUND' print 'FOUND'
@ -377,7 +377,7 @@ class SetEnvVar(object):
android_sdk_root = self._get_input_value() android_sdk_root = self._get_input_value()
if android_sdk_root and not self._is_android_sdk_root_valid(android_sdk_root) and not android_sdk_root_found: if android_sdk_root and not self._is_android_sdk_root_valid(android_sdk_root) and not android_sdk_root_found:
print 'Error: %s is not a valid path of ANDROID_SDK_ROOT. Ignoring it.' % android_sdk_root print 'Error: "%s" is not a valid path of ANDROID_SDK_ROOT. Ignoring it.' % android_sdk_root
if android_sdk_root_found: if android_sdk_root_found:
print 'FOUND' print 'FOUND'
@ -401,7 +401,7 @@ class SetEnvVar(object):
ant_root = self._get_input_value() ant_root = self._get_input_value()
if ant_root and not self._is_ant_root_valid(ant_root) and not ant_found: if ant_root and not self._is_ant_root_valid(ant_root) and not ant_found:
print 'Error: %s is not a valid path of ANT_ROOT. Ignoring it.' % ant_root print 'Error: "%s" is not a valid path of ANT_ROOT. Ignoring it.' % ant_root
if ant_found: if ant_found:
@ -433,7 +433,7 @@ class SetEnvVar(object):
print '\nCOCOS_CONSOLE_ROOT was already added. Edit "%s" for manual changes' % target print '\nCOCOS_CONSOLE_ROOT was already added. Edit "%s" for manual changes' % target
if self._isWindows(): if self._isWindows():
print '\nPlease restart the terminal to make added system variables take effect' print '\nPlease restart the terminal or restart computer to make added system variables take effect'
else: else:
print '\nPlease execute command: "source %s" to make added system variables take effect' % target print '\nPlease execute command: "source %s" to make added system variables take effect' % target
@ -441,7 +441,7 @@ if __name__ == '__main__':
parser = OptionParser() parser = OptionParser()
parser.add_option('-n', '--ndkroot', dest='ndk_root', help='directory of ndk root') parser.add_option('-n', '--ndkroot', dest='ndk_root', help='directory of ndk root')
parser.add_option('-a', '--androidsdkroot', dest='android_sdk_root', help='directory of android sdk root') parser.add_option('-a', '--androidsdkroot', dest='android_sdk_root', help='directory of android sdk root')
parser.add_option('-t', '--antroot', dest='ant_root', help='directory of ant root') parser.add_option('-t', '--antroot', dest='ant_root', help='directory that contains ant/ant.bat')
opts, args = parser.parse_args() opts, args = parser.parse_args()
# set environment variables # set environment variables

View File

@ -1 +1 @@
725d085b1800d788b0a8cf1ec615d750573dce15 4dfa7f46c2e06a4b3b95120bea3b8689f31ddad0

View File

@ -0,0 +1,182 @@
cmake_minimum_required(VERSION 2.6)
set(APP_NAME HelloLua)
project (${APP_NAME})
include(cocos2d-x/build/BuildHelpers.CMakeLists.txt)
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)
if(DEBUG_MODE)
set(CMAKE_BUILD_TYPE DEBUG)
else(DEBUG_MODE)
set(CMAKE_BUILD_TYPE RELEASE)
endif(DEBUG_MODE)
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_CXX_FLAGS ${CMAKE_CXX_FLAGS} "-std=c++11")
if(USE_CHIPMUNK)
message("Using chipmunk ...")
add_definitions(-DLINUX -DCC_ENABLE_CHIPMUNK_INTEGRATION=1)
elseif(USE_BOX2D)
message("Using box2d ...")
add_definitions(-DLINUX -DCC_ENABLE_BOX2D_INTEGRATION=1)
else(USE_CHIPMUNK)
message(FATAL_ERROR "Must choose a physics library.")
endif(USE_CHIPMUNK)
# architecture
if ( CMAKE_SIZEOF_VOID_P EQUAL 8 )
set(ARCH_DIR "64-bit")
else()
set(ARCH_DIR "32-bit")
endif()
set(GAME_SRC
runtime-src/proj.linux/main.cpp
runtime-src/Classes/AppDelegate.cpp
)
set(COCOS2D_ROOT ${CMAKE_SOURCE_DIR}/cocos2d-x)
include_directories(
/usr/include
/usr/include/GLFW
/usr/local/include/GLFW
runtime-src/Classes
${COCOS2D_ROOT}/cocos/scripting/lua-bindings/manual
${COCOS2D_ROOT}/cocos/scripting/lua-bindings/auto
${COCOS2D_ROOT}/external/lua/lua
${COCOS2D_ROOT}/external/lua/tolua
${COCOS2D_ROOT}
${COCOS2D_ROOT}/cocos
${COCOS2D_ROOT}/cocos/audio/include
${COCOS2D_ROOT}/cocos/2d
${COCOS2D_ROOT}/cocos/2d/renderer
${COCOS2D_ROOT}/cocos/2d/platform
${COCOS2D_ROOT}/cocos/2d/platform/desktop
${COCOS2D_ROOT}/cocos/2d/platform/linux
${COCOS2D_ROOT}/cocos/base
${COCOS2D_ROOT}/cocos/physics
${COCOS2D_ROOT}/cocos/editor-support
${COCOS2D_ROOT}/cocos/math/kazmath
${COCOS2D_ROOT}/extensions
${COCOS2D_ROOT}/external
${COCOS2D_ROOT}/external/edtaa3func
${COCOS2D_ROOT}/external/jpeg/include/linux
${COCOS2D_ROOT}/external/tiff/include/linux
${COCOS2D_ROOT}/external/webp/include/linux
${COCOS2D_ROOT}/external/websockets/include/linux
${COCOS2D_ROOT}/external/tinyxml2
${COCOS2D_ROOT}/external/unzip
${COCOS2D_ROOT}/external/chipmunk/include/chipmunk
${COCOS2D_ROOT}/external/freetype2/include/linux
${COCOS2D_ROOT}/external/linux-specific/fmod/include/${ARCH_DIR}
)
link_directories(
/usr/local/lib
${COCOS2D_ROOT}/external/jpeg/prebuilt/linux/${ARCH_DIR}
${COCOS2D_ROOT}/external/tiff/prebuilt/linux/${ARCH_DIR}
${COCOS2D_ROOT}/external/webp/prebuilt/linux/${ARCH_DIR}
${COCOS2D_ROOT}/external/websockets/prebuilt/linux/${ARCH_DIR}
${COCOS2D_ROOT}/external/freetype2/prebuilt/linux/${ARCH_DIR}
${COCOS2D_ROOT}/external/linux-specific/fmod/prebuilt/${ARCH_DIR}
)
# kazmath
add_subdirectory(${COCOS2D_ROOT}/cocos/math/kazmath)
# chipmunk library
add_subdirectory(${COCOS2D_ROOT}/external/chipmunk/src)
# box2d library
add_subdirectory(${COCOS2D_ROOT}/external/Box2D)
# unzip library
add_subdirectory(${COCOS2D_ROOT}/external/unzip)
# tinyxml2 library
add_subdirectory(${COCOS2D_ROOT}/external/tinyxml2)
# audio
add_subdirectory(${COCOS2D_ROOT}/cocos/audio)
# cocos base library
add_subdirectory(${COCOS2D_ROOT}/cocos/base)
# cocos 2d library
add_subdirectory(${COCOS2D_ROOT}/cocos/2d)
# gui
add_subdirectory(${COCOS2D_ROOT}/cocos/ui)
# network
add_subdirectory(${COCOS2D_ROOT}/cocos/network)
# extensions
add_subdirectory(${COCOS2D_ROOT}/extensions)
## Editor Support
# spine
add_subdirectory(${COCOS2D_ROOT}/cocos/editor-support/spine)
# cocosbuilder
add_subdirectory(${COCOS2D_ROOT}/cocos/editor-support/cocosbuilder)
# cocostudio
add_subdirectory(${COCOS2D_ROOT}/cocos/editor-support/cocostudio)
## Scripting
# lua
add_subdirectory(${COCOS2D_ROOT}/external/lua/lua)
# tolua
add_subdirectory(${COCOS2D_ROOT}/external/lua/tolua)
# luabinding
add_subdirectory(${COCOS2D_ROOT}/cocos/scripting/lua-bindings)
# add the executable
add_executable(${APP_NAME}
${GAME_SRC}
)
if ( CMAKE_SIZEOF_VOID_P EQUAL 8 )
set(FMOD_LIB "fmodex64")
else()
set(FMOD_LIB "fmodex")
endif()
target_link_libraries(${APP_NAME}
luabinding
ui
network
spine
cocostudio
cocosbuilder
extensions
audio
cocos2d
)
set(APP_BIN_DIR "${CMAKE_BINARY_DIR}/bin")
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}/../res ${APP_BIN_DIR}/Resources/res
COMMAND ${CMAKE_COMMAND} -E copy_directory ${CMAKE_CURRENT_SOURCE_DIR}/../src ${APP_BIN_DIR}/Resources/src
COMMAND ${CMAKE_COMMAND} -E copy_directory ${COCOS2D_ROOT}/cocos/scripting/lua-bindings/script ${APP_BIN_DIR}/Resources
)

View File

@ -0,0 +1,16 @@
#include "../Classes/AppDelegate.h"
#include "cocos2d.h"
#include <stdlib.h>
#include <stdio.h>
#include <unistd.h>
#include <string>
USING_NS_CC;
int main(int argc, char **argv)
{
// create the application instance
AppDelegate app;
return Application::getInstance()->run();
}

View File

@ -0,0 +1 @@
5d7d0b8ce9780883a780ee5fd9e9317129b41643

View File

@ -204,8 +204,12 @@ local function main()
-- play background music, preload effect -- play background music, preload effect
-- uncomment below for the BlackBerry version -- uncomment below for the BlackBerry version
-- local bgMusicPath = CCFileUtils:getInstance():fullPathForFilename("background.ogg") local bgMusicPath = nil
local bgMusicPath = cc.FileUtils:getInstance():fullPathForFilename("background.mp3") if (cc.PLATFORM_OS_IPHONE == targetPlatform) or (cc.PLATFORM_OS_IPAD == targetPlatform) then
bgMusicPath = CCFileUtils:getInstance():fullPathForFilename("res/background.caf")
else
bgMusicPath = cc.FileUtils:getInstance():fullPathForFilename("res/background.mp3")
end
cc.SimpleAudioEngine:getInstance():playMusic(bgMusicPath, true) cc.SimpleAudioEngine:getInstance():playMusic(bgMusicPath, true)
local effectPath = cc.FileUtils:getInstance():fullPathForFilename("effect1.wav") local effectPath = cc.FileUtils:getInstance():fullPathForFilename("effect1.wav")
cc.SimpleAudioEngine:getInstance():preloadEffect(effectPath) cc.SimpleAudioEngine:getInstance():preloadEffect(effectPath)

View File

@ -0,0 +1 @@
5d7d0b8ce9780883a780ee5fd9e9317129b41643

View File

@ -204,8 +204,12 @@ local function main()
-- play background music, preload effect -- play background music, preload effect
-- uncomment below for the BlackBerry version -- uncomment below for the BlackBerry version
-- local bgMusicPath = CCFileUtils:getInstance():fullPathForFilename("background.ogg") local bgMusicPath = nil
local bgMusicPath = cc.FileUtils:getInstance():fullPathForFilename("background.mp3") if (cc.PLATFORM_OS_IPHONE == targetPlatform) or (cc.PLATFORM_OS_IPAD == targetPlatform) then
bgMusicPath = CCFileUtils:getInstance():fullPathForFilename("res/background.caf")
else
bgMusicPath = cc.FileUtils:getInstance():fullPathForFilename("res/background.mp3")
end
cc.SimpleAudioEngine:getInstance():playMusic(bgMusicPath, true) cc.SimpleAudioEngine:getInstance():playMusic(bgMusicPath, true)
local effectPath = cc.FileUtils:getInstance():fullPathForFilename("effect1.wav") local effectPath = cc.FileUtils:getInstance():fullPathForFilename("effect1.wav")
cc.SimpleAudioEngine:getInstance():preloadEffect(effectPath) cc.SimpleAudioEngine:getInstance():preloadEffect(effectPath)

View File

@ -16,6 +16,8 @@
#define MUSIC_FILE "music.mid" #define MUSIC_FILE "music.mid"
#elif (CC_TARGET_PLATFORM == CC_PLATFORM_BLACKBERRY || CC_TARGET_PLATFORM == CC_PLATFORM_LINUX ) #elif (CC_TARGET_PLATFORM == CC_PLATFORM_BLACKBERRY || CC_TARGET_PLATFORM == CC_PLATFORM_LINUX )
#define MUSIC_FILE "background.ogg" #define MUSIC_FILE "background.ogg"
#elif (CC_TARGET_PLATFORM == CC_PLATFORM_IOS)
#define MUSIC_FILE "background.caf"
#else #else
#define MUSIC_FILE "background.mp3" #define MUSIC_FILE "background.mp3"
#endif // CC_PLATFOR_WIN32 #endif // CC_PLATFOR_WIN32

View File

@ -0,0 +1 @@
5d7d0b8ce9780883a780ee5fd9e9317129b41643

View File

@ -0,0 +1 @@
5d7d0b8ce9780883a780ee5fd9e9317129b41643

View File

@ -17,7 +17,7 @@ local function main()
collectgarbage("setpause", 100) collectgarbage("setpause", 100)
collectgarbage("setstepmul", 5000) collectgarbage("setstepmul", 5000)
--support debug --support debug,when used on ios7.1 64bit,these codes should be commented
local targetPlatform = cc.Application:getInstance():getTargetPlatform() local targetPlatform = cc.Application:getInstance():getTargetPlatform()
if (cc.PLATFORM_OS_IPHONE == targetPlatform) or (cc.PLATFORM_OS_IPAD == targetPlatform) or if (cc.PLATFORM_OS_IPHONE == targetPlatform) or (cc.PLATFORM_OS_IPAD == targetPlatform) or
(cc.PLATFORM_OS_ANDROID == targetPlatform) or (cc.PLATFORM_OS_WINDOWS == targetPlatform) or (cc.PLATFORM_OS_ANDROID == targetPlatform) or (cc.PLATFORM_OS_WINDOWS == targetPlatform) or
@ -193,8 +193,13 @@ local function main()
-- play background music, preload effect -- play background music, preload effect
-- uncomment below for the BlackBerry version -- uncomment below for the BlackBerry version
-- local bgMusicPath = CCFileUtils:getInstance():fullPathForFilename("res/background.ogg") local bgMusicPath = nil
local bgMusicPath = cc.FileUtils:getInstance():fullPathForFilename("res/background.mp3") if (cc.PLATFORM_OS_IPHONE == targetPlatform) or (cc.PLATFORM_OS_IPAD == targetPlatform) then
bgMusicPath = CCFileUtils:getInstance():fullPathForFilename("res/background.caf")
else
bgMusicPath = cc.FileUtils:getInstance():fullPathForFilename("res/background.mp3")
end
cc.SimpleAudioEngine:getInstance():playMusic(bgMusicPath, true) cc.SimpleAudioEngine:getInstance():playMusic(bgMusicPath, true)
local effectPath = cc.FileUtils:getInstance():fullPathForFilename("res/effect1.wav") local effectPath = cc.FileUtils:getInstance():fullPathForFilename("res/effect1.wav")
cc.SimpleAudioEngine:getInstance():preloadEffect(effectPath) cc.SimpleAudioEngine:getInstance():preloadEffect(effectPath)

View File

@ -31,7 +31,7 @@ function AssetManagerModule.newScene(backfunc)
helloLabel:setPosition(cc.p(winSize.width / 2, winSize.height - 40)) helloLabel:setPosition(cc.p(winSize.width / 2, winSize.height - 40))
layer:addChild(helloLabel, 5) layer:addChild(helloLabel, 5)
local sprite = cc.Sprite:create("background.png") local sprite = cc.Sprite:create("Images/background.png")
sprite:setAnchorPoint(cc.p(0.5, 0.5)) sprite:setAnchorPoint(cc.p(0.5, 0.5))
sprite:setPosition(cc.p(winSize.width / 2, winSize.height / 2)) sprite:setPosition(cc.p(winSize.width / 2, winSize.height / 2))
layer:addChild(sprite, 0) layer:addChild(sprite, 0)

View File

@ -100,7 +100,8 @@ local function updateLayer()
local function enter(sender) local function enter(sender)
if not isUpdateItemClicked then if not isUpdateItemClicked then
addSearchPath(pathToSave,true) local realPath = pathToSave .. "/package"
addSearchPath(realPath,true)
end end
assetsManagerModule = reloadModule("src/AssetsManagerTest/AssetsManagerModule") assetsManagerModule = reloadModule("src/AssetsManagerTest/AssetsManagerModule")

View File

@ -1,6 +1,13 @@
require "AudioEngine" require "AudioEngine"
local EFFECT_FILE = "effect1.wav" local EFFECT_FILE = "effect1.wav"
local MUSIC_FILE = "background.mp3"
local MUSIC_FILE = nil
local targetPlatform = cc.Application:getInstance():getTargetPlatform()
if (cc.PLATFORM_OS_IPHONE == targetPlatform) or (cc.PLATFORM_OS_IPAD == targetPlatform) then
MUSIC_FILE = "background.caf"
else
MUSIC_FILE = "background.mp3"
end
local LINE_SPACE = 40 local LINE_SPACE = 40

View File

@ -149,6 +149,10 @@ function CreateTestMenu()
CloseMenu:setPosition(0, 0) CloseMenu:setPosition(0, 0)
CloseMenu:addChild(CloseItem) CloseMenu:addChild(CloseItem)
menuLayer:addChild(CloseMenu) menuLayer:addChild(CloseMenu)
local targetPlatform = cc.Application:getInstance():getTargetPlatform()
if (cc.PLATFORM_OS_IPHONE == targetPlatform) or (cc.PLATFORM_OS_IPAD == targetPlatform) then
CloseMenu:setVisible(false)
end
-- add menu items for tests -- add menu items for tests
local MainMenu = cc.Menu:create() local MainMenu = cc.Menu:create()

@ -1 +1 @@
Subproject commit f2e408f1ce29df573b0ed6bbcc83cf9fd7a795d5 Subproject commit 34dfbf64971a955995fe9762ab33ddbf907a1be3

@ -1 +1 @@
Subproject commit 223a7cd9fdf1d399ecb7b97346e2b5dea5f25331 Subproject commit 67d0fd2ed79e5f7d52b797af897bf5cc23ef7994

View File

@ -48,7 +48,7 @@ skip = Node::[setGLServerState description getUserObject .*UserData getGLServerS
Layer.*::[didAccelerate (g|s)etBlendFunc keyPressed keyReleased], Layer.*::[didAccelerate (g|s)etBlendFunc keyPressed keyReleased],
Menu.*::[.*Target getSubItems create initWithItems alignItemsInRows alignItemsInColumns], Menu.*::[.*Target getSubItems create initWithItems alignItemsInRows alignItemsInColumns],
MenuItem.*::[create setCallback initWithCallback], MenuItem.*::[create setCallback initWithCallback],
Label::[getLettersInfo createWithTTF setTTFConfig], Label::[getLettersInfo createWithTTF setTTFConfig listenToBackground listenToFontAtlasPurge],
Copying::[*], Copying::[*],
LabelProtocol::[*], LabelProtocol::[*],
LabelTextFormatProtocol::[*], LabelTextFormatProtocol::[*],