百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 编程文章 > 正文

CSS3线性渐变、阴影、缩放实现动画下雨效果

qiyuwang 2024-10-18 10:29 8 浏览 0 评论

点击右上方红色按钮关注“web秀”,让你真正秀起来

前言

好雨知时节,当春乃发生。 随风潜入夜,润物细无声。

春节已经过去,新的一年刚刚开始,小伙伴们,今年你的目标是什么?定个小目标,挣它一个亿?分享一下我的目标,是让大家的web前端能力,更上一层楼。

下面进入主题,看下图:

这个动画效果,如果让你来做,你会选择什么方式?相信很多小伙伴都会用gif图片。其实用css实现也很简单。

如果文章中有不懂的知识点,请点击文章最下方,推荐文章哦

动画解析

很明显这个动画效果,是上中下结构,所以我们分3部分实现。

1、:由多个圆拼接而成,并且有上下浮动的动画效果

2、雨滴:多个,从上而下的动画效果

3、阴影:椭圆,缩放动画效果

下面我们按步骤实现

用box-shadow制作多个圆,完成拼接,行程完整的云朵。animation,添加动画,上下浮动。

语法:box-shadow: h-shadow v-shadow blur spread color inset;

注:box-shadow,向框内添加一个或多个阴影。该属性是由逗号分隔的阴影列表,每个阴影由 2-4 个长度值、可选的颜色值以及可选的 inset 关键词来规定。省略长度的值是 0。

相关推荐CSS3 box-shadow实现背景动画

.rainy {
 position: absolute;
 top: 30%;
 left: 50%;
}
.rainy:before {
 content: "";
 color: #333;
 position: absolute;
 height: 50px;
 width: 50px;
 top: 30px;
 left: -40px;
 background: #CCC;
 transform: translate(-50%, -50%);
 border-radius: 50%;
 box-shadow: #CCC 65px -15px 0 -5px, 
 #CCC 25px -25px, 
 #CCC 30px 10px, 
 #CCC 60px 15px 0 -10px, 
 #CCC 85px 5px 0 -5px;
 animation: cloudy 5s ease-in-out infinite;
}
@keyframes cloudy {
 50% {
 transform: translate(-50%, -70%);
 }
 100% {
 transform: translate(-50%, -50%);
 }
}

雨滴

雨滴和云一样,都是用box-shadow来实现,但是雨滴的实现要复杂的多,雨滴数量多,每个雨滴位置的改变。

