FragmentPaintPropertyTreeBuilder::UpdateScrollAndScrollTranslation()
Blink28618 Loka 2025

FragmentPaintPropertyTreeBuilder::UpdateScrollAndScrollTranslation()

The provided sources offer an extensive, line-by-line analysis of Blink’s rendering function, FragmentPaintPropertyTreeBuilder::UpdateScrollAndScrollTranslation(), which is critical for implementing scrolling behavior in Chrome. This function manages the creation and updating of two primary data structures: the Scroll Property Node (which defines the logical scroll container, including its viewport, content size, and CSS properties like overscroll behavior and scroll snapping) and the Scroll Translation Transform Node (which applies the negative scroll offset as a geometric translation to descendant content). The process is part of RenderingNG, which uses separate property trees (Transform, Clip, Effect, Scroll) to achieve efficient, incremental updates. The method ensures that only scrollable objects receive these nodes, updates related scrollbar Effect Nodes, and implements optimizations like directly updating the compositor's transform for simple scroll offset changes without rebuilding the entire paint artifact.

Jaksot(403)

CSS Sticky Positioning and Paint Property Trees

CSS Sticky Positioning and Paint Property Trees

This documentation details how the Blink rendering engine manages CSS sticky positioning through its PrePaint and paint property tree workflows. During the PrePaint phase, the engine identifies sticky...

26 Joulu 202551min

[General] Inside Blink: The Paint Property Tree Builder Pipeline

[General] Inside Blink: The Paint Property Tree Builder Pipeline

The PaintPropertyTreeBuilder is a critical component within Google Chrome’s Blink engine that converts layout data into structural property trees used for rendering. Operating during the PrePaint phas...

24 Joulu 202550min

Inside Blink: The Paint Property Tree Builder Pipeline

Inside Blink: The Paint Property Tree Builder Pipeline

The PaintPropertyTreeBuilder is a critical component within Google Chrome’s Blink engine that converts layout data into structural property trees used for rendering. Operating during the PrePaint phas...

24 Joulu 20251h 4min

Promisify Scroll: Promise-Based Web Scrolling API

Promisify Scroll: Promise-Based Web Scrolling API

The provided text describes a web platform initiative to modernize how browsers handle scrolling by having programmatic scroll methods return JavaScript Promises. Currently, functions like scrollTo() ...

24 Joulu 202528min

CSS Containing Blocks and Blink Engine Implementation

CSS Containing Blocks and Blink Engine Implementation

This text examines how CSS containing blocks function and how the Blink rendering engine implements these rules within Chromium. It explains that a containing block is the essential rectangular refere...

23 Joulu 202526min

Axis-Split Sticky Constraints in Chromium Layout and Compositing

Axis-Split Sticky Constraints in Chromium Layout and Compositing

Chromium is refining its rendering engine to support axis-split sticky constraints, allowing elements to stick to different scroll containers for horizontal and vertical movements. Previously, a singl...

23 Joulu 202533min

Mastering CSS Sticky Positioning and Scroll Containers

Mastering CSS Sticky Positioning and Scroll Containers

This documentation provides a comprehensive analysis of CSS sticky positioning, a hybrid layout scheme that anchors elements within their nearest scroll container while maintaining their space in the ...

20 Joulu 202534min

Blink Paint Property Trees: Construction and Lifecycle Phases

Blink Paint Property Trees: Construction and Lifecycle Phases

The provided text explains the construction and lifecycle of paint property trees within the Blink rendering engine. These structures, which include Transform, Clip, Effect, and Scroll trees, replace ...

20 Joulu 20251h 1min