進捗率を計算してスクロールアニメーションを制御する方法

進捗率を計算してスクロールアニメーションを制御する方法

おじいちゃん

おじいちゃん

計算方法

まずは計算に必要な要素を洗い出してみましょう。
計算に必要なのは下記4つになります。

  1. 始点
  2. 終点
  3. 始点と終点の差
  4. スクロール値

始点と終点の差は、終点から始点を引くことで求めることができます。

 
始点と終点の差 = 終点 – 始点

具体的な例に当てはめて考えていきましょう。

計算をしてみよう

500pxから1200pxの間でスクロールアニメーションさせたい場合、始点が500px終点1200pxとなります。始点と終点の差はさきほどあげた式から700pxになります。

  1. 始点(500px)
  2. 終点(1200px)
  3. 始点と終点の差(700px)
  4. スクロール値(スクロール値により変化)

上記の要素を使って、進捗率が始点、中点、終点のときの値を求めてみましょう。

  • 始点(進捗率0.0%) 0 = 0px(スクロール値) / 700px(始点と終点の差)
  • 中点(進捗率0.5%) 0.5 = 350px(スクロール値) / 700px(始点と終点の差)
  • 終点(進捗率1.0%) 1 = 700px(スクロール値) / 700px(始点と終点の差)

つまり進捗率は下記の式で求めることができます。

 
進捗率 = スクロール値 / 始点と終点の差

始点と終点の差はさきほど終点から始点を引くことで計算していたので、

 
進捗率 = スクロール値 / (終点 - 始点)

となります。

これで0pxから700pxをスクロールした際の進捗率を計算できます。

しかし、今回求めたい値は500pxから1200pxの間の進捗率でした。スクロール値の開始した値が500px、終了した値が1200pxになるように、変化するスクロール値から始点を引きます。

 
進捗率 = (スクロール値 – 始点) / (終点 – 始点)

これで500pxから1200pxをスクロールした際の進捗率の計算方法がわかりました。それでは、スクロールアニメーションを実装するためのJavaScriptを見ていきましょう。

実装方法

var start = 500;    //始点
var end = 1200;     //終点

function eventScroll(){
    //スクロール値を取得
    var scrollTop = window.scrollY;
    //スクロールの度に500px-1200pxの間かどうかを判定
    if(start <= (scrollTop + window.innerHeight) && (scrollTop + window.innerHeight) <= end){
        //進捗率を計算
        var prog = (scrollTop - start) / ( end - start );
        /*--- CSSのプロパティに進捗率を代入して計算 ---*/
    }
}
//windowのスクロールイベントを付与
window.addEventListener('scroll',eventScroll);

上が進捗率を求めるためのJavaScriptになります。

進捗率は英語でprogressなので、スクロールアニメーション系のライブラリでは、progと略されたりしますね。

まとめ

いかがでしたでしょうか。

「今まで適当な値いれてアニメーションさせてました」「いまいち制御できない」という方たちが少しでも考えやすくなってもらえたら幸いです。

そろそろ秋が来て、冬が来ますね。
おでんの季節です。
コンビニでおでんを買うときは、大根と厚揚げとこんにゃくの3つと決めているのですが、今年は違う組み合わせにしてみようかと思ってしてます。大根だけは変えられませんけどね。

楽しみです。染みた大根は沁みます。

ぐっばい〜。

LIGはWebサイト制作を支援しています。ご興味のある方は事業ぺージをぜひご覧ください。

Webサイト制作の実績・料金を見る

この記事のシェア数

おじいちゃん
おじいちゃん フロントエンドエンジニア / 後藤 寛一

フロントエンドエンジニアのおじいちゃんと言います。本当は24歳です。よろしくお願いします。

このメンバーの記事をもっと読む
デザイン力×グローバルな開発体制でDXをトータル支援
お問い合わせ 会社概要DL