blink::PaintArtifactCompositor
Blink28610 Loka 2025

blink::PaintArtifactCompositor

turns chunks into compositor layers & updates cc property trees.

Consumes the new PaintArtifact and does the layerization and property‑tree updates required for compositor draw. It supports fast paths when only values changed (e.g., opacity) or when a scroll only induces raster invalidation, avoiding full rebuilds. It owns a subtree of cc layers corresponding to the artifact. (Chromium Git Repositories)

Key fields

  • scoped_refptr<cc::Layer> root_layer_ — root of the Blink‑owned layer subtree.

  • UpdateType needs_update_ — kRepaint vs kFull (or scroll fast path).

  • Caches/maps for synthesized mask clips and scroll translations seen while layerizing. (Chromium Git Repositories)

Most important methods

  • bool TryFastPathUpdate(const PaintArtifact&) — take a cheap path (no topology change). (Chromium Git Repositories)

  • void Update(const PaintArtifact&, const ViewportProperties&, const StackScrollTranslationVector&, Vector<std::unique_ptr<cc::ViewTransitionRequest>>) — full reconciliation to layers + cc property trees. (Chromium Git Repositories)

  • “Direct update” helpers like DirectlyUpdateCompositedOpacityValue(...), DirectlyUpdateScrollOffsetTransform(...) — skip rebuilds for common animations/scrolling. (Chromium Git Repositories)

Hands off to: PropertyTreeManager (internally) to mirror Blink property nodes to cc trees, ready for commit to the compositor thread.


Jaksot(395)

LayoutSVGForeignObject: Bridging SVG and HTML

LayoutSVGForeignObject: Bridging SVG and HTML

The provided text describes the LayoutSVGForeignObject class within Chromium’s Blink engine, which enables the integration of HTML and CSS content inside an SVG environment. Acting as a technical brid...

2 Tammi 34min

StyleResolver: Blink Architecture and CSS Engine Deep Dive

StyleResolver: Blink Architecture and CSS Engine Deep Dive

The provided text outlines the StyleResolver within Google’s Blink rendering engine, detailing its pivotal role in converting CSS rules into final ComputedStyle objects for DOM elements. This complex ...

2 Tammi 39min

StyleAdjuster: Blink Rendering Engine

StyleAdjuster: Blink Rendering Engine

The provided text explains the StyleAdjuster component within the Blink rendering engine, which serves as a critical post-processing stage in the CSS style resolution pipeline. Positioned between init...

2 Tammi 37min

FragmentBuilder: Architecture and Role

FragmentBuilder: Architecture and Role

In Blink’s LayoutNG engine, the FragmentBuilder class serves as a vital instrument for generating immutable fragment trees, which represent the final geometric output of the layout process. This syste...

2 Tammi 37min

ObjectPaintProperties: Linking Layout and Painting in Blink Engine

ObjectPaintProperties: Linking Layout and Painting in Blink Engine

In the Blink rendering engine, the ObjectPaintProperties structure serves as a vital bridge between the layout and painting phases. It functions by organizing specific visual property nodes—such as tr...

2 Tammi 33min

BoxFragmentBuilder and Layout Architecture in Blink's LayoutNG

BoxFragmentBuilder and Layout Architecture in Blink's LayoutNG

The provided text details the BoxFragmentBuilder, a vital component within the Blink LayoutNG engine that constructs physical representations of layout elements. It acts as a transitional bridge, taki...

2 Tammi 39min

Pseudo-Elements in Blink's Layout Tree

Pseudo-Elements in Blink's Layout Tree

In the Blink rendering engine, CSS pseudo-elements are managed through specialized C++ classes and internal structures that link them to their originating DOM elements. These entities are dynamically ...

2 Tammi 42min

Clip Nodes in the Blink and Chromium Compositor

Clip Nodes in the Blink and Chromium Compositor

The provided text explains how Chromium’s Blink engine and the compositor utilize clip nodes within property trees to manage page geometry and visual masking. These nodes define specific regions where...

2 Tammi 35min