Blink and Compositor Stacking Contexts
Blink28625 Syys 2025

Blink and Compositor Stacking Contexts

These sources provide an extensive technical explanation of how CSS stacking contexts are implemented within the Chromium rendering engine, focusing on the collaboration between the Blink renderer and the cc compositor. The process begins in Blink, where elements triggering a stacking context (via properties like opacity or z-index) are identified, leading to the creation of internal structures like PaintLayer and EffectPaintPropertyNode to manage z-ordering. Blink then produces a PaintArtifact consisting of drawing commands grouped into paint chunks, each linked to a specific set of property nodes that define the context's position, clipping, and effects. This artifact is passed to the cc compositor, which converts the Blink properties into its own PropertyTrees (especially the EffectNode), using this data to decide which stacking contexts require an isolated drawing buffer, known as a RenderSurfaceImpl, for final GPU compositing and accurate visual blending. Ultimately, Blink determines what is painted and ordered, and cc determines how to composite those results efficiently.

Jaksot(396)

blink::LocalFrame

blink::LocalFrame

the document host and local‑root boundary.
The local frame owns the Document and its LocalFrameView. The local root frame coordinates lifecycle for its subtree (including OOPIF boundaries handled late...

9 Loka 202532min

blink::Page

blink::Page

the page container and animation clock keeper. Page holds frame trees and the PageAnimator that services script‑driven animations on each tick. It’s the top‑level context for the document/view that We...

9 Loka 202534min

blink::WebFrameWidgetImpl

blink::WebFrameWidgetImpl

renderer‑main entry to Blink’s lifecycle. This is where a compositor BeginFrame (coming in via content/public and mojo plumbing) first turns into Blink work on the renderer main thread. It receives th...

9 Loka 202532min

Blink's ComputedStyle: An In-Depth Analysis

Blink's ComputedStyle: An In-Depth Analysis

The collection of sources provides a detailed technical analysis of the ComputedStyle object within Blink, the rendering engine for Chromium. The primary source, an in-depth analysis document, explain...

9 Loka 202545min

Chromium LayerContext Deep Dive: RenderingNG and Scroll Updates

Chromium LayerContext Deep Dive: RenderingNG and Scroll Updates

The source material, primarily an excerpt from a 2025 technical report, provides an in-depth analysis of the LayerContext abstraction within the Chromium RenderingNG pipeline, specifically when the br...

8 Loka 202532min

[ext] Blink's Paint Property Tree Builder: A Surgical Tour of Dragons

[ext] Blink's Paint Property Tree Builder: A Surgical Tour of Dragons

(Make it over 20000 words) source text provides an extremely detailed, technical overview of the blink::PaintPropertyTreeBuilder class in Chromium, which is responsible for building the rendering pipe...

7 Loka 20251h 36min

Blink's Paint Property Tree Builder: A Surgical Tour of Dragons

Blink's Paint Property Tree Builder: A Surgical Tour of Dragons

The source text provides an extremely detailed, technical overview of the blink::PaintPropertyTreeBuilder class in Chromium, which is responsible for building the rendering pipeline's four synchronize...

7 Loka 202543min

Chrome Compositor LayerTree Architecture and Input Handling

Chrome Compositor LayerTree Architecture and Input Handling

The text provides a detailed overview of the architecture and function of Chrome's Compositor (cc) component, specifically focusing on the core data structures: LayerTree and LayerTreeImpl. It explain...

7 Loka 202527min