首頁  >  文章  >  web前端  >  聊聊怎麼巧用CSS給一般黑色二維碼添上彩色漸層!

聊聊怎麼巧用CSS給一般黑色二維碼添上彩色漸層!

青灯夜游
青灯夜游轉載
2022-07-14 10:34:142623瀏覽

怎麼巧用 CSS 建立漸層彩色二維碼?以下這篇文章就來跟大家介紹利用CSS為一般黑色二維碼添上彩色漸層的方法,希望對大家有幫助!

聊聊怎麼巧用CSS給一般黑色二維碼添上彩色漸層!

今日,群組有個很有趣的問題,問我如何實作一個彩色的,有漸層的二維碼,像是這樣:

#很有趣的問題,我們在百度谷歌,搜尋qrcode,能搜到非常多在線製作二維碼的工具,它們其中一些也會帶有製作漸變二維碼的功能。但是它們大部分都是 Canvas 或其它程式語言實現的。 【推薦學習:css影片教學

如果我們現在已經有了一張白底黑字的普通二維碼,想把它變成一個漸變色的二維碼?該如何做呢?

本文就將介紹,使用CSS,快速將一個普通黑色二維碼,變成任何我們想要的彩色漸變二維碼

強大的混合模式

有一張原圖,想改變其顏色。在 CSS 中,我們很快可以想到 濾鏡 filter、或是 混合模式 mix-blend-mode

這裡,我們就需要用到 混合模式 mix-blend-mode。混合模式最常見於 photoshop 中,是 PS 中十分強大的功能之一。目前 CSS 已經原生支援了大部分的混合模式。

原理其實非常簡單,我們實作一張漸層圖形,這張圖形透過混合模式中的mix-blend-mode: lighten 與白底黑字的二維碼重疊在一起後,二維碼中的白色區域將保持不變,而二維碼中的黑色區域將展現為漸變圖案中的顏色

聽起來有點繞,透過一個示意圖,一看就懂,我們只需要兩層,原二維碼為一層,然後將漸變圖案疊加在其之上,並且設置mix -blend-mode: lighten 即可:

<div class="g-container">
    <img src="qrcode.png">
</div>
.g-container {
    position: relative;
    width: 200px;
    height: 200px;
    
    &::before {
        content: "";
        position: absolute;
        top: 0;
        left: 0;
        bottom: 0;
        right: 0;
        background: linear-gradient(45deg, #673ab7, #ff5722);
        mix-blend-mode: lighten;
    }
}

這裡,我們用父元素的偽元素節省一個標籤,用作漸變圖層,實際的重疊效果,我製作了一個動畫:

這樣,我們可以透過混合模式,將一張黑色的二維碼圖片,變成了漸層色。

二維碼中間鏤空

當然,這還沒完,有的時候,我們的二維碼中間還會有一些圖案,有一張圓形的或是方形的圖片。

如果使用上述方法,會有一些瑕疵:

那麼,我們還需要根據二維碼的樣式,將漸層圖案中間鏤空!

有趣的是,二維碼中間的圖案,還會有圓形矩形兩種,對於這兩種二維碼,處理的方式還不太一樣。

漸層圖案中心鏤空一個圓形

對於中心圖案是圓形的二維碼,我們只需要實現這樣一個漸變再疊加即可:

這個還是比較簡單的,由於原本是線性漸變,中間需要鏤空一個圓形,最好的方式是使用mask

div {
    background: linear-gradient(45deg, rgb(51, 102, 153), rgb(255, 0, 204));
    mask: radial-gradient(rgba(0, 0, 0, 0), rgba(0, 0, 0, 0) 16%, rgb(0, 0, 0) 16%);
}

漸變圖案中心鏤空一個矩形

但是,對於中間是一個矩形的話,就不太好辦了,我們需要基於漸變圖案實現這樣一個圖形:

#方法其實也有很多,譬如我們把中間透明部分想像成一個div 的content  部分,而周圍漸層顏色區域就是邊框區域。

當然,這裡我使用了clip-path,使用它,也是可以非​​常方便的實現鏤空的矩形:

div {
    background: linear-gradient(45deg, rgb(51, 102, 153), rgb(255, 0, 204));
    clip-path: polygon(0% 0%, 0% 100%, 34% 100%, 34% 34%, 66% 34%, 66% 66%, 34% 66%, 34% 100%, 100% 100%, 100% 0%);
}

製作一個二維碼染色工具

基於上面的知識,我們就可以簡單的建構一個漸層彩色二維碼工具了。

這裡我簡單實作了一個:

我們透過上傳一個普通二維碼,透過自訂漸層顏色,選擇是否需要鏤空,鏤空的類型及大小,快速製作一個漸層彩色二維碼。

簡單示範一下:

一個核心利用 CSS 的小工具就完成啦。

完整的程式碼,可以戳這裡:CodePen - Make A Gradient QrCode

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

#最後

總結一下,本文介紹了利用CSS 混合模式得到漸變二維碼的小技巧,並且利用了maskclip-path 鏤空漸變圖形,一些相關知識點如果你還有所疑問,推薦你再看看我的下列文章:

好了,本文到此結束,希望對你有幫助:)

原文網址:https://segmentfault.com/a/1190000041543121

作者:chokcoco

#(學習影片分享:web前端入門

以上是聊聊怎麼巧用CSS給一般黑色二維碼添上彩色漸層!的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文轉載於:segmentfault.com。如有侵權,請聯絡admin@php.cn刪除