Animation DevTools
Daisuke Akatsuka
Mantaroh Yoshinaga
Brian Birtles
aim
explore possibilities for creating content from the browser, beginning with animation
investigation
- Interviews
- Processes of making animation
- Want to coordinate multiple kinds of content
- Want to apply animation to existing web content
- Importance of layered content
Art Animation Creators
- Want to focus on VR
- Important to be able to start easily
- Need to consider different types of animation used throughout the world
- Want to be able to combine resources
- Emphasised importance of the time axis
- Being able to create animations in the browser would be great since anyone could create animations
- Would like to use animation tools for education
interviews
An anime university professor
Web Animators
- Would love to be able to compare animations with a view to consistency
- In addition to being able to change visual effects like vertex/alpha/color, adjusting delay/duration/easing is even more important
- The time axis is the primary axis that we tweak
- We'd like to share the animation
- It's hard to implement interruption of animations
- Timeline synchronization including synchronizing with music
-
Tools that anyone can use and on any platform
- People love their animation tools
- Tools in the browser can be easily tried
- Associate with different resources
- Being able to re-use animations and effects
Animation expression
-
Common animation parameters
- Basic visual properties: vertex, alpha, color
- Timing properties: duration, delay, easing
(In terms of animation, the timing axis is the more important of the two)
- Interest in VR and 3D
summary
Strong interest in Web/Browser-based animation tools
idea
create material
define Avars
animate
tweak / debug
deploy
Timewaves
Unexpected Avars
Stateful Animations
Layered Animation
data:image/s3,"s3://crabby-images/aba75/aba7587b6809f528cb971070bf51bcec5f947a5f" alt=""
data:image/s3,"s3://crabby-images/ff555/ff555c6d6ee102111e9c153f23c9a714fdfc70c0" alt=""
data:image/s3,"s3://crabby-images/9ba92/9ba921080e3b0b1a72b45fe09000e0125d71819b" alt=""
Design Mode
data:image/s3,"s3://crabby-images/debef/debef581ae4b2fe4585cc01c0bd1f11fe619cf9d" alt=""
Ideas
data:image/s3,"s3://crabby-images/3e221/3e221a77a7e724f2adc6962cde18148ea59403c7" alt=""
Concept #1:
Timewaves
data:image/s3,"s3://crabby-images/aba75/aba7587b6809f528cb971070bf51bcec5f947a5f" alt=""
idea
create material
define Avars
animate
tweak / debug
deploy
"As a platform engineer, I want to inspect all the animations and see exactly what they're doing."
"As an app developer, I want to replay the interactions in my app and fine-tune their timing."
delay
data:image/s3,"s3://crabby-images/3ed25/3ed25786fdb8886246de192c2a59f5f841a36295" alt=""
data:image/s3,"s3://crabby-images/1abbb/1abbb9227e3dd354137fc14af22f48ebef8239ea" alt=""
animation
iterations
data:image/s3,"s3://crabby-images/cf887/cf8878ccc124de57786c9fd5411ac33d72be8ff8" alt=""
iteration start
data:image/s3,"s3://crabby-images/69f12/69f122b4e01372765a8eafde9fe96fb8fe8244a5" alt=""
easing
direction
data:image/s3,"s3://crabby-images/73be3/73be356d348a95cbce34a362516fc8b34716e3ed" alt=""
data:image/s3,"s3://crabby-images/d4d9e/d4d9e7d29bdb8b4137e67f286bfa1cb91913b92f" alt=""
data:image/s3,"s3://crabby-images/a3e02/a3e027e149905d1e7e22bd6e7303e5e3acc49ed4" alt=""
data:image/s3,"s3://crabby-images/b8f5b/b8f5b7b61e0b41a13bc05c314c9812b68557b7f7" alt=""
direction +
iterations +
iteration start +
easing
keyframes
data:image/s3,"s3://crabby-images/73ffd/73ffd0bde330c420a40b307e2cc39d3e2b540f08" alt=""
effect easing
keyframe easing
data:image/s3,"s3://crabby-images/951e7/951e7ab0de9588a7d914b335409cf259aedd2dd6" alt=""
data:image/s3,"s3://crabby-images/9cde8/9cde82b2911e210018ed696fb119a394577139da" alt=""
data:image/s3,"s3://crabby-images/e0ade/e0ade26ebaa024873ba0620b7c996eb02025cc02" alt=""
timing
keyframes
animation
const anim = div.animate(
[ { transform: 'translate(0px)',
backgroundColor: 'red' },
{ transform: 'translate(-20px)',
easing: 'ease-out' },
{ backgroundColor: 'blue' },
{ transform: 'translate(100px)',
backgroundColor: 'green' } ],
{
duration: 500,
iterationStart: 0.5,
iterations: 2.5,
easing: 'ease-in',
direction: 'alternate'
});
data:image/s3,"s3://crabby-images/cb125/cb12517fa52f0d04001649d3c500f11b8ef2cdd9" alt=""
Tweaking timing
data:image/s3,"s3://crabby-images/056f5/056f50ccd989a91dffd42349f3f7da8f1d33b1bd" alt=""
Tweaking timing
data:image/s3,"s3://crabby-images/05a0d/05a0dc40261594f12026100e64c131871942a605" alt=""
Tweaking timing
data:image/s3,"s3://crabby-images/cb051/cb051890ac1baf39c37ca5163c3c3e3da8fc3871" alt=""
Tweaking timing
data:image/s3,"s3://crabby-images/9dcc0/9dcc0d970ea8fbfc8182ed0e872ae55d82250a68" alt=""
Tweaking timing
data:image/s3,"s3://crabby-images/c0da4/c0da43e04653db78d802c78010a3f92422fbc7e1" alt=""
Tweaking keyframes
data:image/s3,"s3://crabby-images/7ebd4/7ebd433a783417a7ecbfee32f9948c8a461cbfd4" alt=""
Adjust keyframe offset
Adjust keyframe easing
Saving changes
CSS Animations
-
Changes to keyframes
-
Update original
@keyframes
(i.e. affects all users of rule)
-
Update original
-
Changes to timing graph
- Updates the winning declaration of each property
CSS Transitions
- Not possible to change repeat count etc.
- Updates the winning declarations of each property
Scripted animations
- Have a button / tab to generate source
Replay?
- DOM changes (e.g. FLIP method, node removal,
display:none
etc.) - Record and replay mode?
Concept #2:
Unexpected Avars
data:image/s3,"s3://crabby-images/b7b3b/b7b3b93d6ef97cc9642817530cdb617bd2eefdcd" alt=""
idea
create material
define Avars
animate
tweak / debug
deploy
"As an animator, I want to discover
new animation expressions."
"As an amateur animator, I want to make animations more easily."
Physical
phenomenon
Human
imagination
Animation expression
Physical
phenomenon
Human
imagination
New animation expression
Computer
support
idea
create material
define Avars
animate
tweak / debug
deploy
Concept #3:
Stateful Animations
data:image/s3,"s3://crabby-images/ff555/ff555c6d6ee102111e9c153f23c9a714fdfc70c0" alt=""
"As an app developer, I want to add animated transitions to my app's interactions"
data:image/s3,"s3://crabby-images/4ba83/4ba83132368acee7130964cba32c31aead660d6c" alt=""
data:image/s3,"s3://crabby-images/3ba4b/3ba4b35c44d8b3113eaef2f4d6af92f6bea1a176" alt=""
data:image/s3,"s3://crabby-images/d219c/d219c9e7aa66a1d81cb97eef1777f8400ef9e5e6" alt=""
data:image/s3,"s3://crabby-images/05042/050426d60bc162d1a90fd09d273e76dbeed4a144" alt=""
data:image/s3,"s3://crabby-images/723df/723df81467119d6f427d16eb233f2d8f5d078617" alt=""
data:image/s3,"s3://crabby-images/3c3ba/3c3ba501d0ce0ff61539ce9a4d40ad6d28781f53" alt=""
data:image/s3,"s3://crabby-images/8411e/8411ef067c779cc337940013276ae8e469bfefff" alt=""
Challenges
- How to work with interactions that modify the DOM?
- How to work with existing apps?
- Save format? CSS? SASS? JSON?
- Does this even need to be an animation tool, or is animation just part of a bigger state editing tool?
- Let's you build Web Components / React components?
idea
create material
define Avars
animate
tweak / debug
deploy
Concept #4:
Layered Animation
data:image/s3,"s3://crabby-images/debef/debef581ae4b2fe4585cc01c0bd1f11fe619cf9d" alt=""
"As a web creator, I want to create web animation content easily"
"As a web creators, I want to reuse web animation / animation's effect"
data:image/s3,"s3://crabby-images/6e7f5/6e7f59d01a7aad6862903d6b069bacf6d7c935e0" alt=""
What is Layered Animation?
Layered Animation ≒ Group of Animation Contents
What is Layer?
Animation Layer consist of Web Animation Contents.
data:image/s3,"s3://crabby-images/84e20/84e206a2ab26baef0c8e11a4bf23988a1430c86a" alt=""
Insert Layered Animation
We can insert web content as "Animation Layer"
Element.appendAnimation("./animatedWebPage.html");
Element.animate("./AnimationEffect.json");
Reuse Layered Animation
We can insert Layered Animation from URL.
And, we can insert Layered Animation effect from JSON file.
Element.appendAnimation("./animatedWebPage.html");
Element.animate("./AnimationEffect.json");
idea
create material
define Avars
animate
tweak / debug
deploy
Concept #5:
Design Mode
data:image/s3,"s3://crabby-images/effa2/effa28b7c011bc04f3f23eac16591ca0ea925b82" alt=""
"As a web developer, I want to make animated components like spinners and highlight effects"
data:image/s3,"s3://crabby-images/c0da4/c0da43e04653db78d802c78010a3f92422fbc7e1" alt=""
data:image/s3,"s3://crabby-images/3e221/3e221a77a7e724f2adc6962cde18148ea59403c7" alt=""
Design mode context
- A keyframe (limited to a single element)
- A CSS ruleset
- A state (cf. Stateful Animations)
- No context (sets element style?)
Other ideas
- Animation recommend
- Built-in physics engine
- Customize animation for myself
- Animation Hub (GitHub-like)
- co-development
- manage making histories
- Cut animation (for mobile)
idea
create material
define Avars
animate
tweak / debug
deploy
Timewaves
Unexpected Avars
Stateful Animations
Layered Animation
data:image/s3,"s3://crabby-images/aba75/aba7587b6809f528cb971070bf51bcec5f947a5f" alt=""
data:image/s3,"s3://crabby-images/ff555/ff555c6d6ee102111e9c153f23c9a714fdfc70c0" alt=""
data:image/s3,"s3://crabby-images/9ba92/9ba921080e3b0b1a72b45fe09000e0125d71819b" alt=""
Design Mode
data:image/s3,"s3://crabby-images/debef/debef581ae4b2fe4585cc01c0bd1f11fe619cf9d" alt=""
Summary
data:image/s3,"s3://crabby-images/3e221/3e221a77a7e724f2adc6962cde18148ea59403c7" alt=""
Animation devtools
By Brian Birtles
Animation devtools
- 2,156