Axis-Split Sticky Constraints in Chromium Layout and Compositing
Blink28623 Joulu 2025

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 single ancestor would trap both axes, but the new system enables independent layout and paint logic for each direction. Blink’s style system now distinguishes per-axis participation, while the layout phase identifies the nearest relevant scroller by skipping ancestors that do not scroll in a specific axis. In the pre-paint phase, the engine generates separate transform nodes for each axis, which are then passed to the compositor to manage independent clamping and offsets. This architectural shift ensures that complex nested scrolling—such as a header staying vertically fixed to the page while moving horizontally within a side-scrolling container—functions intuitively. Testing involves updated Web Platform Tests to validate that coordinate mapping and pixel snapping remain accurate across various writing modes and fragmented layouts.

Jaksot(444)

Refining Pixel Snapping for Split-Axis Sticky Compositing

Refining Pixel Snapping for Split-Axis Sticky Compositing

These sources detail a technical implementation for pixel snapping in a web browser's compositor, specifically addressing how sticky positioning handles subpixel offsets across split axes. The primary...

24 Helmi 34min

InputHandlerProxy in Blink and cc: A Technical Report

InputHandlerProxy in Blink and cc: A Technical Report

The provided technical report details the architecture and function of the InputHandlerProxy within the Chromium renderer as of early 2026. This component operates on the compositor thread to manage u...

24 Helmi 31min

Unix and Linux tee Utility

Unix and Linux tee Utility

The provided text is a technical report on the Unix and Linux tee utility, a command used to duplicate data streams by reading from standard input and writing to both standard output and files. While ...

24 Helmi 35min

Blink Rendering Architecture: Engineering Artifacts and Pipeline Engineering

Blink Rendering Architecture: Engineering Artifacts and Pipeline Engineering

This document explores the RenderingNG pipeline in Chromium, focusing on the architecture and data structures that drive Blink painting and compositing. It details how layout outputs are transformed i...

24 Helmi 33min

[GEM] The Architecture and Mechanics of CSS Layout Containment

[GEM] The Architecture and Mechanics of CSS Layout Containment

This text provides an in-depth technical analysis of the CSS Containment Module, specifically focusing on the contain: layout property and its impact on browser rendering engines. It explains how this...

20 Helmi 34min

Deep Dive into CSS Layout Containment and Blink Implementation

Deep Dive into CSS Layout Containment and Blink Implementation

These sources examine CSS containment, a technical specification that allows developers to isolate specific subtrees of a document to improve browser rendering performance. By establishing containment...

20 Helmi 28min

Chromium Blink Paint Worklets Deep Dive

Chromium Blink Paint Worklets Deep Dive

The provided text explains the Chromium Blink implementation of the CSS Painting API, a tool that allows developers to create custom images through JavaScript. It details an architectural shift where ...

20 Helmi 42min

Oilpan Compaction and Conservative Stack Scanning in Blink GC

Oilpan Compaction and Conservative Stack Scanning in Blink GC

Modern Blink’s Oilpan utilizes a mark-and-sweep garbage collection system, largely integrated within the V8 C++ library, to manage memory for web elements and container backings. While the system supp...

20 Helmi 30min