[JS]SVGを使った滑らかで美しいアニメーションのプログレスバーを簡単に実装できるスクリプト -ProgressBar.js
Post on:2014年10月20日
SVGを使った滑らかで美しいアニメーションのプログレスバーを簡単に実装できるスクリプトを紹介します。
レスポンシブ対応で、描く形状はライン・スクエア・サークル・トライアングル以外にもパスでオリジナルの形状にすることもできます。
data:image/s3,"s3://crabby-images/62f1b/62f1b4cac1b07a207ac59e7baa39d56d7ea801f7" alt="デモのアニメーション"
ProgressBar.jsのデモ
デモはChrome, Safari, Firefox, Opera, IEは9+でご覧ください。
data:image/s3,"s3://crabby-images/6b90b/6b90bad1af029b15ba16538b3b7de32de57ba6ed" alt="サイトのキャプチャ"
まずは一番シンプルなラインのデモから。
※各デモをアニメーションGIFにしてみました。
data:image/s3,"s3://crabby-images/e4b14/e4b14b9dda8b34ed5be2719ba3aa0cff967bd1b8" alt="デモのアニメーション"
Line: オレンジ色のラインをアニメーションで描きます。
data:image/s3,"s3://crabby-images/d11d2/d11d22ff6565f9abbb4d2266b46b0ec20547f02c" alt="デモのアニメーション"
Circle: これもシンプルなデモで円の外周を描きます。
data:image/s3,"s3://crabby-images/ddeda/ddeda1a364585b5c8e9457d74e8c4d8d510974fe" alt="デモのアニメーション"
Clock: 円の外周とカウントを連動させます。
data:image/s3,"s3://crabby-images/073a8/073a8cf13dc38d7e4d09a81cd5eb885d0f03344e" alt="デモのアニメーション"
Custom Shaped Path: 最後はパスを設定して描きます。
ProgressBar.jsの使い方
Step 1: 外部ファイル
当スクリプトを外部ファイルとして記述します。
<body> ... <script src="js/progressbar.js"></script> </body>
Step 2: HTML
一つ目のデモ「Line」を例に。
プログレスバーを配置する要素をdivなどで用意します。
<div class="example-container" id="example-line-container"></div>
Step 3: JavaScript
「Line」を描くには下記のように指定します。
var element = document.getElementById('example-line-container'); var line = new ProgressBar.Line(element, { color: "#FCB03C", trailColor: "#aaa" }); line.animate(1, function() { line.animate(0); })
「Circle」を描く時は「circle」を使い、ストロークのサイズを指定します。
var element = document.getElementById('example-circle-container'); var circle = new ProgressBar.Circle(element, { color: "#FCB03C", strokeWidth: 2, fill: "#aaa" }); circle.animate(1, function() { circle.animate(0); })
sponsors