CSS View Transition Pseudo-elements Explained
Blink28624 Syys 2025

CSS View Transition Pseudo-elements Explained

These sources provide a detailed, technical explanation of the View Transition API implementation within the Chromium web browser, focusing on how CSS pseudo-elements enable smooth animations. The first source explains that view transition pseudos (like ::view-transition-old() and ::view-transition-new()) are temporary, browser-synthesized overlays used to capture and animate visual snapshots of elements during state changes. The second, more extensive source describes the low-level C++ classes in the Blink rendering engine and the cc compositor that orchestrate this process, including the DocumentTransition class, which manages the lifecycle, snapshot capture, and pseudo-element creation, and the SurfaceAnimationManager in the Viz component, which handles the final, performant GPU-accelerated animation of the saved frames using specialized layers and directives. Together, the texts map the high-level CSS API to the complex, multi-process architecture of Chromium, explaining how old and new content are matched, isolated on the top layer, and composited for animation.


Jaksot(398)

Fragmentation in Blink LayoutNG

Fragmentation in Blink LayoutNG

The source provides a comprehensive overview of content fragmentation within the Blink rendering engine, focusing heavily on the transition from the legacy engine to the modern LayoutNG architecture. ...

19 Marras 202550min

Kitty Clipboard Integration Over SSH and Tmux

Kitty Clipboard Integration Over SSH and Tmux

The sources provide a detailed technical guide focused on achieving seamless copy-paste functionality between a local Kitty terminal on macOS and a remote Linux session, especially over SSH. The text ...

19 Marras 202523min

View Transition Deep Dive: Lifecycle and Implementation

View Transition Deep Dive: Lifecycle and Implementation

The sources provide a detailed technical examination of the lifecycle of a View Transition in the Chromium browser engine, outlining the complex coordination across various subsystems like Blink, the ...

19 Marras 202531min

LayerTreeHost Core Lifecycle and Commit Methods

LayerTreeHost Core Lifecycle and Commit Methods

The provided text comprises extensive documentation of the LayerTreeHost class, a foundational component in a compositing system (likely Chromium's cc layer). It thoroughly details the object's lifecy...

18 Marras 202543min

Layer Tree Host Impl: Core Compositor Pipeline

Layer Tree Host Impl: Core Compositor Pipeline

The sources provide detailed excerpts from the C++ implementation of the LayerTreeHostImpl class, a fundamental component of the Chromium compositor that manages rendering operations and state on the ...

17 Marras 202542min

cc Elastic Overscroll Architecture Deep Dive

cc Elastic Overscroll Architecture Deep Dive

The source provides an architectural overview of how elastic overscroll (the "rubber-banding" effect) is implemented within the Chromium Compositor (CC) for both the main viewport and individual scrol...

16 Marras 202533min

SyncedProperty: Cross-Thread Compositor Synchronization

SyncedProperty: Cross-Thread Compositor Synchronization

The source provides a detailed technical exploration of SyncedProperty, a critical synchronization mechanism within Chromium's compositor (cc) designed to manage properties updated concurrently on bot...

16 Marras 202532min

Blink's PendingLayer: Bridge Between Paint and Compositor

Blink's PendingLayer: Bridge Between Paint and Compositor

The document provides an extensive technical overview of the PendingLayer class, a critical internal component within Blink’s Composite After Paint (CAP) architecture. PendingLayer acts as a liaison, ...

15 Marras 202530min