aboutsummaryrefslogtreecommitdiff
path: root/src/ui/controls/margin_container.h
diff options
context:
space:
mode:
authorYuqian Yang <crupest@outlook.com>2018-09-25 05:30:01 +0000
committerYuqian Yang <crupest@outlook.com>2018-09-25 05:30:01 +0000
commitea4b0966d8eb5a8e76dfbe4d833a07a4797a3284 (patch)
treee5918c686f27363bfacf7d47e4b93617872b908d /src/ui/controls/margin_container.h
parent001e1d955132a02a2f7effc841ab9e5ee425eda1 (diff)
parent03d078796ad31eb55d70ad0aa61254b301e989a6 (diff)
downloadcru-ea4b0966d8eb5a8e76dfbe4d833a07a4797a3284.tar.gz
cru-ea4b0966d8eb5a8e76dfbe4d833a07a4797a3284.tar.bz2
cru-ea4b0966d8eb5a8e76dfbe4d833a07a4797a3284.zip
Merge branch 'testing' into 'master'
Add CI. See merge request crupest/CruUI!5
Diffstat (limited to 'src/ui/controls/margin_container.h')
-rw-r--r--src/ui/controls/margin_container.h44
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_;
+ };
+}