今回のお題は、animation
プロパティで細かい動きをつくり込んでいる。
ボタンをつくる要素と静的なスタイル
HTMLドキュメントの<body>
要素に加えるボタンをつくる要素の記述と、<script>
要素に-prefix-freeを読み込んで、
data:image/s3,"s3://crabby-images/db160/db1605d7f11389b789274d620c473c420a7d5c51" alt="図1 ボタンの静的なスタイル 図1 ボタンの静的なスタイル"
<body>要素
<div class="container">
<div class="circle">
<div class="spinner">
</div>
<div class="label">
<p>Button</p>
</div>
</div>
</div>
<link href="https://fonts.googleapis.com/css?family=Raleway:400,900" rel="stylesheet">
<style>
html {
background-color: steelblue;
}
.container {
margin: 150px auto;
text-align: center;
background-color: steelblue;
}
.circle {
background-color: black;
width: 200px;
height: 200px;
border-radius: 50%;
display: inline-block;
overflow: hidden;
cursor: pointer;
}
.spinner {
background-color: #efefef;
height: 50px;
margin-top: 75px;
}
.label {
background-color: cornflowerblue;
height: 190px;
width: 190px;
position: relative;
margin: -120px auto;
border-radius: 50%;
}
.label p {
text-align: center;
margin: 40% auto;
display: inline-block;
font-family: 'Raleway', sans-serif;
font-weight: 900;
font-size: 24pt;
}
</style>
<script src="lib/prefixfree.min.js"></script>
ボタンにマウスポインタが重なったときのアニメーション
ボタンにマウスポインタが重なったときの基本的なアニメーションを加えよう。ボタンの縁として見える大もとの要素class
属性"circle"):hover
擬似クラスで白に変える。内側class
属性"label")transition
プロパティで定めている。ボタンの縁には待ち時間を加えたので、
transition: アニメーション時間 タイミング関数 待ち時間
.circle {
background-color: steelblue /* black */;
transition: 1s ease-in-out;
}
.circle:hover .label {
background-color: ;
transition: 0.3s ease-in-out;
}
.circle:hover .label p {
color: white;
transition: 0.3s ease-in-out;
}
.circle:hover {
background-color: white;
transition: 1s ease-in-out 0.8s;
}
.label {
transition: 0.3s ease-in-out;
}
.label p {
transition: 0.3s ease-in-out;
}
これで、
data:image/s3,"s3://crabby-images/49c57/49c570b297dbe1980f63936055a65905363f86ef" alt="図2 マウスポインタを重ねるとアニメーションするボタン 図2 マウスポインタを重ねるとアニメーションするボタン"
html {
background-color: steelblue;
}
.container {
margin: 150px auto;
text-align: center;
background-color: steelblue;
}
.circle {
background-color: steelblue;
width: 200px;
height: 200px;
border-radius: 50%;
display: inline-block;
overflow: hidden;
cursor: pointer;
transition: 1s ease-in-out;
}
.spinner {
background-color: #efefef;
height: 50px;
margin-top: 75px;
}
.circle:hover .label {
background-color: lightsteelblue;
transition: 0.3s ease-in-out;
}
.circle:hover .label p {
color: white;
transition: 0.3s ease-in-out;
}
.circle:hover {
background-color: white;
transition: 1s ease-in-out 0.8s;
}
.label {
background-color: cornflowerblue;
height: 190px;
width: 190px;
position: relative;
margin: -120px auto;
border-radius: 50%;
transition: 0.3s ease-in-out;
}
.label p {
text-align: center;
margin: 40% auto;
display: inline-block;
font-family: 'Raleway', sans-serif;
font-weight: 900;
font-size: 24pt;
transition: 0.3s ease-in-out;
}
ボタンの周囲を回るアニメーション
残るは、class
属性"spinner")@keyframes
規則clockwise)。マウスポインタが外れたときの逆回しも、animation
プロパティに定めた@keyframes
規則anti-clockwise)。:hover
擬似クラスには、@keyframes
規則scale)。それぞれの@keyframes
規則は後で示そう。
さらに、class
属性"spinner")filter
プロパティにblur()
関数でぼかした。引数にはぼけ幅を渡す。また、cubic-bezier()
はタイミング関数を4つの引数で定める。引数の与え方と値がどう変わるかについては、
.circle {
opacity: 0.99;
}
.spinner {
animation: anti-clockwise 1s ease-in-out;
transform: scaleY(2);
}
.circle:hover .spinner {
filter: blur(5px);
animation: clockwise 1s cubic-bezier(1, 0.22, 1, 0.92),
scale 2s 1s ease-in-out;
}
回転の時計回り@keyframes
は、
@keyframes clockwise {
from {
transform: rotate(0deg);
}
to {
transform: rotate(1080deg);
}
}
@keyframes anti-clockwise {
from {
transform: rotate(1080deg);
}
to {
transform: rotate(0deg);
}
}
@keyframes scale {
from {
transform: scaleY(2);
}
to {
transform: scaleY(4);
}
}
data:image/s3,"s3://crabby-images/a978b/a978b0467ac346fc4eb662014347bf1319a51551" alt="図3 ボタンにマウスポインタを重ねると左右の要素がくるくる回る 図3 ボタンにマウスポインタを重ねると左右の要素がくるくる回る"
html {
background-color: steelblue;
}
.container {
margin: 150px auto;
text-align: center;
background-color: steelblue;
}
.circle {
background-color: steelblue;
width: 200px;
height: 200px;
border-radius: 50%;
display: inline-block;
overflow: hidden;
cursor: pointer;
opacity: 0.99;
transition: 1s ease-in-out;
}
.spinner {
background-color: #efefef;
height: 50px;
margin-top: 75px;
animation: anti-clockwise 1s ease-in-out;
transform: scaleY(2);
}
.circle:hover .label {
background-color: lightsteelblue;
transition: 0.3s ease-in-out;
}
.circle:hover .label p {
color: white;
transition: 0.3s ease-in-out;
}
.circle:hover .spinner {
filter: blur(5px);
animation: clockwise 1s cubic-bezier(1, 0.22, 1, 0.92),
scale 2s 1s ease-in-out;
}
@keyframes clockwise {
from {
transform: rotate(0deg);
}
to {
transform: rotate(1080deg);
}
}
@keyframes anti-clockwise {
from {
transform: rotate(1080deg);
}
to {
transform: rotate(0deg);
}
}
@keyframes scale {
from {
transform: scaleY(2);
}
to {
transform: scaleY(4);
}
}
.circle:hover {
background-color: white;
transition: 1s ease-in-out 0.8s;
}
.label {
background-color: cornflowerblue;
height: 190px;
width: 190px;
position: relative;
margin: -120px auto;
border-radius: 50%;
transition: 0.3s ease-in-out;
}
.label p {
text-align: center;
margin: 40% auto;
display: inline-block;
font-family: 'Raleway', sans-serif;
font-weight: 900;
font-size: 24pt;
transition: 0.3s ease-in-out;
}
cubic-bezier()関数とopacityプロパティの役割
cubic-bezier()
関数について、cubic-bezier()
関数に渡す。たとえば、ease
は、
cubic-bezier(x1, y1, x2, y2)
「Cubic Bezier Generator」cubic-bezier()
関数の4つの引数値を入力すると、ease-in
にもっとめりはりを利かせた曲線になる。
data:image/s3,"s3://crabby-images/d65d4/d65d437528a5a4069ab957b7528a8b44b0dfa4f9" alt="図4 「Cubic Bezier Generator」で描いたcubic-bezier(1, 0.22, 1, 0.92)のグラフ 図4 「Cubic Bezier Generator」で描いたcubic-bezier(1, 0.22, 1, 0.92)のグラフ"
もうひとつ、opacity
プロパティをなぜ加えたのか、opacity
プロパティを不透明
.circle {
/* opacity: 0.99; */
}
data:image/s3,"s3://crabby-images/cc7d6/cc7d62b9c24337b89958cf3c3f5c232a0f069332" alt="図5 左右の要素が円形の外にはみ出す 図5 左右の要素が円形の外にはみ出す"