.rainy {
 position: absolute;
 width: 3px;
 height: 6px;
 top: 30%;
 left: 50%;
 animation: rainy_rain .7s infinite linear;
}
.rainy:before {
 ...
}
@keyframes cloudy {
 ...
}
@keyframes rainy_rain {
 0% {
 box-shadow: 
 rgba(0, 0, 0, 0) -10px 30px, 
 rgba(0, 0, 0, 0) 40px 40px, 
 rgba(0, 0, 0, .3) -50px 75px, 
 rgba(0, 0, 0, .3) 55px 50px, 
 rgba(0, 0, 0, .3) -18px 100px, 
 rgba(0, 0, 0, .3) 12px 95px, 
 rgba(0, 0, 0, .3) -31px 45px, 
 rgba(0, 0, 0, .3) 30px 35px;
 }
 25% {
 box-shadow:
 rgba(0, 0, 0, .3) -10px 45px,
 rgba(0, 0, 0, .3) 40px 60px,
 rgba(0, 0, 0, .3) -50px 90px,
 rgba(0, 0, 0, .3) 55px 65px,
 rgba(0, 0, 0, 0) -18px 120px,
 rgba(0, 0, 0, 0) 12px 120px,
 rgba(0, 0, 0, .3) -31px 70px,
 rgba(0, 0, 0, .3) 30px 60px;
 }
 26% {
 box-shadow:
 rgba(0, 0, 0, .3) -10px 45px,
 rgba(0, 0, 0, .3) 40px 60px,
 rgba(0, 0, 0, .3) -50px 90px,
 rgba(0, 0, 0, .3) 55px 65px,
 rgba(0, 0, 0, 0) -18px 40px,
 rgba(0, 0, 0, 0) 12px 20px,
 rgba(0, 0, 0, .3) -31px 70px,
 rgba(0, 0, 0, .3) 30px 60px;
 }
 50% {
 box-shadow:
 rgba(0, 0, 0, .3) -10px 70px,
 rgba(0, 0, 0, .3) 40px 80px,
 rgba(0, 0, 0, 0) -50px 100px,
 rgba(0, 0, 0, .3) 55px 80px,
 rgba(0, 0, 0, .3) -18px 60px,
 rgba(0, 0, 0, .3) 12px 45px,
 rgba(0, 0, 0, .3) -31px 95px,
 rgba(0, 0, 0, .3) 30px 85px;
 }
 51% {
 box-shadow:
 rgba(0, 0, 0, .3) -10px 70px,
 rgba(0, 0, 0, .3) 40px 80px,
 rgba(0, 0, 0, 0) -50px 45px,
 rgba(0, 0, 0, .3) 55px 80px,
 rgba(0, 0, 0, .3) -18px 60px,
 rgba(0, 0, 0, .3) 12px 45px,
 rgba(0, 0, 0, .3) -31px 95px,
 rgba(0, 0, 0, .3) 30px 85px;
 }
 75% {
 box-shadow:
 rgba(0, 0, 0, .3) -10px 95px,
 rgba(0, 0, 0, .3) 40px 100px,
 rgba(0, 0, 0, .3) -50px 60px,
 rgba(0, 0, 0, 0) 55px 95px,
 rgba(0, 0, 0, .3) -18px 80px,
 rgba(0, 0, 0, .3) 12px 70px,
 rgba(0, 0, 0, 0) -31px 120px,
 rgba(0, 0, 0, 0) 30px 110px;
 }
 76% {
 box-shadow:
 rgba(0, 0, 0, .3) -10px 95px,
 rgba(0, 0, 0, .3) 40px 100px,
 rgba(0, 0, 0, .3) -50px 60px,
 rgba(0, 0, 0, 0) 55px 35px,
 rgba(0, 0, 0, .3) -18px 80px,
 rgba(0, 0, 0, .3) 12px 70px,
 rgba(0, 0, 0, 0) -31px 25px,
 rgba(0, 0, 0, 0) 30px 15px;
 }
 100% {
 box-shadow:
 rgba(0, 0, 0, 0) -10px 120px,
 rgba(0, 0, 0, 0) 40px 120px,
 rgba(0, 0, 0, .3) -50px 75px,
 rgba(0, 0, 0, .3) 55px 50px,
 rgba(0, 0, 0, .3) -18px 100px,
 rgba(0, 0, 0, .3) 12px 95px, 
 rgba(0, 0, 0, .3) -31px 45px, 
 rgba(0, 0, 0, .3) 30px 35px;
 }
}

阴影

阴影实现是最简单的啦,加上缩放,透明度改变就可以了,当然要和上面的云配合起来,云上,阴影变小,云下,阴影变大。

.rainy:after {
 content: "";
 position: absolute;
 top: 120px;
 left: 50%;
 height: 15px;
 width: 120px;
 background: rgba(0, 0, 0, .5);
 border-radius: 50%;
 transform: translate(-50%, -50%);
 animation: cloudy_shadow 5s ease-in-out infinite;
}
@keyframes cloudy_shadow {
 50% {
 transform: translate(-50%, -50%) scale(0.8);
 background: rgba(0, 0, 0, .2);
 }
 100% {
 transform: translate(-50%, -50%) scale(1);
 background: rgba(0, 0, 0, .5);
 }
}

演示地址:http://demo.javanx.cn/raindrop/index2.html

推荐文章

CSS3 box-shadow实现背景动画

从浅到深的学习 CSS3阴影(box-shadow)

CSS3最容易混淆属性transition transform animation translate

公告

喜欢小编的点击关注,了解更多知识!

源码地址和源文件下载请点击下方“了解更多”

相关推荐

# 安装打开 ubuntu-22.04.3-LTS 报错 解决方案

