diff options
author | crupest <crupest@outlook.com> | 2022-01-24 18:21:39 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2022-01-24 18:21:39 +0800 |
commit | 7a95d9af36221f36402495513c3563c5dc2163ad (patch) | |
tree | 03ab7b98ec65cf46c3af1f18dfbdb89df16e4284 | |
parent | ffaf8978508ac5ca6457906c26b9db18728d4eba (diff) | |
download | cru-7a95d9af36221f36402495513c3563c5dc2163ad.tar.gz cru-7a95d9af36221f36402495513c3563c5dc2163ad.tar.bz2 cru-7a95d9af36221f36402495513c3563c5dc2163ad.zip |
...
-rw-r--r-- | include/cru/ui/mapper/style/ClickStateConditionMapper.hpp | 26 | ||||
-rw-r--r-- | src/ui/CMakeLists.txt | 3 | ||||
-rw-r--r-- | src/ui/mapper/style/ClickStateConditionMapper.cpp | 33 |
3 files changed, 62 insertions, 0 deletions
diff --git a/include/cru/ui/mapper/style/ClickStateConditionMapper.hpp b/include/cru/ui/mapper/style/ClickStateConditionMapper.hpp new file mode 100644 index 00000000..f60a27a1 --- /dev/null +++ b/include/cru/ui/mapper/style/ClickStateConditionMapper.hpp @@ -0,0 +1,26 @@ +#pragma once +#include "../Mapper.hpp" +#include "IConditionMapper.hpp" +#include "cru/ui/style/Condition.hpp" + +namespace cru::ui::mapper::style { +class ClickStateConditionMapper + : public BasicPtrMapper<ui::style::ClickStateCondition>, + public IConditionMapper { + public: + CRU_DEFAULT_CONSTRUCTOR_DESTRUCTOR(ClickStateConditionMapper) + + public: + bool SupportMapFromXml() override { return true; } + bool XmlElementIsOfThisType(xml::XmlElementNode* node) override; + + ClonablePtr<ui::style::Condition> MapConditionFromXml( + xml::XmlElementNode* node) override { + return MapFromXml(node); + } + + public: + ClonablePtr<ui::style::ClickStateCondition> DoMapFromXml( + xml::XmlElementNode* node) override; +}; +} // namespace cru::ui::mapper::style diff --git a/src/ui/CMakeLists.txt b/src/ui/CMakeLists.txt index da4754f6..fc2ef76b 100644 --- a/src/ui/CMakeLists.txt +++ b/src/ui/CMakeLists.txt @@ -35,10 +35,13 @@ add_library(cru_ui SHARED mapper/PointMapper.cpp mapper/SizeMapper.cpp mapper/ThicknessMapper.cpp + mapper/style/AndConditionMapper.cpp mapper/style/BorderStylerMapper.cpp + mapper/style/ClickStateConditionMapper.cpp mapper/style/CursorStylerMapper.cpp mapper/style/FocusConditionMapper.cpp mapper/style/NoConditionMapper.cpp + mapper/style/OrConditionMapper.cpp render/BorderRenderObject.cpp render/CanvasRenderObject.cpp render/FlexLayoutRenderObject.cpp diff --git a/src/ui/mapper/style/ClickStateConditionMapper.cpp b/src/ui/mapper/style/ClickStateConditionMapper.cpp new file mode 100644 index 00000000..8e162a86 --- /dev/null +++ b/src/ui/mapper/style/ClickStateConditionMapper.cpp @@ -0,0 +1,33 @@ +#include "cru/ui/mapper/style/ClickStateConditionMapper.hpp" +#include "cru/common/ClonablePtr.hpp" +#include "cru/common/Exception.hpp" +#include "cru/ui/helper/ClickDetector.hpp" +#include "cru/ui/style/Condition.hpp" + +namespace cru::ui::mapper::style { +bool ClickStateConditionMapper::XmlElementIsOfThisType( + xml::XmlElementNode *node) { + return node->GetTag().CaseInsensitiveEqual(u"ClickStateCondition"); +} + +ClonablePtr<ui::style::ClickStateCondition> +ClickStateConditionMapper::DoMapFromXml(xml::XmlElementNode *node) { + auto state = helper::ClickState::None; + auto value_attr = node->GetOptionalAttributeCaseInsensitive(u"value"); + if (value_attr) { + if (value_attr->CaseInsensitiveEqual(u"none")) { + state = helper::ClickState::None; + } else if (value_attr->CaseInsensitiveEqual(u"hover")) { + state = helper::ClickState::Hover; + } else if (value_attr->CaseInsensitiveEqual(u"press")) { + state = helper::ClickState::Press; + } else if (value_attr->CaseInsensitiveEqual(u"pressinactive")) { + state = helper::ClickState::PressInactive; + } else { + throw Exception(u"Unknown click state: " + *value_attr); + } + } + + return ui::style::ClickStateCondition::Create(state); +} +} // namespace cru::ui::mapper::style |