diff options
author | crupest <crupest@outlook.com> | 2022-02-24 15:56:01 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2022-02-24 15:56:01 +0800 |
commit | 640401bf2f4b3da3708970a1408b27e159f93631 (patch) | |
tree | c9692f9c6e8a3efdadabc5929029837450efd6af /src/ui/mapper | |
parent | d9a3b8c14b9ab1bc591ca7c373daaf7141d2d098 (diff) | |
download | cru-640401bf2f4b3da3708970a1408b27e159f93631.tar.gz cru-640401bf2f4b3da3708970a1408b27e159f93631.tar.bz2 cru-640401bf2f4b3da3708970a1408b27e159f93631.zip |
...
Diffstat (limited to 'src/ui/mapper')
-rw-r--r-- | src/ui/mapper/MapperRegistry.cpp | 2 | ||||
-rw-r--r-- | src/ui/mapper/MeasureLengthMapper.cpp | 29 | ||||
-rw-r--r-- | src/ui/mapper/style/PreferredSizeStylerMapper.cpp | 9 |
3 files changed, 38 insertions, 2 deletions
diff --git a/src/ui/mapper/MapperRegistry.cpp b/src/ui/mapper/MapperRegistry.cpp index b70418ef..9ae95a59 100644 --- a/src/ui/mapper/MapperRegistry.cpp +++ b/src/ui/mapper/MapperRegistry.cpp @@ -5,6 +5,7 @@ #include "cru/ui/mapper/CornerRadiusMapper.h" #include "cru/ui/mapper/CursorMapper.h" #include "cru/ui/mapper/FontMapper.h" +#include "cru/ui/mapper/MeasureLengthMapper.h" #include "cru/ui/mapper/PointMapper.h" #include "cru/ui/mapper/SizeMapper.h" #include "cru/ui/mapper/ThicknessMapper.h" @@ -33,6 +34,7 @@ MapperRegistry::MapperRegistry() { RegisterMapper(new BrushMapper()); RegisterMapper(new CornerRadiusMapper()); RegisterMapper(new FontMapper()); + RegisterMapper(new MeasureLengthMapper()); RegisterMapper(new PointMapper()); RegisterMapper(new SizeMapper()); RegisterMapper(new ThicknessMapper()); diff --git a/src/ui/mapper/MeasureLengthMapper.cpp b/src/ui/mapper/MeasureLengthMapper.cpp new file mode 100644 index 00000000..6a0f95e3 --- /dev/null +++ b/src/ui/mapper/MeasureLengthMapper.cpp @@ -0,0 +1,29 @@ +#include "cru/ui/mapper/MeasureLengthMapper.h" +#include "cru/ui/render/MeasureRequirement.h" + +namespace cru::ui::mapper { +bool MeasureLengthMapper::XmlElementIsOfThisType(xml::XmlElementNode* node) { + return node->GetTag().CaseInsensitiveEqual(u"MeasureLength"); +} + +render::MeasureLength MeasureLengthMapper::DoMapFromString(String str) { + if (str.CaseInsensitiveEqual(u"notspecified")) { + return render::MeasureLength::NotSpecified(); + } + if (str.CaseInsensitiveEqual(u"unspecified")) { + return render::MeasureLength::NotSpecified(); + } + auto value = str.ParseToFloat(); + if (value < 0) { + return render::MeasureLength::NotSpecified(); + } + return render::MeasureLength(value); +} + +render::MeasureLength MeasureLengthMapper::DoMapFromXml( + xml::XmlElementNode* node) { + auto value_attr = node->GetOptionalAttributeCaseInsensitive(u"value"); + if (!value_attr) return {}; + return DoMapFromString(*value_attr); +} +} // namespace cru::ui::mapper diff --git a/src/ui/mapper/style/PreferredSizeStylerMapper.cpp b/src/ui/mapper/style/PreferredSizeStylerMapper.cpp index b4382c19..9e03dfeb 100644 --- a/src/ui/mapper/style/PreferredSizeStylerMapper.cpp +++ b/src/ui/mapper/style/PreferredSizeStylerMapper.cpp @@ -1,4 +1,5 @@ #include "cru/ui/mapper/style/PreferredSizeStylerMapper.h" +#include "cru/ui/mapper/MapperRegistry.h" #include "cru/ui/render/MeasureRequirement.h" #include "cru/ui/style/Styler.h" @@ -11,14 +12,18 @@ bool PreferredSizeStylerMapper::XmlElementIsOfThisType( ClonablePtr<ui::style::PreferredSizeStyler> PreferredSizeStylerMapper::DoMapFromXml(xml::XmlElementNode* node) { render::MeasureSize size; + + auto measure_length_mapper = + MapperRegistry::GetInstance()->GetMapper<render::MeasureLength>(); + auto width_attribute = node->GetOptionalAttributeCaseInsensitive(u"width"); if (width_attribute) { - size.width = width_attribute->ParseToFloat(); + size.width = measure_length_mapper->MapFromString(*width_attribute); } auto height_attribute = node->GetOptionalAttributeCaseInsensitive(u"height"); if (height_attribute) { - size.height = height_attribute->ParseToFloat(); + size.height = measure_length_mapper->MapFromString(*height_attribute); } return ui::style::PreferredSizeStyler::Create(size); |