mirror of https://github.com/axmolengine/axmol.git
Merge branch 'luamerage' of https://github.com/chuanweizhang2013/cocos2d-x into luamerage
This commit is contained in:
commit
9e43eb639f
|
@ -1 +1 @@
|
||||||
b8bc5839895bfc413816baa425d43a2b8e48205d
|
874372f8d3779318a2f70b74984575e632ff0dc8
|
47
README.md
47
README.md
|
@ -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
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
bbf0323293cba3d7ee58ef36706831a8761692d8
|
b8986c04c89d3861f82fb99b0df633ac2cc4a13c
|
|
@ -1 +1 @@
|
||||||
66526d30a3e76bb1b54c7615a18c467845798e78
|
2c5a07d179e9514618036dfb7cfedd3f9cf4c506
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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;
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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>
|
||||||
|
|
|
@ -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>
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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));
|
||||||
;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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];
|
||||||
|
|
|
@ -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
|
||||||
{
|
{
|
||||||
|
|
|
@ -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.
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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));
|
||||||
|
|
|
@ -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)
|
||||||
|
|
||||||
--------------------------------
|
--------------------------------
|
||||||
|
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
|
@ -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
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
b0dc5acd96b5d7e94c40c01097a6f969719a6110
|
44ccccc9572e8345c6b9903e8f10abcf0937d1cc
|
|
@ -1 +1 @@
|
||||||
337366fa551a6f02e7f44e832e351fad51895ca5
|
cb29285429f792ed191dc2135b5f80ca5e52e9d1
|
|
@ -1 +1 @@
|
||||||
6deb0e9e9ec193559f4eaa0f48310265bc32a491
|
6830e4b8f10511215bf059042bfd7eca7cc03679
|
|
@ -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);
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
b1abe1fd74f3d67444e32b3a3a0cad5c86b4269a
|
0a46232432ba108d165f69ca9435f3ae0e911a27
|
|
@ -1 +1 @@
|
||||||
d0b810bd90f5639ba15e03fc5e083b762225a16d
|
11bba6be0cebc89eb4c7195a61d021e51719468f
|
|
@ -328,6 +328,32 @@ int register_all_cocos2dx_ui(lua_State* tolua_S);
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
fe27a3bee5f56dc93ee7ae540adb0d88245d8072
|
9ad446c3528688b8df8fe36f8d72cec5eb49789d
|
|
@ -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";
|
||||||
|
|
|
@ -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: \
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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();
|
||||||
|
|
||||||
|
|
|
@ -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];
|
||||||
|
|
|
@ -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());
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
{
|
{
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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)
|
||||||
|
|
|
@ -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));
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
c135286e812602cc184684b59b4d074f723ef4a5
|
dc1d98e73cda98024add3420a06fa29651c863d0
|
|
@ -0,0 +1 @@
|
||||||
|
9b09288998b6198388456c41ccbdd5596622abe5
|
|
@ -1 +1 @@
|
||||||
3303f759eb8c682843322ffa9f8c69563d241ca5
|
81b071fde15c160fb96e2b28a22142e903fdf5a4
|
|
@ -0,0 +1 @@
|
||||||
|
690402fd689da9d29621e7665db2f40ac4e947eb
|
|
@ -1 +1 @@
|
||||||
39c4d5970691b3a3ca47be0f7d2a0b5c72e9e2ee
|
e8281e5ccfc438a1d097b9704010312801ea192e
|
|
@ -0,0 +1 @@
|
||||||
|
dd93f7d77c23392642750b58fb0f41eda9218b69
|
|
@ -1 +1 @@
|
||||||
fc2d13f253f62b28ad1d37a4a24da1e977acba20
|
d8eeb3fe1c71ca56139f7e31f0b502da876c692b
|
|
@ -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 */
|
||||||
|
|
|
@ -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;
|
||||||
|
|
|
@ -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;
|
||||||
}
|
}
|
||||||
|
|
|
@ -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);
|
||||||
|
|
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -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}
|
||||||
|
|
|
@ -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 */
|
||||||
|
|
|
@ -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]);
|
||||||
|
|
|
@ -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},
|
||||||
|
|
|
@ -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 */
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
|
@ -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': {
|
||||||
|
|
|
@ -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;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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");
|
||||||
}
|
}
|
||||||
|
|
|
@ -0,0 +1 @@
|
||||||
|
a064ce4dee79c042cebd3ab706673cd2a7bc4a4e
|
|
@ -1 +1 @@
|
||||||
2a8128e7d552dc8b2d79c1cbd8c84c21ad578672
|
c4decf3cb39b46189df24c54868f46e985b15de2
|
|
@ -0,0 +1 @@
|
||||||
|
13d38a8f7cf04ee464b3eaf5fd7464853499390e
|
|
@ -1 +1 @@
|
||||||
fb78024e2f81c33d196af83e7740de7c7f4ea021
|
373f86ef034bf18f5d52588747c02d7896884730
|
|
@ -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
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
60433133a48054eb884d9e6a0cee95fe4ba22b1c
|
286c39ddabb05b91c81ee5d7ec0a1301d0be3108
|
|
@ -0,0 +1 @@
|
||||||
|
39aa0b352df6cb1adf2390cf199910b21a3b3c12
|
|
@ -1 +1 @@
|
||||||
5fe8aca7e0bfa91c79b4b6b0a562f88a6653c452
|
e5cd88ead5723950d6f69e8bd72b4b18b2f9d893
|
|
@ -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
|
|
@ -1 +1 @@
|
||||||
c26c3c22887023d322926dcbbd0f69377deedaf8
|
7f9f32e81cbd068ab7a9c408a26eedfdcc8d6e30
|
|
@ -0,0 +1 @@
|
||||||
|
904e2e16f2f4846b4550b9ba25e8b709f6c4337e
|
|
@ -1 +1 @@
|
||||||
4c5c7d34a90f5fcac954f6d44803173224d8ead2
|
6b5decfe3f5b19bacfbd9778cb58843a7161a6a9
|
|
@ -1 +1 @@
|
||||||
ee4ee6cc26274f6d3138d08d429d6ba49b629f53
|
5c60f0b27edd2650caee8a96948272604a8098d5
|
|
@ -1 +1 @@
|
||||||
5d0743ce07a9c865d4367d8e3db161148676f2c8
|
36c2d4cb652d9a93fa2a285cb8c73f237612bb46
|
61
setup.py
61
setup.py
|
@ -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
|
||||||
|
|
|
@ -1 +1 @@
|
||||||
879acef60464ae6a0af99e8e5d809245f8cdbe56
|
4dfa7f46c2e06a4b3b95120bea3b8689f31ddad0
|
|
@ -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
Loading…
Reference in New Issue