搜尋
首頁web前端css教學聊聊如何利用 SVG 實現圖片馬賽克效果

不借助 Javascript,如何利用 SVG 實現圖片馬賽克效果?下面這篇文章就來帶大家詳細了解一下,希望對大家有幫助!

聊聊如何利用 SVG 實現圖片馬賽克效果

之前在公眾號轉發了好友 Vajoy 的一篇文章 -- 巧用 CSS 把圖片馬賽克風格化

核心是利用了 CSS 中一個很有趣的屬性 -- image-rendering,它可以用來設定圖片縮放演算法。 【推薦學習:css影片教學

何為 image-rendering?

CSS 屬性 image-rendering 用於設定影像縮放演算法。它適用於元素本身,適用於元素其他屬性中的圖像,也應用於子元素。

語法比較簡單:

{
    image-rendering: auto;              // 默认值,使用双线性(bilinear)算法进行重新采样(高质量)
    image-rendering: smooth;         // 使用能最大化图像客观观感的算法来缩放图像。让照片更“平滑”
    image-rendering: crisp-edges;  // 使用可有效保留对比度和图像中的边缘的算法来对图像进行缩放
    image-rendering: pixelated;      // 放大图像时, 使用最近邻居算法,因此,图像看着像是由大块像素组成的
}

其中,image-rendering: pixelated 比較有意思,可以將一張低精度影像馬賽克化。

譬如,假設我們有一張300px x 300px 的圖像,我們讓他轉換成30px x 30px

我們再把失真後的圖片,放大到300px x 300px

在此基礎上,我們給這張圖片設置image-rendering: pixelated,就能得到一張被馬賽克化圖片:

<img  src="/static/imghwm/default1.png" data-src="pic.jpeg?30x30" class="lazy" alt="聊聊如何利用 SVG 實現圖片馬賽克效果" >
img {
    width: 300px;
    height: 300px;
    image-rendering: pixelated
}

<strong>image-rendering: pixelated</strong> 實現馬賽克效果的限制

OK,那麼為什麼需要先縮小再放大,然後才運用image-rendering: pixelated 呢?我們來做個對比,直接給原圖設定image-rendering: pixelated

直接給原圖設定image-rendering: pixelated 只會讓圖片更有鋸齒感,而不會直接產生馬賽克的效果。

這也和image-rendering: pixelated 的描述吻合,放大影像時, 使用最近鄰居演算法,因此,影像看著像是由大塊像素組成的

我們只有基於放大模糊後的圖像,才能利用 image-rendering: pixelated 得到一張被馬賽克的圖片!

利用 CSS 再圖片縮小後再放大?

那麼,假設我們只有一張清晰的原圖,又想利用 CSS 得到一個馬賽克效果,可行麼?順著這個思路,我們可以想到:

能否利用 CSS 縮小圖片後再放大,再運用 image-rendering: pixelated 呢?

不行。 WEB 上的圖片像極了Photoshop 裡的智慧型物件- 你可以任意修改它的尺寸(例如放大很多倍讓其模糊),但最後再把圖片改回原本的大小時,圖片會變回原來的樣子(沒有任何失真)

所以,要想在只有一張原圖的情況下,得到一張模糊的圖像,就不得不求助於 Canvas,這樣一來就稍顯麻煩了。我們只是想要個馬賽克效果而已。

SVG 濾鏡疊加實現馬賽克效果

這就可以引出今天的主角了,SVG 濾鏡,使用幾層SVG 濾鏡的疊加,其實可以非常輕鬆的實現一個馬賽克效果濾鏡。

並且,SVG 濾鏡可以透過 CSS filter,輕鬆的引入。

程式碼其實也非常的簡單,SVG 定義一個濾鏡,利用多層濾鏡的疊加效果實現一個馬賽克效果,然後,透過CSS filter 引入,可以運用在任何元素上:

<img  src="/static/imghwm/default1.png" data-src="任意无需缩放的原图.png" class="lazy" alt="聊聊如何利用 SVG 實現圖片馬賽克效果" >
<svg>
  <filter>
    <feflood></feflood>
    <fecomposite></fecomposite>
    <fetile></fetile>
    <fecomposite></fecomposite>
    <femorphology></femorphology>
  </filter>
