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

来源:https://www.cnblogs.com/coco1s/archive/2017/12/27/8124815.html
-Advertisement-
Play Games

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


本文接前文:不可思議的混合模式 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 變亮這個混合模式,核心代碼如下:

<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 訂閱收藏。

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

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


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 直接上代碼: html: css: js: 效果如圖: 實現思路與註意的點: 1、獲取內容的高度要等到dom載入完成之後,在mounted裡加一個setTimeout函數,保證能真正獲取到 2、當內容的高度高於自己設定的要展示的高度的時候,則只限定在自己要展示的高度中,加一個class解決,註意要o ...
  • 什麼是Inferno Inferno可以看做是React的另一個精簡、高性能實現。它的使用方式跟React基本相同,無論是JSX語法、組件的建立、組件的生命周期,還是與Redux或Mobx的配合、路由控制等,都可以基本按照React的方式來開發,只有微小的不同。不過Inferno是專門針對網頁開發的 ...
  • vue想要獲取dom元素的高,一般情況下我們都可以想到寫在mounted函數里,即dom載入完再獲取,但是結果並不如我們所想,又想到用一個 來獲取,發現根本沒用啊/。。 所以好的辦法就是用一個setTimeout定時器,時間可以設為0,但是有時候生效,有時候不生效,還是加一個小的時間值比較保險,這樣 ...
  • 因公司需求,要做一個掃描語音播報的功能,所以用到一些音頻/視頻標簽 考慮到 <embed> 標簽對於ie的相容性更好一些所以,我在這採用了 <embed> 標簽,在使用中遇到的一些問題和處理方法,如有不對的地方和可以改進的地方歡迎指教 問題1:在使用<embed> 標簽使用中發現在其屬性autopl ...
  • (1) 安裝webpack 在安裝 Webpack 前,你本地環境需要支持 node.js。 由於 npm 安裝速度慢,本教程使用了淘寶的鏡像及其命令 cnpm,安裝使用介紹參照:使用淘寶 NPM 鏡像。 使用 cnpm 安裝 webpack: cnpm install webpack –g (2) ...
  • 1 2 3 4 5 Document 6 31 75 76 77 78 79 張朋1 80 張朋2 81 張朋3 82 張朋4 83 張朋5 84 張朋6 85 張朋7 86 張朋8 87 張朋9 88 張朋10 89 90 91 92 ...
  • 首先準備兩個盒子: 再寫樣式: 最後是js代碼部分: 演示效果:http://localhost:63342/demo/work7.html ...
  • AngularJS路由使用案例: javaee.html代碼: angularjs.html代碼: easyui.html代碼: mysql.html代碼: ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...