aboutsummaryrefslogtreecommitdiff
path: root/src/ui/render
diff options
context:
space:
mode:
Diffstat (limited to 'src/ui/render')
-rw-r--r--src/ui/render/render_object.cpp10
-rw-r--r--src/ui/render/window_render_object.cpp21
2 files changed, 10 insertions, 21 deletions
diff --git a/src/ui/render/render_object.cpp b/src/ui/render/render_object.cpp
index 7f6255f7..d220b1c1 100644
--- a/src/ui/render/render_object.cpp
+++ b/src/ui/render/render_object.cpp
@@ -18,6 +18,7 @@ void RenderObject::AddChild(RenderObject* render_object, const int position) {
children_.insert(children_.cbegin() + position, render_object);
render_object->SetParent(this);
+ render_object->SetRenderHostRecursive(GetRenderHost());
OnAddChild(render_object, position);
}
@@ -30,6 +31,7 @@ void RenderObject::RemoveChild(const int position) {
const auto removed_child = *i;
children_.erase(i);
removed_child->SetParent(nullptr);
+ removed_child->SetRenderHostRecursive(nullptr);
OnRemoveChild(removed_child, position);
}
@@ -140,4 +142,12 @@ void RenderObject::NotifyAfterLayoutRecursive(RenderObject* render_object) {
NotifyAfterLayoutRecursive(o);
}
}
+
+void RenderObject::SetRenderHostRecursive(IRenderHost* host) {
+ SetRenderHost(host);
+ for (const auto child : GetChildren()) {
+ child->SetRenderHostRecursive(host);
+ }
+}
+
} // namespace cru::ui::render
diff --git a/src/ui/render/window_render_object.cpp b/src/ui/render/window_render_object.cpp
index 12fc2ce1..1001be87 100644
--- a/src/ui/render/window_render_object.cpp
+++ b/src/ui/render/window_render_object.cpp
@@ -88,27 +88,6 @@ RenderObject* WindowRenderObject::HitTest(const Point& point) {
return Rect{Point{}, GetSize()}.IsPointInside(point) ? this : nullptr;
}
-namespace {
-void SetRenderHostRecursive(RenderObject* render_object, IRenderHost* host) {
- render_object->SetRenderHost(host);
- for (const auto child : render_object->GetChildren()) {
- SetRenderHostRecursive(child, host);
- }
-}
-} // namespace
-
-void WindowRenderObject::OnAddChild(RenderObject* new_child, int position) {
- CRU_UNUSED(position)
-
- SetRenderHostRecursive(new_child, render_host_.get());
-}
-
-void WindowRenderObject::OnRemoveChild(RenderObject* new_child, int position) {
- CRU_UNUSED(position)
-
- SetRenderHostRecursive(new_child, nullptr);
-}
-
Size WindowRenderObject::OnMeasureContent(const Size& available_size) {
if (const auto child = GetChild()) child->Measure(available_size);
return available_size;