Renderowanie w Flutter obejmuje trzy drzewa — drzewo Widget (konfiguracja), drzewo Element (zinstancjonowane, zarządzane widgety) oraz drzewo RenderObject (układ i rysowanie). Zrozumienie tego potoku demistyfikuje, jak Flutter wydajnie przekształca widgety w piksele.
Trzy drzewa
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
