يتضمن رسم واجهة المستخدم في Flutter ثلاث أشجار — شجرة Widget (التكوين)، شجرة Element (الـ widgets المُنشأة والمُدارة)، وشجرة RenderObject (التخطيط والرسم). فهم هذا خط الأنابيب يوضح كيف يحول Flutter الـ widgets بكفاءة إلى بكسلات.
الأشجار الثلاث
WIDGET tree → immutable CONFIGURATION (what you write: the description of the UI)
→ cheap to create/recreate; rebuilt often (build() returns new widgets)
ELEMENT tree → the INSTANTIATED widgets; manages lifecycle and LINKS widgets to render
objects; PERSISTS across rebuilds (this is the key to efficiency)
RENDEROBJECT tree → does the actual LAYOUT, PAINTING, and hit-testing (the heavy objects)
→ expensive; REUSED and updated (not recreated) across rebuilds
