#include "WidgetReader/ListViewReader/ListViewReader.h" #include "ui/UIListView.h" #include "platform/FileUtils.h" #include "2d/SpriteFrameCache.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(ax::ui::Widget* widget, CocoLoader* cocoLoader, stExpCocoNode* cocoNode) { ScrollViewReader::setPropsFromBinary(widget, cocoLoader, cocoNode); ListView* listView = static_cast(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(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 ListViewReader::createOptionsWithFlatBuffers(pugi::xml_node objectData, flatbuffers::FlatBufferBuilder* builder) { auto temp = WidgetReader::getInstance()->createOptionsWithFlatBuffers(objectData, builder); auto widgetOptions = *(Offset*)(&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.emplace_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
*)(&options); } void ListViewReader::setPropsWithFlatBuffers(ax::Node* node, const flatbuffers::Table* listViewOptions) { ListView* listView = static_cast(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()->findFrame(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