Merge branch 'luamerage' of https://github.com/chuanweizhang2013/cocos2d-x into luamerage

This commit is contained in:
chuanweizhang2013 2014-03-15 18:34:02 +08:00
commit 9e43eb639f
133 changed files with 1473 additions and 575 deletions

View File

@ -1 +1 @@
b8bc5839895bfc413816baa425d43a2b8e48205d 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 new project for linux ### ### Build and run new project for OSX ###
$ 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

@ -224,7 +224,7 @@ if __name__ == '__main__':
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.
@ -247,6 +247,7 @@ if __name__ == '__main__':
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();
@ -65,11 +71,36 @@ FontAtlas::FontAtlas(Font &theFont)
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
*/ */
@ -77,6 +80,21 @@ 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::DefultFontSize; 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

@ -46,6 +46,11 @@ public:
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);
static std::unordered_map<std::string, FontAtlas *> _atlasMap; static std::unordered_map<std::string, FontAtlas *> _atlasMap;

View File

@ -33,10 +33,14 @@
#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
const int Label::DefultFontSize = 50; const int Label::DistanceFieldFontSize = 50;
Label* Label::create() Label* Label::create()
{ {
@ -208,15 +212,15 @@ bool Label::setCharMap(const std::string& plistFile)
FontAtlas *newAtlas = FontAtlasCache::getFontAtlasCharMap(plistFile); FontAtlas *newAtlas = FontAtlasCache::getFontAtlasCharMap(plistFile);
if (!newAtlas) if (!newAtlas)
return false;
if (initWithFontAtlas(newAtlas))
{ {
_currentLabelType = LabelType::CHARMAP; reset();
return true; return false;
} }
return false; setFontAtlas(newAtlas);
_currentLabelType = LabelType::CHARMAP;
return true;
} }
bool Label::setCharMap(Texture2D* texture, int itemWidth, int itemHeight, int startCharMap) bool Label::setCharMap(Texture2D* texture, int itemWidth, int itemHeight, int startCharMap)
@ -224,15 +228,15 @@ bool Label::setCharMap(Texture2D* texture, int itemWidth, int itemHeight, int st
FontAtlas *newAtlas = FontAtlasCache::getFontAtlasCharMap(texture,itemWidth,itemHeight,startCharMap); FontAtlas *newAtlas = FontAtlasCache::getFontAtlasCharMap(texture,itemWidth,itemHeight,startCharMap);
if (!newAtlas) if (!newAtlas)
return false;
if (initWithFontAtlas(newAtlas))
{ {
_currentLabelType = LabelType::CHARMAP; reset();
return true; return false;
} }
return false; setFontAtlas(newAtlas);
_currentLabelType = LabelType::CHARMAP;
return true;
} }
bool Label::setCharMap(const std::string& charMapFile, int itemWidth, int itemHeight, int startCharMap) bool Label::setCharMap(const std::string& charMapFile, int itemWidth, int itemHeight, int startCharMap)
@ -240,15 +244,15 @@ bool Label::setCharMap(const std::string& charMapFile, int itemWidth, int itemHe
FontAtlas *newAtlas = FontAtlasCache::getFontAtlasCharMap(charMapFile,itemWidth,itemHeight,startCharMap); FontAtlas *newAtlas = FontAtlasCache::getFontAtlasCharMap(charMapFile,itemWidth,itemHeight,startCharMap);
if (!newAtlas) if (!newAtlas)
return false;
if (initWithFontAtlas(newAtlas))
{ {
_currentLabelType = LabelType::CHARMAP; reset();
return true; return false;
} }
return false; setFontAtlas(newAtlas);
_currentLabelType = LabelType::CHARMAP;
return true;
} }
Label::Label(FontAtlas *atlas /* = nullptr */, TextHAlignment hAlignment /* = TextHAlignment::LEFT */, Label::Label(FontAtlas *atlas /* = nullptr */, TextHAlignment hAlignment /* = TextHAlignment::LEFT */,
@ -274,17 +278,18 @@ Label::Label(FontAtlas *atlas /* = nullptr */, TextHAlignment hAlignment /* = Te
, _currNumLines(-1) , _currNumLines(-1)
, _textSprite(nullptr) , _textSprite(nullptr)
, _contentDirty(false) , _contentDirty(false)
, _currentLabelType(LabelType::STRING_TEXTURE)
, _currLabelEffect(LabelEffect::NORMAL)
, _shadowBlurRadius(0)
{ {
_cascadeColorEnabled = true; _cascadeColorEnabled = true;
_batchNodes.push_back(this);
_fontDefinition._fontName = "Helvetica"; reset();
_fontDefinition._fontSize = 12;
_fontDefinition._alignment = TextHAlignment::LEFT; #if CC_ENABLE_CACHE_TEXTURE_DATA
_fontDefinition._vertAlignment = TextVAlignment::TOP; 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()
@ -301,28 +306,40 @@ Label::~Label()
CC_SAFE_RELEASE_NULL(_reusedLetter); CC_SAFE_RELEASE_NULL(_reusedLetter);
} }
bool Label::init() void Label::reset()
{ {
bool ret = true; TTFConfig temp;
_fontConfig = temp;
_fontDefinition._fontName = "Helvetica";
_fontDefinition._fontSize = 12;
_fontDefinition._alignment = _hAlignment;
_fontDefinition._vertAlignment = _vAlignment;
_fontDirty = false;
_fontName = "Helvetica";
_fontSize = 12;
_batchNodes.clear();
_batchNodes.push_back(this);
if (_fontAtlas) if (_fontAtlas)
{ {
ret = SpriteBatchNode::initWithTexture(_fontAtlas->getTexture(0), 30); FontAtlasCache::releaseFontAtlas(_fontAtlas);
if (_reusedLetter == nullptr) _fontAtlas = nullptr;
{
_reusedLetter = Sprite::createWithTexture(_fontAtlas->getTexture(0));
_reusedLetter->setOpacityModifyRGB(_isOpacityModifyRGB);
_reusedLetter->retain();
_reusedLetter->setAnchorPoint(Point::ANCHOR_TOP_LEFT);
_reusedLetter->setBatchNode(this);
}
} }
_currentLabelType = LabelType::STRING_TEXTURE;
_currLabelEffect = LabelEffect::NORMAL; _currLabelEffect = LabelEffect::NORMAL;
initProgram(); _shadowBlurRadius = 0;
return ret; Node::removeAllChildrenWithCleanup(true);
_textSprite = nullptr;
CC_SAFE_RELEASE_NULL(_reusedLetter);
} }
void Label::initProgram() void Label::updateShaderProgram()
{ {
switch (_currLabelEffect) switch (_currLabelEffect)
{ {
@ -349,32 +366,33 @@ void Label::initProgram()
_uniformEffectColor = glGetUniformLocation(_shaderProgram->getProgram(), "v_effectColor"); _uniformEffectColor = glGetUniformLocation(_shaderProgram->getProgram(), "v_effectColor");
} }
bool Label::initWithFontAtlas(FontAtlas* atlas,bool distanceFieldEnabled /* = false */, bool useA8Shader /* = false */) void Label::setFontAtlas(FontAtlas* atlas,bool distanceFieldEnabled /* = false */, bool useA8Shader /* = false */)
{ {
FontAtlas *oldAtlas = _fontAtlas; if (atlas == _fontAtlas)
bool oldDistanceFieldEnable = _useDistanceField; {
bool oldA8ShaderEnabel = _useA8Shader; FontAtlasCache::releaseFontAtlas(atlas);
return;
}
if (_fontAtlas)
{
FontAtlasCache::releaseFontAtlas(_fontAtlas);
_fontAtlas = nullptr;
}
_fontAtlas = atlas; _fontAtlas = atlas;
_useDistanceField = distanceFieldEnabled; SpriteBatchNode::initWithTexture(_fontAtlas->getTexture(0), 30);
_useA8Shader = useA8Shader; if (_reusedLetter == nullptr)
bool ret = Label::init();
if (oldAtlas)
{ {
if (ret) _reusedLetter = Sprite::createWithTexture(_fontAtlas->getTexture(0));
{ _reusedLetter->setOpacityModifyRGB(_isOpacityModifyRGB);
FontAtlasCache::releaseFontAtlas(oldAtlas); _reusedLetter->retain();
_reusedLetter->setAnchorPoint(Point::ANCHOR_TOP_LEFT);
_reusedLetter->setBatchNode(this);
} }
else else
{ {
_fontAtlas = oldAtlas; _reusedLetter->setTexture(_fontAtlas->getTexture(0));
_useDistanceField = oldDistanceFieldEnable;
_useA8Shader = oldA8ShaderEnabel;
Label::init();
FontAtlasCache::releaseFontAtlas(atlas);
}
} }
if (_fontAtlas) if (_fontAtlas)
@ -382,8 +400,10 @@ bool Label::initWithFontAtlas(FontAtlas* atlas,bool distanceFieldEnabled /* = fa
_commonLineHeight = _fontAtlas->getCommonLineHeight(); _commonLineHeight = _fontAtlas->getCommonLineHeight();
_contentDirty = true; _contentDirty = true;
} }
_useDistanceField = distanceFieldEnabled;
return ret; _useA8Shader = useA8Shader;
_currLabelEffect = LabelEffect::NORMAL;
updateShaderProgram();
} }
bool Label::setTTFConfig(const TTFConfig& ttfConfig) bool Label::setTTFConfig(const TTFConfig& ttfConfig)
@ -391,52 +411,54 @@ bool Label::setTTFConfig(const TTFConfig& ttfConfig)
FontAtlas *newAtlas = FontAtlasCache::getFontAtlasTTF(ttfConfig); FontAtlas *newAtlas = FontAtlasCache::getFontAtlasTTF(ttfConfig);
if (!newAtlas) if (!newAtlas)
return false;
if (initWithFontAtlas(newAtlas,ttfConfig.distanceFieldEnabled,true))
{ {
reset();
return false;
}
setFontAtlas(newAtlas,ttfConfig.distanceFieldEnabled,true);
_fontConfig = ttfConfig; _fontConfig = ttfConfig;
if (ttfConfig.outlineSize > 0) if (_fontConfig.outlineSize > 0)
{ {
_fontConfig.distanceFieldEnabled = false; _fontConfig.distanceFieldEnabled = false;
_useDistanceField = false; _useDistanceField = false;
_useA8Shader = false; _useA8Shader = false;
_currLabelEffect = LabelEffect::OUTLINE; _currLabelEffect = LabelEffect::OUTLINE;
initProgram(); updateShaderProgram();
} }
else if(ttfConfig.distanceFieldEnabled) else if(ttfConfig.distanceFieldEnabled)
{ {
this->setFontScale(1.0f * ttfConfig.fontSize / DefultFontSize); this->setFontScale(1.0f * ttfConfig.fontSize / DistanceFieldFontSize);
} }
_currentLabelType = LabelType::TTF; _currentLabelType = LabelType::TTF;
return true; return true;
} }
else
{
return false;
}
}
bool Label::setBMFontFilePath(const std::string& bmfontFilePath, const Point& imageOffset /* = Point::ZERO */) bool Label::setBMFontFilePath(const std::string& bmfontFilePath, const Point& imageOffset /* = Point::ZERO */)
{ {
FontAtlas *newAtlas = FontAtlasCache::getFontAtlasFNT(bmfontFilePath,imageOffset); FontAtlas *newAtlas = FontAtlasCache::getFontAtlasFNT(bmfontFilePath,imageOffset);
if (!newAtlas) if (!newAtlas)
return false;
if (initWithFontAtlas(newAtlas))
{ {
_currentLabelType = LabelType::BMFONT; reset();
return true; return false;
} }
return false; setFontAtlas(newAtlas);
_currentLabelType = LabelType::BMFONT;
return true;
} }
void Label::setFontDefinition(const FontDefinition& textDefinition) void Label::setFontDefinition(const FontDefinition& textDefinition)
{ {
reset();
_fontDefinition = textDefinition; _fontDefinition = textDefinition;
_currentLabelType = LabelType::STRING_TEXTURE; _fontName = textDefinition._fontName;
_fontSize = textDefinition._fontSize;
_contentDirty = true; _contentDirty = true;
} }
@ -744,7 +766,7 @@ void Label::enableGlow(const Color3B& glowColor)
return; return;
_currLabelEffect = LabelEffect::GLOW; _currLabelEffect = LabelEffect::GLOW;
_effectColor = glowColor; _effectColor = glowColor;
initProgram(); updateShaderProgram();
} }
void Label::enableOutline(const Color4B& outlineColor,int outlineSize /* = 1 */) void Label::enableOutline(const Color4B& outlineColor,int outlineSize /* = 1 */)
@ -760,7 +782,7 @@ void Label::enableOutline(const Color4B& outlineColor,int outlineSize /* = 1 */)
auto config = _fontConfig; auto config = _fontConfig;
config.outlineSize = outlineSize; config.outlineSize = outlineSize;
setTTFConfig(config); setTTFConfig(config);
initProgram(); updateShaderProgram();
} }
} }
_fontDefinition._stroke._strokeEnabled = true; _fontDefinition._stroke._strokeEnabled = true;
@ -797,13 +819,13 @@ void Label::disableEffect()
setTTFConfig(_fontConfig); setTTFConfig(_fontConfig);
} }
_currLabelEffect = LabelEffect::NORMAL; _currLabelEffect = LabelEffect::NORMAL;
initProgram(); updateShaderProgram();
_contentDirty = true; _contentDirty = true;
} }
void Label::setFontScale(float fontScale) void Label::setFontScale(float fontScale)
{ {
_fontScale = fontScale; _fontScale = fontScale * CC_CONTENT_SCALE_FACTOR();
Node::setScale(_fontScale); Node::setScale(_fontScale);
} }
@ -940,12 +962,30 @@ void Label::updateContent()
_contentDirty = false; _contentDirty = false;
} }
void Label::updateFont()
{
if (_fontName.find('.') != _fontName.npos)
{
_fontConfig.fontFilePath = _fontName;
_fontConfig.fontSize = _fontSize;
setTTFConfig(_fontConfig);
}
_fontDefinition._fontName = _fontName;
_fontDefinition._fontSize = _fontSize;
_contentDirty = true;
_fontDirty = false;
}
void Label::visit(Renderer *renderer, const kmMat4 &parentTransform, bool parentTransformUpdated) void Label::visit(Renderer *renderer, const kmMat4 &parentTransform, bool parentTransformUpdated)
{ {
if (! _visible || _originalUTF8String.empty()) if (! _visible || _originalUTF8String.empty())
{ {
return; return;
} }
if (_fontDirty)
{
updateFont();
}
if (_contentDirty) if (_contentDirty)
{ {
updateContent(); updateContent();
@ -987,72 +1027,30 @@ void Label::visit(Renderer *renderer, const kmMat4 &parentTransform, bool parent
void Label::setFontName(const std::string& fontName) void Label::setFontName(const std::string& fontName)
{ {
if (fontName.find('.') != fontName.npos) if (fontName != _fontName)
{ {
auto config = _fontConfig; _fontName = fontName;
config.fontFilePath = fontName; _fontDirty = true;
if (setTTFConfig(config))
{
return;
}
}
if (_fontDefinition._fontName != fontName)
{
_fontDefinition._fontName = fontName;
_contentDirty = true;
} }
} }
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)
{ {
if (_currentLabelType == LabelType::TTF) if (_fontSize != fontSize)
{ {
if (_fontConfig.fontSize == fontSize) _fontSize = fontSize;
{ _fontDirty = true;
return;
}
if (_fontConfig.distanceFieldEnabled)
{
_fontConfig.fontSize = fontSize;
this->setFontScale(1.0f * fontSize / DefultFontSize);
}
else
{
auto fontConfig = _fontConfig;
fontConfig.fontSize = fontSize;
setTTFConfig(fontConfig);
}
}
else if(_fontDefinition._fontSize != fontSize)
{
_fontDefinition._fontSize = fontSize;
_fontConfig.fontSize = fontSize;
_contentDirty = true;
} }
} }
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
@ -1204,6 +1202,10 @@ std::string Label::getDescription() const
const Size& Label::getContentSize() const const Size& Label::getContentSize() const
{ {
if (_fontDirty)
{
const_cast<Label*>(this)->updateFont();
}
if (_contentDirty) if (_contentDirty)
{ {
const_cast<Label*>(this)->updateContent(); const_cast<Label*>(this)->updateContent();
@ -1211,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

@ -59,7 +59,7 @@ typedef struct _ttfConfig
bool distanceFieldEnabled; bool distanceFieldEnabled;
int outlineSize; int outlineSize;
_ttfConfig(const char* filePath = "",int size = 36, const GlyphCollection& glyphCollection = GlyphCollection::DYNAMIC, _ttfConfig(const char* filePath = "",int size = 12, const GlyphCollection& glyphCollection = GlyphCollection::DYNAMIC,
const char *customGlyphCollection = nullptr,bool useDistanceField = false,int outline = 0) const char *customGlyphCollection = nullptr,bool useDistanceField = false,int outline = 0)
:fontFilePath(filePath) :fontFilePath(filePath)
,fontSize(size) ,fontSize(size)
@ -78,7 +78,7 @@ typedef struct _ttfConfig
class CC_DLL Label : public SpriteBatchNode, public LabelProtocol class CC_DLL Label : public SpriteBatchNode, public LabelProtocol
{ {
public: public:
static const int DefultFontSize; static const int DistanceFieldFontSize;
static Label* create(); static Label* create();
@ -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);
@ -259,15 +268,13 @@ protected:
*/ */
virtual ~Label(); virtual ~Label();
virtual bool initWithFontAtlas(FontAtlas* atlas,bool distanceFieldEnabled = false, bool useA8Shader = false); virtual void setFontAtlas(FontAtlas* atlas,bool distanceFieldEnabled = false, bool useA8Shader = false);
bool recordLetterInfo(const cocos2d::Point& point,const FontLetterDefinition& letterDef, int spriteIndex); bool recordLetterInfo(const cocos2d::Point& point,const FontLetterDefinition& letterDef, int spriteIndex);
bool recordPlaceholderInfo(int spriteIndex); bool recordPlaceholderInfo(int spriteIndex);
void setFontScale(float fontScale); void setFontScale(float fontScale);
virtual bool init();
virtual void alignText(); virtual void alignText();
bool computeHorizontalKernings(unsigned short int *stringToRender); bool computeHorizontalKernings(unsigned short int *stringToRender);
@ -279,14 +286,20 @@ protected:
virtual void updateColor() override; virtual void updateColor() override;
virtual void initProgram(); virtual void updateShaderProgram();
void drawShadowWithoutBlur(); void drawShadowWithoutBlur();
void createSpriteWithFontDefinition(); void createSpriteWithFontDefinition();
void updateFont();
void reset();
bool _isOpacityModifyRGB; bool _isOpacityModifyRGB;
bool _contentDirty; bool _contentDirty;
bool _fontDirty;
std::string _fontName;
int _fontSize;
LabelType _currentLabelType; LabelType _currentLabelType;
std::vector<SpriteBatchNode*> _batchNodes; std::vector<SpriteBatchNode*> _batchNodes;

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,6 +94,7 @@ protected:
{ {
_string.clear(); _string.clear();
} }
virtual void updateColor() override;
// string to render // string to render
std::string _string; std::string _string;

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
{ {
@ -311,8 +312,6 @@ protected:
/** 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

@ -121,13 +121,31 @@ float tweenTo(float time, TweenType type, float *easingParam)
break; break;
case Elastic_EaseIn: case Elastic_EaseIn:
delta = elasticEaseIn(time, easingParam[0]); {
float period = 0.3f;
if (nullptr != easingParam) {
period = easingParam[0];
}
delta = elasticEaseIn(time, period);
}
break; break;
case Elastic_EaseOut: case Elastic_EaseOut:
delta = elasticEaseOut(time, easingParam[0]); {
float period = 0.3f;
if (nullptr != easingParam) {
period = easingParam[0];
}
delta = elasticEaseOut(time, period);
}
break; break;
case Elastic_EaseInOut: case Elastic_EaseInOut:
delta = elasticEaseInOut(time, easingParam[0]); {
float period = 0.3f;
if (nullptr != easingParam) {
period = easingParam[0];
}
delta = elasticEaseInOut(time, period);
}
break; break;

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)"
@ -183,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" />
@ -559,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
*/ */
if (glview->isOpenGLReady())
{
director->end(); director->end();
director->mainLoop(); 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

@ -235,7 +235,7 @@ public:
*/ */
void setMoment(float moment); void setMoment(float moment);
/** get the body moment of inertia. */ /** get the body moment of inertia. */
inline float getMoment(float moment) const { return _moment; } inline float getMoment() const { return _moment; }
/** /**
* @brief add moment of inertia to body. * @brief add moment of inertia to body.
* if _moment(moment of the body) == PHYSICS_INFINITY, it remains. * if _moment(moment of the body) == PHYSICS_INFINITY, it remains.

View File

@ -504,8 +504,8 @@ void PhysicsShapeBox::getPoints(Point* points) const
Size PhysicsShapeBox::getSize() const Size PhysicsShapeBox::getSize() const
{ {
cpShape* shape = _info->getShapes().front(); cpShape* shape = _info->getShapes().front();
return PhysicsHelper::cpv2size(cpv(cpvdist(cpPolyShapeGetVert(shape, 0), cpPolyShapeGetVert(shape, 1)), return PhysicsHelper::cpv2size(cpv(cpvdist(cpPolyShapeGetVert(shape, 1), cpPolyShapeGetVert(shape, 2)),
cpvdist(cpPolyShapeGetVert(shape, 1), cpPolyShapeGetVert(shape, 2)))); cpvdist(cpPolyShapeGetVert(shape, 0), cpPolyShapeGetVert(shape, 1))));
} }
// PhysicsShapePolygon // PhysicsShapePolygon

View File

@ -211,6 +211,11 @@ void PhysicsWorld::debugDraw()
{ {
PhysicsBody* body = dynamic_cast<PhysicsBody*>(obj); PhysicsBody* body = dynamic_cast<PhysicsBody*>(obj);
if (!body->isEnabled())
{
continue;
}
for (auto& shape : body->getShapes()) for (auto& shape : body->getShapes())
{ {
_debugDraw->drawShape(*dynamic_cast<PhysicsShape*>(shape)); _debugDraw->drawShape(*dynamic_cast<PhysicsShape*>(shape));

View File

@ -43,7 +43,6 @@
-------------------------------- --------------------------------
-- @function [parent=#PhysicsBody] getMoment -- @function [parent=#PhysicsBody] getMoment
-- @param self -- @param self
-- @param #float float
-- @return float#float ret (return value: float) -- @return float#float ret (return value: float)
-------------------------------- --------------------------------

View File

@ -0,0 +1,16 @@
--------------------------------
-- @module RichElement
--------------------------------
-- @function [parent=#RichElement] init
-- @param self
-- @param #int int
-- @param #color3B_table color3b
-- @param #unsigned char char
-- @return bool#bool ret (return value: bool)
--------------------------------
-- @function [parent=#RichElement] RichElement
-- @param self
return nil

View File

@ -0,0 +1,26 @@
--------------------------------
-- @module RichElementCustomNode
--------------------------------
-- @function [parent=#RichElementCustomNode] init
-- @param self
-- @param #int int
-- @param #color3B_table color3b
-- @param #unsigned char char
-- @param #cc.Node node
-- @return bool#bool ret (return value: bool)
--------------------------------
-- @function [parent=#RichElementCustomNode] create
-- @param self
-- @param #int int
-- @param #color3B_table color3b
-- @param #unsigned char char
-- @param #cc.Node node
-- @return RichElementCustomNode#RichElementCustomNode ret (return value: ccui.RichElementCustomNode)
--------------------------------
-- @function [parent=#RichElementCustomNode] RichElementCustomNode
-- @param self
return nil

View File

@ -0,0 +1,26 @@
--------------------------------
-- @module RichElementImage
--------------------------------
-- @function [parent=#RichElementImage] init
-- @param self
-- @param #int int
-- @param #color3B_table color3b
-- @param #unsigned char char
-- @param #char char
-- @return bool#bool ret (return value: bool)
--------------------------------
-- @function [parent=#RichElementImage] create
-- @param self
-- @param #int int
-- @param #color3B_table color3b
-- @param #unsigned char char
-- @param #char char
-- @return RichElementImage#RichElementImage ret (return value: ccui.RichElementImage)
--------------------------------
-- @function [parent=#RichElementImage] RichElementImage
-- @param self
return nil

View File

@ -0,0 +1,30 @@
--------------------------------
-- @module RichElementText
--------------------------------
-- @function [parent=#RichElementText] init
-- @param self
-- @param #int int
-- @param #color3B_table color3b
-- @param #unsigned char char
-- @param #char char
-- @param #char char
-- @param #float float
-- @return bool#bool ret (return value: bool)
--------------------------------
-- @function [parent=#RichElementText] create
-- @param self
-- @param #int int
-- @param #color3B_table color3b
-- @param #unsigned char char
-- @param #char char
-- @param #char char
-- @param #float float
-- @return RichElementText#RichElementText ret (return value: ccui.RichElementText)
--------------------------------
-- @function [parent=#RichElementText] RichElementText
-- @param self
return nil

View File

@ -0,0 +1,57 @@
--------------------------------
-- @module RichText
--------------------------------
-- @function [parent=#RichText] insertElement
-- @param self
-- @param #ccui.RichElement richelement
-- @param #int int
--------------------------------
-- @function [parent=#RichText] setAnchorPoint
-- @param self
-- @param #point_table point
--------------------------------
-- @function [parent=#RichText] pushBackElement
-- @param self
-- @param #ccui.RichElement richelement
--------------------------------
-- @function [parent=#RichText] formatText
-- @param self
--------------------------------
-- @function [parent=#RichText] ignoreContentAdaptWithSize
-- @param self
-- @param #bool bool
--------------------------------
-- @function [parent=#RichText] setVerticalSpace
-- @param self
-- @param #float float
--------------------------------
-- @function [parent=#RichText] getContentSize
-- @param self
-- @return size_table#size_table ret (return value: size_table)
--------------------------------
-- overload function: removeElement(ccui.RichElement)
--
-- overload function: removeElement(int)
--
-- @function [parent=#RichText] removeElement
-- @param self
-- @param #int int
--------------------------------
-- @function [parent=#RichText] create
-- @param self
-- @return RichText#RichText ret (return value: ccui.RichText)
--------------------------------
-- @function [parent=#RichText] RichText
-- @param self
return nil

View File

@ -91,4 +91,29 @@
-- @field [parent=#ccui] Helper#Helper Helper preloaded module -- @field [parent=#ccui] Helper#Helper Helper preloaded module
--------------------------------------------------------
-- the ccui RichElement
-- @field [parent=#ccui] RichElement#RichElement RichElement preloaded module
--------------------------------------------------------
-- the ccui RichElementText
-- @field [parent=#ccui] RichElementText#RichElementText RichElementText preloaded module
--------------------------------------------------------
-- the ccui RichElementImage
-- @field [parent=#ccui] RichElementImage#RichElementImage RichElementImage preloaded module
--------------------------------------------------------
-- the ccui RichElementCustomNode
-- @field [parent=#ccui] RichElementCustomNode#RichElementCustomNode RichElementCustomNode preloaded module
--------------------------------------------------------
-- the ccui RichText
-- @field [parent=#ccui] RichText#RichText RichText preloaded module
return nil return nil

View File

@ -1 +1 @@
b0dc5acd96b5d7e94c40c01097a6f969719a6110 44ccccc9572e8345c6b9903e8f10abcf0937d1cc

View File

@ -1 +1 @@
337366fa551a6f02e7f44e832e351fad51895ca5 cb29285429f792ed191dc2135b5f80ca5e52e9d1

View File

@ -1 +1 @@
6deb0e9e9ec193559f4eaa0f48310265bc32a491 6830e4b8f10511215bf059042bfd7eca7cc03679

View File

@ -25,7 +25,7 @@ int lua_cocos2dx_spine_Skeleton_setToSetupPose(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_setToSetupPose'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_setToSetupPose'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -68,7 +68,7 @@ int lua_cocos2dx_spine_Skeleton_setBlendFunc(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_setBlendFunc'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_setBlendFunc'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -114,7 +114,7 @@ int lua_cocos2dx_spine_Skeleton_onDraw(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_onDraw'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_onDraw'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -163,7 +163,7 @@ int lua_cocos2dx_spine_Skeleton_setSlotsToSetupPose(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_setSlotsToSetupPose'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_setSlotsToSetupPose'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -206,7 +206,7 @@ int lua_cocos2dx_spine_Skeleton_getBlendFunc(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_getBlendFunc'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_getBlendFunc'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -250,7 +250,7 @@ int lua_cocos2dx_spine_Skeleton_setSkin(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_setSkin'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_setSkin'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -297,7 +297,7 @@ int lua_cocos2dx_spine_Skeleton_setBonesToSetupPose(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_setBonesToSetupPose'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_Skeleton_setBonesToSetupPose'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -329,7 +329,7 @@ static int lua_cocos2dx_spine_Skeleton_finalize(lua_State* tolua_S)
int lua_register_cocos2dx_spine_Skeleton(lua_State* tolua_S) int lua_register_cocos2dx_spine_Skeleton(lua_State* tolua_S)
{ {
tolua_usertype(tolua_S,"sp.Skeleton"); tolua_usertype(tolua_S,"sp.Skeleton");
tolua_cclass(tolua_S,"Skeleton","sp.Skeleton","cc.Node",NULL); tolua_cclass(tolua_S,"Skeleton","sp.Skeleton","cc.Node",nullptr);
tolua_beginmodule(tolua_S,"Skeleton"); tolua_beginmodule(tolua_S,"Skeleton");
tolua_function(tolua_S,"setToSetupPose",lua_cocos2dx_spine_Skeleton_setToSetupPose); tolua_function(tolua_S,"setToSetupPose",lua_cocos2dx_spine_Skeleton_setToSetupPose);
@ -366,7 +366,7 @@ int lua_cocos2dx_spine_SkeletonAnimation_addAnimation(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_addAnimation'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_addAnimation'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -439,7 +439,7 @@ int lua_cocos2dx_spine_SkeletonAnimation_getCurrent(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_getCurrent'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_getCurrent'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -494,7 +494,7 @@ int lua_cocos2dx_spine_SkeletonAnimation_setMix(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_setMix'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_setMix'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -546,7 +546,7 @@ int lua_cocos2dx_spine_SkeletonAnimation_setAnimation(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_setAnimation'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_setAnimation'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -599,7 +599,7 @@ int lua_cocos2dx_spine_SkeletonAnimation_clearTracks(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_clearTracks'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_clearTracks'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -642,7 +642,7 @@ int lua_cocos2dx_spine_SkeletonAnimation_clearTrack(lua_State* tolua_S)
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_clearTrack'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_clearTrack'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -695,7 +695,7 @@ int lua_cocos2dx_spine_SkeletonAnimation_onAnimationStateEvent(lua_State* tolua_
#if COCOS2D_DEBUG >= 1 #if COCOS2D_DEBUG >= 1
if (!cobj) if (!cobj)
{ {
tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_onAnimationStateEvent'", NULL); tolua_error(tolua_S,"invalid 'cobj' in function 'lua_cocos2dx_spine_SkeletonAnimation_onAnimationStateEvent'", nullptr);
return 0; return 0;
} }
#endif #endif
@ -739,7 +739,7 @@ static int lua_cocos2dx_spine_SkeletonAnimation_finalize(lua_State* tolua_S)
int lua_register_cocos2dx_spine_SkeletonAnimation(lua_State* tolua_S) int lua_register_cocos2dx_spine_SkeletonAnimation(lua_State* tolua_S)
{ {
tolua_usertype(tolua_S,"sp.SkeletonAnimation"); tolua_usertype(tolua_S,"sp.SkeletonAnimation");
tolua_cclass(tolua_S,"SkeletonAnimation","sp.SkeletonAnimation","sp.Skeleton",NULL); tolua_cclass(tolua_S,"SkeletonAnimation","sp.SkeletonAnimation","sp.Skeleton",nullptr);
tolua_beginmodule(tolua_S,"SkeletonAnimation"); tolua_beginmodule(tolua_S,"SkeletonAnimation");
tolua_function(tolua_S,"addAnimation",lua_cocos2dx_spine_SkeletonAnimation_addAnimation); tolua_function(tolua_S,"addAnimation",lua_cocos2dx_spine_SkeletonAnimation_addAnimation);

View File

@ -1 +1 @@
b1abe1fd74f3d67444e32b3a3a0cad5c86b4269a 0a46232432ba108d165f69ca9435f3ae0e911a27

View File

@ -1 +1 @@
d0b810bd90f5639ba15e03fc5e083b762225a16d 11bba6be0cebc89eb4c7195a61d021e51719468f

View File

@ -328,6 +328,32 @@ int register_all_cocos2dx_ui(lua_State* tolua_S);

View File

@ -1 +1 @@
fe27a3bee5f56dc93ee7ae540adb0d88245d8072 9ad446c3528688b8df8fe36f8d72cec5eb49789d

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

@ -68,14 +68,16 @@ static const int CC_EDIT_BOX_PADDING = 5;
bool EditBoxImplAndroid::initWithSize(const Size& size) bool EditBoxImplAndroid::initWithSize(const Size& size)
{ {
int fontSize = getFontSizeAccordingHeightJni(size.height-12); int fontSize = getFontSizeAccordingHeightJni(size.height-12);
_label = LabelTTF::create("", "", size.height-12); _label = Label::create();
_label->setFontSize(size.height-12);
// align the text vertically center // align the text vertically center
_label->setAnchorPoint(Point(0, 0.5f)); _label->setAnchorPoint(Point(0, 0.5f));
_label->setPosition(Point(CC_EDIT_BOX_PADDING, size.height / 2.0f)); _label->setPosition(Point(CC_EDIT_BOX_PADDING, size.height / 2.0f));
_label->setColor(_colText); _label->setColor(_colText);
_editBox->addChild(_label); _editBox->addChild(_label);
_labelPlaceHolder = LabelTTF::create("", "", size.height-12); _labelPlaceHolder = Label::create();
_labelPlaceHolder->setFontSize(size.height-12);
// align the text vertically center // align the text vertically center
_labelPlaceHolder->setAnchorPoint(Point(0, 0.5f)); _labelPlaceHolder->setAnchorPoint(Point(0, 0.5f));
_labelPlaceHolder->setPosition(Point(CC_EDIT_BOX_PADDING, size.height / 2.0f)); _labelPlaceHolder->setPosition(Point(CC_EDIT_BOX_PADDING, size.height / 2.0f));
@ -167,7 +169,7 @@ void EditBoxImplAndroid::setText(const char* pText)
long length = cc_utf8_strlen(_text.c_str(), -1); long length = cc_utf8_strlen(_text.c_str(), -1);
for (long i = 0; i < length; i++) for (long i = 0; i < length; i++)
{ {
strToShow.append("\u25CF"); strToShow.append("*");
} }
} }
else else
@ -178,15 +180,12 @@ void EditBoxImplAndroid::setText(const char* pText)
_label->setString(strToShow.c_str()); _label->setString(strToShow.c_str());
// Clip the text width to fit to the text box // Clip the text width to fit to the text box
// FIXME: After re-implement LabelTTF by Label, '(g|s)etTextureRect' will not work, it's because LabelTTF is inherited from Node rather than Sprite now.
// float fMaxWidth = _editSize.width - CC_EDIT_BOX_PADDING * 2;
// Rect clippingRect = _label->getTextureRect();
// if(clippingRect.size.width > fMaxWidth) {
// clippingRect.size.width = fMaxWidth;
// _label->setTextureRect(clippingRect);
// }
float fMaxWidth = _editSize.width - CC_EDIT_BOX_PADDING * 2;
auto labelSize = _label->getContentSize();
if(labelSize.width > fMaxWidth) {
_label->setDimensions(fMaxWidth,labelSize.height);
}
} }
else else
{ {

View File

@ -84,8 +84,8 @@ public:
virtual void closeKeyboard(); virtual void closeKeyboard();
private: private:
LabelTTF* _label; Label* _label;
LabelTTF* _labelPlaceHolder; Label* _labelPlaceHolder;
EditBox::InputMode _editBoxInputMode; EditBox::InputMode _editBoxInputMode;
EditBox::InputFlag _editBoxInputFlag; EditBox::InputFlag _editBoxInputFlag;
EditBox::KeyboardReturnType _keyboardReturnType; EditBox::KeyboardReturnType _keyboardReturnType;

View File

@ -123,8 +123,8 @@ private:
void adjustTextFieldPosition(); void adjustTextFieldPosition();
void placeInactiveLabels(); void placeInactiveLabels();
LabelTTF* _label; Label* _label;
LabelTTF* _labelPlaceHolder; Label* _labelPlaceHolder;
Size _contentSize; Size _contentSize;
Point _position; Point _position;
Point _anchorPoint; Point _anchorPoint;

View File

@ -327,13 +327,13 @@ void EditBoxImplIOS::initInactiveLabels(const Size& size)
{ {
const char* pDefaultFontName = [[_systemControl.textField.font fontName] UTF8String]; const char* pDefaultFontName = [[_systemControl.textField.font fontName] UTF8String];
_label = LabelTTF::create("", "", 0.0f); _label = Label::create();
_label->setAnchorPoint(Point(0, 0.5f)); _label->setAnchorPoint(Point(0, 0.5f));
_label->setColor(Color3B::WHITE); _label->setColor(Color3B::WHITE);
_label->setVisible(false); _label->setVisible(false);
_editBox->addChild(_label, kLabelZOrder); _editBox->addChild(_label, kLabelZOrder);
_labelPlaceHolder = LabelTTF::create("", "", 0.0f); _labelPlaceHolder = Label::create();
// align the text vertically center // align the text vertically center
_labelPlaceHolder->setAnchorPoint(Point(0, 0.5f)); _labelPlaceHolder->setAnchorPoint(Point(0, 0.5f));
_labelPlaceHolder->setColor(Color3B::GRAY); _labelPlaceHolder->setColor(Color3B::GRAY);
@ -362,14 +362,11 @@ void EditBoxImplIOS::setInactiveText(const char* pText)
_label->setString(getText()); _label->setString(getText());
// Clip the text width to fit to the text box // Clip the text width to fit to the text box
// FIXME: After re-implement LabelTTF by Label, '(g|s)etTextureRect' will not work, it's because LabelTTF is inherited from Node rather than Sprite now. float fMaxWidth = _editBox->getContentSize().width - CC_EDIT_BOX_PADDING * 2;
// float fMaxWidth = _editBox->getContentSize().width - CC_EDIT_BOX_PADDING * 2; Size labelSize = _label->getContentSize();
// Rect clippingRect = _label->getTextureRect(); if(labelSize.width > fMaxWidth) {
// if(clippingRect.size.width > fMaxWidth) _label->setDimensions(fMaxWidth,labelSize.height);
// { }
// clippingRect.size.width = fMaxWidth;
// _label->setTextureRect(clippingRect);
// }
} }
void EditBoxImplIOS::setFont(const char* pFontName, int fontSize) void EditBoxImplIOS::setFont(const char* pFontName, int fontSize)

View File

@ -70,14 +70,16 @@ void EditBoxImplWin::doAnimationWhenKeyboardMove(float duration, float distance)
bool EditBoxImplWin::initWithSize(const Size& size) bool EditBoxImplWin::initWithSize(const Size& size)
{ {
//! int fontSize = getFontSizeAccordingHeightJni(size.height-12); //! int fontSize = getFontSizeAccordingHeightJni(size.height-12);
_label = LabelTTF::create("", "", size.height-12); _label = Label::create();
_label->setFontSize(size.height-12);
// align the text vertically center // align the text vertically center
_label->setAnchorPoint(Point(0, 0.5f)); _label->setAnchorPoint(Point(0, 0.5f));
_label->setPosition(Point(5, size.height / 2.0f)); _label->setPosition(Point(5, size.height / 2.0f));
_label->setColor(_colText); _label->setColor(_colText);
_editBox->addChild(_label); _editBox->addChild(_label);
_labelPlaceHolder = LabelTTF::create("", "", size.height-12); _labelPlaceHolder = Label::create();
_labelPlaceHolder->setFontSize(size.height-12);
// align the text vertically center // align the text vertically center
_labelPlaceHolder->setAnchorPoint(Point(0, 0.5f)); _labelPlaceHolder->setAnchorPoint(Point(0, 0.5f));
_labelPlaceHolder->setPosition(Point(5, size.height / 2.0f)); _labelPlaceHolder->setPosition(Point(5, size.height / 2.0f));

View File

@ -84,8 +84,8 @@ public:
virtual void onEnter(void); virtual void onEnter(void);
private: private:
LabelTTF* _label; Label* _label;
LabelTTF* _labelPlaceHolder; Label* _labelPlaceHolder;
EditBox::InputMode _editBoxInputMode; EditBox::InputMode _editBoxInputMode;
EditBox::InputFlag _editBoxInputFlag; EditBox::InputFlag _editBoxInputFlag;
EditBox::KeyboardReturnType _keyboardReturnType; EditBox::KeyboardReturnType _keyboardReturnType;

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

@ -87,19 +87,6 @@ class SetEnvVar(object):
return file_to_write return file_to_write
def _update_system_variable(self, origin_content, target_content):
is_updated = False
file = open(self.file_used_for_setup, 'a')
for line in fileinput.input(file_to_write, inplace=1):
if line.startswith(origin_content):
line = target_content
if_undated = True
sys.stdout.write(line)
file.close()
return is_updated
def _find_string_in_file(self, string, file_path): def _find_string_in_file(self, string, file_path):
with open(file_path) as f: with open(file_path) as f:
for line in f: for line in f:
@ -118,7 +105,9 @@ class SetEnvVar(object):
0, 0,
_winreg.KEY_SET_VALUE | _winreg.KEY_READ) _winreg.KEY_SET_VALUE | _winreg.KEY_READ)
_winreg.SetValueEx(env, key, 0, _winreg.REG_SZ, value) _winreg.SetValueEx(env, key, 0, _winreg.REG_SZ, value)
_winreg.FlushKey(env)
_winreg.CloseKey(env) _winreg.CloseKey(env)
except Exception: except Exception:
if env: if env:
_winreg.CloseKey(env) _winreg.CloseKey(env)
@ -271,6 +260,9 @@ class SetEnvVar(object):
if not android_sdk_root: if not android_sdk_root:
return False return False
if self._isWindows():
android_path = os.path.join(android_sdk_root, 'tools/android.bat')
else:
android_path = os.path.join(android_sdk_root, 'tools/android') android_path = os.path.join(android_sdk_root, 'tools/android')
if os.path.isfile(android_path): if os.path.isfile(android_path):
return True return True
@ -281,7 +273,7 @@ class SetEnvVar(object):
ant_path = '' ant_path = ''
if self._isWindows(): if self._isWindows():
ant_path = os.path.join(ant_root, 'ant.exe') ant_path = os.path.join(ant_root, 'ant.bat')
else: else:
ant_path = os.path.join(ant_root, 'ant') ant_path = os.path.join(ant_root, 'ant')
@ -290,6 +282,35 @@ class SetEnvVar(object):
else: else:
return False return False
def set_windows_path(self, cocos_consle_root):
import _winreg
try:
env = None
path = None
env = _winreg.OpenKeyEx(_winreg.HKEY_CURRENT_USER,
'Environment',
0,
_winreg.KEY_SET_VALUE | _winreg.KEY_READ)
path = _winreg.QueryValueEx(env, 'Path')[0]
path = path + ';' + cocos_consle_root
path.replace('/', '\\')
_winreg.SetValueEx(env, 'Path', 0, _winreg.REG_SZ, path)
_winreg.FlushKey(env)
_winreg.CloseKey(env)
except Exception:
if not path:
path = cocos_consle_root.replace('/', '\\')
_winreg.SetValueEx(env, 'Path', 0, _winreg.REG_SZ, path)
_winreg.FlushKey(env)
else:
_winreg.SetValueEx(env, 'Path', 0, _winreg.REG_SZ, path)
_winreg.FlushKey(env)
if env:
_winreg.CloseKey(env)
return False
return True
def set_console_root(self): def set_console_root(self):
@ -297,6 +318,8 @@ class SetEnvVar(object):
print '-> Adding COCOS2D_CONSOLE_ROOT environment variable...', print '-> Adding COCOS2D_CONSOLE_ROOT environment variable...',
if not self._find_environment_variable(COCOS_CONSOLE_ROOT): if not self._find_environment_variable(COCOS_CONSOLE_ROOT):
cocos_consle_root = os.path.join(self.current_absolute_path, 'tools/cocos2d-console/bin') cocos_consle_root = os.path.join(self.current_absolute_path, 'tools/cocos2d-console/bin')
if self._isWindows():
self.set_windows_path(cocos_consle_root)
if self._set_environment_variable(COCOS_CONSOLE_ROOT, cocos_consle_root): if self._set_environment_variable(COCOS_CONSOLE_ROOT, cocos_consle_root):
print 'OK' print 'OK'
print ' -> Added: %s = %s' % (COCOS_CONSOLE_ROOT, cocos_consle_root) print ' -> Added: %s = %s' % (COCOS_CONSOLE_ROOT, cocos_consle_root)
@ -328,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'
@ -354,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'
@ -378,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:
@ -410,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
@ -418,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 @@
879acef60464ae6a0af99e8e5d809245f8cdbe56 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
)

Some files were not shown because too many files have changed in this diff Show More