開局一張圖,構建神奇的 CSS 效果

来源:https://www.cnblogs.com/coco1s/archive/2022/12/19/16991627.html
-Advertisement-
Play Games

假設,我們有這樣一張 Gif 圖: 利用 CSS,我們嘗試來搞一些事情。 圖片的 Glitch Art 風 在這篇文章中 --CSS 故障藝術,我們介紹了利用混合模式製作一種暈眩感覺的視覺效果。有點類似於抖音的 LOGO。 像是這樣: 假設,我們有這樣一張圖: 只需要一個標簽即可 <div clas ...


假設,我們有這樣一張 Gif 圖:

利用 CSS,我們嘗試來搞一些事情。

圖片的 Glitch Art 風

在這篇文章中 --CSS 故障藝術,我們介紹了利用混合模式製作一種暈眩感覺的視覺效果。有點類似於抖音的 LOGO。

像是這樣:

假設,我們有這樣一張圖:

只需要一個標簽即可

<div class="mix"></div>

給兩張同樣的圖片,疊加上 青色#0ff 和 紅色#f00,並且錯開一定的距離,兩張圖都要加上 background-blend-mode: lighten,其中一張再加上 mix-blend-mode: darken

.mix {
    width: 400px;
    height: 400px;
    background: url($img), #0ff;
    background-blend-mode: lighten;

  &::after {
    content: '';
    position: absolute;
    margin-left: 10px;
    width: 400px;
    height: 400px;
    background: url($img), #f00;
    background-blend-mode: lighten;
    mix-blend-mode: darken;
  }
}

得到如下效果:

簡單解釋下:

  1. 因為圖片本身不是紅色和青色的,所以需要通過 background-image 疊加上這兩種顏色,並通過 background-blend-mode: lighten 讓其表現出來

  2. 為了保持中間疊加部分的原色,需要再疊加一個 mix-blend-mode: darken 反向處理一下。(不理解的同學可以打開調試,手動關掉幾個混合模式,自己感受感受即可)

完整的 DEMO:

圖片的類抖音 LOGO Glitch 效果

當然,這裡使用 Gif 圖也是完全可以的,我們替換下我們的 Gif 圖,看看會得到什麼樣的一種效果:

有點意思,完整的代碼你可以戳這裡:iKUN - 使用background-blend-mode | mix-blend-mode 實現類抖音LOGO暈眩效果

多圖融合

混合模式當然不止是這樣。

我們再來實現一個有趣的效果。

首先,找一張地球圖,可能像是這樣(是不是有點眼熟):

把我們的人物放上去,得到這樣一種效果:

神奇的事情在於,如果,我們給疊加在上面的動圖,添加一個混合模式,會發生什麼呢?嘗試一下:

通過混合模式 mix-blend-mode: multiply,巧妙的消除了大部分非人物的背景,再通過 filter: contrast(3) 加深這個效果,徹底去掉動圖背景,融入了我們的地球背景中。

這樣,我們巧妙的將兩張圖,融合成了一張圖。

當然,多調試調試,還能有不一樣的效果,這裡我實現了兩種不一樣的效果,完整的代碼如下:

<div></div>
<div class="white"></div>
div {
    position: relative;
    margin: auto;
    width: 400px;
    height: 500px;
    flex-shrink: 0;
    background: url(earth.jpg);
    background-size: cover;
    background-position: 0 -150px;
    background-repeat: no-repeat;
    
    &::before {
        content: "";
        position: absolute;
        top: 240px;
        left: 160px;
        width: 70px;
        height: 90px;
        background: var(cxk.gif);
        background-size: cover;
        background-position: -30px 0;
        mix-blend-mode: multiply;
        filter: contrast(3);
    }
}


.white {
    &::before {
        mix-blend-mode: color-dodge;
        filter: invert(1) contrast(3);
    }
}

.black {
    &::before {
        background: var(--bgUrl), #000;
        background-size: cover;
        background-position: -70px 0;
        mix-blend-mode: multiply;
        filter: contrast(3);
    }
}

這樣,我們就得到了兩種不一樣的效果:

完整的 Demo,你可以戳這裡:CodePen Demo -- CSS iKUN Animation

幹掉背景

上面的效果不錯,但是,還遠遠不夠。

有的時候,我們只想更突出主題,不想過多的看到背景元素。

怎麼辦呢?

這裡,我介紹兩種還不錯的小技巧,當然,這個技巧對圖片本身可能會有一點點要求。

第一個技巧,是我在這篇文章中,曾經介紹過的一個技巧 -- 巧用 background-clip 實現超強的文字動效

這裡的核心在於,藉助 background-clip: text 能夠只在文字部分展示圖片內容的特性,結合濾鏡和混合模式的處理,實現一種文字動圖效果。達到有效的去除一些背景的干擾。

我們一起來看看。

還是這張 Gif 圖:

我們首先通過濾鏡 filter: grayscale(1),將他從彩色的,處理成黑白灰的:

p {
    background: url(xxx);
    filter: grayscale(1);
}

處理後的圖片,大概會是這樣:

image

基於一張黑白底色的圖片,我們再運用 background-clip: text,再通過混合模式 mix-blend-mode: hard-light,並且,很重要的一點,我們把這個效果放在黑色的背景之上:

body {
  background: #000;
}
p {
  color: transparent;
  background: url(xxx) center/cover;
  background-clip: text;
  filter: grayscale(1);
  mix-blend-mode: hard-light;
}

將會得到這樣一種神奇的效果,通過混合模式的疊加處理,文字的亮部將會保留,而暗部則會與黑色背景融合:

image

當然,我們更希望的是,人的部分展示保留,而 Gif 圖片中的背景部分被隱藏,就完美了!

這裡,我們繼續優化下代碼,我們希望能把被 grayscale() 處理過的原圖的明暗部分置換,剛好,在 filter 中,存在一個 invert() 函數,能夠反轉輸入圖像的色值。

因此,在 grayscale() 之後,再配合一次 invert(1) 函數:

body {
  background: #000;
}
p {
  color: transparent;
  background: url(xxx) center/cover;
  background-clip: text;
  filter: grayscale(1) invert(1);
  mix-blend-mode: hard-light;
}

OK,至此,我們利用純 CSS 實現了這樣一種 unbelievable 的文字效果:

合理添加混合模式 mix-blend-mode,能夠更好的去除背景的干擾,實際使用的時候根據不同圖片的顏色需要進行一定的調試。

CodePen Demo - iKUN Animation

另一種幹掉背景的方式

那是不是只有上述的方式可以幹掉圖片的背景,保留主體人物部分呢?

當然不止,還有其他方式。下麵,我們不藉助 background-clip: text,通過另外一種藉助混合模式和濾鏡的方式去掉背景干擾。

我們藉助 Demo 1 的例子繼續,就是如下這個效果:

在這個例子的基礎上,我們直接加上 filter: grayscale(1) invert(1)mix-blend-mode: hard-light,像是這樣:

.mix {
    background: url($img), #0ff;
    background-blend-mode: lighten;
    filter: grayscale(1) invert(1);
    mix-blend-mode: hard-light;

  &::after {
    content: '';
    position: absolute;
    margin-left: 10px;
    background: url($img), #f00;
    background-blend-mode: lighten;
    mix-blend-mode: darken;
  }
}

看看效果:

Wow,怎麼做到的呢?我們來調試一些,你就能更好的 Get 到其中的奧妙:

這裡,核心發揮作用的還是 filter: grayscale(1) invert(1),而 mix-blend-mode: hard-light 的意義是讓一些不那麼明顯的背景直接比較被幹掉。

完整的代碼,你可以戳:CodePen Demo -- iKUN Animation

再動起來

有點意思,但還不夠。我們再回到 background-clip: text 的效果中。

背景圖在動,我們能不能讓文字也動起來呢?這樣,整個動畫就處於一種 Gif 在圖,我們的內容也在動的雙重動效之下。

嘗試一下,這裡為了嘗試更多的效果,我藉助了 CSS-doodle 這個庫,這裡我們核心要做的事情是:

  1. 藉助 background-clip: text 只展示文字部分的背景圖的特性,首先設置多個重疊在一起的 DIV
  2. 每個 DIV 都藉助文章上面介紹的技巧,設置背景圖,利用 filter: grayscale(1) invert(1),只展示人的部分
  3. 給每個 DIV 添加文本內容,添加 background-clip: text
  4. 隨機給文本設置初始高度定位
  5. 通過動畫讓文本動起來,並且設置不同的 animation-delay

上面其實只是最核心的一些流程介紹,可以結合代碼一起看看,完整的 CSS-doodle 代碼如下:

<css-doodle grid="10x10">
    :doodle {
        @size: 70vmin 70vmin;
    }
    :container {
        position: relative;
        filter: grayscale(1) invert(1);
    }
    position: absolute;
    inset: 0;
    
    :after {
        position: absolute;
        content:"---------";
        inset: 0;
        font-size: 24px;
        line-height: 0;
        color: transparent;
        background: url(xxx)
        center/cover;
        background-clip: text;
        padding-top: @r(69vmin);
        animation: move .5s @r(-0.99s) infinite linear;
    }
    
    @keyframes move {
        0% {
            padding-left: 0
        }
        100% {
            padding-left: 70vmin;
        }
    }
</css-doodle>
html,
body {
    position: relative;
    margin: 0;
    width: 100%;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background-color: #000;
    cursor: pointer;
}

這樣,我們就得到了一種圖在動,內容也在動的效果:

