難以想象的混合模式 background-blend-mode

本文轉載於:猿2048網站難以想象的混合模式 background-blend-modephp

本文接前文:難以想象的混合模式 mix-blend-mode 。因爲 mix-blend-mode 這個屬性的強大,不少應用場景和動效的製做不斷完善和被髮掘出來,遂另起一文繼續介紹一些使用 mix-blend-mode 製做的酷炫動畫。css

CSS3 新增了一個頗有意思的屬性 -- mix-blend-mode ,其中 mix 和 blend 的中文意譯均爲混合,那麼這個屬性的做用直譯過來就是混合混合模式,固然,咱們咱們一般稱之爲混合模式。html

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

 

mix-blend-mode 簡介

關於 mix-blend-mode 最基本的用法和描述,能夠簡單看看上篇文章 難以想象的混合模式 mix-blend-modegithub

 

background-blend-mode 簡介

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

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

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-modeurl

固然,這裏使用的是 background-blend-mode:lighten 變亮這個混合模式,核心代碼以下:

<div class="container"></div>
.container {
    background: url($pic1), url($pic2);
    background-size: cover;
    background-blend-mode: lighten;
}

咱們能夠嘗試其餘的組合,也就是改變 background-blend-mode 的各類取值,將會獲得各類不一樣的感官效果。

 

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

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

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

timg

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

image

產生的效果以下:

bg-gif

咱們能夠嘗試其餘的組合,將會獲得各類不一樣的感官效果。

 

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

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

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

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

image

經過混合漸變背景色,配合 Hover 效果,咱們能夠給這些圖配上一些咱們想要的色彩:

bgblendmodehover

代碼很是簡單,示意以下:

.pic {
    background: url($img),
        linear-gradient(#f00, #00f);
    background-size: cover, 100% 100%;
    background-position: 0 0, -300px 0;
    background-blend-mode: luminosity;
    background-repeat: no-repeat;
    transition: .5s background-position linear;
}

.pic:hover { 
    background-position: 0 0, 0 0; 
}

這裏有幾點須要注意的:

  • 這裏使用了背景色漸變更畫,背景色的漸變更畫有幾種方式實現(戳這裏瞭解更多方法),這裏使用的是位移 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

並且這裏的具體顏色(漸變、純色皆可),動畫方向均可以能夠隨意控制的。

又或者是這種 hover fadeIn 效果:

bgblendhover2

 

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

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

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

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

這裏咱們使用 mix-blend-mode 也可以輕易實現,咱們只須要構造出黑色文字,白色底色的文字 div ,疊加上圖片,再運用 mix-blend-mode 便可,簡單原理以下:

image

核心代碼以下,能夠看看:

<div class="container">
    <div class="pic"></div>
    <div class="text">IMAGE</div>
</div>
.pic {
    position: relative;
    width: 100%;
    height: 100%;
    background: url($img);
    background-repeat: no-repeat;
    background-size: cover;
}

.text {
    position: absolute;
    width:100%;
    height:100%;
    color: #000;
    mix-blend-mode: lighten;
    background-color: #fff;
}

最後

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

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

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

相關文章
相關標籤/搜索