ホームページ >ウェブフロントエンド >CSSチュートリアル >CSSを使用してすりガラス効果を実現するにはどうすればよいですか?

CSSを使用してすりガラス効果を実現するにはどうすればよいですか?

青灯夜游
青灯夜游転載
2021-01-11 18:34:114593ブラウズ

CSSを使用してすりガラス効果を実現するにはどうすればよいですか?次の記事では、CSSを使用してすりガラス効果を実現する方法を紹介します。一定の参考値があるので、困っている友達が参考になれば幸いです。

CSSを使用してすりガラス効果を実現するにはどうすればよいですか?

実際、すりガラスのぼかし効果は技術的には比較的簡単で、CSS フィルターの blur 属性を使用するだけです。ただし、優れたすりガラス効果を実現するには、多くの細部に注意を払う必要があります。


#たとえば、ページの中央にあるテキスト領域を変更する必要がある場合、上の図を曇りガラス効果に変換する場合、最初に思い浮かぶのは、それに透明度を設定し、ぼかしフィルターを追加することです:

.content {
    background-color: rgba(0,0,0,0.3);
    -webkit-filter: blur(2px);
    -moz-filter: blur(2px);
    -ms-filter: blur(2px);
    -o-filter: blur(2px);
    filter: blur(2px);    
}

しかし、生成される効果は次のとおりです:

この失敗例から 2 つの結論が得られます:

1. 要素に直接ブラーを使用すると、ブラーが発生します。テキストがぼやけないようにするには、ぼかし効果を個別に適用するための追加レイヤーの必要性を取り除きます。

2. ぼかし効果はその背後にある要素には適用されないため、コンテンツ領域を使用して背景と同じ背景画像を使用し、ぼかしをかける必要があります。

まずは最初の問題を解決しましょう:

もう 1 つのレベルを追加する方法は、要素の追加ではなく、疑似要素によって行われます。

.content {
    z-index: 1;
}
.content:after {
    content: '';
    position: absolute;
    top: 0;
    left: 0;
    right: 0;
    bottom: 0;
    background-color: rgba(255,255,255,0.8);
    z-index: -1;
}

注意点が2つあり、擬似要素はホスト要素のサイズをwidth:100%、height:100%で継承できないため、コンテンツのサイズは;コンテンツの下に擬似要素を配置する場合はz-index:-1を設定し、背景画像に隠れないようにする場合はコンテンツにz-index:1を設定します。

効果:

##次に、コンテンツにも同じ設定を行います::背景画像の後。

上の図のように、同じbackground-positionとbackground-sizeを設定しても、画像の中央部分と背景サイズが同じになります。大きな背景はまだ正常に接合されていません。

この問題の解決策は非常に簡単で、background-attachment:fixed 属性を追加してぼかすだけです。

.content {
    background-position: center top;
    background-size: cover;
}
.content::after {
    background-image: url(xxx.jpg);
    background-position: center top;
    background-size: cover;
    background-attachment: fixed;
    -webkit-filter: blur(20px);
    -moz-filter: blur(20px);
    -ms-filter: blur(20px);
    -o-filter: blur(20px);
    filter: blur(20px);
}

基本的に望んでいた効果が得られたことがわかります。唯一の欠点は、要素の端のぼかし効果が弱まっていることです。 。この問題を解決するために、擬似要素の範囲を拡張すると同時に、その効果がコンテンツの範囲を超えないようにするために、overflow:hidden 属性を設定します。

.content {
  overflow: hidden;
}
.content::after {
  margin: -30px;
}

こんな完璧なすりガラス効果が完成しました ブラウザウィンドウのサイズをいくら変えても、コンテンツ部分の背景画像はすべてbackground-attachment属性のおかげで、背景との接合が非常にうまくなります。

デモとソース コードのアドレス:

https://darylxyx.github.io/Demo/blur/

https://github. com /Darylxyx/css-collection/tree/master/blur

プログラミング関連の知識については、

プログラミング学習 をご覧ください。 !

以上がCSSを使用してすりガラス効果を実現するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事はcnblogs.comで複製されています。侵害がある場合は、admin@php.cn までご連絡ください。