當然,這個效果可能會有一點繞!實際上你可以想象一下,把圖片固定,通過 background-clip: text 透出圖片內容,同時,讓文本內容動起來,就是如此。如果去掉 background-clip: text 看看下圖,可能你會更好理解一點:

當然,實際上如果去掉 background-clip: text 並不會如上圖所示,因為這裡每一層會使用一張背景圖,background-clip 無法引用於它的子元素,只能應用於本身,所以這個動畫也有一個缺陷,如果圖層數量太多,效果會比較卡頓。

CodePen Demo -- CSS Doodle - iKUN Animation

修改每個 DIV 的文本內容,得到的效果也不相同,像是把內容替換成 .。.,可以得到這樣的效果:

CodePen Demo -- CSS Doodle - iKUN Animation

3D 視角

OK,最後我們再來嘗試下 3D 視角。

使用 CSS,我們可以非常輕鬆的實現 3D 多面體,像是這樣:

如果我們把每邊的圖片,替換成上述的效果,再把我們的視角放置於中間,會發生什麼呢?看看,八面體的圖片牆:

再嘗試把視角,放進 3D 照片牆的中間:

Wow,是不是挺有意思的,完整的 Demo,你可以戳這裡:iKUN Animation

不斷改變 perspective,還可以得到不一樣的觀感體驗,感興趣的,可以自己調試調試。

總結

總結一下,本文通過一張 Gif 圖,介紹了一些利用 CSS 來實現的有趣例子。

當然,CSS 的強大遠不止這樣,本文僅僅是挖掘了一個方向,從將人物凸顯的方向,列出了一些我認為比較有意思的動效。

核心用到了混合模式、濾鏡、background-clip、CSS-Doodle 以及配合了一些動畫,這些日常中大家可能用的不太多的屬性,如果你對這些屬性還不是特別瞭解,希望進階一下,不妨再看看我的這些文章:

最後

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

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

-Advertisement-
Play Games
更多相關文章
  • GreatSQL社區原創內容未經授權不得隨意使用,轉載請聯繫小編並註明來源。 GreatSQL是MySQL的國產分支版本,使用上與MySQL一致。 作者:葉金榮 文章來源:社區原創 可能會執行非常慢,線上生產環境千萬別寫出這種SQL ... 背景交代 用 tpcc-mysql 工具生成 50個倉庫 ...
  • 1. 判斷本地是否已經安裝MySQL ① 在運行界面輸入services.msc進入服務界面,查看是否有MySQL服務 ② 進入任務管理器,點擊服務看是否有MySQL服務 2. 安裝MySQL(壓縮包版) 1. 下載MySQL社區伺服器(ZIP): MySQL zip下載 點擊No thanks,j ...
  • 華為運動健康服務(HUAWEI Health Kit)提供原子化數據開放,用戶數據被授權獲取後,應用可通過介面訪問運動健康數據,對相關數據進行增、刪、改、查等操作。這篇文章彙總了申請開通Health Kit測試許可權的常見問題,並給出了詳細解答,希望為開發者提供相關參考。 (1) 申請Health K ...
  • 本文簡介 點贊 + 關註 + 收藏 = 學會了 作為一隻前端,只懂 Vue、React 感覺已經和大家拉不開距離了。 可視化、機器學習等領域 JS 都有涉及到,而可視化方面已經被很多領域用到,比如大屏項目。 可視化領域相關的技術有 canvas 和 SVG ,而這兩個東東是遲早要接觸的了。 在我接觸 ...
  • 本章將繼續和大家分享Vue的一些基礎知識。話不多說,下麵我們直接上代碼: 本文內容大部分摘自Vue的官網:https://v2.cn.vuejs.org/v2/guide/ 一、計算屬性 示例如下: <!DOCTYPE html> <html lang="en"> <head> <meta char ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 前言: 該篇文章用到的主要技術:vue3、three.js 我們先看看成品效果: 高清大圖預覽(會有些慢): 座機小圖預覽: 廢話不多說,直接進入正題 Three.js的基礎知識 想象一下,在一個虛擬的3D世界中都需要什麼?首先,要有一個 ...
  • 在七牛雲校園黑客馬拉松中,一款設計優秀、邏輯清晰的白板作品脫穎而出,獲得第二名的好成績,這就是來自鄭州大學Since團隊的White Rose白板,以下是他們的設計和架構分享。 一、前言 White Rose是參加七牛雲hackathon比賽的作品,賽題的主要內容是開發一個「多人協作白板」,旨在鼓勵 ...
  • 一、ES2015中有四種相等演算法1. 抽象(非嚴格)相等比較。(==)2. 嚴格相等比較。( )3. 同值。(Object.is())4. 同值零。二、JavaScript提供三種不同的值比較操作1. 嚴格相等比較,使用 比較符號。(在兩者進行比較時,不會執行類型轉換)2. 抽象相等比較,使用 == ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...