mirror of https://github.com/axmolengine/axmol.git
373 lines
11 KiB
C++
373 lines
11 KiB
C++
|
|
|
|
#include "WidgetReader/TextFieldReader/TextFieldExReader.h"
|
|
|
|
#include "ui/UITextFieldEx.h"
|
|
#include "platform/CCFileUtils.h"
|
|
#include "CocoLoader.h"
|
|
#include "CSParseBinary_generated.h"
|
|
#include "LocalizationManager.h"
|
|
|
|
#include "WidgetReader/NodeReader/NodeReader.h"
|
|
|
|
#include "flatbuffers/flatbuffers.h"
|
|
|
|
USING_NS_AX;
|
|
using namespace ui;
|
|
using namespace flatbuffers;
|
|
|
|
inline Color4B Color4BFromFb(const flatbuffers::Color* pColor)
|
|
{
|
|
return Color4B(pColor->r(), pColor->g(), pColor->b(), pColor->a());
|
|
}
|
|
|
|
inline Color3B Color3BFromFb(const flatbuffers::Color* pColor)
|
|
{
|
|
return Color3B(pColor->r(), pColor->g(), pColor->b());
|
|
}
|
|
|
|
namespace cocostudio
|
|
{
|
|
static TextFieldExReader* instanceTextFieldExReader = nullptr;
|
|
|
|
static const char* P_PlaceHolder = "placeHolder";
|
|
static const char* P_Text = "text";
|
|
static const char* P_FontSize = "fontSize";
|
|
static const char* P_FontName = "fontName";
|
|
static const char* P_TouchSizeWidth = "touchSizeWidth";
|
|
static const char* P_TouchSizeHeight = "touchSizeHeight";
|
|
static const char* P_MaxLengthEnable = "maxLengthEnable";
|
|
static const char* P_MaxLength = "maxLength";
|
|
static const char* P_PasswordEnable = "passwordEnable";
|
|
static const char* P_PasswordStyleText = "passwordStyleText";
|
|
|
|
IMPLEMENT_CLASS_NODE_READER_INFO(TextFieldExReader)
|
|
|
|
TextFieldExReader::TextFieldExReader() {}
|
|
|
|
TextFieldExReader::~TextFieldExReader() {}
|
|
|
|
TextFieldExReader* TextFieldExReader::getInstance()
|
|
{
|
|
if (!instanceTextFieldExReader)
|
|
{
|
|
instanceTextFieldExReader = new TextFieldExReader();
|
|
}
|
|
return instanceTextFieldExReader;
|
|
}
|
|
|
|
void TextFieldExReader::destroyInstance()
|
|
{
|
|
AX_SAFE_DELETE(instanceTextFieldExReader);
|
|
}
|
|
|
|
Offset<Table> TextFieldExReader::createOptionsWithFlatBuffers(pugi::xml_node objectData,
|
|
flatbuffers::FlatBufferBuilder* builder)
|
|
{
|
|
auto temp = WidgetReader::getInstance()->createOptionsWithFlatBuffers(objectData, builder);
|
|
auto widgetOptions = *(Offset<WidgetOptions>*)(&temp);
|
|
|
|
std::string path;
|
|
std::string plistFile;
|
|
int resourceType = 0;
|
|
|
|
std::string fontName;
|
|
int fontSize = 20;
|
|
std::string text;
|
|
bool isLocalized = false;
|
|
std::string placeHolder = "Text Field Extend";
|
|
bool passwordEnabled = false;
|
|
std::string passwordStyleText = "*";
|
|
bool maxLengthEnabled = false;
|
|
int maxLength = 10;
|
|
bool isEnabled = true;
|
|
bool isEditable = true;
|
|
Color4B textColor;
|
|
Color4B placeholderColor;
|
|
Color4B cursorColor;
|
|
|
|
// attributes
|
|
auto attribute = objectData.first_attribute();
|
|
while (attribute)
|
|
{
|
|
std::string_view name = attribute.name();
|
|
std::string_view value = attribute.value();
|
|
|
|
if (name == "PlaceHolderText")
|
|
{
|
|
placeHolder = value;
|
|
}
|
|
else if (name == "LabelText")
|
|
{
|
|
text = value;
|
|
}
|
|
else if (name == "IsLocalized")
|
|
{
|
|
isLocalized = (value == "True") ? true : false;
|
|
}
|
|
else if (name == "FontSize")
|
|
{
|
|
fontSize = atoi(value.data());
|
|
}
|
|
else if (name == "FontName")
|
|
{
|
|
fontName = value;
|
|
}
|
|
else if (name == "MaxLengthText")
|
|
{
|
|
maxLength = atoi(value.data());
|
|
}
|
|
else if (name == "PasswordEnable")
|
|
{
|
|
passwordEnabled = (value == "True") ? true : false;
|
|
}
|
|
else if (name == "PasswordStyleText")
|
|
{
|
|
passwordStyleText = value;
|
|
}
|
|
else if (name == "Enabled")
|
|
{
|
|
isEnabled = (value == "True") ? true : false;
|
|
}
|
|
else if (name == "Editable")
|
|
{
|
|
isEditable = (value == "True") ? true : false;
|
|
}
|
|
|
|
attribute = attribute.next_attribute();
|
|
}
|
|
|
|
// child elements
|
|
auto child = objectData.first_child();
|
|
while (child)
|
|
{
|
|
std::string_view name = child.name();
|
|
|
|
if (name == "FontResource")
|
|
{
|
|
attribute = child.first_attribute();
|
|
|
|
while (attribute)
|
|
{
|
|
name = attribute.name();
|
|
std::string_view value = attribute.value();
|
|
|
|
if (name == "Path")
|
|
{
|
|
path = value;
|
|
}
|
|
else if (name == "Type")
|
|
{
|
|
resourceType = 0;
|
|
}
|
|
else if (name == "Plist")
|
|
{
|
|
plistFile = value;
|
|
}
|
|
|
|
attribute = attribute.next_attribute();
|
|
}
|
|
}
|
|
else if (name == "TextColor")
|
|
{
|
|
attribute = child.first_attribute();
|
|
|
|
while (attribute)
|
|
{
|
|
name = attribute.name();
|
|
std::string_view value = attribute.value();
|
|
|
|
if (name == "A")
|
|
{
|
|
textColor.a = atoi(value.data());
|
|
}
|
|
else if (name == "R")
|
|
{
|
|
textColor.r = atoi(value.data());
|
|
}
|
|
else if (name == "G")
|
|
{
|
|
textColor.g = atoi(value.data());
|
|
}
|
|
else if (name == "B")
|
|
{
|
|
textColor.b = atoi(value.data());
|
|
}
|
|
|
|
attribute = attribute.next_attribute();
|
|
}
|
|
}
|
|
else if (name == "PlaceholderColor")
|
|
{
|
|
attribute = child.first_attribute();
|
|
|
|
while (attribute)
|
|
{
|
|
name = attribute.name();
|
|
std::string_view value = attribute.value();
|
|
|
|
if (name == "A")
|
|
{
|
|
placeholderColor.a = atoi(value.data());
|
|
}
|
|
else if (name == "R")
|
|
{
|
|
placeholderColor.r = atoi(value.data());
|
|
}
|
|
else if (name == "G")
|
|
{
|
|
placeholderColor.g = atoi(value.data());
|
|
}
|
|
else if (name == "B")
|
|
{
|
|
placeholderColor.b = atoi(value.data());
|
|
}
|
|
|
|
attribute = attribute.next_attribute();
|
|
}
|
|
}
|
|
else if (name == "CursorColor")
|
|
{
|
|
attribute = child.first_attribute();
|
|
|
|
while (attribute)
|
|
{
|
|
name = attribute.name();
|
|
std::string_view value = attribute.value();
|
|
|
|
if (name == "A")
|
|
{
|
|
cursorColor.a = atoi(value.data());
|
|
}
|
|
else if (name == "R")
|
|
{
|
|
cursorColor.r = atoi(value.data());
|
|
}
|
|
else if (name == "G")
|
|
{
|
|
cursorColor.g = atoi(value.data());
|
|
}
|
|
else if (name == "B")
|
|
{
|
|
cursorColor.b = atoi(value.data());
|
|
}
|
|
|
|
attribute = attribute.next_attribute();
|
|
}
|
|
}
|
|
|
|
child = child.next_sibling();
|
|
}
|
|
|
|
Color f_textColor(textColor.a, textColor.r, textColor.g, textColor.b);
|
|
Color f_placeholderColor(placeholderColor.a, placeholderColor.r, placeholderColor.g, placeholderColor.b);
|
|
Color f_cursorColor(255, cursorColor.r, cursorColor.g, cursorColor.b);
|
|
auto options = CreateTextFieldExOptions(
|
|
*builder, widgetOptions,
|
|
CreateResourceData(*builder, builder->CreateString(path), builder->CreateString(plistFile), resourceType),
|
|
builder->CreateString(fontName), fontSize, builder->CreateString(text), builder->CreateString(placeHolder),
|
|
passwordEnabled, builder->CreateString(passwordStyleText), maxLength, &f_textColor, &f_placeholderColor,
|
|
&f_cursorColor, isEnabled, isEditable, isLocalized);
|
|
|
|
return *(Offset<Table>*)(&options);
|
|
}
|
|
|
|
void TextFieldExReader::setPropsWithFlatBuffers(ax::Node* node, const flatbuffers::Table* textFieldOptions)
|
|
{
|
|
TextFieldEx** pTextField = (TextFieldEx**)(node);
|
|
auto options = (TextFieldExOptions*)textFieldOptions;
|
|
|
|
std::string placeholder = options->placeholderText()->c_str();
|
|
|
|
std::string text = options->text()->c_str();
|
|
bool isLocalized = options->isLocalized();
|
|
if (isLocalized)
|
|
{
|
|
ILocalizationManager* lm = LocalizationHelper::getCurrentManager();
|
|
std::string localizedTxt = lm->getLocalizationString(text);
|
|
std::string::size_type newlineIndex = localizedTxt.find("\n");
|
|
if (newlineIndex != std::string::npos)
|
|
localizedTxt = localizedTxt.substr(0, newlineIndex);
|
|
text = (localizedTxt);
|
|
}
|
|
|
|
int fontSize = options->fontSize();
|
|
|
|
std::string fontName = options->fontName()->c_str();
|
|
|
|
bool fileExist = false;
|
|
std::string errorFilePath;
|
|
auto resourceDataDic = (options->fontResource());
|
|
std::string path = resourceDataDic->path()->c_str();
|
|
if (path != "")
|
|
{
|
|
if (FileUtils::getInstance()->isFileExist(path))
|
|
{
|
|
fileExist = true;
|
|
}
|
|
else
|
|
{
|
|
errorFilePath = path;
|
|
fileExist = false;
|
|
}
|
|
if (fileExist)
|
|
{
|
|
fontName = (path);
|
|
}
|
|
}
|
|
|
|
// bool maxLengthEnabled = options->maxLengthEnabled() != 0;
|
|
// textField->setMaxLengthEnabled(maxLengthEnabled);
|
|
auto textField = TextFieldEx::create(placeholder, fontName, fontSize);
|
|
|
|
*pTextField = textField;
|
|
|
|
int maxLength = options->maxLength();
|
|
textField->setMaxLength(maxLength);
|
|
bool passwordEnabled = options->passwordEnabled() != 0;
|
|
|
|
textField->setPasswordEnabled(passwordEnabled);
|
|
|
|
/*if (passwordEnabled)
|
|
{
|
|
std::string passwordStyleText = options->passwordStyleText()->c_str();
|
|
textField->setPasswordStyleText(passwordStyleText.c_str());
|
|
}*/
|
|
textField->setString(text);
|
|
|
|
textField->setTextColor(Color4BFromFb(options->textColor()));
|
|
textField->setPlaceholderColor(Color4BFromFb(options->placeholderColor()));
|
|
textField->setCursorColor(Color3BFromFb(options->cursorColor()));
|
|
|
|
auto widgetReader = NodeReader::getInstance();
|
|
widgetReader->setPropsWithFlatBuffers(textField, (Table*)options->nodeOptions());
|
|
|
|
// textField->setUnifySizeEnabled(false);
|
|
// textField->ignoreContentAdaptWithSize(false);
|
|
|
|
auto widgetOptions = options->nodeOptions();
|
|
|
|
Size contentSize(widgetOptions->size()->width(), widgetOptions->size()->height());
|
|
textField->setContentSize(contentSize);
|
|
|
|
textField->setEnabled(options->enabled());
|
|
textField->setEditable(options->editable());
|
|
|
|
textField->enableIME(nullptr);
|
|
/*if (!textField->isIgnoreContentAdaptWithSize())
|
|
{
|
|
((Label*)(textField->getVirtualRenderer()))->setLineBreakWithoutSpace(true);
|
|
}*/
|
|
}
|
|
|
|
Node* TextFieldExReader::createNodeWithFlatBuffers(const flatbuffers::Table* textFieldOptions)
|
|
{
|
|
TextFieldEx* textField = nullptr; // TextFieldEx::create("dummy", "Courier New", 18);
|
|
|
|
setPropsWithFlatBuffers((Node*)&textField, (Table*)textFieldOptions);
|
|
|
|
return textField;
|
|
}
|
|
|
|
} // namespace cocostudio
|