成人怡红院-成人怡红院视频在线观看-成人影视大全-成人影院203nnxyz-美女毛片在线看-美女免费黄

站長資訊網
最全最豐富的資訊網站

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

怎么利用CSS實現圓角及波浪效果?下面本篇文章帶大家了解一下怎么巧用CSS濾鏡構建圓角及波浪效果,希望對大家有所幫助!

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

本文,將另辟蹊徑,介紹一種使用濾鏡去構建圓角的獨特方式。【推薦學習:css視頻教程】

首先,我們來看這樣一個圖形:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

一個矩形,沒什么特別的,代碼如下:

div {     width: 200px;     height: 40px;     background-color: #000; }

如果,我們現在需要給這個矩形的兩端加上圓角,像是這樣,該怎么做呢:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

So easy,不過就是加個 border-radius 而已:

div {     width: 200px;     height: 40px;   + border-radius: 40px;     background-color: #000; }

好,那如果,不再是直線,而是一條曲線,希望曲線兩端,帶有圓角,像是這樣,又該怎么辦呢:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

到這,基本上觸及了傳統 CSS 的天花板,想通過一個屬性搞定這個效果是不太可能了。

當然,有這樣一種方式,通過首尾兩端,利用兩個偽元素,實現兩個圓形,疊加上去:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

emm,這也是一個可行的方案,主要是定位會稍微有點點麻煩。那么除了這個方式以及直接使用 SVG 外,還有沒有其他方法能夠實現帶圓角的曲線?

有!在 CSS 中,我們還可以通過 filter: contrast() 配合 filter: blur() 這對組合來實現這個圖形。

filter: contrast() 配合 filter: blur() 的奇妙化學作用

在 神奇的濾鏡!巧妙實現內凹的平滑圓角 一文中,其實已經介紹過這個組合的另類用法。

經常閱讀我的文章的小伙伴,對 filter: contrast() 配合 filter: blur() 的組合一定不陌生,上經典的一張圖:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

單獨將兩個濾鏡拿出來,它們的作用分別是:

  • filter: blur(): 給圖像設置高斯模糊效果。

  • filter: contrast(): 調整圖像的對比度。

但是,當他們“合體”的時候,產生了奇妙的融合現象。

仔細看兩圓相交的過程,在邊與邊接觸的時候,會產生一種邊界融合的效果,通過對比度濾鏡把高斯模糊的模糊邊緣給干掉,利用高斯模糊實現融合效果。

當然,重點來了,blur 與 contrast 濾鏡的組合不僅能用于這種融合效果,其特殊的性質使得它們的組合可以將直角變成圓角!

先看看之前的一個例子:

首先,我們只需要實現這樣一個圖形:

<div class="g-container">     <div class="g-content">         <div class="g-filter"></div>     </div> </div>
.g-container {     position: relative;     width: 300px;     height: 100px;          .g-content {         height: 100px;                  .g-filter {             height: 100px;             background: radial-gradient(circle at 50% -10px, transparent 0, transparent 39px, #000 40px, #000);         }     } }

得到這樣一個簡單的圖形:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

看到這里,肯定會疑惑,為什么這個圖形需要用 3 層 div 嵌套的方式?不是一個 div 就足夠了嗎?

是因為我們又要運用 filter: contrast()filter: blur() 這對神奇的組合。

我們簡單改造一下上述代碼,仔細觀察和上述 CSS 的異同:

.g-container {     position: relative;     width: 300px;     height: 100px;          .g-content {         height: 100px;         filter: contrast(20);         background-color: white;         overflow: hidden;                  .g-filter {             filter: blur(10px);             height: 100px;             background: radial-gradient(circle at 50% -10px, transparent 0, transparent 29px, #000 40px, #000);         }     } }

我們給 .g-content 添加了 filter: contrast(20)background-color: white,給 .g-filter 添加了 filter: blur(10px)

神奇的事情發生了,我們得到了這樣一個效果:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

通過對比度濾鏡把高斯模糊的模糊邊緣給干掉,將原本的直角,變成了圓角,Amazing。

通過一個 Gif 圖更直觀的感受:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

完整的代碼你可以戳這里:CodePen Demo – Smooth concave rounded corners By filter

https://codepen.io/Chokcoco/pen/JjroBPo

通過濾鏡實現圓角圓弧

到這里,你應該知道如何通過直角圓弧得到圓角圓弧了。就是借助 filter: contrast() 配合 filter: blur() 的組合。

直接上代碼:

div {     position: relative;     width: 250px;     height: 250px;     filter: contrast(20);     background-color: #fff;     overflow: hidden; } div::before {     content: "";     position: absolute;     top: 0;     left: 0;     bottom: 0;     right: 0;     filter: blur(7px);     border: 25px solid transparent;     border-bottom: 25px solid #000;     border-radius: 50%; }

效果如下:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

通過 Gif 看,更加直觀:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

CodePen Demo — Arc with rounded corners

https://codepen.io/Chokcoco/pen/bGveoPY

使用 filter: contrast() 配合 filter: blur() 實現波浪效果

好了,有了上面的鋪墊,我們再來看一個有意思的。使用 filter: contrast() 配合 filter: blur() 實現波浪效果。

在之前,我們如果想使用純 CSS,實現下述的波浪效果,是非常的困難的:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

這種波浪效果,通常會使用在優惠券等切圖中:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

在之前,我們是怎么去做的呢?如果不切圖,使用純 CSS 的話,需要使用兩層漸變進行疊加,大概是這樣,感受一下:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

其代碼也比較復雜,需要不斷的調試漸變,使兩個徑向漸變吻合:

div {     position: relative;     width: 400px;     height: 160px;     background: linear-gradient(90deg, #945700 0%, #f49714 100%);          &::before,     &::after {         content: "";         position: absolute;         top: 0;         right: 0;         bottom :0;     }     &::before {         width: 10px;         background-image: radial-gradient(circle at -5px 10px, transparent 12px, #fff 13px, #fff 0px);         background-size: 20px 20px;         background-position: 0 15px;     }     &::after {         width: 15px;         background-image: radial-gradient(circle at 15px 10px, #fff 12px, transparent 13px, transparent 0px);         background-size: 20px 40px;         background-position: 0 15px;     } }

那么,如果使用 filter: contrast() 配合 filter: blur() 的話,整個過程將會變得非常簡單。

我們只需要實現這樣一個圖形:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

這個圖形使用漸變是容易得到的:

div {     background: radial-gradient(circle at 20px 0, transparent, transparent 20px, #000 21px, #000 40px);     background-size: 80px 100%; }

按照上文介紹的技巧,只需要應用上 filter: contrast() 配合 filter: blur(),就能將銳利的直角轉化成圓角。我們嘗試一下:

<div class="g-container">     <div class="g-inner"></div> </div>
.g-container {     position: relative;     margin: auto;     height: 200px;     padding-top: 100px;     filter: contrast(20);     background-color: #fff;     overflow: hidden; }  .g-inner {     position: relative;     height: 200px;     background: radial-gradient(circle at 20px 0, transparent, transparent 20px, #000 21px, #000 40px);     background-size: 80px 100%;     filter: blur(10px) }

可以寫在 1 個 DIV 里面(通過元素和它的偽元素構造父子關系),也可以用 2 個,都可以,問題不大。

得到如下所示的波浪圖形:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

我們希望它波浪的地方的確是波了,但是我們不希望的地方,它也變成了圓角:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

這是 filter: blur() 的一個問題,好在,我們是可以使用 backdrop-filter() 去規避掉這個問題的,我們簡單改造下代碼:

.g-container {     position: relative;     width: 380px;     padding-top: 100px;     filter: contrast(20);     background-color: #fff;     overflow: hidden;          &::before {         content: "";         position: absolute;         top: 0;         left: 0;         bottom: 0;         right: 0;         backdrop-filter: blur(10px);         z-index: 1;     } } .g-inner {     position: relative;     width: 380px;     height: 100px;     background: radial-gradient(circle at 20px 0, transparent, transparent 20px, #000 21px, #000 40px);     background-size: 80px 100%; }

這樣,我們就實現了一份完美的波浪效果:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

部分同學可能對上面的 padding-top 100px 有所疑惑,這個也是目前我所發現的一個 BUG,暫未解決,不影響使用,你可以嘗試將 padding-top: 100px 替換成 height: 100px。

基于這種方式實現的波浪效果,我們甚至可以給它加上動畫,讓他動起來,也非常的好做,簡單改造下代碼:

.g-inner {     position: relative;   - width: 380px;   + width: 480px;     height: 100px;     background: radial-gradient(circle at 20px 0, transparent, transparent 20px, #000 21px, #000 40px);     background-size: 80px 100%;   + animation: move 1s infinite linear;  }  @keyframes move {     100% {         transform: translate(-80px, 0);     } }

通過一個簡單的位移動畫,并且使之首尾幀一致,看上去就是連續的:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

完整的代碼,你可以戳這里:CodePen Demo — Pure CSS Wave

https://codepen.io/Chokcoco/pen/PoRzeav

SVG 濾鏡,讓使用更簡單

這就結束了嗎?沒有!上述雙濾鏡的組合固然強大,確實還是有一點麻煩。

在強大的群友的補充下,再補充一種 SVG 濾鏡的方案。這里,對于大部分場景,我們可以借助 SVG 濾鏡,在 CSS 中一行引入,實現同樣的功能。

看這樣一個 DEMO,我們有這樣一個三角形:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

我們想通過它得到一個圓角三角形:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

借助 SVG 濾鏡,其實也可以快速達成,省去了上面還需要疊加一個 filter: contrast() 的煩惱:

<div class="g-triangle"></div> <svg width="0">     <filter id="blur" color-interpolation-filters="sRGB">       <feGaussianBlur stdDeviation="10" />       <feComponentTransfer>           <feFuncA type="table" tableValues="0 0 10"/>       </feComponentTransfer>     </filter> </svg>
div {         border: 60px solid transparent;         border-left: 120px solid #f48;         filter: url(#blur); }

效果如下:

聊聊怎么使用CSS濾鏡實現圓角及波浪效果

是的,利用 filter: url(xxx) 可以快速引入一個定義好的 SVG 濾鏡。也可以這樣,直接嵌入到 URL 中:

div {         border: 60px solid transparent;         border-left: 120px solid #f48;         filter: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='blur' color-interpolation-filters='sRGB'%3E%3CfeGaussianBlur stdDeviation='10'/%3E%3CfeComponentTransfer%3E%3CfeFuncA type='table' tableValues='0 0 10'/%3E%3C/feComponentTransfer%3E%3C/filter%3E%3C/svg%3E#blur"); }

完整的代碼,你可以戳這里:CodePen Demo — triangle with rounded corners and shadow

https://codepen.io/Chokcoco/pen/QWmEXPY

總結一下

本文介紹了一種使用 filter: contrast() 配合 filter: blur() 的方式,將直角圖形變為圓角圖形的方式,在一些特定的場景下,可能有著妙用。同時,在很多場景下,可以使用 SVG 濾鏡簡化操作。

不過,這種方式也有幾個小缺陷:

  • 使用了 filter: contrast() 之后,圖形的尺寸可能相對而言會縮小一點點,要達到固定所需尺寸的話,要一定的調試

  • 此方式產生的圖形,畢竟經過了一次 filter: blur(),放大來看圖形會有一定的鋸齒,可以通過調整 contrast 和 blur 的大小盡可能的去除,但是沒法完全去掉

當然,我覺得這兩個小缺點瑕不掩瑜,在特定的場景下,此方式還是有一定的用武之地的。

原文地址:https://segmentfault.com/a/1190000042217200

作者:chokcoco

(學習視頻分享:web前端入門)

贊(0)
分享到: 更多 (0)
?
網站地圖   滬ICP備18035694號-2    滬公網安備31011702889846號
CF穿越火线女去衣看奶| 与亲女洗澡时伦了| 天天狠天天透天干天干| 成人免费无码大片A毛片直播| 日本极品少妇XXXX| 国偷自产一区二区免费视频| 在线播放国产精品三级| 丝袜AV在线丝袜AV天堂| 久久人搡人人玩人妻精品| 成年奭片免费观看视频天天看| 亚洲AV无码精品色午夜| 欧美一区二区视频在线| 国产性自爱拍偷在在线播放| 99精产国品一二三产区区| 亚洲AⅤ无码乱码在线观看性色 | 人妻av无码一区二区三区| 四川小少妇BBAABBAA| 极品少妇的粉嫩小泬看片| 曰本A级毛片无卡免费视频VA | 内地CHINA高潮VIDEO| 成人免费无码不卡毛片| 亚洲乱亚洲乱妇24P| 人妻熟妇乱又伦精品无码专区| 国产一卡2卡3卡4卡无卡国色| 中文字幕在线观看| 亚洲AV成人无码精品久久漂雪| 男生把感叹号放进女生的括号 | 极品尤物爆乳自慰呻吟| 偷看自己婆给别人玩经过| 国产精品白丝AV嫩草影院| 中文字幕日韩精品有码视频 | 99品一二三产区区别| 性色AV.网站免费| 京东天美麻豆果冻传媒| 被老外添嫩苞添高潮NP视频| 亚洲一二三四2021不卡| 亚洲 欧洲 日韩 综合 第一页| 三个男人躁我一个爽| 欧美极品少妇XXXXⅩ另类| 久久综合九色综合欧美婷婷 | 少妇爆乳无码专区| 免费极品AV一视觉盛宴| 又白又大的两座峰| 人与畜禽共性关系的重要性有哪些| 蜜桃AV自慰久久久久免费网站| 精品久久久久久久久中文字幕| 国产成人无码免费视频79| 成人国产欧美大片一区| 成年丰满熟妇午夜免费视频| 中文字幕伊人久久| 永久免费AⅤ无码网站国产| 亚洲午夜成人精品无码| 亚洲爆乳少妇无码激情| 亚洲S久久久久一区二区| 性做久久久久久免费观看| 香蕉久久人人爽人人爽人人片AV | 无码吃奶揉捏奶头高潮视频| 无码人妻精品一区二区三区9厂 | 好爽别插了无码视频| 含羞草亚洲AV无码久久精品| 国产粉嫩嫩00在线正在播放| ワンピースのエロ.WWW在线| 99久久99久久精品免费看蜜桃 | 中文字幕精品无码| GOGO少妇无码肉肉视频| 1000部拍拍拍18勿入免费视| JAPANESE成熟丰满熟妇| ASS年轻少妇BBWPIC精品| 欧美精品一区二区| 国产精品乱码久久久久久软件 | 久久不卡国产精品无码| 麻豆国产成人AV在线播放 | 夜夜躁婷婷AV蜜桃妖精视频| 综合成人亚洲偷自拍色| 成年无码动漫AV片在线尤物| 国内精品久久久久久久影院 | 日本XXXX色视频在线播放| 人妻少妇中文字幕在线一区| 色噜噜狠狠色综合久色AⅤ网| 性FREE毛茸茸VIDEOS| 亚洲日韩中文字幕无码一区| 国产粉嫩呻吟一区二区三区| 机长脔到她哭H粗话H动漫| 胯下娇喘的班主任| 色欲麻豆国产福利精品| 亚洲AV成人深夜一区午夜网站| 野花日本大全免费观看3中文版5| A级毛片毛片免费观的看久| 国产乱人伦精品一区二区| 久久精品国产亚洲AV蜜臀色欲| 免费女人18毛片A级毛片视频| 全部孕妇毛片丰满孕妇孕交| 小妖精又紧又湿高潮H视频69| 中文字日产幕码三区的做法大全 | 野花香影院在线观看视频免费| 日本成熟少妇喷浆在线观看| 欧美VIDEOS另类极品| 先锋影音人妻啪啪VA资源网站| 99久久国语露脸精品国产| 哈昂~哈昂够了太多了男男| 免费A级毛片无码无遮挡| 十八18禁国产精品WWW| 亚洲精品成人A在线观看| 99热门精品一区二区三区无码 | 久久99精品久久久久蜜芽| 日韩国产成人精品视频| 亚洲人成人一区二区三区| XXXXBBBB欧美残疾人| 精品国产一区二区三区不卡在线| 人妻一本久道久久综合久久鬼色| 亚洲精品成人AV观看| 铜铜铜铜铜铜铜铜好大好深色| 亚欧成人无码AV在线播放| 亚洲精品无码专区久久同性男| 国产 | 欧洲野花视频欧洲1| 男人一边吃奶一边弄下边好爽| 亚洲 另类 在线 欧美 制服| 大量潮喷潮喷极限高H| 免费一看一级毛片少妇丰满2| 亚洲 欧美 激情 另类 校园| 国产高潮视频在线观看| 日韩亚洲AV人人夜夜澡人人爽| 777亚洲熟妇自拍无码区| 老翁的大肉蟒进进出出| 亚洲夜夜性无码国产盗摄| 国内一区二区三区香蕉AⅤ| 无码中文字幕日韩专区视频| 成人免费一区二区三区视频| 强奷秘书吸乳免费观看| 4HC88四虎WWW在线影院| 免费无码久久成人网站入口| 欧美一区二区在线视频| 天天做天天爱夜夜爽毛片| JIZZJIZZJIZZ亚洲熟| 久久久久人妻精品一区三寸| 性中国VODAFONEWIFI| 国产精品久久久久影院| 无码熟妇人妻AV在线影片免费| 国产69精品久久久久久人妻精品 | 久欠精品国国产99国产精2 | MM1313亚洲精品无码| 欧洲人激情毛片无码视频| 欧美成人看片黄A免费看| 野花AⅤ亚洲高清完整版在线观看 野花 高清 中文 免费 日本 | 37大但文体艺术A级都市天气 | 深夜成人毛片天堂| 国产成人一区二区三区在线| 无码GOGO大胆啪啪艺术| 国产亚洲AV无码AV男人的天堂| 无人区码一码二码三码| 国产精品毛多多水多| 亚洲乱色熟女一区二区三区麻豆| 国模精品一区二区三区| 亚洲国产精品VA在线播放| 玩弄放荡人妇系列AV在线网站| 国产精品XXX大片免费观看| 亚洲乱亚洲乱少妇无码| 女学生14毛片视频片二毛| 被主人调教边C边打屁股作文 | 亚洲成亚洲乱码一二三四区软件| 精品国产亚洲一区二区三区在线观| 一本色道无码道DVD在线观看| 欧美一级 片内射黑人| 国产精品国产三级国产AV麻豆| 小少妇BBBBBBBBBBBB| 野花AⅤ亚洲高清完整版在线观看 野花 高清 中文 免费 日本 | 日韩成视频在线精品| 国产免费福利在线视频| 竹菊影视欧美日韩一区二区三区四| 日本免费黄色网址| 国内精品久久久久电影院| 2023年新番肉食系| 亚洲A成人无码网站在线| 欧美人和黑人牲交网站上线| 韩漫嘿啾漫画进入| 自拍偷自拍亚洲精品情侣| 日本乱熟人妻精品中文字幕| 寂寞夜晚看的MV字幕高清网站| 97久久久精品综合88久久| 无码专区3D动漫精品免费| 女性C春合欢液高朝液精华液| 精品久久久久久亚洲综合网| 丰满少妇XXXⅩBBBB视频| 亚洲AV成人午夜电影在线观看| 欧美老少配XXXOOO性HD| 色妞WWW精品免费视频| 皇帝在御花园进入贵妃的小说| 第一章少妇初尝云雨| 18禁无码无遮挡H动漫免费看| 无码精品人妻一区二区| 男女做爰高清免费直播网站| 国产九九久久99精品影院| 成人亚洲A片Ⅴ一区二区小说| 中文午夜人妻无码看片| 亚洲AV蜜桃无码精品无码| 日本最新免费二区| 屁屁影院最新发布页CCYY| 免费A级毛片在线播放不收费| 很嫩很紧直喷白浆在线| 国产AVXXXX无套内射|