mirror of https://github.com/axmolengine/axmol.git
Add listview and pageview reader
This commit is contained in:
parent
f0eb5d28c1
commit
ad535e2fcb
|
@ -619,7 +619,7 @@ void WidgetPropertiesReader0250::setPropsForLabelAtlasFromJsonDictionary(Widget*
|
||||||
const char* cmft = dicHelper->getStringValue_json(options, "charMapFile");
|
const char* cmft = dicHelper->getStringValue_json(options, "charMapFile");
|
||||||
cmf_tp = tp_c.append(cmft).c_str();
|
cmf_tp = tp_c.append(cmft).c_str();
|
||||||
|
|
||||||
labelAtlas->setProperty(dicHelper->getStringValue_json(options, "stringValue"),cmf_tp,dicHelper->getIntValue_json(options, "itemWidth"),dicHelper->getIntValue_json(options,"itemHeight"),dicHelper->getStringValue_json(options, "startCharMap"));
|
labelAtlas->setProperty(dicHelper->getStringValue_json(options, "stringValue"),cmf_tp,dicHelper->getIntValue_json(options, "itemWidth") / CC_CONTENT_SCALE_FACTOR() ,dicHelper->getIntValue_json(options,"itemHeight") / CC_CONTENT_SCALE_FACTOR(), dicHelper->getStringValue_json(options, "startCharMap"));
|
||||||
}
|
}
|
||||||
setColorPropsForWidgetFromJsonDictionary(widget,options);
|
setColorPropsForWidgetFromJsonDictionary(widget,options);
|
||||||
}
|
}
|
||||||
|
@ -1024,9 +1024,20 @@ Widget* WidgetPropertiesReader0300::widgetFromJsonDictionary(JsonDictionary *dat
|
||||||
JsonDictionary* subData = dicHelper->getDictionaryFromArray_json(data, "children", i);
|
JsonDictionary* subData = dicHelper->getDictionaryFromArray_json(data, "children", i);
|
||||||
Widget* child = widgetFromJsonDictionary(subData);
|
Widget* child = widgetFromJsonDictionary(subData);
|
||||||
if (child)
|
if (child)
|
||||||
|
{
|
||||||
|
if (dynamic_cast<PageView*>(widget))
|
||||||
|
{
|
||||||
|
dynamic_cast<PageView*>(widget)->addPage(static_cast<Layout*>(child));
|
||||||
|
}
|
||||||
|
else if (dynamic_cast<ListView*>(widget))
|
||||||
|
{
|
||||||
|
dynamic_cast<ListView*>(widget)->pushBackCustomItem(child);
|
||||||
|
}
|
||||||
|
else
|
||||||
{
|
{
|
||||||
widget->addChild(child);
|
widget->addChild(child);
|
||||||
}
|
}
|
||||||
|
}
|
||||||
CC_SAFE_DELETE(subData);
|
CC_SAFE_DELETE(subData);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -1525,7 +1536,7 @@ void WidgetPropertiesReader0300::setPropsForLabelAtlasFromJsonDictionary(Widget*
|
||||||
std::string tp_c = m_strFilePath;
|
std::string tp_c = m_strFilePath;
|
||||||
const char* cmfPath = dicHelper->getStringValue_json(cmftDic, "path");
|
const char* cmfPath = dicHelper->getStringValue_json(cmftDic, "path");
|
||||||
const char* cmf_tp = tp_c.append(cmfPath).c_str();
|
const char* cmf_tp = tp_c.append(cmfPath).c_str();
|
||||||
labelAtlas->setProperty(dicHelper->getStringValue_json(options, "stringValue"),cmf_tp,dicHelper->getIntValue_json(options, "itemWidth"),dicHelper->getIntValue_json(options,"itemHeight"),dicHelper->getStringValue_json(options, "startCharMap"));
|
labelAtlas->setProperty(dicHelper->getStringValue_json(options, "stringValue"),cmf_tp,dicHelper->getIntValue_json(options, "itemWidth") / CC_CONTENT_SCALE_FACTOR(),dicHelper->getIntValue_json(options,"itemHeight") / CC_CONTENT_SCALE_FACTOR(), dicHelper->getStringValue_json(options, "startCharMap"));
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case 1:
|
case 1:
|
||||||
|
@ -1931,11 +1942,26 @@ void WidgetPropertiesReader0300::setPropsForLabelBMFontFromJsonDictionary(Widget
|
||||||
|
|
||||||
void WidgetPropertiesReader0300::setPropsForPageViewFromJsonDictionary(Widget*widget,JsonDictionary* options)
|
void WidgetPropertiesReader0300::setPropsForPageViewFromJsonDictionary(Widget*widget,JsonDictionary* options)
|
||||||
{
|
{
|
||||||
|
setPropsForLayoutFromJsonDictionary(widget, options);
|
||||||
}
|
}
|
||||||
|
|
||||||
void WidgetPropertiesReader0300::setPropsForListViewFromJsonDictionary(Widget* widget, JsonDictionary* options)
|
void WidgetPropertiesReader0300::setPropsForListViewFromJsonDictionary(Widget* widget, JsonDictionary* options)
|
||||||
{
|
{
|
||||||
|
setPropsForLayoutFromJsonDictionary(widget, options);
|
||||||
|
|
||||||
|
ListView* listView = (ListView*)widget;
|
||||||
|
|
||||||
|
float innerWidth = DICTOOL->getFloatValue_json(options, "innerWidth");
|
||||||
|
float innerHeight = DICTOOL->getFloatValue_json(options, "innerHeight");
|
||||||
|
listView->setInnerContainerSize(Size(innerWidth, innerHeight));
|
||||||
|
int direction = DICTOOL->getFloatValue_json(options, "direction");
|
||||||
|
listView->setDirection((SCROLLVIEW_DIR)direction);
|
||||||
|
|
||||||
|
ListViewGravity gravity = (ListViewGravity)DICTOOL->getIntValue_json(options, "gravity");
|
||||||
|
listView->setGravity(gravity);
|
||||||
|
|
||||||
|
float itemMargin = DICTOOL->getFloatValue_json(options, "itemMargin");
|
||||||
|
listView->setItemsMargin(itemMargin);
|
||||||
|
}
|
||||||
|
|
||||||
}
|
}
|
||||||
}
|
|
Loading…
Reference in New Issue