Animating SVG with CSS and JavaScript
data:image/s3,"s3://crabby-images/1de20/1de206f23d104b6f2e0a28f62129a167ff00a6a5" alt=""
SVG ... what?
Scalable Vector Graphics
-
Animating with CSS
- Transition & Transform & Rotate
- Keyframes Animation
- Demo: Alien Ship / Letter Drawing
-
Animating with CSS and Javascript*
- Demo: Fullstack
Text
* we will not cover details on this
data:image/s3,"s3://crabby-images/21ec5/21ec5bdcb5cb59621bc8fd9d7401959557318903" alt=""
Vector
Made of mathematical calculations that form objects and lines.
Resolution-independent: Can be printed at any size/resolution.
Easily convertible to raster
cons: It is not the best format for photographs or photo-like elements with blends of color.
Raster
Made of pixels
cons: It cannot be scaled up without losing quality.
Depending on the complexity of the image, conversion to vector may be time consuming.
CSS'ing SVGs
<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 -50 400 200">
<g class="gear">
<circle class="gear-bg" fill="#39ADD1" cx="200" cy="50" r="90"></circle>
<path class="gear-icon" fill="#FFFFFF" d="M231.9,10.9c-1.8-0.6-3.6-0.6-5.1,0.3L216.2,17c-1.5-0.9-3-1.2-4.2-1.8l-3.1-11.5
6,1.
......... (mathematical calculations....more about this)
2.7-3.9-3.3l-11.5-3c-0.3-1.5-1.2-3-1.8-4.2l5.7-10.6c0.9-1.5,0.9-3.3,0.3-5.1c-0.6-1.8-1.8-3-3-4.2
C234.6,12.4,233.1,11.5,231.9,10.9z M211.4,38.8c6.1,6,6.1,16.4,0.1,22.4s-16.3,6.1-22.4,0c-6.1-6.1-6.1-16.4-0.1-22.4
S205,32.5,211.4,38.8z"></path>
</g>
</svg>
Before CSS: SVG Presentation Attributes
gear.svg
Shared with CSS |
SVG-Only |
---|---|
|
clip-rule, flood-color, flood-opacity, stop-opacity, kerning, tech-anchor, color-profile, color-rendering, fill, fill-opacity, fill-rule, marker, marker-end, marker-mid, marker-start, stroke, stroke-width, stop-color, lighting-color, enable-background, dominant-baseline, color-interpolation-filters, color-interpolation, glyph-orientation-horizontal, glyph-orientation-vertical, shape-rendering, baseline-shift, alignment-baseline, stroke-miterlimit, stroke-linejoin, stroke-linecap, stroke-dashoffset, stroke-dasharray, stroke-opacit y |
In SVG2, more presentation attributes will be added.
CSS recipe
Transition: <property> <duration> <time-function> <delay>
Defaults to all
Defaults to ease
Defaults to 0
example:
.gear-icon {
transition: transform .4s ease-out;
transform-origin: 50% 50%;
}
data:image/s3,"s3://crabby-images/c18b7/c18b739885c7f8a8fac399b304ec9ebdd600e3d1" alt=""
Animating SVGs with CSS
Using CSS Transitions
Rotate & Scale
data:image/s3,"s3://crabby-images/17eaf/17eaf6addee2017564c0fc17b20c50bc635377d8" alt=""
data:image/s3,"s3://crabby-images/52a8d/52a8dfd9fb0b31ca88661b0df30aed57153b338d" alt=""
Source: Treehouse
data:image/s3,"s3://crabby-images/c18b7/c18b739885c7f8a8fac399b304ec9ebdd600e3d1" alt=""
Checkout time functions in Dev tool !
transform-origin: SVG vs HTML
transform-origin (default value)
HTML Elements (div, ::before, etc.)
SVG Elements (circle, rect, etc.)
50% 50%
(the center of the element itself, calculated relative to its box model)
0 0
(top left corner of the SVG canvas, not of the element itself)
data:image/s3,"s3://crabby-images/305a2/305a2f40719b55a92ea9c53e85b12d8c29d83f26" alt=""
transform-origin: SVG vs HTML
Example: 45deg Rotation
<!DOCTYPE html>
<div style="width: 100px; height: 100px; background-color: orange"> </div>
<svg style="width: 150px; height: 150px; background-color: #eee">
<rect width="100" height="100" x="25" y="25" fill="orange" />
</svg>
Setting transform-origin in SVG using CSS
- Using percentage values: The value is set relative to the element's bounding box, which includes the stroke used to draw its border.
- Using absolute values: The origin is set relative to the SVG canvas.
Setting transform-origin in SVG using CSS
Example
<!DOCTYPE html>
<style>
div, rect {
transform-origin: 50% 50%;
}
</style>
Using CSS Animations & Transforms
Keyframes
Keyframe Animation
Text
data:image/s3,"s3://crabby-images/38cdb/38cdb79ce60b1453929163e2acb6594fcdaf8d5e" alt=""
The list of transitions should happen over the course of the animation
Example: bouncing shape
codepen source
data:image/s3,"s3://crabby-images/65eb9/65eb9393b8ad229d6dc6de4e98fa05f7be20ae6b" alt=""
Demo: Alien Ships
<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink" version="1.1" x="0px" y="0px" viewBox="0 0 450 250" enable-background="new 0 0 450 250" xml:space="preserve" class="svg ufo-building">
<g class="ufo-building-float">
<g class="building">
.........
<g class="building-body">
.......
</g>
<g class="building-flames">
.......
</g>
</g>
<g class="ufo-big">
........
<g class="ufo-big-lights">
.........
</g>
</g>
<g class="ufo-small">
.........
</g>
</g>
</svg>
data:image/s3,"s3://crabby-images/6dfeb/6dfebb874d48c5012201f0023cc953ae5a0cd13f" alt=""
data:image/s3,"s3://crabby-images/feca8/feca844c67467241071c28ad0d22a05e8efa3582" alt=""
data:image/s3,"s3://crabby-images/44d7b/44d7bffb8af9550ae903a833c2cbcfbd71c8f948" alt=""
"building"
"ufo-big"
"ufo-small"
All three are grouped in the "ufo-building-float" class
index.html
keyframes
@keyframes ufo-building-float {
0% {transform: translateY(0)}
25% {transform: translateY(-25px)}
75% {transform: translateY(25px)}
100% {transform: translateY(0)}
}
.ufo-building-float {
animation: ufo-building-float 5s linear infinite;
}
@keyframes ufo-big {
0% {opacity: 0}
15%, 70% {opacity: 1}
85%, 100% {opacity: 0}
}
@keyframes ufo-small {
0%, 10% {opacity: 0}
25%, 85% {opacity: 1}
100% {opacity: 0}
}
.ufo-big {
animation: ufo-big 5s ease infinite;
}
.ufo-small {
animation: ufo-small 5s ease infinite;
}
@keyframes ufo-big-lights {
0% {fill: #000}
20% {fill: #fbcb43}
40%, 100% {fill: #000}
}
.ufo-big-lights-light {
animation: ufo-big-lights 2.5s ease infinite;
}
.ufo-big-lights--2 {animation-delay: .2s}
.ufo-big-lights--3 {animation-delay: .4s}
.ufo-big-lights--4 {animation-delay: .6s}
.ufo-big-lights--5 {animation-delay: .8s}
@keyframes building-flames {
0% {transform: scale(1, 1)}
50% {transform: scale(1, 1.1)}
100% {transform: scale(1, 1)}
}
.building-flames path {
fill: #d84437;
animation : building-flames .15s ease infinite;
transform-origin: center top;
}
Moving up and down
hide and show
style.css
Animate Recipe
@keyframes kfName {
0% { <property> : <value>; } //from here
20% { <property> : <value>; }
40%, 100% { <property> : <value>; } // to here
}
<property name / animate target> {
animation: kfName <duration> <delay> <iteration>; //iteration can be infinite / finite
}
Creating the Illusion
data:image/s3,"s3://crabby-images/e6aa7/e6aa79779972d3579d5ebb83c78a7023d21a7f9d" alt=""
<svg viewBox="0 0 500 500" xmlns="http://www.w3.org/2000/svg">
<defs/>
<path class="letterS" d=" ...... "/>
</svg>
svg {
display: block;
margin: 2em, auto 0;
width: 70%;
}
@keyframes offset {
100% {
stroke-dashoffset: 0;
}
}
.letterS {
fill: #FFF;
stroke: #000;
stroke-width: 2;
stroke-dasharray: 800; // in JS: pathclassName.getTotalLength()
stroke-dashoffset: 800;
animation: offset 5s linear forwards;
}
index.html
style.css
And animating other attributes that simply cannot be set/styled/changed via CSS..
Animating SVG with Javascript
Demo: Fullstack drawing
data:image/s3,"s3://crabby-images/49948/4994828441f53c1b253172a058eaf0af239b0329" alt=""
Sources
<Library>
Javascript: Snap
<Tool>
Creating SVG: Adobe Illustrator / Boxy SVG (Chrome Extension)
<Course/Tutorial>
1. SVG Basics (Treehouse)
2. Web Animation (CodeSchool)
3. Animating SVG with CSS (Treehouse)
data:image/s3,"s3://crabby-images/f5cdd/f5cddd0ba447b5e1168c21dc5af021e060acf2e5" alt=""
Questions?
Animating SVG with CSS and Snap.svg
By Karen mao
Animating SVG with CSS and Snap.svg
Fronteers, October 2014, Amsterdam.
- 1,557