diff options
author | crupest <crupest@outlook.com> | 2018-09-25 13:37:33 +0800 |
---|---|---|
committer | crupest <crupest@outlook.com> | 2018-09-25 13:37:33 +0800 |
commit | ccbc293c0158d4450c0db344474193f17925403f (patch) | |
tree | 1ecde3132b3299ab2f272f541a76bced67f983b1 /src/ui/controls/margin_container.h | |
parent | 184c3b2b39d3fa34f9349a7d7fbebe49bc62f7fc (diff) | |
parent | ea4b0966d8eb5a8e76dfbe4d833a07a4797a3284 (diff) | |
download | cru-ccbc293c0158d4450c0db344474193f17925403f.tar.gz cru-ccbc293c0158d4450c0db344474193f17925403f.tar.bz2 cru-ccbc293c0158d4450c0db344474193f17925403f.zip |
Merge branch 'master' into issue4-dev
Diffstat (limited to 'src/ui/controls/margin_container.h')
-rw-r--r-- | src/ui/controls/margin_container.h | 44 |
1 files changed, 44 insertions, 0 deletions
diff --git a/src/ui/controls/margin_container.h b/src/ui/controls/margin_container.h new file mode 100644 index 00000000..0eafc40e --- /dev/null +++ b/src/ui/controls/margin_container.h @@ -0,0 +1,44 @@ +#pragma once + +#include <initializer_list> + +#include "ui/control.h" + +namespace cru::ui::controls +{ + class MarginContainer : public Control + { + public: + static MarginContainer* Create(const Thickness& margin = Thickness::Zero(), const std::initializer_list<Control*>& children = std::initializer_list<Control*>()) + { + const auto margin_container = new MarginContainer(margin); + for (const auto control : children) + margin_container->AddChild(control); + return margin_container; + } + + protected: + explicit MarginContainer(const Thickness& margin); + + public: + MarginContainer(const MarginContainer& other) = delete; + MarginContainer(MarginContainer&& other) = delete; + MarginContainer& operator=(const MarginContainer& other) = delete; + MarginContainer& operator=(MarginContainer&& other) = delete; + ~MarginContainer() override = default; + + Thickness GetMargin() const + { + return margin_; + } + + void SetMargin(const Thickness& margin); + + protected: + Size OnMeasure(const Size& available_size) override; + void OnLayout(const Rect& rect) override; + + private: + Thickness margin_; + }; +} |