新たに始まった連載
ボタンのもとになる静的スタイル
まず、<body>
要素に書くコードだ。プッシュボタンにする<a>
要素は、class
属性"button"を定めた<p>
要素に含める。それをさらに、class
属性"container"の<div>
要素で包んだ。
<body>
<div class="container">
<p class="button"><a href="#">Push Button</a></p>
</div>
</body>
プッシュボタンのもととなるスタイル<style>
要素で定める。まだ、
data:image/s3,"s3://crabby-images/f9926/f992671e8f1909ca22f0c5d2c85b6609533995e0" alt="図1 プッシュボタンのもととなるスタイル 図1 プッシュボタンのもととなるスタイル"
<style>
body {
background: white;
font: 30px sans-serif;
}
.button a {
display: block;
width: 200px;
margin: 0 auto;
padding: 10px;
color: white;
text-align: center;
text-decoration: none;
background-color: lightseagreen;
}
</style>
ボタンの角に丸みを加える
ボタンらしく、border-radius
だ。プロパティの値には、
border-radius: 角丸の半径
プッシュボタンclass
属性"button")<a>
要素に、
.button a {
border-radius: 5px;
}
data:image/s3,"s3://crabby-images/559f2/559f2b81a36e4742554bcb192b7079d2e108877c" alt="図2 プッシュボタンの角に丸みを加えた 図2 プッシュボタンの角に丸みを加えた"
影でボタンを立体的に見せる
さらに、box-shadow
プロパティでボタンに影を加えたい。オプションinset
は後で用いる。水平・
box-shadow: [inset] 水平のずれ 垂直のずれ ぼけ幅 カラー
プッシュボタンclass
属性"button")<a>
要素には、rgba()
関数で半透明にしている。
.button a {
box-shadow: 4px 4px 8px rgba(0, 0, 0, 0.6);
}
data:image/s3,"s3://crabby-images/bbc36/bbc361e89cc745efba09179e2315d3425648cbe2" alt="図3 プッシュボタン外側の右下に影が加わった 図3 プッシュボタン外側の右下に影が加わった"
box-shadow
プロパティには、inset
を与えると、
.button a {
box-shadow: inset 4px 4px 4px rgba(255, 255, 255, 0.6),
inset -4px -4px 4px rgba(0, 0, 0, 0.4);
}
data:image/s3,"s3://crabby-images/66665/6666586aec453a2409ec23332fdd4acb4c6a09b9" alt="図4 プッシュボタン内側の左上に白と右下に黒の影が加わった 図4 プッシュボタン内側の左上に白と右下に黒の影が加わった"
プッシュボタンの外側右下の影も加えた<style>
要素の記述はつぎのとおりだ。これで、
body {
background: white;
font: 30px sans-serif;
}
.button a {
display: block;
width: 200px;
margin: 0 auto;
padding: 10px;
color: white;
text-align: center;
text-decoration: none;
background-color: lightseagreen;
border-radius: 5px;
box-shadow: inset 4px 4px 4px rgba(255, 255, 255, 0.6),
inset -4px -4px 4px rgba(0, 0, 0, 0.4),
4px 4px 8px rgba(0, 0, 0, 0.6);
}
data:image/s3,"s3://crabby-images/1e141/1e1417da2cea500168dc13f8035bd69d2ba90463" alt="図5 出っ張ったプッシュボタンの右下に影を加えた表現 図5 出っ張ったプッシュボタンの右下に影を加えた表現"
マウスポインタを重ねたときのボタンの表現
プッシュボタンにマウスポインタを重ねたとき、<a>
要素の:hover
擬似クラスで、transform
プロパティで位置を少し下げる。translateY()
関数が垂直位置を動かす。これで、
.button a:hover {
background-color: mediumaquamarine;
box-shadow: inset 2px 2px 4px rgba(255, 255, 255, 0.6),
inset -2px -2px 4px rgba(0, 0, 0, 0.4),
2px 2px 4px rgba(0, 0, 0, 0.8);
transform: translateY(2px);
}
data:image/s3,"s3://crabby-images/11830/118305816da81b9881bbffd24773e6817999a4a6" alt="図6 マウスポインタを重ねたときのプッシュボタンの表現 図6 マウスポインタを重ねたときのプッシュボタンの表現"
プッシュボタンのボックスの位置を下げるには、transform
プロパティでなく、top
プロパティで変えることもできる。だが、transform
は位置を動かすだけでなく、
.button a {
position:relative;
}
.button a:hover {
top: 2px;
}
プッシュボタン上でマウスボタンを押したときの表現は、<a>
要素の:active
擬似クラスにつぎのように定める。内側inset
オプション)
.button a:active {
color: gainsboro;
background-color: darkcyan;
box-shadow: inset -2px -2px 4px rgba(255, 255, 255, 0.4),
inset 2px 2px 4px rgba(0, 0, 0, 0.8),
1px 1px 1px rgba(0, 0, 0, 0.6);
transform: translateY(4px);
}
data:image/s3,"s3://crabby-images/4e4e2/4e4e225f5dd9dad5d8fa0ed8be8ba3e3b3811306" alt="図7 マウスボタンを押したときのプッシュボタンの表現 図7 マウスボタンを押したときのプッシュボタンの表現"
ベンダープレフィックスと-prefix-free
ひとつ注意しておかなければならないのは、transform
プロパティの仕様だ。本稿執筆時現在では-webkit
を加えることになる。
.button a:active {
-webkit-transform: translateY(4px);
transform: translateY(4px);
}
この連載はCSS3のアニメーションでどのような表現ができるのか、<script>
要素に読み込めばよく
<script src="lib/prefixfree.min.js"></script>
data:image/s3,"s3://crabby-images/5d646/5d64617a82229cbf505f2511b6359c488fa197be" alt="図8 -prefix-freeサイト 図8 -prefix-freeサイト"
ボタンに滑らかなアニメーションを定める
擬似クラス:hover
と:active
に定めたプッシュボタンの見た目は、transition
プロパティ<a>
要素にプロパティを定めれば、
.button a {
transition: 0.5s;
}
プッシュボタンを押したときの動き:active
擬似クラス)transition
プロパティを定め直してもよい。だが、transition-duration
プロパティを使うことにしよう。
.button a:active {
transition-duration: 0.2s;
}
これで今回のお題のプッシュボタンのアニメーションはでき上がった。ここまで書いてきた<script>
と<style>
の定めはつぎのコード1のとおりだ。併せて、
<script src="lib/prefixfree.min.js"></script>
<style>
body {
background: white;
font: 30px sans-serif;
}
.button a {
display: block;
width: 200px;
margin: 0 auto;
padding: 10px;
color: white;
text-align: center;
text-decoration: none;
background-color: lightseagreen;
border-radius: 5px;
box-shadow: inset 4px 4px 4px rgba(255, 255, 255, 0.6),
inset -4px -4px 4px rgba(0, 0, 0, 0.4),
4px 4px 8px rgba(0, 0, 0, 0.6);
transition: 0.5s;
}
.button a:hover {
background-color: mediumaquamarine;
box-shadow: inset 2px 2px 4px rgba(255, 255, 255, 0.6),
inset -2px -2px 4px rgba(0, 0, 0, 0.4),
2px 2px 4px rgba(0, 0, 0, 0.8);
transform: translateY(2px);
}
.button a:active {
color: gainsboro;
background-color: darkcyan;
box-shadow: inset -2px -2px 4px rgba(255, 255, 255, 0.4),
inset 2px 2px 4px rgba(0, 0, 0, 0.8),
1px 1px 1px rgba(0, 0, 0, 0.6);
transform: translateY(4px);
transition-duration: 0.2s;
}
</style>