概要

animation-range-startは、CSSでアニメーションの再生を開始する位置を設定するためのプロパティです。このプロパティを使うことで、アニメーションを特定の位置から開始させることができ、視覚効果を調整する際に役立ちます。たとえば、アニメーション全体を再生せず、一部分だけを再生したいときや、特定のタイミングからアニメーションを始めたい場合に効果的です。しかし、animation-range-startは現在、実験的なプロパティであり、ブラウザのサポートが限られているため、利用には注意が必要です。

animation-range-startの基本

構文

animation-range-start: <percentage> | <time>;
  • percentage
    アニメーションの再生開始位置をパーセンテージで指定します。たとえば、50%と設定すると、アニメーションの半分の位置から再生が開始されます。
  • time
    秒(s)やミリ秒(ms)で開始位置を指定します。たとえば、2sと指定すると、アニメーションの2秒目から再生が始まります。

使用例

基本的な使用例 - アニメーションを途中から開始

以下の例では、animation-range-startを使用して、アニメーションを50%の位置から開始します。

@keyframes fadeInOut {
    0% {
        opacity: 0;
    }
    50% {
        opacity: 1;
    }
    100% {
        opacity: 0;
    }
}
.box {
    width: 100px;
    height: 100px;
    background-color: #3498db;
    animation: fadeInOut 4s infinite;
    animation-range-start: 50%;
}

この設定により、アニメーションは「fadeInOut」の50%の位置、つまりフェードインが完了した状態から再生されます。

時間指定でのアニメーション開始

次に、アニメーションの再生を時間指定で制御する例です。以下のコードでは、アニメーションが2秒後から開始されます。

@keyframes slideRight {
    0% {
        transform: translateX(0);
    }
    100% {
        transform: translateX(200px);
    }
}
.slider {
    width: 100px;
    height: 100px;
    background-color: #e74c3c;
    animation: slideRight 5s infinite;
    animation-range-start: 2s;
}

この設定では、アニメーションが開始されてから2秒経過した時点で再生がスタートします。

注意点

  • ブラウザのサポート状況
    animation-range-startは現在、ほとんどのブラウザでサポートされていない実験的なプロパティです。使用する場合は、ブラウザの互換性情報を確認し、代替手段を検討する必要があります。
  • 代替手段の検討
    現在のブラウザ環境では、animation-delayやJavaScriptでアニメーションの開始タイミングを制御するのが一般的です。特に複雑なアニメーションの場合は、JavaScriptを使って正確な制御が可能です。
  • パフォーマンスの考慮
    animation-range-startを使用するとアニメーションの負荷が高くなる場合があります。ブラウザの対応状況を確認し、パフォーマンスへの影響を考慮して設定を行いましょう。

animation-range-startの対応ブラウザ

  • Chrome: 非サポート
  • Firefox: 非サポート
  • Safari: 非サポート
  • Edge: 非サポート
  • Opera: 非サポート 現時点では、主要なブラウザでanimation-range-startはサポートされていません。そのため、実際のプロジェクトでの使用は避け、他の方法でアニメーションの開始位置を制御することをおすすめします。

まとめ

animation-range-startは、アニメーションの再生を特定のタイミングから開始させることができる便利なプロパティです。しかし、実験的な段階にあるため、現時点での使用は推奨されません。代替手段として、animation-delayやJavaScriptを使用してアニメーションの開始位置を調整する方法が現実的です。今後のブラウザの進化に期待しつつ、最適なアニメーション表現を追求しましょう。