Working with Living Style Guide Animation
Extendible,
Composable
Working on a large team means ability to iterate is key
//---- timing ----//
$class-slug: t !default;
@for $i from 1 through 7 {
.#{$class-slug}-#{$i} {
animation-duration: 0.8 - (0.1s * $i);
}
}
Timing Increment
Like h1, h2
//---- ease ----//
$easein-quad: cubic-bezier(0.55, 0.085, 0.68, 0.53);
$easeout-quad: cubic-bezier(0.25, 0.46, 0.45, 0.94);
$easein-back: cubic-bezier(.57, .07, .6, 1.71);
$easeout-back: cubic-bezier(0.175, 0.885, 0.32, 1.275);
Ease Variables
Brand-specific
.entrance {
animation-timing-function: $easeout-quad;
}
.entrance-emphasis {
animation-timing-function: $easeout-back;
}
.exit {
animation-timing-function: $easein-quad;
}
.exit-emphasis {
animation-timing-function: $easein-back;
}
Ease Reuse
Meaningful classes
//animations
@keyframes pop {
0% {
transform: scale(0.9) translateZ(0);
}
100% {
transform: scale(1) translateZ(0);
}
}
.pop {
animation-name: pop;
@extend .anim-fill-both;
}
Animations
Only what you need
.anim-fill-both {
animation-fill-mode: both;
}
Extend/Mixins
Animation Fill Mode or Common Uses
Of Note:
- t5 is like h5- body copy
- ~250ms is a good response time, under 400ms is under the doherty threshold (re-popularized by Halt and Catch Fire)
- Hook into animation-play-state and native JS for single movements
- Larger movements need components
Buy-in
data:image/s3,"s3://crabby-images/7137d/7137dd816c11fdb05e1efb8e2d72dee8dc4da5c4" alt=""
data:image/s3,"s3://crabby-images/0a8eb/0a8eba3f5423ed9734441e5f738cbfd3ad4901ad" alt=""
Build Trust
This pen.
data:image/s3,"s3://crabby-images/86886/868866e6fd61aa8fa5ac720614e8a3f52fa05b62" alt=""
Main Principle:
Design everything first, slowly unveil things.
data:image/s3,"s3://crabby-images/51698/51698939a5563fd0034104b446c16ad26d7124ad" alt=""
Prototyping
Thumbnails-
Notes for yourself
data:image/s3,"s3://crabby-images/79100/7910098c49022cd5a4b67e591ef2e96280196fc5" alt=""
data:image/s3,"s3://crabby-images/fe837/fe83733d10137e76ffc7a7d862f878feb595c8a9" alt=""
Storyboards-
Notes for collaboration
data:image/s3,"s3://crabby-images/2d48a/2d48a2650b0aa4fbd3f6afc55b9b0228161da35a" alt=""
Low Fidelity Prototypes
Show the motion
data:image/s3,"s3://crabby-images/cc476/cc476828c70386d3feb286403a0a06761f5168c7" alt=""
Low Fidelity Prototypes-
screenshot to build on top of
Principle
FramerJS
After Effects
Keynote
Straight up code
Tools
Communication
Get small projects off the ground to build trust
Align with the why
Google Material Design
!=
Motion Design
Branding
Have an opinion
Style and Branding:
Not one size fits all
Adhering to your branding means motion solves the problem for your users.
- What happens repeatedly
- Easing structures
- User flow
- Toggle on/off?
Style and Branding
data:image/s3,"s3://crabby-images/978cc/978ccfd07278e73891fb39fdacd14c743638f012" alt=""
this pen.
Responsive
What needs to change, what doesn't
onMouseOver || onTouchStart
Responsive Interactions
Responsive Consistency
- SVG is great for responsive
- Canvas can be resolution-independant
- Eases should stay the same, but timing can be adjusted
- Specify initial-scale=1.0 in the meta tag so that the device is not waiting the required 300ms
- Must either start from a larger touch-target (40px x 40px or greater) or use @media(pointer:coarse)as support allows
Invisible animation
UX Animation & UX Choreography
Mental Maps
context-shifting in UX
data:image/s3,"s3://crabby-images/cd0ee/cd0ee090759bb3417881963f7e51eb2ada172f08" alt=""
data:image/s3,"s3://crabby-images/3236a/3236a2365de9da7d8fd446f5ed50243858c49972" alt=""
data:image/s3,"s3://crabby-images/6f5da/6f5da8cde5672c9455b9525f00021e236c6c2181" alt=""
Spacial Maps - Cognitive Leaks
Kathy Sierra- Badass: Making Users Awesome
Interruption
data:image/s3,"s3://crabby-images/b71b8/b71b834ab096fb2c48abe081b7fc474554bef2c4" alt=""
Spacial Maps - connecting two states
data:image/s3,"s3://crabby-images/78a9d/78a9df7d46f95a94e93344509821c6bf923efa5a" alt=""
data:image/s3,"s3://crabby-images/624dd/624dd5898b9220303a996908326db1e1e584447f" alt=""
data:image/s3,"s3://crabby-images/19d95/19d95b781d96d566ee42fdbed95b5393edbb6c85" alt=""
data:image/s3,"s3://crabby-images/d76f4/d76f42bb0d5392c0a348f6c9226bb23af11ae188" alt=""
From this CSS-Tricks Article
data:image/s3,"s3://crabby-images/f7af0/f7af04c60bb5786f0a57019f712e588ff51db63a" alt=""
Revealing
- xxx Modals die 4eva xxx
- breaks context
- "brute force" UX
data:image/s3,"s3://crabby-images/1bb4a/1bb4a565f30677336e955108a023980962ec90c0" alt=""
data:image/s3,"s3://crabby-images/b50ce/b50ceb1b7f3417c6dc1e785979fdd323826d1fe6" alt=""
modals suck!
it's not them, it's their typical UX pattern!
Revealing
data:image/s3,"s3://crabby-images/c643a/c643a4e27cb4d3518251983def65e066a6b16474" alt=""
Perceived Performance
Perceived Performance
Custom Loaders:
Viget did an experiment and found that despite some individual variation, novel loaders as a whole had a higher wait time and lower abandon rate than generic ones
data:image/s3,"s3://crabby-images/6f268/6f2686bd89dc829cf3d821c1108e06448b5a2bfc" alt=""
data:image/s3,"s3://crabby-images/1adc1/1adc1ab66e7e34b00c509e0f34ca0380d73d7d85" alt=""
22 sec
14 sec
Loading times
Treehouse: Percieved Performance
data:image/s3,"s3://crabby-images/faeef/faeefbb8086697bed6669b2cd5b5115aac96acc2" alt=""
Spatial Awareness
data:image/s3,"s3://crabby-images/4a4b2/4a4b20a54904dc2a8bc185f8f8fb9d87faca6643" alt=""
Interaction
Right tool for the right job
data:image/s3,"s3://crabby-images/e3e70/e3e705c3d3fa168bdfac61329b21be6cba1b9028" alt=""
Performance
- Opacity
- Transforms
- Hardware Acceleration
@mixin accelerate() {
transform: translateZ(0);
backface-visibility: hidden;
perspective: 1000px;
}
.foo {
@include accelerate(transform);
}
data:image/s3,"s3://crabby-images/75ba5/75ba55d28c8d5355a988e20fedbaceb260cfc0f0" alt=""
src: Wealthfront
Case Study: Netflix
Hardware Acceleration vs Control
this pen.
You're on a trip exploring a city
You're trying to build out the day of activities
Lonely Planet
data:image/s3,"s3://crabby-images/d6f45/d6f45e688645128349441972afc91115d098070f" alt=""
but...
data:image/s3,"s3://crabby-images/7c669/7c6690563d27ae461061b1fc7543ffd148627b09" alt=""
data:image/s3,"s3://crabby-images/aaa9c/aaa9c6a6012f9299726f5a6b84645afbd20964bc" alt=""
data:image/s3,"s3://crabby-images/b9bac/b9bac34f2748fb05733c8a08ae9210995c575042" alt=""
data:image/s3,"s3://crabby-images/4f8dc/4f8dc54157b3ad231155060e774d74234937a15d" alt=""
data:image/s3,"s3://crabby-images/dd127/dd1275bad1b884c0f1e07287f2cc1bb2ca47a35c" alt=""
data:image/s3,"s3://crabby-images/ceb6b/ceb6bc9cd693258251129e419c73be0687c9e1f0" alt=""
data:image/s3,"s3://crabby-images/4e2f6/4e2f6d8e94066c277186953d907a9797ea9d52aa" alt=""
Google Maps
data:image/s3,"s3://crabby-images/aa6d2/aa6d2c1319bfd916af70293699764ba6fede6480" alt=""
data:image/s3,"s3://crabby-images/beb7d/beb7d46fd003aa6f40208505989c80392cc83448" alt=""
data:image/s3,"s3://crabby-images/67e0d/67e0ddefbd23292eaf3cbfd1f9110f538f4e5fbd" alt=""
data:image/s3,"s3://crabby-images/5cff5/5cff54de70c97bbc939e43544f5f48486277a76f" alt=""
data:image/s3,"s3://crabby-images/1c57b/1c57b88b6f2d1ba3731fd3e52645471a0d563ef8" alt=""
data:image/s3,"s3://crabby-images/7619d/7619ddab2ce269e55f19c0561be21861364b3449" alt=""
This Demo.
Thank you!
Working with Living Style Guide Animation
By sdrasner
Working with Living Style Guide Animation
- 6,906