axmol/extensions/cocostudio/WidgetReader/ListViewReader/ListViewReader.cpp

586 lines
18 KiB
C++

#include "WidgetReader/ListViewReader/ListViewReader.h"
#include "ui/UIListView.h"
#include "platform/CCFileUtils.h"
#include "2d/CCSpriteFrameCache.h"
#include "CocoLoader.h"
#include "CSParseBinary_generated.h"
#include "FlatBuffersSerialize.h"
#include "flatbuffers/flatbuffers.h"
USING_NS_AX;
using namespace ui;
using namespace flatbuffers;
namespace cocostudio
{
static const char* P_Direction = "direction";
static const char* P_ItemMargin = "itemMargin";
static ListViewReader* instanceListViewReader = nullptr;
IMPLEMENT_CLASS_NODE_READER_INFO(ListViewReader)
ListViewReader::ListViewReader() {}
ListViewReader::~ListViewReader() {}
ListViewReader* ListViewReader::getInstance()
{
if (!instanceListViewReader)
{
instanceListViewReader = new ListViewReader();
}
return instanceListViewReader;
}
void ListViewReader::destroyInstance()
{
AX_SAFE_DELETE(instanceListViewReader);
}
void ListViewReader::setPropsFromBinary(axis::ui::Widget* widget, CocoLoader* cocoLoader, stExpCocoNode* cocoNode)
{
ScrollViewReader::setPropsFromBinary(widget, cocoLoader, cocoNode);
ListView* listView = static_cast<ListView*>(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);
if (key == P_Direction)
{
listView->setDirection((ScrollView::Direction)valueToInt(value));
}
else if (key == P_Gravity)
{
listView->setGravity((ListView::Gravity)valueToInt(value));
}
else if (key == P_ItemMargin)
{
listView->setItemsMargin(valueToFloat(value));
}
} // end of for loop
}
void ListViewReader::setPropsFromJsonDictionary(Widget* widget, const rapidjson::Value& options)
{
ScrollViewReader::setPropsFromJsonDictionary(widget, options);
ListView* listView = static_cast<ListView*>(widget);
int direction = DICTOOL->getFloatValue_json(options, P_Direction, 2);
listView->setDirection((ScrollView::Direction)direction);
ListView::Gravity gravity = (ListView::Gravity)DICTOOL->getIntValue_json(options, P_Gravity, 3);
listView->setGravity(gravity);
float itemMargin = DICTOOL->getFloatValue_json(options, P_ItemMargin);
listView->setItemsMargin(itemMargin);
}
Offset<Table> ListViewReader::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;
bool clipEnabled = false;
Color3B bgColor;
Color3B bgStartColor;
Color3B bgEndColor;
int colorType = 0;
uint8_t bgColorOpacity = 255;
Vec2 colorVector(0.0f, -0.5f);
Rect capInsets;
Size scale9Size;
bool backGroundScale9Enabled = false;
Size innerSize(200, 300);
int direction = 0;
bool bounceEnabled = false;
int itemMargin = 0;
std::string directionType;
std::string horizontalType;
std::string verticalType;
// attributes
auto attribute = objectData.first_attribute();
while (attribute)
{
std::string_view name = attribute.name();
std::string_view value = attribute.value();
if (name == "ClipAble")
{
clipEnabled = (value == "True") ? true : false;
}
else if (name == "ComboBoxIndex")
{
colorType = atoi(value.data());
}
else if (name == "BackColorAlpha")
{
bgColorOpacity = atoi(value.data());
}
else if (name == "Scale9Enable")
{
if (value == "True")
{
backGroundScale9Enabled = true;
}
}
else if (name == "Scale9OriginX")
{
capInsets.origin.x = atof(value.data());
}
else if (name == "Scale9OriginY")
{
capInsets.origin.y = atof(value.data());
}
else if (name == "Scale9Width")
{
capInsets.size.width = atof(value.data());
}
else if (name == "Scale9Height")
{
capInsets.size.height = atof(value.data());
}
else if (name == "DirectionType")
{
directionType = value;
}
else if (name == "HorizontalType")
{
horizontalType = value;
}
else if (name == "VerticalType")
{
verticalType = value;
}
else if (name == "IsBounceEnabled")
{
bounceEnabled = (value == "True") ? true : false;
}
else if (name == "ItemMargin")
{
itemMargin = atoi(value.data());
}
attribute = attribute.next_attribute();
}
// child elements
auto child = objectData.first_child();
while (child)
{
std::string_view name = child.name();
if (name == "InnerNodeSize")
{
auto attributeInnerNodeSize = child.first_attribute();
while (attributeInnerNodeSize)
{
name = attributeInnerNodeSize.name();
auto value = attributeInnerNodeSize.value();
if (name == "Width")
{
innerSize.width = atof(value.data());
}
else if (name == "Height")
{
innerSize.height = atof(value.data());
}
attributeInnerNodeSize = attributeInnerNodeSize.next_attribute();
}
}
else if (name == "Size" && backGroundScale9Enabled)
{
auto attributeSize = child.first_attribute();
while (attributeSize)
{
name = attributeSize.name();
auto value = attributeSize.value();
if (name == "X")
{
scale9Size.width = atof(value.data());
}
else if (name == "Y")
{
scale9Size.height = atof(value.data());
}
attributeSize = attributeSize.next_attribute();
}
}
else if (name == "SingleColor")
{
auto attributeSingleColor = child.first_attribute();
while (attributeSingleColor)
{
name = attributeSingleColor.name();
auto value = attributeSingleColor.value();
if (name == "R")
{
bgColor.r = atoi(value.data());
}
else if (name == "G")
{
bgColor.g = atoi(value.data());
}
else if (name == "B")
{
bgColor.b = atoi(value.data());
}
attributeSingleColor = attributeSingleColor.next_attribute();
}
}
else if (name == "EndColor")
{
auto attributeEndColor = child.first_attribute();
while (attributeEndColor)
{
name = attributeEndColor.name();
auto value = attributeEndColor.value();
if (name == "R")
{
bgEndColor.r = atoi(value.data());
}
else if (name == "G")
{
bgEndColor.g = atoi(value.data());
}
else if (name == "B")
{
bgEndColor.b = atoi(value.data());
}
attributeEndColor = attributeEndColor.next_attribute();
}
}
else if (name == "FirstColor")
{
auto attributeFirstColor = child.first_attribute();
while (attributeFirstColor)
{
name = attributeFirstColor.name();
auto value = attributeFirstColor.value();
if (name == "R")
{
bgStartColor.r = atoi(value.data());
}
else if (name == "G")
{
bgStartColor.g = atoi(value.data());
}
else if (name == "B")
{
bgStartColor.b = atoi(value.data());
}
attributeFirstColor = attributeFirstColor.next_attribute();
}
}
else if (name == "ColorVector")
{
auto attributeColorVector = child.first_attribute();
while (attributeColorVector)
{
name = attributeColorVector.name();
auto value = attributeColorVector.value();
if (name == "ScaleX")
{
colorVector.x = atof(value.data());
}
else if (name == "ScaleY")
{
colorVector.y = atof(value.data());
}
attributeColorVector = attributeColorVector.next_attribute();
}
}
else if (name == "FileData")
{
std::string texture;
std::string texturePng;
auto attributeFileData = child.first_attribute();
while (attributeFileData)
{
name = attributeFileData.name();
auto value = attributeFileData.value();
if (name == "Path")
{
path = value;
}
else if (name == "Type")
{
resourceType = getResourceType(value);
}
else if (name == "Plist")
{
plistFile = value;
texture = value;
}
attributeFileData = attributeFileData.next_attribute();
}
if (resourceType == 1)
{
FlatBuffersSerialize* fbs = FlatBuffersSerialize::getInstance();
fbs->_textures.push_back(builder->CreateString(texture));
}
}
child = child.next_sibling();
}
Color f_bgColor(255, bgColor.r, bgColor.g, bgColor.b);
Color f_bgStartColor(255, bgStartColor.r, bgStartColor.g, bgStartColor.b);
Color f_bgEndColor(255, bgEndColor.r, bgEndColor.g, bgEndColor.b);
ColorVector f_colorVector(colorVector.x, colorVector.y);
CapInsets f_capInsets(capInsets.origin.x, capInsets.origin.y, capInsets.size.width, capInsets.size.height);
FlatSize f_scale9Size(scale9Size.width, scale9Size.height);
FlatSize f_innerSize(innerSize.width, innerSize.height);
auto options = CreateListViewOptions(
*builder, widgetOptions,
CreateResourceData(*builder, builder->CreateString(path), builder->CreateString(plistFile), resourceType),
clipEnabled, &f_bgColor, &f_bgStartColor, &f_bgEndColor, colorType, bgColorOpacity, &f_colorVector,
&f_capInsets, &f_scale9Size, backGroundScale9Enabled, &f_innerSize, direction, bounceEnabled, itemMargin,
builder->CreateString(directionType), builder->CreateString(horizontalType),
builder->CreateString(verticalType));
return *(Offset<Table>*)(&options);
}
void ListViewReader::setPropsWithFlatBuffers(axis::Node* node, const flatbuffers::Table* listViewOptions)
{
ListView* listView = static_cast<ListView*>(node);
auto options = (ListViewOptions*)listViewOptions;
bool clipEnabled = options->clipEnabled() != 0;
listView->setClippingEnabled(clipEnabled);
bool backGroundScale9Enabled = options->backGroundScale9Enabled() != 0;
listView->setBackGroundImageScale9Enabled(backGroundScale9Enabled);
auto f_bgColor = options->bgColor();
Color3B bgColor(f_bgColor->r(), f_bgColor->g(), f_bgColor->b());
auto f_bgStartColor = options->bgStartColor();
Color3B bgStartColor(f_bgStartColor->r(), f_bgStartColor->g(), f_bgStartColor->b());
auto f_bgEndColor = options->bgEndColor();
Color3B bgEndColor(f_bgEndColor->r(), f_bgEndColor->g(), f_bgEndColor->b());
auto f_colorVecor = options->colorVector();
Vec2 colorVector(f_colorVecor->vectorX(), f_colorVecor->vectorY());
listView->setBackGroundColorVector(colorVector);
int bgColorOpacity = options->bgColorOpacity();
int colorType = options->colorType();
listView->setBackGroundColorType(Layout::BackGroundColorType(colorType));
listView->setBackGroundColor(bgStartColor, bgEndColor);
listView->setBackGroundColor(bgColor);
listView->setBackGroundColorOpacity(bgColorOpacity);
bool fileExist = false;
std::string errorFilePath;
auto imageFileNameDic = (options->backGroundImageData());
int imageFileNameType = imageFileNameDic->resourceType();
std::string imageFileName = imageFileNameDic->path()->c_str();
if (imageFileName != "")
{
switch (imageFileNameType)
{
case 0:
{
if (FileUtils::getInstance()->isFileExist(imageFileName))
{
fileExist = true;
}
else
{
errorFilePath = imageFileName;
fileExist = false;
}
break;
}
case 1:
{
std::string plist = imageFileNameDic->plistFile()->c_str();
SpriteFrame* spriteFrame = SpriteFrameCache::getInstance()->getSpriteFrameByName(imageFileName);
if (spriteFrame)
{
fileExist = true;
}
else
{
if (FileUtils::getInstance()->isFileExist(plist))
{
ValueMap value = FileUtils::getInstance()->getValueMapFromFile(plist);
ValueMap metadata = value["metadata"].asValueMap();
std::string textureFileName = metadata["textureFileName"].asString();
if (!FileUtils::getInstance()->isFileExist(textureFileName))
{
errorFilePath = textureFileName;
}
}
else
{
errorFilePath = plist;
}
fileExist = false;
}
break;
}
default:
break;
}
if (fileExist)
{
listView->setBackGroundImage(imageFileName, (Widget::TextureResType)imageFileNameType);
}
}
auto widgetOptions = options->widgetOptions();
auto f_color = widgetOptions->color();
Color3B color(f_color->r(), f_color->g(), f_color->b());
listView->setColor(color);
int opacity = widgetOptions->alpha();
listView->setOpacity(opacity);
// auto f_innerSize = options->innerSize();
// Size innerSize(f_innerSize->width(), f_innerSize->height());
// listView->setInnerContainerSize(innerSize);
// int direction = options->direction();
// listView->setDirection((ScrollView::Direction)direction);
bool bounceEnabled = options->bounceEnabled() != 0;
listView->setBounceEnabled(bounceEnabled);
// int gravityValue = options->gravity();
// ListView::Gravity gravity = (ListView::Gravity)gravityValue;
// listView->setGravity(gravity);
std::string directionType = options->directionType()->c_str();
if (directionType == "")
{
listView->setDirection(ListView::Direction::HORIZONTAL);
std::string verticalType = options->verticalType()->c_str();
if (verticalType == "")
{
listView->setGravity(ListView::Gravity::TOP);
}
else if (verticalType == "Align_Bottom")
{
listView->setGravity(ListView::Gravity::BOTTOM);
}
else if (verticalType == "Align_VerticalCenter")
{
listView->setGravity(ListView::Gravity::CENTER_VERTICAL);
}
}
else if (directionType == "Vertical")
{
listView->setDirection(ListView::Direction::VERTICAL);
std::string horizontalType = options->horizontalType()->c_str();
if (horizontalType == "")
{
listView->setGravity(ListView::Gravity::LEFT);
}
else if (horizontalType == "Align_Right")
{
listView->setGravity(ListView::Gravity::RIGHT);
}
else if (horizontalType == "Align_HorizontalCenter")
{
listView->setGravity(ListView::Gravity::CENTER_HORIZONTAL);
}
}
float itemMargin = options->itemMargin();
listView->setItemsMargin(itemMargin);
auto widgetReader = WidgetReader::getInstance();
widgetReader->setPropsWithFlatBuffers(node, (Table*)options->widgetOptions());
if (backGroundScale9Enabled)
{
auto f_capInsets = options->capInsets();
Rect capInsets(f_capInsets->x(), f_capInsets->y(), f_capInsets->width(), f_capInsets->height());
listView->setBackGroundImageCapInsets(capInsets);
auto f_scale9Size = options->scale9Size();
Size scale9Size(f_scale9Size->width(), f_scale9Size->height());
listView->setContentSize(scale9Size);
}
else
{
if (!listView->isIgnoreContentAdaptWithSize())
{
Size contentSize(widgetOptions->size()->width(), widgetOptions->size()->height());
listView->setContentSize(contentSize);
}
}
}
Node* ListViewReader::createNodeWithFlatBuffers(const flatbuffers::Table* listViewOptions)
{
ListView* listView = ListView::create();
setPropsWithFlatBuffers(listView, (Table*)listViewOptions);
return listView;
}
int ListViewReader::getResourceType(std::string_view key)
{
if (key == "Normal" || key == "Default")
{
return 0;
}
FlatBuffersSerialize* fbs = FlatBuffersSerialize::getInstance();
if (fbs->_isSimulator)
{
if (key == "MarkedSubImage")
{
return 0;
}
}
return 1;
}
} // namespace cocostudio