cc Transform and Scroll Trees
Blink28628 Syys 2025

cc Transform and Scroll Trees

The source text details the architecture of Chromium's compositor, focusing on the tandem operation of two critical data structures: the Transform Tree and the Scroll Tree. The Transform Tree manages visual coordinate space transformations, including CSS transforms and scroll offsets, with each TransformNode calculating its final position relative to its parent using local matrices and the scroll translation. In parallel, the Scroll Tree, composed of ScrollNodes, handles the logical state of scrollable elements, defining constraints like scrollable bounds, allowed directions, and scroll chaining behavior. Crucially, the sources explain that the two trees are linked via a shared ElementId and that while the Scroll Tree determines how a scroll should happen (bounds and policy), the Transform Tree executes the change by holding and applying the live scroll_offset to visually move the layer content, enabling smooth, composite-threaded scrolling.

Jaksot(427)

Trees in Viz: Chrome's Centralized Compositing Engine

Trees in Viz: Chrome's Centralized Compositing Engine

The source details a significant re-architecture of the Chromium rendering pipeline, known as JellyMander, centered on the feature Trees in Viz (TiV). This change shifts the core task of frame composi...

30 Marras 202530min

PaintLayerPainter: Blink's Bridge from Layout to Rendering

PaintLayerPainter: Blink's Bridge from Layout to Rendering

The source material provides an exhaustive technical analysis of Blink’s PaintLayerPainter, the central coordinator responsible for executing the CSS painting algorithm to generate visual output. This...

30 Marras 202541min

Blink Property Trees: Scene Graph for Compositing

Blink Property Trees: Scene Graph for Compositing

The sources provide a comprehensive technical analysis of the Paint Property Tree Builder (PPTB) in Blink, which is the mechanism responsible for creating the crucial intermediate data structures know...

30 Marras 202540min

The Architecture of Chromium's Safe Callback Cancellation

The Architecture of Chromium's Safe Callback Cancellation

The source material provides a comprehensive examination of Chromium's CancelableCallback utility, which was introduced to allow for the safe and explicit cancellation of tasks that have been schedule...

29 Marras 202539min

B6: RenderProcessHost: Lifecycle and Architecture Management

B6: RenderProcessHost: Lifecycle and Architecture Management

The provided documents outline the essential functions of the RenderProcessHost (RPH), a crucial component within Chromium's multi-process architecture that resides in the browser process to manage a ...

28 Marras 202532min

B5: Platform View Architecture

B5: Platform View Architecture

The source provides an architectural overview of Layer 5 in Chromium, which is responsible for interfacing the browser’s content output with the native operating system view layer. This layer is struc...

28 Marras 202533min

B4: Render Host Layer: RVH and RWH

B4: Render Host Layer: RVH and RWH

The technical documentation provides an extensive overview of two crucial browser-side components in Chromium's multi-process architecture: the RenderViewHost (RVH) and the RenderWidgetHost(RWH). The ...

28 Marras 202539min

B3: RenderFrameHost: Core Document Lifeline

B3: RenderFrameHost: Core Document Lifeline

The source documentation provides a detailed analysis of the RenderFrameHost (RFH) and its implementing class, RenderFrameHostImpl, which constitute the essential browser-side representation of every ...

28 Marras 202534min