今回のお題は、animation
プロパティを使う。transition
プロパティよりも細かくつくり込めるので、
円形の縁取りを与えたボタン
ボタンのテキストのフォントには、<script>
要素で-prefix-freeを読み込んである
<link href="https://fonts.googleapis.com/css?family=Oswald" rel="stylesheet">
<script src="lib/prefixfree.min.js"></script>
data:image/s3,"s3://crabby-images/f39de/f39de49d96e5ac3f981dd7b09fd7afd0acb4903b" alt="図1 Google FontsのOswald 図1 Google FontsのOswald"
<body>
要素にはつぎのコード1のように、<div>
要素class
属性"button")<a>
要素class
属性"button-item")<span>
要素にテキストを書き加えた。
<div class="button">
<a class="button-item" href="#">
<span>Puls Button</span>
</a>
</div>
<style>
要素に以下のコード2のCSSを定めると、:before
擬似要素で加えた。border
プロパティを与えるとともに、border-radius
プロパティの値を50%とすることで円形にしている。
data:image/s3,"s3://crabby-images/7f890/7f8905e5619d30acfc6d5454143b238fbc7ee20d" alt="図2 ボタンの静的なスタイル 図2 ボタンの静的なスタイル"
.button {
position: absolute;
display: flex;
align-items: center;
top: 50%;
left: 50%;
margin-left: -80px;
margin-top: -80px;
width: 160px;
height: 160px;
text-align: center;
}
.button:before {
position: absolute;
content: "";
top: 0;
left: 0;
width: 160px;
height: 160px;
border: 1px solid deeppink;
border-radius: 50%;
}
.button-item {
color: deeppink;
font-size: 40px;
font-family: 'Oswald', sans-serif;
line-height: 1em;
text-decoration: none;
}
.button span {
position: absolute;
top: 1em;
}
ボタンの円形の縁取りを鼓動のようにアニメーションさせる
それでは、class
属性"button"):hover
擬似クラス)、
:before
擬似要素に、animation
プロパティを定める。@keyframes
規則transform
プロパティにscale()
関数で伸縮させて、
.button:hover:before {
animation: pop 0.5s;
}
@keyframes pop {
0% {
transform: scale(1);
}
50% {
transform: scale(1.2);
}
90% {
transform: scale(0.9);
}
100% {
transform: scale(1);
}
}
data:image/s3,"s3://crabby-images/8a7f3/8a7f3bba455c28bd3b0953253064f4ee00fbf42c" alt="図3 ポインタを重ねると円が鼓動のようなアニメーションで伸縮する 図3 ポインタを重ねると円が鼓動のようなアニメーションで伸縮する"
.button {
position: absolute;
display: flex;
align-items: center;
top: 50%;
left: 50%;
margin-left: -80px;
margin-top: -80px;
width: 160px;
height: 160px;
text-align: center;
}
.button:before {
position: absolute;
content: "";
top: 0;
left: 0;
width: 160px;
height: 160px;
border: 1px solid deeppink;
border-radius: 50%;
}
.button:hover:before {
animation: pop 0.5s;
}
@keyframes pop {
0% {
transform: scale(1);
}
50% {
transform: scale(1.2);
}
90% {
transform: scale(0.9);
}
100% {
transform: scale(1);
}
}
.button-item {
color: deeppink;
font-size: 40px;
font-family: 'Oswald', sans-serif;
line-height: 1em;
text-decoration: none;
}
.button span {
position: absolute;
top: 1em;
}
塗りの円を中心から広げてアニメーションさせる
:after
擬似要素でもうひとつ塗りの円を加える。線が塗りになるほかは、:before
と同じ初期設定だ。それを、transform
プロパティにscale()
関数で小さく縮めておく
.button:before, .button:after {
/* 初期設定 */
}
.button:after {
background-color: deeppink;
transform: scale(0.1);
}
data:image/s3,"s3://crabby-images/03b8e/03b8e5681f5473e094e72238f70716c21eff8e3d" alt="図4 :after擬似要素で加えられた塗りの小さな円 図4 :after擬似要素で加えられた塗りの小さな円"
塗りの円の:after
擬似要素にanimation
プロパティで、@keyframes
規則opacity
プロパティは0にしておく。アニメーションには伸縮に加え、opacity
プロパティ)animation-fill-mode
プロパティをforwards
にすると、
.button:after {
opacity: 0;
transform: scale(0.1);
}
.button:hover:after {
animation: pulse 0.5s;
animation-fill-mode: forwards;
}
@keyframes pulse {
50% {
transform: scale(1.2);
opacity: 1;
}
70% {
transform: scale(0.9);
opacity: 1;
}
100% {
transform: scale(1);
opacity: 1;
}
}
data:image/s3,"s3://crabby-images/2098f/2098fd6478deea6b4aa7a37b0770d4e7a2ed5213" alt="図5 ポインタを重ねると塗りの円がアニメーションで広がって伸縮する 図5 ポインタを重ねると塗りの円がアニメーションで広がって伸縮する"
さらに、<span>
要素)transition
プロパティでつぎのようにちょっとしたアニメーションを加える。マウスポインタを重ねると、z-index
プロパティを定めた。
.button span {
z-index: 1;
transition: 0.5s;
}
.button:hover span {
color: white;
transform: translateY(-5px);
}
これでボタンにマウスポインタを重ねると、@keyframes
規則のキーフレームの定めが細かいとはいえ、
.button {
position: absolute;
display: flex;
align-items: center;
top: 50%;
left: 50%;
margin-left: -80px;
margin-top: -80px;
width: 160px;
height: 160px;
text-align: center;
}
.button:before, .button:after {
position: absolute;
content: "";
top: 0;
left: 0;
width: 160px;
height: 160px;
border: 1px solid deeppink;
border-radius: 50%;
}
.button:after {
background-color: deeppink;
opacity: 0;
transform: scale(0.1);
}
.button:hover:before {
animation: pop 0.5s;
}
.button:hover:after {
animation: pulse 0.5s;
animation-fill-mode: forwards;
}
@keyframes pop {
0% {
transform: scale(1);
}
50% {
transform: scale(1.2);
}
90% {
transform: scale(0.9);
}
100% {
transform: scale(1);
}
}
@keyframes pulse {
50% {
transform: scale(1.2);
opacity: 1;
}
70% {
transform: scale(0.9);
opacity: 1;
}
100% {
transform: scale(1);
opacity: 1;
}
}
.button-item {
color: deeppink;
font-size: 40px;
font-family: 'Oswald', sans-serif;
line-height: 1em;
text-decoration: none;
}
.button span {
position: absolute;
top: 1em;
z-index: 1;
transition: 0.5s;
}
.button:hover span {
color: white;
transform: translateY(-5px);
}