通常の影は、box-shadowまたはtext-shadowを使用して簡単に実装できます。 しかし、内側の影を作る必要がある場合はどうでしょうか? この記事では、ほんの数行のコードでこのような影を作成する方法について説明します。
data:image/s3,"s3://crabby-images/2957e/2957e3686348670f27faf1571e946e942a7c2461" alt=""
構文
まず、CSSに影を実装する2つの主な方法を見てみましょう。
箱影
box-shadowコンストラクトには、いくつかの異なる値が含まれます。
水平オフセットと
垂直オフセット -それぞれ
水平オフセットと
垂直オフセット 。 これらの値は、オブジェクトが影を落とす方向を示します。
ぼかし半径と
広がり半径は少し複雑です。 彼らの違いは何ですか?
ぼかしの半径の値が異なる2つの要素の例を見てみましょう。
data:image/s3,"s3://crabby-images/c30fa/c30fa1d26c8d47cda363844c13ebd1d3421b5904" alt=""
影の端がぼやけています。
スプレッド半径の値が異なると、次のことがわかります。
data:image/s3,"s3://crabby-images/8a01c/8a01c772378f0a42cad60ed7260f3ef6a90ee370" alt=""
この場合、影が広い範囲に散らばっていることがわかります。
blur radiusと
spread radiusの値を指定しない場合、それらは0になります。
テキスト影
構文は
box-shadowに非常に似てい
ます :
data:image/s3,"s3://crabby-images/e66fd/e66fdb6e94cb8349f59e5f3d9de9232476a7b8ec" alt=""
値は似ていますが、
spread-shadowはありません。 使用例:
data:image/s3,"s3://crabby-images/b3e35/b3e3506343316f216ef0bbb49816f831cbf18a96" alt=""
ボックスシャドウのインセット
オブジェクト内の影を「回転」させるには、CSSに
インセットを追加する必要があります。
data:image/s3,"s3://crabby-images/e4900/e490083bb4d677a718d3947318e9d17d2b6e2845" alt=""
ボックスシャドウの基本的な構文を理解したので、内部シャドウの実装方法を理解するのは非常に簡単です。 値は同じで、色を追加できます(RGBを16進数):
data:image/s3,"s3://crabby-images/cc139/cc139ed02270ed0c588102674db9b94685aa8a12" alt=""
RGBカラー、アルファ値は影の透明度に関与します:
data:image/s3,"s3://crabby-images/3c00b/3c00bf54b2c576e445c3e73b1405ca0cbdc4632e" alt=""
影のある画像
画像に内側の影を追加することは、通常の
divよりも少し複雑です。 はじめに、通常の画像コードを次に示します。
<img src="1450826938745827786460" alt="airplane">
次のようなシャドウを追加できると想定するのは論理的です。
img { box-shadow: inset 0px 0px 10px rgba(0,0,0,0.5); }
しかし、影は見えません:
data:image/s3,"s3://crabby-images/9c47f/9c47fa80c6ff5d513844bf885b345ccd6af22464" alt=""
この問題を解決するにはいくつかの方法があり、それぞれに長所と短所があります。 それらのうちの2つを検討してください。 最初の方法は、画像を通常の
divにラップすることです。
<div> <img src="1450826938745827786460" alt="airplane"> </div>
div { height: 200px; width: 400px; box-shadow: inset 0px 0px 10px rgba(0,0,0,0.9); } img { height: 200px; width: 400px; position: relative; z-index: -2; }
data:image/s3,"s3://crabby-images/8b547/8b54736fb768493c093d80c7bbea5a7c0c41f225" alt=""
すべて動作しますが、HTMLとCSSマークアップを少し追加する必要があります。 2番目の方法は、目的のブロックの背景画像を設定することです。
<div> </div>
div { height: 200px; width: 400px; background: url(http://lorempixum.com/400/200/transport/2); box-shadow: inset 0px 0px 10px rgba(0,0,0,0.9); }
data:image/s3,"s3://crabby-images/8b547/8b54736fb768493c093d80c7bbea5a7c0c41f225" alt=""
内側のシャドウを使用すると、次のことが起こります。
data:image/s3,"s3://crabby-images/42d93/42d93b3a358551c6f0b3cab1bcff9f941bc310fe" alt=""
テキスト影のインセット
テキストの内側の影を実装するには、コードに
インセットを追加するだけで
は機能しません。
data:image/s3,"s3://crabby-images/437f3/437f325b77ce738af5102357c9a80b3ea6743f3a" alt=""
解決するには、最初に
h1見出しに適用して、暗い背景と明るい影を設定します。
h1 { background-color: #565656; color: transparent; text-shadow: 0px 2px 3px rgba(255,255,255,0.5); }
結果は次のとおりです。
data:image/s3,"s3://crabby-images/456b1/456b14a6268bc8f9cb68c48225a30c390fc77826" alt=""
秘密の成分
background-clipを追加し
ます 。これは、テキストを超えるすべてのものをカットします(暗い背景上):
h1 { background-color: #565656; color: transparent; text-shadow: 0px 2px 3px rgba(255,255,255,0.5); -webkit-background-clip: text; -moz-background-clip: text; background-clip: text; }
data:image/s3,"s3://crabby-images/36d96/36d966693c0c8fc8bac696d565d4527f8039d142" alt=""
ほとんど必要なものが判明しました。 ここで、テキストを少し暗く(アルファ)すると、結果は次のようになります。
data:image/s3,"s3://crabby-images/15ed0/15ed0b5dca545a7f8fcba1fdf33650709897e168" alt=""
ブラウザのサポート
caniuseのブラウザによるバックグラウンドクリップのサポートを確認してください。
data:image/s3,"s3://crabby-images/65631/65631db50b7fd7a65d7d278f93ba7df93e6fccd8" alt=""