不可思議的混合模式 background-blend-mode

chokcoco發表於2017-12-27

本文接前文:不可思議的混合模式 mix-blend-mode 。由於 mix-blend-mode 這個屬性的強大,很多應用場景和動效的製作不斷完善和被髮掘出來,遂另起一文繼續介紹一些使用 mix-blend-mode 製作的酷炫動畫。

CSS3 新增了一個很有意思的屬性 — mix-blend-mode ,其中 mix 和 blend 的中文意譯均為混合,那麼這個屬性的作用直譯過來就是混合混合模式,當然,我們我們通常稱之為混合模式。

混合模式最常見於 photoshop 中,是 PS 中十分強大的功能之一。當然,瞎用亂用混合模式誰都會,利用混合模式將多個圖層混合得到一個新的效果,只是要用到恰到好處,或者說在 CSS 中利用混合模式製作出一些效果則需要對混合模式很深的理解及不斷的嘗試。

mix-blend-mode 簡介

關於 mix-blend-mode 最基本的用法和描述,可以簡單看看上篇文章 不可思議的混合模式 mix-blend-mode

background-blend-mode 簡介

除了 mix-blend-mode ,CSS 還提供一個 background-blend-mode 。也就是背景的混合模式。

  • 可以是背景圖片與背景圖片的混合,
  • 也可以是背景圖片和背景色的之間的混合。

background-blend-mode 的可用取值與 mix-blend-mode一樣,不重複介紹,下面直接進入應用階段。

background-blend-mode 基礎應用

對於 background-blend-mode ,最簡單的應用就是將兩個或者多個圖片利用混合模式疊加在一起。假設我們存在下述兩張圖片,可以利用背景混合模式 background-blend-mode 疊加在一起:

person
timg

經過背景混合模式 background-blend-mode:lighten 處理之後:

image

CodePen Demo — image mix by bg-blend-mode

當然,這裡使用的是 background-blend-mode:lighten 變亮這個混合模式,核心程式碼如下:

我們可以嘗試其他的組合,也就是改變 background-blend-mode 的各種取值,將會得到各種不同的感官效果。

使用 background-blend-mode: difference 製作黑白反向動畫

黑色白色這兩種顏色,無疑是使用頻率最高也是我認為最搭的兩個顏色。當這兩種顏色結合在一起,總是能碰撞出不一樣的火花。

扯遠了,藉助 difference 差值混合模式,配合黑白 GIF,能產生奇妙的效果,假設我們擁有這樣一張 GIF 圖(圖片來自網路,侵刪):

timg

利用 background-blend-mode: difference ,將它疊加到不同的黑白背景之下(黑白背景由 CSS 畫出來):

image

產生的效果如下:

bg-gif

 
demo1
我們可以嘗試其他的組合,將會得到各種不同的感官效果。

使用 background-blend-mode 製作 hover 效果

想象一下,在上面第一個例子中,如果背景的黑白蒙層不是一開始就疊加在 GIF 圖下,而是通過某些互動手段疊加上去。

應用這種方式,我們可以使用 background-blend-mode 來製作點選或者 hover 時候的蒙板效果。

假設我們有這樣一張原圖(黑白效果較好):

image

通過混合漸變背景色,配合 Hover 效果,我們可以給這些圖配上一些我們想要的色彩:

bgblendmodehover
demo2
 

程式碼非常簡單,示意如下:

這裡有幾點需要注意的:

  • 這裡使用了背景色漸變動畫,背景色的漸變動畫有幾種方式實現(戳這裡瞭解更多方法),這裡使用的是位移 background-position
  • 實現上述效果使用的 background-blend-mode 不限制具體某一種混合模式,可以自己多嘗試

使用 mix-blend-mode || background-blend-mode 改變圖示的顏色

如果再運用上一篇文章介紹的知識 兩行 CSS 程式碼實現圖片任意顏色賦色技術 ,我們可以實現 ICON 的顏色的動態改變。

假設我們有這樣一張 ICON 圖,注意主色是黑色,底色的白色(底色不是透明色),所以符合要求的 JPG、PNG、GIF 圖都可以:

iconmonstr-cursor-31

利用 background-blend-mode: lighten 可以實現動態改變圖示主色的效果:

bgblendhover

而且這裡的具體顏色(漸變、純色皆可),動畫方向都可以可以隨意控制的。demo3

 

又或者是這種 hover fadeIn 效果:

bgblendhover2demo4

 

使用 mix-blend-mode 製作文字背景圖

我們將上面 ICON 這個場景延伸一下,ICON 圖可以延伸為任意黑色主色白色底色圖片,而顏色則可以是純色、漸變色、或者是圖片。

那麼我們可以嘗試讓文字帶上漸變色,或者說讓文字透出圖片。當然這個效果有一些 CSS 屬性也可以完成。

譬如 background-clip: text 背景裁剪就可以讓文字帶上漸變色或者展示圖片,可以戳這裡看看 使用 background-clip 實現文字漸變

這裡我們使用 mix-blend-mode 也能夠輕易實現,我們只需要構造出黑色文字,白色底色的文字 div ,疊加上圖片,再運用 mix-blend-mode 即可,簡單原理如下:

image

核心程式碼如下,可以看看:

demo5

最後

更多精彩 CSS 技術文章彙總在我的 Github — iCSS ,持續更新,歡迎點個 star 訂閱收藏。

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

如果還有什麼疑問或者建議,可以多多交流,原創文章,文筆有限,才疏學淺,文中若有不正之處,萬望告知。

打賞支援我寫出更多好文章,謝謝!

打賞作者

打賞支援我寫出更多好文章,謝謝!

任選一種支付方式

不可思議的混合模式 background-blend-mode 不可思議的混合模式 background-blend-mode

相關文章