</svg>
img {
    width: 300px;
    height: 300px;
    filter: url(#pixelate);
}

這樣,我們就得到了一個馬賽克效果:

如果你只是想使用這個效果,你甚至不需要去理解整個SVG <filter> 到底做了什麼事情,當然,如果你是一個一問到底的人,那麼需要有一定的SVG 基礎,建議可以看看我的這幾篇關於SVG 濾鏡的介紹:</filter>

CSS/SVG 實現馬賽克的限制

當然,CSS/SVG 濾鏡實現馬賽克的限制在於,如果你不想給使用者看到原圖的,那麼在客戶端直接使用這個方式相當於直接把原圖的暴露了。

因為 CSS/SVG 濾鏡的方式是在前端進行圖片馬賽克化的,而且需要原始圖片。

當然,利用上述的兩個實作圖片馬賽克技巧,我們還是可以用來製作一些簡單的互動效果的,像是這樣:

#上述的DEMO 和SVG 濾鏡的全部程式碼,你都可以在這兩個DEMO 中找到:

原文網址:https://www.cnblogs.com/coco1s/p/16134088.html

#作者:ChokCoco

(學習影片分享:web前端

以上是聊聊如何利用 SVG 實現圖片馬賽克效果的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述
本文轉載於:博客园。如有侵權,請聯絡admin@php.cn刪除
使用頁面CMS進行靜態站點內容管理使用頁面CMS進行靜態站點內容管理May 13, 2025 am 09:24 AM

我知道,我知道:有大量的內容管理系統選項可用,而我進行了幾個測試,但實際上沒有一個是一個,y&#039;知道嗎?怪異的定價模型,艱難的自定義,有些甚至最終成為整個&

鏈接HTML中CSS文件的最終指南鏈接HTML中CSS文件的最終指南May 13, 2025 am 12:02 AM

鏈接CSS文件到HTML可以通過在HTML的部分使用元素實現。 1)使用標籤鏈接本地CSS文件。 2)多個CSS文件可通過添加多個標籤實現。 3)外部CSS文件使用絕對URL鏈接,如。 4)確保正確使用文件路徑和CSS文件加載順序,優化性能可使用CSS預處理器合併文件。

CSS Flexbox與網格:全面評論CSS Flexbox與網格:全面評論May 12, 2025 am 12:01 AM

選擇Flexbox還是Grid取決於佈局需求:1)Flexbox適用於一維佈局,如導航欄;2)Grid適合二維佈局,如雜誌式佈局。兩者在項目中可結合使用,提升佈局效果。

如何包括CSS文件:方法和最佳實踐如何包括CSS文件:方法和最佳實踐May 11, 2025 am 12:02 AM

包含CSS文件的最佳方法是使用標籤在HTML的部分引入外部CSS文件。 1.使用標籤引入外部CSS文件,如。 2.對於小型調整,可以使用內聯CSS,但應謹慎使用。 3.大型項目可使用CSS預處理器如Sass或Less,通過@import導入其他CSS文件。 4.為了性能,應合併CSS文件並使用CDN,同時使用工具如CSSNano進行壓縮。

Flexbox vs Grid:我應該學習兩者嗎?Flexbox vs Grid:我應該學習兩者嗎?May 10, 2025 am 12:01 AM

是的,youshouldlearnbothflexboxandgrid.1)flexboxisidealforone-demensional,flexiblelayoutslikenavigationmenus.2)gridexcelstcelsintwo-dimensional,confffferDesignssignssuchasmagagazineLayouts.3)blosebothenHancesSunHanceSlineHancesLayOutflexibilitibilitibilitibilitibilityAnderibilitibilityAndresponScormentilial anderingStruction

軌道力學(或我如何優化CSS KeyFrames動畫)軌道力學(或我如何優化CSS KeyFrames動畫)May 09, 2025 am 09:57 AM

重構自己的代碼看起來是什麼樣的?約翰·瑞亞(John Rhea)挑選了他寫的一個舊的CSS動畫,並介紹了優化它的思維過程。

CSS動畫:很難創建它們嗎?CSS動畫:很難創建它們嗎?May 09, 2025 am 12:03 AM

CSSanimationsarenotinherentlyhardbutrequirepracticeandunderstandingofCSSpropertiesandtimingfunctions.1)Startwithsimpleanimationslikescalingabuttononhoverusingkeyframes.2)Useeasingfunctionslikecubic-bezierfornaturaleffects,suchasabounceanimation.3)For

@KeyFrames CSS:最常用的技巧@KeyFrames CSS:最常用的技巧May 08, 2025 am 12:13 AM

@keyframesispopularduetoitsversatoryand and powerincreatingsmoothcsssanimations.keytricksinclude:1)definingsmoothtransitionsbetnestates,2)使用AnimatingMultatingMultationMultationProperPertiessimultane,3)使用使用4)使用BombingeNtibalibility,4)使用CombanningWiThjavoFofofofoftofofo

See all articles

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

熱工具

WebStorm Mac版

WebStorm Mac版

好用的JavaScript開發工具

EditPlus 中文破解版

EditPlus 中文破解版

體積小,語法高亮,不支援程式碼提示功能

SecLists

SecLists

SecLists是最終安全測試人員的伙伴。它是一個包含各種類型清單的集合,這些清單在安全評估過程中經常使用,而且都在一個地方。 SecLists透過方便地提供安全測試人員可能需要的所有列表,幫助提高安全測試的效率和生產力。清單類型包括使用者名稱、密碼、URL、模糊測試有效載荷、敏感資料模式、Web shell等等。測試人員只需將此儲存庫拉到新的測試機上,他就可以存取所需的每種類型的清單。

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Atom編輯器mac版下載

Atom編輯器mac版下載

最受歡迎的的開源編輯器