30
25

More than 3 years have passed since last update.

SCSSで使うcubic-bezier値を変数化しておく

Last updated at Posted at 2015-05-20

元ネタ

Easing Function
http://easings.net/ja

  • イージングアニメーションの種類がたくさんライブラリ化されていて、JSで使用できる。
  • Compass Ceaser プラグインを入れればSCSS上で ceaser($easing名) として呼び出すことが可能。

SCSS変数にした

Ceaserプラグインを入れなくてもSCSS上で呼び出せるようにしたいと思って、
SCSSの変数として移植させていただいたのが下記。元ネタ のeasing名とcubic-bezier値をまま移植しています。

例:transitionやanimationの中で使える
.hoge {
  transition: all .2s $easeOutCubic;
}

コード

variable.scss
/*
 * Easing function
 * Original:http://easings.net/
 */

$easeInSine:     cubic-bezier(0.47,  0,     0.745, 0.715);
$easeOutSine:    cubic-bezier(0.39,  0.575, 0.565, 1    );
$easeInOutSine:  cubic-bezier(0.445, 0.05,  0.55,  0.95 );
$easeInQuad:     cubic-bezier(0.55,  0.085, 0.68,  0.53 );
$easeOutQuad:    cubic-bezier(0.25,  0.46,  0.45,  0.94 );
$easeInOutQuad:  cubic-bezier(0.455, 0.03,  0.515, 0.955);

$easeInCubic:    cubic-bezier(0.55,  0.055, 0.675, 0.19 );
$easeOutCubic:   cubic-bezier(0.215, 0.61,  0.355, 1    );
$easeInOutCubic: cubic-bezier(0.645, 0.045, 0.355, 1    );
$easeInQuart:    cubic-bezier(0.895, 0.03,  0.685, 0.22 );
$easeOutQuart:   cubic-bezier(0.165, 0.84,  0.44,  1    );
$easeInOutQuart: cubic-bezier(0.77,  0,     0.175, 1    );

$easeInQuint:    cubic-bezier(0.755, 0.05,  0.855, 0.06 );
$easeOutQuint:   cubic-bezier(0.23,  1,     0.32,  1    );
$easeInOutQuint: cubic-bezier(0.86,  0,     0.07,  1    );
$easeInExpo:     cubic-bezier(0.95,  0.05,  0.795, 0.035);
$easeOutExpo:    cubic-bezier(0.19,  1,     0.22,  1    );
$easeInOutExpo:  cubic-bezier(1,     0,     0,     1    );

$easeInCirc:     cubic-bezier(0.6,   0.04,  0.98,  0.335);
$easeOutCirc:    cubic-bezier(0.075, 0.82,  0.165, 1    );
$easeInOutCirc:  cubic-bezier(0.785, 0.135, 0.15,  0.86 );
$easeInBack:     cubic-bezier(0.6,  -0.28,  0.735, 0.045);
$easeOutBack:    cubic-bezier(0.175, 0.885, 0.32,  1.275);
$easeInOutBack:  cubic-bezier(0.68, -0.55,  0.265, 1.55 );

$ease まで書いた所でエディタがサジェストを出してくれるので便利。
これら全部を使い分けるというよりは、今回はこれとこれを使う、
というのを決めてさらに変数でラップしておくのも良さそう。

ただし「Elastic」や「Bounce」などベジエ曲線で表現できないものは非対応なので、JSで呼び出すか、CSSだけの場合は @keyframe で書く必要がある。

追記

通常のtiming-functionも同じノリで書きたいときは、

$ease:      ease;        // = cubic-bezier(0.25, 0.1, 0.25, 1.0)
$linear:    linear;      // = cubic-bezier(0.0,  0.0, 1.0,  1.0)
$easeIn:    ease-in;     // = cubic-bezier(0.42, 0,   1.0,  1.0)
$easeOut:   ease-out;    // = cubic-bezier(0,    0,   0.58, 1.0)
$easeInOut: ease-in-out; // = cubic-bezier(0.42, 0,   0.58, 1.0)

も変数化しておくといいかも...?
(例:$easeOutQuintを 普通のease-outにしたいときに Quintを削るだけでいいので)

30
25
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
30
25