aboutsummaryrefslogtreecommitdiff
path: root/include/cru/ui/controls/LayoutControl.hpp
diff options
context:
space:
mode:
authorcrupest <crupest@outlook.com>2020-11-09 16:18:20 +0800
committercrupest <crupest@outlook.com>2020-11-09 16:18:20 +0800
commit349b26d350d46fd6c48c6895ee9d8ef81add1315 (patch)
tree05ad55ea728f9f5451c554f7faf7a76260aaddf8 /include/cru/ui/controls/LayoutControl.hpp
parent12301a4e71de0802019381215a821ce58723c39a (diff)
downloadcru-349b26d350d46fd6c48c6895ee9d8ef81add1315.tar.gz
cru-349b26d350d46fd6c48c6895ee9d8ef81add1315.tar.bz2
cru-349b26d350d46fd6c48c6895ee9d8ef81add1315.zip
...
Diffstat (limited to 'include/cru/ui/controls/LayoutControl.hpp')
-rw-r--r--include/cru/ui/controls/LayoutControl.hpp18
1 files changed, 17 insertions, 1 deletions
diff --git a/include/cru/ui/controls/LayoutControl.hpp b/include/cru/ui/controls/LayoutControl.hpp
index cbdb8aa2..106dd94d 100644
--- a/include/cru/ui/controls/LayoutControl.hpp
+++ b/include/cru/ui/controls/LayoutControl.hpp
@@ -5,6 +5,8 @@ namespace cru::ui::controls {
class LayoutControl : public Control {
protected:
LayoutControl() = default;
+ explicit LayoutControl(render::RenderObject* container_render_object)
+ : container_render_object_(container_render_object) {}
public:
LayoutControl(const LayoutControl& other) = delete;
@@ -15,5 +17,19 @@ class LayoutControl : public Control {
using Control::AddChild;
using Control::RemoveChild;
+
+ protected:
+ // If container render object is not null. Render object of added or removed
+ // child control will automatically sync to the container render object.
+ render::RenderObject* GetContainerRenderObject() const;
+ void SetContainerRenderObject(render::RenderObject* ro) {
+ container_render_object_ = ro;
+ }
+
+ void OnAddChild(Control* child, Index position) override;
+ void OnRemoveChild(Control* child, Index position) override;
+
+ private:
+ render::RenderObject* container_render_object_ = nullptr;
};
-} // namespace cru::ui
+} // namespace cru::ui::controls