diff options
Diffstat (limited to 'src/ui/mapper/style/ContentBrushStylerMapper.cpp')
-rw-r--r-- | src/ui/mapper/style/ContentBrushStylerMapper.cpp | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/src/ui/mapper/style/ContentBrushStylerMapper.cpp b/src/ui/mapper/style/ContentBrushStylerMapper.cpp new file mode 100644 index 00000000..e83f4988 --- /dev/null +++ b/src/ui/mapper/style/ContentBrushStylerMapper.cpp @@ -0,0 +1,30 @@ +#include "cru/ui/mapper/style/ContentBrushStylerMapper.h" +#include "cru/common/ClonablePtr.h" +#include "cru/platform/graphics/Brush.h" +#include "cru/ui/mapper/MapperRegistry.h" +#include "cru/ui/style/Styler.h" +#include "cru/xml/XmlNode.h" + +namespace cru::ui::mapper::style { +ContentBrushStylerMapper::ContentBrushStylerMapper() { + SetAllowedTags({u"ContentBrushStyler"}); +} + +ContentBrushStylerMapper::~ContentBrushStylerMapper() {} + +ClonablePtr<ui::style::ContentBrushStyler> +ContentBrushStylerMapper::DoMapFromXml(xml::XmlElementNode* node) { + auto brush_mapper = MapperRegistry::GetInstance() + ->GetSharedPtrMapper<platform::graphics::IBrush>(); + + std::shared_ptr<platform::graphics::IBrush> brush; + + for (auto child_node : node->GetChildren()) { + if (child_node->IsElementNode()) { + brush = brush_mapper->MapFromXml(child_node->AsElement()); + } + } + + return ui::style::ContentBrushStyler::Create(std::move(brush)); +} +} // namespace cru::ui::mapper::style |