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.mzph.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,…