Skill v1.0.0
Trusted Publisher100/100version: "1.0.0" name: scrollytelling-and-parallax-data-visualization description: Design and implement parallax scrolling and scrollytelling data visualizations. Use when the user asks for parallax scrolling, scrollytelling, scroll-driven timelines, sticky graphics, Scrollama, ScrollTrigger, ScrollTimeline, view timelines, rich-media timelines, moviescrollers, scroll-scrubbed charts, staged narrative reveals, or interactive visual stories where scrolling changes a data visualization or media scene.
Scrollytelling and Parallax Data Visualization
Overview
Use this skill when scrolling is part of the explanation, not just navigation. Scrollytelling is an author-led narrative structure in which text, data marks, imagery, video, maps, or camera states change as the reader scrolls. Parallax is one possible scrollytelling technique: layers move at different rates to create depth, reveal scale, or connect foreground evidence to background context.
Default assumption: preserve native scrolling and make every scene meaningful as a still. Do not use parallax or scroll-scrubbed motion as decoration. Use it only when staged reveal, state change, elapsed time, spatial movement, or rich-media synchronization materially reduces interpretation cost.
When To Use It
- A timeline, map, chart, 3D scene, video, or illustrated substrate needs staged reveal while the reader scrolls.
- The story benefits from a linear author-led path before optional reader exploration.
- A sticky graphic, side-by-side text/visual layout, overlay text on media, or scroll-scrubbed transition is being planned or implemented.
- The user mentions Scrollama, GSAP ScrollTrigger, Motion
useScroll, CSSScrollTimeline, ViewTimeline, IntersectionObserver,position: sticky, parallax layers, moviescroller, or scroll-driven animation.
Avoid scrollytelling when the story is clearer as a static chart, direct-label small multiples, a conventional article with inline figures, or an explicit stepper. Prefer a stepper when the states are discrete and the reader needs direct access, known length, replay, or controlled comparison more than continuous scroll.
Working Pattern
- Define the story contract:
- one-sentence takeaway
- author-led sequence and any reader-controlled exploration
- why scrolling is necessary
- what the first frame, each key frame, and final frame prove
- For fictional, synthetic, or illustrative stories, require a data-rich simulation before storyboarding. Use
../../references/foundations/fictional-data-story-simulation.mdto define entity, temporal, spatial or physical, event, outcome, and derived comparison layers. - For art-directed, image-supported, composite, or existing-page scrollytelling work, use
../../references/foundations/meaning-preserving-visual-design-workflow.mdand../../references/foundations/mobile-first-responsive-visualization.md. Apply those shared references for Codex concept generation, large-screen/mobile variants, approval or iteration, scene contracts, and implementation deferral. - Choose the scrollytelling technique:
- graphic sequence
- animated transition
- pan and zoom
- moviescroller
- show-and-play
- parallax depth layer
- sticky side-by-side or overlay
- stacked mobile fallback or mobile-specific stepper
- Model scenes as data, not ad hoc scroll math. Each scene declares text, visual state, data layer, media asset, annotation, scroll trigger or progress range, reduced-motion fallback, static key frame, embedded visualization skill owner, visual-density role, interactive discovery affordance, asset-continuity requirement, scroll-controlled media behavior, and any approved concept/key-frame contract. Approved key-frame concepts are binding scene contracts: the implementation must preserve their evidence hierarchy, staging, label-safe regions, interaction meaning, and static fallback unless a deviation is approved or recorded as meaning-preserving.
- For each embedded visual layer, use
../../references/foundations/embedded-visualization-self-use.mdto name the primary specialist owner and mini-brief the layer's job, data shape, encoding, interaction, fallback, accessibility, QA check, and delegated or local fresh-pass status before scene composition. - Require every scene to include at least one evidence-bearing visual change: chart transition, map or layer reveal, annotation shift, camera move, particle or flow state, video frame or state, or interactive hotspot. If the scene only adds drama, simplify or add real evidence.
- Pick the lightest implementation:
- native scroll and
position: stickyfor pinning - IntersectionObserver or Scrollama for step triggers
- CSS scroll-driven animations for simple transform or opacity when support and fallback are acceptable
- Motion or GSAP ScrollTrigger for complex React choreography, scrubbing, pinning, snapping, or timeline labels
- D3/SVG, Canvas2D, WebGL, deck.gl, PixiJS, Three.js, or video only when the visual layer requires it
- Protect the browser contract:
- do not scrolljack
- keep feedback immediate, reversible, and interruptible
- preserve standard wheel, touch, scrollbar, and keyboard behavior
- avoid surprise autoplay, especially audio
- account for mobile browser chrome, changing viewport height, touch momentum, and keyboard-open states
- Build accessibility and fallbacks before polish:
- honor
prefers-reduced-motion - provide static key frames, a stacked version, or a stepped fallback
- keep focus order and reading order coherent
- ensure the main claim survives screenshots and static export
- Test performance and interpretation:
- profile scroll jank on desktop and mobile
- verify no layout thrashing or layout-triggering animation
- reserve media dimensions and lazy-load offscreen assets
- test fast scroll, reverse scroll, resize, reduced motion, keyboard navigation, and mobile browser chrome changes
Routing
- Use
../visualization-strategy-and-critique/SKILL.mdfirst when deciding whether the story should be scrollytelling, a stepper, small multiples, or a static editorial chart. - Use
../react-and-nextjs-data-visualization/SKILL.mdwhen the implementation is a React or Next.js story surface, especially with hydration, client-only libraries, dynamic imports, or route-level asset loading. - Use
../d3-data-visualization/SKILL.mdwhen SVG data marks, labels, annotations, and scene-state transitions are the core work. - Use
../canvas2d-data-visualization/SKILL.mdwhen dense flat marks or custom hit testing make SVG too heavy. - Use
../threejs-data-visualization/SKILL.mdwhen WebGL, GPU layers, particles, flow, or camera-led 3D are necessary. - Use
../geospatial-and-cartographic-visualization/SKILL.mdfor map scrollytelling, fly-to sequences, route stories, or pan/zoom geography. - Use
../accessibility-and-inclusive-visualization/SKILL.mdwhen motion sensitivity, keyboard path, screen-reader alternatives, or static fallbacks are central. - Use
../testing-data-visualizations/SKILL.mdwhen validating scroll states, visual regression, render readiness, media loading, or reduced-motion behavior. - Use
../../references/foundations/fictional-data-story-simulation.mdwhen sparse invented data would otherwise force the scroll story to rely on walls of text, decorative parallax, or generic chart tiles.
Output Expectations
- State whether scrollytelling is justified and what would be lost in a simpler format.
- Name the scrollytelling technique and the reader's path through scenes.
- Provide a scene contract with trigger/progress ranges and static fallbacks.
- For Codex image-generated layout or key-frame concepts, use the shared design workflow for concept images, approval status, approved references, binding semantic design contract, locked and flexible elements, data-bound layers, mobile/landscape continuation, approved deviations, and concept-to-result fidelity checks.
- For every embedded visual layer, provide the specialist owner, mini-brief summary, QA check, and whether delegated fresh context, a local fresh specialist pass, or a lightweight exception was used.
- For fictional stories, provide the simulated-world data richness contract and the specialist mini-brief for every embedded visualization layer.
- Name the implementation stack and why it is the lightest reliable option.
- Call out browser behavior explicitly: native scroll, sticky pinning, event listeners, scroll ownership, and keyboard behavior.
- State reduced-motion behavior, mobile portrait path, optional landscape path, media loading plan, spotty-connection behavior, and performance risks.
- Include the first-frame, key-frame, final-frame, and screenshot acceptance criteria.
References
./references/story-patterns-and-scene-contracts.md./references/implementation-and-performance.md./references/accessibility-testing-and-review.md../../references/foundations/meaning-preserving-visual-design-workflow.md../../references/foundations/embedded-visualization-self-use.md../../references/foundations/mobile-first-responsive-visualization.md
Representative Prompts
- "Make a parallax scrolling timeline with maps and video."
- "Use Scrollama for a data story."
- "Should this be scrollytelling or a stepper?"
- "Design a scroll-driven visualization that is accessible and performant."
- "Build a sticky graphic story where the chart changes as the reader scrolls."
- "Storyboard a moviescroller that advances video frames with scroll progress."