css炫酷的3D水波紋文字效果實現詳解

在這里插入圖片描述

炫酷的3D水波紋文字效果實現詳解

這里寫目錄標題

  • 炫酷的3D水波紋文字效果實現詳解
    • 項目概述
    • 技術棧
    • 核心實現
      • 1. 基礎布局
      • 2. 漸變背景
      • 3. 文字效果實現
        • 3.1 基礎樣式
        • 3.2 文字漂浮動畫
      • 4. 水波紋效果
        • 4.1 模糊效果
        • 4.2 水波動畫
      • 5. 交互效果
    • 技術要點
    • 項目難點與解決方案
    • 總結

項目概述

在這個項目中,我們實現了一個具有3D水波紋效果的文字動畫。當用戶hover文字時,會觸發水波紋擴散效果,同時文字本身具有漂浮動畫和模糊效果,營造出夢幻的水中文字效果。

技術棧

  • HTML5
  • CSS3(動畫、漸變、混合模式等)

核心實現

1. 基礎布局

首先,我們需要創建基本的HTML結構:

<div class="text-container"><div class="text" data-text="水波紋">水波紋</div><div class="water-effect"><div class="water-ripple"></div></div>
</div>

2. 漸變背景

使用CSS的linear-gradient創建漸變背景,增加視覺效果:

background: linear-gradient(45deg, #12c2e9, #c471ed, #f64f59);

3. 文字效果實現

3.1 基礎樣式
.text {font-size: 5rem;font-weight: bold;color: rgba(255, 255, 255, 0.8);text-transform: uppercase;letter-spacing: 0.2em;position: relative;animation: float 6s ease-in-out infinite;
}
3.2 文字漂浮動畫

使用@keyframes實現文字的上下漂浮效果:

@keyframes float {0%, 100% {transform: translateY(0) rotateX(0deg);}50% {transform: translateY(-20px) rotateX(5deg);}
}

4. 水波紋效果

4.1 模糊效果

使用偽元素和filter屬性創建水波紋的模糊效果:

.text::before {content: attr(data-text);position: absolute;left: 0;top: 0;width: 100%;height: 100%;color: rgba(255, 255, 255, 0.5);filter: blur(12px);animation: water-effect 3s cubic-bezier(0.4, 0, 0.2, 1) infinite;
}
4.2 水波動畫

定義水波效果的動畫:

@keyframes water-effect {0%, 100% {transform: translateY(0) skewX(0deg) scale(1);filter: blur(12px) brightness(1);}25% {transform: translateY(-15px) skewX(-4deg) scale(1.05);filter: blur(16px) brightness(1.3);}75% {transform: translateY(15px) skewX(4deg) scale(0.95);filter: blur(18px) brightness(0.7);}
}

5. 交互效果

當用戶hover文字時觸發水波紋擴散動畫:

.water-ripple {position: absolute;top: 50%;left: 50%;transform: translate(-50%, -50%);width: 200%;height: 200%;background: radial-gradient(circle at center, rgba(255,255,255,0.2) 0%, transparent 80%);opacity: 0;mix-blend-mode: overlay;
}@keyframes ripple {0% {transform: translate(-50%, -50%) scale(0.3);opacity: 0.8;}100% {transform: translate(-50%, -50%) scale(2);opacity: 0;}
}

技術要點

  1. CSS動畫性能優化:使用transform和opacity進行動畫,避免使用影響布局的屬性
  2. 3D效果:通過perspective屬性和rotateX變換創建3D效果
  3. 混合模式:使用mix-blend-mode實現更真實的水波紋效果
  4. 動畫曲線:精心調整cubic-bezier曲線,使動畫更加流暢自然

項目難點與解決方案

  1. 水波紋效果的真實感

    • 難點:單純的放大動畫無法模擬真實的水波紋
    • 解決:結合使用radial-gradient和mix-blend-mode創建漸變效果
  2. 文字模糊效果的性能

    • 難點:過多的filter效果可能導致性能問題
    • 解決:將模糊效果限制在偽元素上,并適當調整blur值
  3. 動畫流暢度

    • 難點:多個動畫同時進行可能造成卡頓
    • 解決:使用transform屬性進行動畫,避免重排重繪

總結

這個項目展示了如何使用純CSS實現復雜的視覺效果。通過合理運用CSS3的新特性,我們可以創建出既美觀又性能優良的動畫效果。項目中的技術點和解決方案對于其他類似的動畫效果實現也具有參考價值。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/75612.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/75612.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/75612.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

八、重學C++—動態多態(運行期)

上一章節&#xff1a; 七、重學C—靜態多態&#xff08;編譯期&#xff09;-CSDN博客https://blog.csdn.net/weixin_36323170/article/details/146999362?spm1001.2014.3001.5502 本章節代碼&#xff1a; cpp/dynamicPolymorphic.cpp CuiQingCheng/cppstudy - 碼云 - 開源中…

eventEmitter實現

沒有做任何異常處理,簡單模擬實現 事件對象的每一個事件都對應一個數組 /*__events {"事件1":[cb1,cb2],"事件2":[cb3,cb4],"事件3":[...],"事件4":[...],};*/class E{__events {};constructor(){}//注冊監聽回調on(type , callbac…

Mysql 中 B 樹 vs B+ 樹

&#x1f333; 什么是 B樹 和 B樹&#xff1f; 它們都是多路平衡查找樹&#xff08;M-Way Search Tree&#xff09;&#xff0c;用于提升磁盤讀寫效率&#xff0c;常用于數據庫&#xff08;如 MySQL&#xff09;、操作系統中的索引結構。 &#x1f50d; B樹 和 B樹 的核心區別…

藍橋云客---九宮幻方

1.九宮幻方 - 藍橋云課 九宮幻方 題目描述 小明最近在教鄰居家的小朋友小學奧數&#xff0c;而最近正好講述到了三階幻方這個部分&#xff0c;三階幻方指的是將1~9不重復的填入一個3 * 3的矩陣當中&#xff0c;使得每一行、每一列和每一條對角線的和都是相同的。 三階幻方又…

OrangePi5Plus開發板不能正確識別USB 3.0 設備 (綠聯HUB和Camera)

1、先插好上電&#xff08;可正確識別&#xff09; 2、上電開機后插入USB 3.0 設備&#xff0c;報錯如下&#xff0c;只能檢測到USB2.0--480M&#xff0c;識別不到USB3.0-5Gbps&#xff0c;重新插拔也不行 Apr 4 21:30:00 orangepi5plus kernel: [ 423.575966] usb 5-1: re…

LiveData 和 MutableLiveData 的區別

LiveData 和 MutableLiveData 的區別 主要在于是否可以修改數據&#xff0c;但它們的工作原理基本相同。下面我們深入對比它們的行為、特性&#xff0c;以及它們在 ViewModel 和 UI 層中的使用方式。 1. LiveData 和 MutableLiveData 的基本區別 特性LiveDataMutableLiveData可…

SDK中窗口調用

存在窗口A和B的win32程序 , 當點擊窗口A中的按鈕后會彈出窗口B #include <windows.h>// 窗口 B 的窗口過程 LRESULT CALLBACK WindowProcB(HWND hwnd, UINT uMsg, WPARAM wParam, LPARAM lParam) {switch (uMsg) {case WM_DESTROY:PostQuitMessage(0);break;default:ret…

進行性核上性麻痹:飲食調理為健康護航

進行性核上性麻痹是一種復雜的神經退行性疾病&#xff0c;目前雖無法根治&#xff0c;但合理的健康飲食有助于緩解癥狀、提高患者生活質量。 高蛋白質食物在患者飲食中占據重要地位。魚肉&#xff0c;尤其是富含 Omega-3 脂肪酸的三文魚、鱈魚等&#xff0c;不僅蛋白質含量豐富…

【Windows+Cursor】從0到1配置Arxiv MCP Server,實現論文自主查詢、下載、分析、綜述生成

1. 安裝UV Installation | uv powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex" 將安裝路徑添加到環境變量 C:\Users\xxxxxx\.local\bin 2. git clone 代碼 git clone https://github.com/blazickjp/arxiv-mcp-server.git…

WPF 教程:給 TreeView 添加 SelectedItem 雙向綁定支持(MVVM-Friendly)

&#x1f332;WPF 教程&#xff1a;給 TreeView 添加 SelectedItem 雙向綁定支持&#xff08;MVVM-Friendly&#xff09; 在 WPF 的 MVVM 應用中&#xff0c;TreeView 是非常常見的控件&#xff0c;但它有個“頑固”的缺陷&#xff1a; ?它的 SelectedItem 不是依賴屬性&…

Linux環境下內存錯誤問題排查與修復

最近這幾天服務器總是掉線&#xff0c;要查一下服務器的問題。可以首先查看一下計算機硬件&#xff0c;這是一臺某魚上拼湊的服務器&#xff1a; sudo lshw -shortH/W path Device Class Description system NF5270M3 (To be filled by O…

函數和模式化——python

一、模塊和包 將一段代碼保存為應該擴展名為.py 的文件&#xff0c;該文件就是模塊。Python中的模塊分為三種&#xff0c;分別為&#xff1a;內置模塊、第三方模塊和自定義模塊。 內置模塊和第三方模塊又稱為庫內置模塊&#xff0c;有 python 解釋器自帶&#xff0c;不用單獨安…

windows下載安裝遠程桌面工具RealVNC-Server教程(RealVNC_E4_6_1版帶注冊碼)

文章目錄 前言一、下載安裝包二、安裝步驟三、使用VNC-Viewer客戶端遠程連接&#xff0c;輸入ip地址&#xff0c;密碼完成連接 前言 在現代工作和生活中&#xff0c;遠程控制軟件為我們帶來了極大的便利。RealVNC - Server 是一款功能強大的遠程控制服務器軟件&#xff0c;通過…

Android Dagger 2 框架的注解模塊深入剖析 (一)

本人掘金號&#xff0c;歡迎點擊關注&#xff1a;https://juejin.cn/user/4406498335701950 一、引言 在 Android 開發中&#xff0c;依賴注入&#xff08;Dependency Injection&#xff0c;簡稱 DI&#xff09;是一種強大的設計模式&#xff0c;它能夠有效降低代碼的耦合度&…

HTML語言的空值合并

HTML語言的空值合并 引言 在現代Web開發中&#xff0c;HTML&#xff08;超文本標記語言&#xff09;是構建網頁的基礎語言。隨著前端技術的快速發展&#xff0c;開發者們面臨著大量不同的工具和技術&#xff0c;尤其是在數據處理和用戶交互方面。空值合并是一些編程語言中常用…

【數據結構】樹的介紹

目錄 一、樹1.1什么是樹&#xff1f;1.2 樹的概念與結構1.3樹的相關術語1.4 樹形結構實際運用場景 二、二叉樹2.1 概念與結構2.2 特殊的二叉樹2.2.1 滿二叉樹2.2.2 完全二叉樹 個人主頁&#xff0c;點擊這里~ 數據結構專欄&#xff0c;點擊這里~ 一、樹 1.1什么是樹&#xff1…

Muduo網絡庫實現 [十三] - HttpRequest模塊

目錄 設計思路 成員設計 模塊實現 設計思路 首先我們要先知道HTTP的請求的流程是什么樣子的&#xff0c;不然我們會學的很迷糊。對于HTTP請求如何到來以及去往哪里&#xff0c;我們應該很清楚的知道 HTTP請求在服務器系統中的傳遞流程是一個多層次的過程: 客戶端發起請求…

6. RabbitMQ 死信隊列的詳細操作編寫

6. RabbitMQ 死信隊列的詳細操作編寫 文章目錄 6. RabbitMQ 死信隊列的詳細操作編寫1. 死信的概念2. 消息 TTL 過期(觸發死信隊列)3. 隊列超過隊列的最大長度(觸發死信隊列)4. 消息被拒(觸發死信隊列)5. 最后&#xff1a; 1. 死信的概念 先從概念上解釋上搞清楚這個定義&#…

如何使用Selenium進行自動化測試?

&#x1f345; 點擊文末小卡片 &#xff0c;免費獲取軟件測試全套資料&#xff0c;資料在手&#xff0c;漲薪更快 對于很多剛入門的測試新手來說&#xff0c;大家都將自動化測試作為自己職業發展的一個主要階段。可是&#xff0c;在成為一名合格的自動化測試工程師之前&#…

洛谷題單3-P5724 【深基4.習5】求極差 最大跨度值 最大值和最小值的差-python-流程圖重構

題目描述 給出 n n n 和 n n n 個整數 a i a_i ai?&#xff0c;求這 n n n 個整數中的極差是什么。極差的意思是一組數中的最大值減去最小值的差。 輸入格式 第一行輸入一個正整數 n n n&#xff0c;表示整數個數。 第二行輸入 n n n 個整數 a 1 , a 2 … a n a_1,…