axmol/extensions/cocostudio/WidgetReader/TextBMFontReader/TextBMFontReader.cpp

268 lines
8.8 KiB
C++
Raw Normal View History

2019-11-23 20:27:39 +08:00
2020-08-03 20:31:47 +08:00
#include "cocostudio/WidgetReader/TextBMFontReader/TextBMFontReader.h"
2019-11-23 20:27:39 +08:00
#include "2d/CCFontAtlasCache.h"
#include "ui/UITextBMFont.h"
#include "platform/CCFileUtils.h"
2020-08-03 20:31:47 +08:00
#include "cocostudio/CocoLoader.h"
#include "cocostudio/CSParseBinary_generated.h"
#include "cocostudio/LocalizationManager.h"
2019-11-23 20:27:39 +08:00
#include "flatbuffers/flatbuffers.h"
USING_NS_CC;
using namespace ui;
using namespace flatbuffers;
namespace cocostudio
{
static const char* P_FileNameData = "fileNameData";
static const char* P_Text = "text";
static TextBMFontReader* instanceTextBMFontReader = nullptr;
IMPLEMENT_CLASS_NODE_READER_INFO(TextBMFontReader)
TextBMFontReader::TextBMFontReader()
{
}
TextBMFontReader::~TextBMFontReader()
{
}
TextBMFontReader* TextBMFontReader::getInstance()
{
if (!instanceTextBMFontReader)
{
instanceTextBMFontReader = new (std::nothrow) TextBMFontReader();
}
return instanceTextBMFontReader;
}
void TextBMFontReader::destroyInstance()
{
CC_SAFE_DELETE(instanceTextBMFontReader);
}
void TextBMFontReader::setPropsFromBinary(cocos2d::ui::Widget *widget, CocoLoader *cocoLoader, stExpCocoNode *cocoNode)
{
this->beginSetBasicProperties(widget);
TextBMFont* labelBMFont = static_cast<TextBMFont*>(widget);
stExpCocoNode *stChildArray = cocoNode->GetChildArray(cocoLoader);
for (int i = 0; i < cocoNode->GetChildNum(); ++i) {
std::string key = stChildArray[i].GetName(cocoLoader);
std::string value = stChildArray[i].GetValue(cocoLoader);
//read all basic properties of widget
CC_BASIC_PROPERTY_BINARY_READER
//read all color related properties of widget
CC_COLOR_PROPERTY_BINARY_READER
else if(key == P_FileNameData){
stExpCocoNode *backGroundChildren = stChildArray[i].GetChildArray(cocoLoader);
std::string resType = backGroundChildren[2].GetValue(cocoLoader);
Widget::TextureResType imageFileNameType = (Widget::TextureResType)valueToInt(resType);
std::string backgroundValue = this->getResourcePath(cocoLoader, &stChildArray[i], imageFileNameType);
2019-11-24 23:15:56 +08:00
2019-11-23 20:27:39 +08:00
if (imageFileNameType == (Widget::TextureResType)0) {
2020-08-04 10:55:30 +08:00
labelBMFont->setFntFile(backgroundValue);
2019-11-23 20:27:39 +08:00
}
}else if(key == P_Text){
labelBMFont->setString(value);
}
} //end of for loop
this->endSetBasicProperties(widget);
}
void TextBMFontReader::setPropsFromJsonDictionary(Widget *widget, const rapidjson::Value &options)
{
WidgetReader::setPropsFromJsonDictionary(widget, options);
std::string jsonPath = GUIReader::getInstance()->getFilePath();
TextBMFont* labelBMFont = static_cast<TextBMFont*>(widget);
const rapidjson::Value& cmftDic = DICTOOL->getSubDictionary_json(options, P_FileNameData);
int cmfType = DICTOOL->getIntValue_json(cmftDic, P_ResourceType);
switch (cmfType)
{
case 0:
{
std::string tp_c = jsonPath;
const char* cmfPath = DICTOOL->getStringValue_json(cmftDic, P_Path);
const char* cmf_tp = tp_c.append(cmfPath).c_str();
labelBMFont->setFntFile(cmf_tp);
break;
}
case 1:
CCLOG("Wrong res type of LabelAtlas!");
break;
default:
break;
}
const char* text = DICTOOL->getStringValue_json(options, P_Text,"Text Label");
labelBMFont->setString(text);
WidgetReader::setColorPropsFromJsonDictionary(widget, options);
}
2019-11-24 23:15:56 +08:00
Offset<Table> TextBMFontReader::createOptionsWithFlatBuffers(pugi::xml_node objectData,
2019-11-23 20:27:39 +08:00
flatbuffers::FlatBufferBuilder *builder)
{
auto temp = WidgetReader::getInstance()->createOptionsWithFlatBuffers(objectData, builder);
auto widgetOptions = *(Offset<WidgetOptions>*)(&temp);
std::string text = "Fnt Text Label";
bool isLocalized = false;
2020-08-04 10:55:30 +08:00
std::string path;
std::string plistFlie;
2019-11-23 20:27:39 +08:00
int resourceType = 0;
// attributes
2019-11-24 23:15:56 +08:00
auto attribute = objectData.first_attribute();
2019-11-23 20:27:39 +08:00
while (attribute)
{
2019-11-24 23:15:56 +08:00
std::string name = attribute.name();
std::string value = attribute.value();
2019-11-23 20:27:39 +08:00
if (name == "LabelText")
{
text = value;
}
else if (name == "IsLocalized")
{
isLocalized = (value == "True") ? true : false;
}
2019-11-24 23:15:56 +08:00
attribute = attribute.next_attribute();
2019-11-23 20:27:39 +08:00
}
// child elements
2019-11-24 23:15:56 +08:00
auto child = objectData.first_child();
2019-11-23 20:27:39 +08:00
while (child)
{
2019-11-24 23:15:56 +08:00
std::string name = child.name();
2019-11-23 20:27:39 +08:00
if (name == "LabelBMFontFile_CNB")
{
2019-11-24 23:15:56 +08:00
attribute = child.first_attribute();
2019-11-23 20:27:39 +08:00
while (attribute)
{
2019-11-24 23:15:56 +08:00
name = attribute.name();
std::string value = attribute.value();
2019-11-23 20:27:39 +08:00
if (name == "Path")
{
path = value;
}
else if (name == "Type")
{
resourceType = 0;
}
else if (name == "Plist")
{
plistFlie = value;
}
2019-11-24 23:15:56 +08:00
attribute = attribute.next_attribute();
2019-11-23 20:27:39 +08:00
}
}
2019-11-24 23:15:56 +08:00
child = child.next_sibling();
2019-11-23 20:27:39 +08:00
}
auto options = CreateTextBMFontOptions(*builder,
widgetOptions,
CreateResourceData(*builder,
builder->CreateString(path),
builder->CreateString(plistFlie),
resourceType),
builder->CreateString(text),
isLocalized);
return *(Offset<Table>*)(&options);
}
void TextBMFontReader::setPropsWithFlatBuffers(cocos2d::Node *node, const flatbuffers::Table *textBMFontOptions)
{
TextBMFont* labelBMFont = static_cast<TextBMFont*>(node);
auto options = (TextBMFontOptions*)textBMFontOptions;
2020-08-04 10:55:30 +08:00
auto cmftDic = (options->fileNameData());
2019-11-23 20:27:39 +08:00
bool fileExist = false;
2020-08-04 10:55:30 +08:00
std::string errorFilePath;
std::string errorContent;
std::string path = cmftDic->path()->c_str();
int cmfType = cmftDic->resourceType();
2019-11-23 20:27:39 +08:00
switch (cmfType)
{
case 0:
{
if (FileUtils::getInstance()->isFileExist(path))
{
FontAtlas* newAtlas = FontAtlasCache::getFontAtlasFNT(path);
if (newAtlas)
{
fileExist = true;
}
else
{
errorContent = "has problem";
fileExist = false;
}
}
break;
}
default:
break;
}
if (fileExist)
{
labelBMFont->setFntFile(path);
}
std::string text = options->text()->c_str();
bool isLocalized = options->isLocalized() != 0;
if (isLocalized)
{
ILocalizationManager* lm = LocalizationHelper::getCurrentManager();
labelBMFont->setString(lm->getLocalizationString(text));
}
else
{
labelBMFont->setString(text);
}
auto widgetReader = WidgetReader::getInstance();
widgetReader->setPropsWithFlatBuffers(node, (Table*)options->widgetOptions());
labelBMFont->ignoreContentAdaptWithSize(true);
}
Node* TextBMFontReader::createNodeWithFlatBuffers(const flatbuffers::Table *textBMFontOptions)
{
2020-08-04 00:14:35 +08:00
TextBMFont* textBMFont = TextBMFont::create();
2019-11-23 20:27:39 +08:00
setPropsWithFlatBuffers(textBMFont, (Table*)textBMFontOptions);
return textBMFont;
}
}