From 56633dab8c1bf9d25a6367a651b5b054055a2130 Mon Sep 17 00:00:00 2001 From: crupest Date: Thu, 27 Jan 2022 20:07:15 +0800 Subject: ... --- src/ui/mapper/BrushMapper.cpp | 40 ++++++++++++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 src/ui/mapper/BrushMapper.cpp (limited to 'src/ui/mapper/BrushMapper.cpp') diff --git a/src/ui/mapper/BrushMapper.cpp b/src/ui/mapper/BrushMapper.cpp new file mode 100644 index 00000000..bfaef507 --- /dev/null +++ b/src/ui/mapper/BrushMapper.cpp @@ -0,0 +1,40 @@ +#include "cru/ui/mapper/BrushMapper.hpp" +#include "../Helper.hpp" +#include "cru/platform/Color.hpp" +#include "cru/platform/graphics/Brush.hpp" +#include "cru/platform/graphics/Factory.hpp" +#include "cru/ui/mapper/ColorMapper.hpp" +#include "cru/ui/mapper/MapperRegistry.hpp" +#include "cru/xml/XmlNode.hpp" + +#include + +namespace cru::ui::mapper { +bool BrushMapper::XmlElementIsOfThisType(xml::XmlElementNode* node) { + auto color_mapper = MapperRegistry::GetInstance()->GetMapper(); + return color_mapper->XmlElementIsOfThisType(node) || + node->GetTag().CaseInsensitiveEqual(u"Brush"); +} + +std::shared_ptr BrushMapper::DoMapFromXml( + xml::XmlElementNode* node) { + auto color_mapper = MapperRegistry::GetInstance()->GetMapper(); + + Color color = colors::transparent; + + if (color_mapper->XmlElementIsOfThisType(node)) { + color = color_mapper->MapFromXml(node); + } else { + for (auto child : node->GetChildren()) { + if (child->IsElementNode()) { + auto c = child->AsElement(); + if (color_mapper->XmlElementIsOfThisType(node)) { + color = color_mapper->MapFromXml(node); + } + } + } + } + + return GetGraphicsFactory()->CreateSolidColorBrush(color); +} +} // namespace cru::ui::mapper -- cgit v1.2.3