blink::WebFrameWidgetImpl
Blink2869 Loka 2025

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 the frame tick, decides what lifecycle phases to run (e.g. style/layout/paint), and pushes the work into the local root’s LocalFrameView. (Chromium Git Repositories)

Key fields (why they matter)

* scoped_refptr root_layer_ — holds the Blink‑owned root cc layer for this widget’s subtree; exists so Blink can update properties before the commit boundary. (Chromium Git Repositories)

* std::unique_ptr animation_host_ — lets main‑thread animations be driven and ticked in sync with lifecycle updates. (Chromium Git Repositories)

* std::unique_ptr layer_tree_view_ — the view side of the compositor connection that WebFrameWidgetImpl closes/tears down when the widget goes away. (Chromium Git Repositories)

Most important methods (how they advance the pixel)

* void BeginMainFrame(base::TimeTicks last_frame_time) — entry point for a new main‑thread frame; schedules lifecycle phase execution in Blink. (Chromium Git Repositories)

* void UpdateLifecycle(WebLifecycleUpdate requested_update, DocumentUpdateReason reason) — runs the Blink lifecycle (style → layout → pre‑paint/paint) as needed for this frame. (Chromium Git Repositories)

* void RecordEndOfFrameMetrics(base::TimeTicks frame_begin_time) — stamps timing for UMA/UKM; not directly pixel‑producing but tied to the same lifecycle boundary. (Chromium Git Repositories)

Hands off to: LocalFrameView of the local root to perform style/layout/paint.

Jaksot(397)

gpu::SkiaOutputSurfaceImplOnGpu / gpu::CommandBuffer

gpu::SkiaOutputSurfaceImplOnGpu / gpu::CommandBuffer

Bridges Skia’s recorded commands to the GPU command buffer; submits and SwapBuffers to present. (Backend: GL/Vulkan/Metal via GPU process.)

23 Syys 202532min

viz::SkiaRenderer

viz::SkiaRenderer

Renderer that turns quads into Skia operations (recording DDLs / drawing to the output surface).

23 Syys 202552min

viz::Display

viz::Display

The display compositor that walks the aggregated render passes and issues draw commands for the final output.

23 Syys 202538min

cc::LayerTreeHostImpl (Input Handler & Scroll Logic)

cc::LayerTreeHostImpl (Input Handler & Scroll Logic)

Scroll processing and overscroll detection in the compositor. The LayerTreeHostImpl in cc implements the compositor-thread InputHandler that processes gesture scroll updates and flings. It manages the...

23 Syys 202527min

blink::EventHandler (Blink core input handling)

blink::EventHandler (Blink core input handling)

Scroll chain builder and overscroll chaining logic. Blink’s EventHandler is responsible for building the scroll chain (the sequence of nested scrollable ancestors) when the user scrolls an element . I...

23 Syys 202526min

blink::ElasticOverscrollController

blink::ElasticOverscrollController

Overscroll orchestration and animation. This Blink-side controller manages the rubber-banding (elastic stretch and rebound) effect when a scrollable area is overscrolled. It observes gesture scroll ev...

23 Syys 202526min

viz::Surface / SurfaceAggregator

viz::Surface / SurfaceAggregator

Receives frames from one or more surfaces (main page and OOPIFs), aggregates them into a single display frame.

23 Syys 202535min

viz::CompositorFrameSink (client side)

viz::CompositorFrameSink (client side)

The submission interface used by cc to hand the frame to viz.

23 Syys 202531min