#安装打开ubuntu-22.04.3-LTS报错解决方案WslRegisterDistributionfailedwitherror:0x800701bcError:0x80070...

利用阿里云镜像在ubuntu上安装Docker

简介:...

如何将Ubuntu Kylin(优麒麟)19.10系统升级到20.04版本

UbuntuKylin系统使用一段时间后,有新的版本发布,如何将现有的UbuntuKylin系统升级到最新版本?可以通过下面的方法进行升级。1.先查看相关的UbuntuKylin系统版本情况。使...

Ubuntu 16.10内部代号确认为Yakkety Yak

在正式宣布Ubuntu16.04LTS(XenialXerus)的当天,Canonical创始人MarkShuttleworth还非常开心的在个人微博上宣布Ubuntu下个版本16.10的内...

如何在win11的wsl上装ubuntu(怎么在windows上安装ubuntu)

在Windows11的WSL(WindowsSubsystemforLinux)上安装Ubuntu非常简单。以下是详细的步骤:---...

Win11学院:如何在Windows 11上使用WSL安装Ubuntu

IT之家2月18日消息,科技媒体pureinfotech昨日(2月17日)发布博文,介绍了3中简便的方法,让你轻松在Windows11系统中,使用WindowsSubs...

如何查看Linux的IP地址(如何查看Linux的ip地址)

本头条号每天坚持更新原创干货技术文章,欢迎关注本头条号"Linux学习教程",公众号名称“Linux入门学习教程"。...

怎么看电脑系统?(怎么看电脑系统配置)

要查看电脑的操作系统信息,可以按照以下步骤操作,根据不同的操作系统选择对应的方法:一、Windows系统通过系统属性查看右键点击桌面上的“此电脑”(或“我的电脑”)图标,选择“属性”。在打开的...

如何查询 Linux 内核版本?这些命令一定要会!

Linux内核是操作系统的核心,负责管理硬件资源、调度进程、处理系统调用等关键任务。不同的内核版本可能支持不同的硬件特性、提供新的功能,或者修复了已知的安全漏洞。以下是查询内核版本的几个常见场景:...

深度剖析:Linux下查看系统版本与CPU架构

在Linux系统管理、维护以及软件部署的过程中,精准掌握系统版本和CPU架构是极为关键的基础操作。这些信息不仅有助于我们深入了解系统特性、判断软件兼容性,还能为后续的软件安装、性能优化提供重要依据。接...

504 错误代码解析与应对策略(504错误咋解决)

在互联网的使用过程中,用户偶尔会遭遇各种错误提示,其中504错误代码是较为常见的一种。504错误并非意味着网站被屏蔽,它实际上是指服务器在规定时间内未能从上游服务器获取响应,专业术语称为“Ga...

猎聘APP和官网崩了?回应:正对部分职位整改,临时域名可登录

10月12日,有网友反映猎聘网无法打开,猎聘APP无法登录。截至10月14日,仍有网友不断向猎聘官方微博下反映该情况,而猎聘官方微博未发布相关情况说明,只是在微博内对反映该情况的用户进行回复,“抱歉,...

域名解析的原理是什么?域名解析的流程是怎样的?

域名解析是网站正常运行的关键因素,因此网站管理者了解域名解析的原理和流程对于做好域名管理、解决常见解析问题,保障网站的正常运转十分必要。那么域名解析的原理是什么?域名解析的流程是怎样的?接下来,中科三...

Linux无法解析域名的解决办法(linux 不能解析域名)

如果由于误操作,删除了系统原有的dhcp相关设置就无法正常解析域名。  此时,需要手动修改配置文件:  /etc/resolv.conf  将域名解析服务器手动添加到配置文件中  该文件是DNS域名解...

域名劫持是什么?(域名劫持是什么)

域名劫持是互联网攻击的一种方式,通过攻击域名解析服务器(DNS),或伪造域名解析服务器(DNS)的方法,把目标网站域名解析到错误的地址从而实现用户无法访问目标网站的目的。说的直白些,域名劫持,就是把互...

取消回复欢迎 发表评论: