使用 CSS 实现多立方体悬停颜色效果实现

2024-03-31 10:12

本文主要是介绍使用 CSS 实现多立方体悬停颜色效果实现,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

使用 CSS 实现多立方体悬停效果实现

效果展示

在这里插入图片描述

CSS 知识点

  • filter 属性的 hue-rotate 值运用
  • 使用 CSS 实现立方体

场景布局分析

从效果图可以看出,要实现 3*3 的立方体集合,我们需要考虑一下怎么安排小立方体的布局。我这里的做法是使用span实现单个小立方体,而用一个div元素来状态一列 3 个小立方体,这样就形成一列,然后再找一个div元素来装载 3 列立法体形成大立方体的一个面,形成整体布局后使用transform属性实现立体效果。具体布局如下:

在这里插入图片描述

整体页面布局

<!-- 整体容器,整体控制布局 -->
<div class="container"><!-- 3*3 大立方体的一个面,这里只是展示一个面,两外两个面可以直接复制一样的代码形成另外一个面 --><div class="cube"><!-- 状态3个小立方体的一例容器 --><div style="--x: -1;--y:0"><!-- 小立方体 --><span style="--i:3"></span><span style="--i:2"></span><span style="--i:1"></span></div><div style="--x: 0;--y:0"><span style="--i:3"></span><span style="--i:2"></span><span style="--i:1"></span></div><div style="--x: 1;--y:0"><span style="--i:3"></span><span style="--i:2"></span><span style="--i:1"></span></div></div>
</div>

实现单个立方体

1. 形成小立方体的基础布局

.container .cube {position: relative;z-index: 2;
}.container .cube div {position: absolute;display: flex;flex-direction: column;
}.container .cube div span {position: relative;display: inline-block;width: 50px;height: 50px;background: #dcdcdc;z-index: calc(1 * var(--i));transition: 1.5s;
}/* 立方体左侧面 */
.container .cube div span::before {content: "";position: absolute;left: -40px;width: 40px;height: 100%;background: #fff;transform-origin: right;
}/* 立方体上侧面 */
.container .cube div span::after {content: "";position: absolute;top: -40px;left: 0;width: 100%;height: 40px;background: #f2f2f2;transform-origin: bottom;
}

实现上述代码后效果如下:

在这里插入图片描述

2. 使用 transform 属性形成基础立体效果

.container {position: relative;top: -80px;transform: skewY(-20deg);
}

实现上述代码后的效果如下:

在这里插入图片描述

3. 使用 transform 属性实现立方体

在上述代码的基础上,修改成如下的代码:

.container .cube div span::before {content: "";position: absolute;left: -40px;width: 40px;height: 100%;background: #fff;transform-origin: right;transform: skewY(45deg);transition: 1.5s;
}.container .cube div span::after {content: "";position: absolute;top: -40px;left: 0;width: 100%;height: 40px;background: #f2f2f2;transform-origin: bottom;transform: skewX(45deg);transition: 1.5s;
}

最终实现效果如下:

在这里插入图片描述

实现一列立方体

有了单个立方体后实现一列立方体就方便实现。具体代码如下:

.container .cube div {position: absolute;display: flex;flex-direction: column;gap: 30px;
}

实现上述代码后,页面效果如下:

在这里插入图片描述

实现大立方体的一个面

形成一列效果后,我们使用translate和 css 变量实现完成立方体的一个面。具体代码如下:

.container .cube div {position: absolute;display: flex;flex-direction: column;gap: 30px;translate: calc(-70px * var(--x)) calc(-60px * var(--y));
}

实现上述代码后,页面效果如下:

在这里插入图片描述

实现 3*3 的大立方体

实现了一个面后,我们实现大立方体就很简单,只要使用translate来修改其他面的位置就可以,具体代码如下:

.container .cube:nth-child(2) {z-index: 1;translate: -60px -60px;
}.container .cube:nth-child(3) {z-index: 3;translate: 60px 60px;
}

实现上述代码后,页面效果如下:

在这里插入图片描述

实现立方体属性悬停效果

整体布局实现后,我们就可以在小立方体上添加对应的鼠标移动样式,具体的代码如下:

.container .cube div span:hover {transition: 0s;background: #ef4149;filter: drop-shadow(0 0 30px #ef4149);
}.container .cube div span:hover::before {transition: 0s;background: #f75d64;
}.container .cube div span:hover::after {transition: 0s;background: #f75d64;
}

实现上述代码后,页面效果如下:

在这里插入图片描述

使用动画实现立方体多种颜色变化

.container {position: relative;top: -80px;transform: skewY(-20deg);/* 总容器来控制小立体的颜色变化 */animation: animate 5s linear infinite;
}@keyframes animate {0% {filter: hue-rotate(0deg);}100% {filter: hue-rotate(360deg);}
}

完整代码下载

完整代码下载

这篇关于使用 CSS 实现多立方体悬停颜色效果实现的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/864089

相关文章

Java 压缩包解压实现代码

《Java压缩包解压实现代码》Java标准库(JavaSE)提供了对ZIP格式的原生支持,通过java.util.zip包中的类来实现压缩和解压功能,本文将重点介绍如何使用Java来解压ZIP或RA... 目录一、解压压缩包1.zip解压代码实现:2.rar解压代码实现:3.调用解压方法:二、注意事项三、总

NGINX 配置内网访问的实现步骤

《NGINX配置内网访问的实现步骤》本文主要介绍了NGINX配置内网访问的实现步骤,Nginx的geo模块限制域名访问权限,仅允许内网/办公室IP访问,具有一定的参考价值,感兴趣的可以了解一下... 目录需求1. geo 模块配置2. 访问控制判断3. 错误页面配置4. 一个完整的配置参考文档需求我们有一

Linux实现简易版Shell的代码详解

《Linux实现简易版Shell的代码详解》本篇文章,我们将一起踏上一段有趣的旅程,仿照CentOS–Bash的工作流程,实现一个功能虽然简单,但足以让你深刻理解Shell工作原理的迷你Sh... 目录一、程序流程分析二、代码实现1. 打印命令行提示符2. 获取用户输入的命令行3. 命令行解析4. 执行命令

基于MongoDB实现文件的分布式存储

《基于MongoDB实现文件的分布式存储》分布式文件存储的方案有很多,今天分享一个基于mongodb数据库来实现文件的存储,mongodb支持分布式部署,以此来实现文件的分布式存储,需要的朋友可以参考... 目录一、引言二、GridFS 原理剖析三、Spring Boot 集成 GridFS3.1 添加依赖

利用Python实现Excel文件智能合并工具

《利用Python实现Excel文件智能合并工具》有时候,我们需要将多个Excel文件按照特定顺序合并成一个文件,这样可以更方便地进行后续的数据处理和分析,下面我们看看如何使用Python实现Exce... 目录运行结果为什么需要这个工具技术实现工具的核心功能代码解析使用示例工具优化与扩展有时候,我们需要将

使用Nginx配置文件服务器方式

《使用Nginx配置文件服务器方式》:本文主要介绍使用Nginx配置文件服务器方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1. 为什么选择 Nginx 作为文件服务器?2. 环境准备3. 配置 Nginx 文件服务器4. 将文件放入服务器目录5. 启动 N

使用nohup和--remove-source-files在后台运行rsync并记录日志方式

《使用nohup和--remove-source-files在后台运行rsync并记录日志方式》:本文主要介绍使用nohup和--remove-source-files在后台运行rsync并记录日... 目录一、什么是 --remove-source-files?二、示例命令三、命令详解1. nohup2.

Python+PyQt5实现文件夹结构映射工具

《Python+PyQt5实现文件夹结构映射工具》在日常工作中,我们经常需要对文件夹结构进行复制和备份,本文将带来一款基于PyQt5开发的文件夹结构映射工具,感兴趣的小伙伴可以跟随小编一起学习一下... 目录概述功能亮点展示效果软件使用步骤代码解析1. 主窗口设计(FolderCopyApp)2. 拖拽路径

Spring AI 实现 STDIO和SSE MCP Server的过程详解

《SpringAI实现STDIO和SSEMCPServer的过程详解》STDIO方式是基于进程间通信,MCPClient和MCPServer运行在同一主机,主要用于本地集成、命令行工具等场景... 目录Spring AI 实现 STDIO和SSE MCP Server1.新建Spring Boot项目2.a

Qt之QMessageBox的具体使用

《Qt之QMessageBox的具体使用》本文介绍Qt中QMessageBox类的使用,用于弹出提示、警告、错误等模态对话框,具有一定的参考价值,感兴趣的可以了解一下... 目录1.引言2.简单介绍3.常见函数4.按钮类型(QMessage::StandardButton)5.分步骤实现弹窗6.总结1.引言