mirror of https://github.com/axmolengine/axmol.git
Merge pull request #2811 from carlomorgantinizynga/finalTTFLabelChanges
fixed #2265: new CCLabelTTF createWithFontDefinition method, and new test
This commit is contained in:
commit
6938b27ab5
|
@ -96,6 +96,18 @@ CCLabelTTF* CCLabelTTF::create(const char *string, const char *fontName, float f
|
||||||
return NULL;
|
return NULL;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
CCLabelTTF * CCLabelTTF::createWithFontDefinition(const char *string, ccFontDefinition &textDefinition)
|
||||||
|
{
|
||||||
|
CCLabelTTF *pRet = new CCLabelTTF();
|
||||||
|
if(pRet && pRet->initWithStringAndTextDefinition(string, textDefinition))
|
||||||
|
{
|
||||||
|
pRet->autorelease();
|
||||||
|
return pRet;
|
||||||
|
}
|
||||||
|
CC_SAFE_DELETE(pRet);
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
bool CCLabelTTF::init()
|
bool CCLabelTTF::init()
|
||||||
{
|
{
|
||||||
return this->initWithString("", "Helvetica", 12);
|
return this->initWithString("", "Helvetica", 12);
|
||||||
|
|
|
@ -70,6 +70,10 @@ public:
|
||||||
const CCSize& dimensions, CCTextAlignment hAlignment,
|
const CCSize& dimensions, CCTextAlignment hAlignment,
|
||||||
CCVerticalTextAlignment vAlignment);
|
CCVerticalTextAlignment vAlignment);
|
||||||
|
|
||||||
|
|
||||||
|
/** Create a lable with string and a font definition*/
|
||||||
|
static CCLabelTTF * createWithFontDefinition(const char *string, ccFontDefinition &textDefinition);
|
||||||
|
|
||||||
/** initializes the CCLabelTTF with a font name and font size */
|
/** initializes the CCLabelTTF with a font name and font size */
|
||||||
bool initWithString(const char *string, const char *fontName, float fontSize);
|
bool initWithString(const char *string, const char *fontName, float fontSize);
|
||||||
|
|
||||||
|
|
|
@ -1506,9 +1506,6 @@ TTFFontShadowAndStroke::TTFFontShadowAndStroke()
|
||||||
|
|
||||||
CCSize shadowOffset(12.0, 12.0);
|
CCSize shadowOffset(12.0, 12.0);
|
||||||
|
|
||||||
// create the label shadow only
|
|
||||||
CCLabelTTF* fontShadow = new CCLabelTTF();
|
|
||||||
|
|
||||||
ccFontDefinition shadowTextDef;
|
ccFontDefinition shadowTextDef;
|
||||||
shadowTextDef.m_fontSize = 20;
|
shadowTextDef.m_fontSize = 20;
|
||||||
shadowTextDef.m_fontName = std::string("Marker Felt");
|
shadowTextDef.m_fontName = std::string("Marker Felt");
|
||||||
|
@ -1519,7 +1516,8 @@ TTFFontShadowAndStroke::TTFFontShadowAndStroke()
|
||||||
shadowTextDef.m_shadow.m_shadowBlur = 1.0;
|
shadowTextDef.m_shadow.m_shadowBlur = 1.0;
|
||||||
shadowTextDef.m_fontFillColor = tintColorRed;
|
shadowTextDef.m_fontFillColor = tintColorRed;
|
||||||
|
|
||||||
fontShadow->initWithStringAndTextDefinition("Shadow Only Red Text", shadowTextDef);
|
// shadow only label
|
||||||
|
CCLabelTTF* fontShadow = CCLabelTTF::createWithFontDefinition("Shadow Only Red Text", shadowTextDef);
|
||||||
|
|
||||||
// add label to the scene
|
// add label to the scene
|
||||||
this->addChild(fontShadow);
|
this->addChild(fontShadow);
|
||||||
|
@ -1527,9 +1525,7 @@ TTFFontShadowAndStroke::TTFFontShadowAndStroke()
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
// create the label stroke only
|
// create the stroke only label
|
||||||
CCLabelTTF* fontStroke = new CCLabelTTF();
|
|
||||||
|
|
||||||
ccFontDefinition strokeTextDef;
|
ccFontDefinition strokeTextDef;
|
||||||
strokeTextDef.m_fontSize = 20;
|
strokeTextDef.m_fontSize = 20;
|
||||||
strokeTextDef.m_fontName = std::string("Marker Felt");
|
strokeTextDef.m_fontName = std::string("Marker Felt");
|
||||||
|
@ -1540,7 +1536,8 @@ TTFFontShadowAndStroke::TTFFontShadowAndStroke()
|
||||||
|
|
||||||
strokeTextDef.m_fontFillColor = tintColorYellow;
|
strokeTextDef.m_fontFillColor = tintColorYellow;
|
||||||
|
|
||||||
fontStroke->initWithStringAndTextDefinition("Stroke Only Yellow Text", strokeTextDef);
|
// stroke only label
|
||||||
|
CCLabelTTF* fontStroke = CCLabelTTF::createWithFontDefinition("Stroke Only Yellow Text", strokeTextDef);
|
||||||
|
|
||||||
// add label to the scene
|
// add label to the scene
|
||||||
this->addChild(fontStroke);
|
this->addChild(fontStroke);
|
||||||
|
@ -1549,8 +1546,6 @@ TTFFontShadowAndStroke::TTFFontShadowAndStroke()
|
||||||
|
|
||||||
|
|
||||||
// create the label stroke and shadow
|
// create the label stroke and shadow
|
||||||
CCLabelTTF* fontStrokeAndShadow = new CCLabelTTF();
|
|
||||||
|
|
||||||
ccFontDefinition strokeShaodwTextDef;
|
ccFontDefinition strokeShaodwTextDef;
|
||||||
strokeShaodwTextDef.m_fontSize = 20;
|
strokeShaodwTextDef.m_fontSize = 20;
|
||||||
strokeShaodwTextDef.m_fontName = std::string("Marker Felt");
|
strokeShaodwTextDef.m_fontName = std::string("Marker Felt");
|
||||||
|
@ -1567,12 +1562,15 @@ TTFFontShadowAndStroke::TTFFontShadowAndStroke()
|
||||||
|
|
||||||
strokeShaodwTextDef.m_fontFillColor = tintColorBlue;
|
strokeShaodwTextDef.m_fontFillColor = tintColorBlue;
|
||||||
|
|
||||||
fontStrokeAndShadow->initWithStringAndTextDefinition("Stroke & Shadow Blue Text", strokeShaodwTextDef);
|
// shadow + stroke label
|
||||||
|
CCLabelTTF* fontStrokeAndShadow = CCLabelTTF::createWithFontDefinition("Stroke & Shadow Blue Text", strokeShaodwTextDef);
|
||||||
|
|
||||||
// add label to the scene
|
// add label to the scene
|
||||||
this->addChild(fontStrokeAndShadow);
|
this->addChild(fontStrokeAndShadow);
|
||||||
fontStrokeAndShadow->setPosition(ccp(s.width/2,s.height/4*1.1));
|
fontStrokeAndShadow->setPosition(ccp(s.width/2,s.height/4*1.1));
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
std::string TTFFontShadowAndStroke::title()
|
std::string TTFFontShadowAndStroke::title()
|
||||||
|
|
Loading…
Reference in New Issue