[JS]物理法則に基づいたさまざまなアニメーションを実装できるスクリプト -Dynamics.js
Post on:2015年6月30日
反発係数を使って弾み具合を変化させたり、運動量に応じて質量を変化させたり、引っ張ると引っ張り返され押すと押し返されるなど、物理法則に基づいた滑らかなさまざまなアニメーションを実装できるスクリプトを紹介します。
data:image/s3,"s3://crabby-images/e3b9d/e3b9d47d7a1f4331c3fe67cd072ac1f36b86c2da" alt="デモのアニメーション"
Dynamics.js
Dynamics.js -GitHub
Dynamics.jsのデモ
デモでは、物理法則に基づいたさまざまなアニメーションを楽しめます。
data:image/s3,"s3://crabby-images/912d5/912d544b00b22706b002f763936dec6c734260f3" alt="デモのキャプチャ"
いくつかアニメーションGIFにしてみました。
data:image/s3,"s3://crabby-images/66df4/66df43303a86a372f0e82b9b38c209949372b87c" alt="デモのアニメーション"
ローダーで使用しているボールは落下した後、反発係数を元にバウンドの高さが少しずつ小さくなります。
data:image/s3,"s3://crabby-images/88c41/88c414feb7b83425241d927c6ccd40805404015a" alt="デモのアニメーション"
メニューが開いた時、その運動量に応じて質量を変化させています。
data:image/s3,"s3://crabby-images/4f753/4f753338af355abc8252ecece9362c989495c175" alt="デモのアニメーション"
SVGで作成したボタンにもアニメーションを適用できます。
data:image/s3,"s3://crabby-images/3bf97/3bf97a03aa5178efa60ecd1a3628264441be6905" alt="デモのキャプチャ"
物理法則に基づいたさまざまな動きは、ブルーのプルダウンからいろいろ試すこともできます。
Dynamics.jsの使い方
Step 1: 外部ファイル
当スクリプトを外部ファイルとして記述します。
<body> ... コンテンツ ... <script src="dynamics.js"></script> </body>
Step 2: JavaScript
適用するエレメントを指定し、アニメーションを設定します。
elは要素、el内のプロパティはアニメーションさせるプロパティと値、typeはアニメーションの種類、frequency, frictionはアニメーションの細かい設定、durationはタイミングです。
var el = document.getElementById("logo") dynamics.animate(el, { translateX: 350, scale: 2, opacity: 0.5 }, { type: dynamics.spring, frequency: 200, friction: 200, duration: 1500 })
SVGの実装例です。
var path = document.querySelector("path") dynamics.animate(path, { d: "M0,0 L0,100 L100,50 L0,0 Z", fill: "#FF0000", rotateZ: 45, // rotateCX and rotateCY are the center of the rotation rotateCX: 100, rotateCY: 100 }, { friction: 800 })
sponsors