{"slug": "animation-vocabulary", "title": "Animation Vocabulary", "summary": "A glossary of common animation patterns is provided, defining terms such as fade in/out, slide in, scale in, pop in, reveal, keyframes, stagger, orchestration, translate, scale, rotate, skew, 3D tilt, crossfade, morph, scroll reveal, parallax, hover effect, and drag. The glossary is intended to help users describe desired animations when prompting AI.", "body_md": "A glossary of common animation patterns taught in the course. Use these names to describe what you want when prompting an AI.\n\nHow elements appear and disappear.\n\nFade in / Fade out — Element appears or disappears by changing opacity.\n\nSlide in — Element enters by sliding in from off-screen (left, right, top, or bottom).\n\nScale in — Element grows from smaller to full size as it appears, often paired with a fade.\n\nPop in — Element appears with a slight overshoot, like it bounces into place.\n\nReveal — Content is uncovered gradually, often by animating a clip-path or mask.\n\nEnter / Exit — The animation an element plays when it’s added to or removed from the screen.\n\nCoordinating multiple elements or moments.\n\nKeyframes — Defined points in an animation (0%, 50%, 100%) that the browser fills the gaps between.\n\nInterpolation / Tween — Generating all the in-between frames between a start and end value, so motion is continuous.\n\nStagger — Animate several items one after another with a small delay between each, creating a cascade.\n\nOrchestration — Deliberately timing multiple animations so they feel like one coordinated motion.\n\nDelay — Time before an animation starts.\n\nDuration — How long an animation takes.\n\nFill mode — Whether an element keeps its first or last frame's styles before the animation starts or after it ends (e.g. forwards).\n\nStepped animation — An animation that is divided into discrete steps, like a countdown timer.\n\nChanging an element’s position, size, or angle.\n\nTranslate — Move an element along the X or Y axis.\n\nScale — Make an element bigger or smaller.\n\nRotate — Spin an element around a point.\n\nSkew — Slant an element along the X or Y axis, shearing it out of its rectangular shape.\n\n3D tilt / Flip — Rotate in 3D space (rotateX / rotateY) to add depth.\n\nPerspective — How strong the 3D effect looks — a lower value exaggerates depth, like the viewer is closer.\n\nTransform origin — The anchor point a scale or rotation grows or spins from.\n\nOrigin-aware animation — An element animates out of its trigger, like a popover growing from the button that opened it instead of from its own center which is the default in CSS.\n\nConnecting one state, view, or element to another.\n\nCrossfade — One element fades out as another fades in, in the same spot.\n\nContinuity transition — A change that keeps the user oriented by visually connecting before and after. For example, making the same rectangle bigger and smaller.\n\nMorph — One shape smoothly turns into another shape, e.g. Dynamic Island.\n\nShared element transition — An element travels and transforms from one position into another, like a thumbnail expanding into a card.\n\nLayout animation — When an element’s size or position changes, it animates to the new spot instead of snapping.\n\nAccordion / Collapse — A section smoothly expands and collapses its height to show or hide content.\n\nDirection-aware transition — Content slides one way going forward and the opposite way going back, so navigation has a sense of direction.\n\nMotion tied to scrolling or navigating between views.\n\nScroll reveal — Elements fade or slide into place as they enter the viewport.\n\nScroll-driven animation — An animation whose progress is tied directly to scroll position.\n\nParallax — Background and foreground move at different speeds while scrolling, creating depth.\n\nPage transition — An animation that plays when navigating from one page or route to another.\n\nView transition — The browser morphs between two states or pages, connecting shared elements.\n\nResponding to the user’s actions.\n\nHover effect — Visual change when the cursor moves over an element.\n\nPress / Tap feedback — A subtle scale-down when an element is clicked, so it feels physical.\n\nHold to confirm — A progress effect that fills up while the user holds a button.\n\nDrag — Moving an element by grabbing it, often with momentum when released.\n\nDrag to reorder — Dragging items in a list to rearrange them, while the others shift to make room.\n\nSwipe to dismiss — Dragging an element off-screen to close it, like a drawer or toast.\n\nRubber-banding — Resistance and snap-back when you drag past a boundary (the iOS overscroll feel).\n\nShake / Wiggle — A quick side-to-side jitter signaling an error or rejected input.\n\nRipple — A circle expanding from the point of a tap, confirming the press.\n\nHow speed changes over an animation.\n\nEasing — The rate at which an animation speeds up or slows down.\n\nEase-out — Starts fast, ends slow. The default for most UI and anything responding to the user.\n\nEase-in — Starts slow, ends fast. Usually avoided; can feel sluggish.\n\nEase-in-out — Slow, fast, slow. Good for elements already on screen moving from A to B.\n\nLinear — Constant speed. Avoid for UI; reserve for spinners or marquees.\n\nCubic-bezier — A custom easing curve you define for precise control.\n\nAsymmetric easing — A curve that accelerates and decelerates at different rates. Feels more alive than a symmetric one.\n\nPhysics-based motion as an alternative to fixed-duration easing.\n\nSpring — Motion driven by physics (tension, mass, damping) rather than a set duration.\n\nStiffness / Tension — How strongly the spring pulls toward its target. Higher feels snappier.\n\nDamping — How quickly a spring settles. Lower damping means more bounce and oscillation.\n\nMass — How heavy the animated element feels. More mass makes it slower and more sluggish.\n\nBounce — A spring that overshoots and settles, adding playfulness.\n\nPerceptual duration — How long a spring feels finished, even though it keeps micro-settling underneath.\n\nMomentum — Motion that carries velocity, especially after a drag or interruption.\n\nVelocity — How fast and in which direction an element is moving. A spring carries it into the next animation when interrupted, so a flicked element keeps its speed.\n\nInterruptible animation — An animation that can be smoothly redirected mid-flight instead of finishing first.\n\nAnimations that run on their own.\n\nMarquee — Text or content that scrolls continuously in a loop.\n\nLoop — An animation that repeats, a set number of times or infinitely.\n\nAlternate (yoyo) — A loop that plays forward then reverses each iteration, instead of jumping back to the start.\n\nOrbit — An element circling around another in a continuous path.\n\nPulse — A gentle repeating scale or opacity change to draw attention.\n\nFloat — A gentle, continuous up-and-down drift that makes a static element feel alive and weightless.\n\nIdle animation — Subtle motion that plays while an element is just sitting there, waiting to be interacted with.\n\nThe small touches that separate good from great.\n\nBlur — A blur filter used to soften an element or mask tiny imperfections.\n\nClip-path — Clipping an element to a shape, used for reveals, masks, and before/after sliders.\n\nMask — Hiding or revealing parts of an element using a shape or gradient — like clip-path, but with soft, fadeable edges.\n\nBefore / after slider — A draggable divider that wipes between two overlaid images to compare them.\n\nLine drawing — An SVG path that draws itself in, like an invisible pen tracing it.\n\nText morph — Text that animates character by character when it changes, drawing attention to the new value.\n\nSkeleton / Shimmer — A placeholder with a moving sheen shown while content loads.\n\nNumber ticker — Digits rolling or counting up to a value.\n\nTabular numbers — Fixed-width digits so numbers don’t shift around as they change. Essential for tickers, timers, and counters.\n\nTypewriter — Text appearing one character at a time, as if being typed.\n\nWhat keeps motion smooth instead of stuttering.\n\nFrame rate (FPS) — Frames drawn per second. 60fps is the baseline for smooth motion; 120fps on newer displays.\n\nJank — Visible stutter when the browser drops frames because it can't keep up with the animation.\n\nDropped frame — A frame the browser missed its deadline to draw, causing a tiny hitch in motion.\n\nCompositing — Letting the GPU move or fade an element on its own layer without redoing layout or paint.\n\nwill-change — A CSS hint that an element is about to animate, so the browser can promote it to its own layer ahead of time.\n\nLayout thrashing — Animating properties like width, height, top, or left that force the browser to recalculate layout every frame, causing jank.\n\nConcepts that guide when and how to animate.\n\nPurposeful animation — Motion should serve a function — orient, give feedback, show relationships — not just decorate.\n\nAnticipation — A small wind-up in the opposite direction before a move, hinting at what's about to happen.\n\nFollow-through — Parts of an element keep moving and settle slightly after the main motion stops, adding weight.\n\nSquash & stretch — Deforming an element as it moves to convey weight, speed, and flexibility.\n\nPerceived performance — The right animation makes an interface feel faster, even when it isn’t.\n\nFrequency of use — The more often a user sees an animation, the shorter and subtler it should be.\n\nSpatial consistency — Animating so an element keeps its identity and position across states, so users never lose track of where things went.\n\nHardware acceleration — Animating transform and opacity lets the GPU keep motion smooth.\n\nReduced motion — Respecting the user’s prefers-reduced-motion setting by toning down or removing motion.\n\nJoin the waitlist to get **two free preview lessons ** and behind-the-scenes content every two weeks.\n\n**Enrollment opens on August 25th**, for 10 days.", "url": "https://wpnews.pro/news/animation-vocabulary", "canonical_source": "https://animations.dev/vocabulary", "published_at": "2026-06-13 04:22:37+00:00", "updated_at": "2026-06-13 04:49:39.285139+00:00", "lang": "en", "topics": ["developer-tools"], "entities": [], "alternates": {"html": "https://wpnews.pro/news/animation-vocabulary", "markdown": "https://wpnews.pro/news/animation-vocabulary.md", "text": "https://wpnews.pro/news/animation-vocabulary.txt", "jsonld": "https://wpnews.pro/news/animation-vocabulary.jsonld"}}