Merge pull request #2811 from carlomorgantinizynga/finalTTFLabelChanges

fixed #2265: new CCLabelTTF createWithFontDefinition method, and new test
This commit is contained in:
James Chen 2013-06-07 19:44:23 -07:00
commit 6938b27ab5
3 changed files with 28 additions and 14 deletions

View File

@ -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);

View File

@ -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);

View File

@ -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()