明天就是中秋节了,就想着用CSS画一个月亮送给园友们吧。但是就画一个月亮也太简单了些,于是便加了一些星星点缀以及流星坠落的效果。这篇文章就用纯CSS为大家实现一个“流星赶月”的效果。

实现效果

点击运行查看

画个月亮

首先我们先让全屏背景变成黑色,然后实现一个大月亮,并加点"渐变",“光晕"等效果

  • html
  <body>
<div class="wrap">
<div class="moon"></div>
</div>
</body>
  • css

.wrap {
background: #000000;
width: 100vw;
height: 100vh;
position: relative;
}
.moon {
width: 100px;
height: 100px;
border-radius: 50%;
background-image: linear-gradient(40deg, #f9fabe, #fffd3b);
position: absolute;
top: 10%;
right: 20%;
box-shadow: 0 0 30px 0px #fffd3b, 0 0 80px 0 #ffffff;
}

此时大月亮就出来了

然后给月亮加点”渐明渐暗“的动画效果,使用filter属性中的brightness就可以实现

      @keyframes moonflashing {
0% {
filter: brightness(0.8);
}
50% {
filter: brightness(1.3);
}
100% {
filter: brightness(0.8);
}
}

星星点缀

天空中只有月亮没有星星怎么能行,我们在天空中加几个星星

  • html
      <div class="star star1"></div>
<div class="star star2"></div>
<div class="star star3"></div>
<div class="star star4"></div>
<div class="star star5"></div>
<div class="star star6"></div>
<div class="star star7"></div>
  • css
      .star {
width: 2px;
height: 2px;
border-radius: 50%;
background: #ffffff;
position: absolute;
animation: starflashing 2s infinite;
}
.star1 {
top: 50%;
right: 20%;
}
.star2 {
top: 70%;
right: 30%;
}
.star3 {
top: 40%;
left: 20%;
}
.star4 {
top: 60%;
right: 10%;
}
.star5 {
top: 55%;
right: 44%;
}
.star6 {
top: 10%;
left: 30%;
}
.star7 {
top: 15%;
left: 20%;
}

然后再为星星加上“一闪一闪”的动画

      @keyframes starflashing {
0% {
filter: brightness(0.3);
}
50% {
filter: brightness(1);
}
100% {
filter: brightness(0.3);
}
}

此时天空中便有了一闪一闪亮晶晶的星星啦

流星划过

接下来便是”流星“的实现了,我们先画一个静态的流星,流星包括它的头+尾巴。我们可以先画个流星头

  • html
 <div class="meteor"></div>
  • css
     .meteor {
position: absolute;
width: 4px;
height: 4px;
top: 30%;
left: 30%;
background: #ffffff;
border-radius: 50%;
box-shadow: 0 0 5px 5px #636262;
}

流星头实现很简单,就是一个圆加box-shadow阴影效果

然后再画它的尾巴。我们可以用它的伪元素实现

      .meteor:after {
content: "";
display: block;
border: 0px solid #fff;
border-width: 2px 100px;
border-color: transparent transparent transparent
rgba(255, 255, 255, 0.3);
}

注意这里的色值要用rgba形式,因为需要它的透明效果

再将其旋转45度,使用translate3d进行平移调整对齐

 transform: rotate(-45deg) translate3d(1px, 1px, 0);
transform-origin: 0% 0%;

接下来我们要做的就是让流星坠落下去,我们可以先定义一个动画

      .meteor {
position: absolute;
width: 4px;
height: 4px;
top: 30%;
left: 30%;
background: #ffffff;
border-radius: 50%;
box-shadow: 0 0 5px 5px #636262;
animation: meteorflashing 3s infinite linear 1s;
}
@keyframes meteorflashing {
0% {
opacity: 0;
transform: scale(0) translate3d(0, 0, 0);
}
50% {
opacity: 1;
transform: scale(1) translate3d(-200px, 200px, 0);
}
100% {
opacity: 0;
transform: scale(1) translate3d(-500px, 500px, 0);
}
}

这时候便实现了流星坠落的效果(闭上眼睛想象一下它是动的)

最后我们多加一点流星并给它们不同的延迟时间与动画时间

  • html
      <div class="meteor meteor1"></div>
<div class="meteor meteor2"></div>
<div class="meteor meteor3"></div>
<div class="meteor meteor4"></div>
<div class="meteor meteor5"></div>
  • css
      .meteor {
position: absolute;
width: 4px;
height: 4px;
opacity: 0;
background: #ffffff;
border-radius: 50%;
box-shadow: 0 0 5px 5px #636262;
}
.meteor:after {
content: "";
display: block;
border: 0px solid #fff;
border-width: 2px 100px 2px 100px;
border-color: transparent transparent transparent
rgba(255, 255, 255, 0.3);
transform: rotate(-45deg) translate3d(1px, 1px, 0);
transform-origin: 0% 0%;
}
.meteor1 {
top: 2vh;
left: 30vw;
animation: meteorflashing 2s infinite linear 1s;
}
.meteor2 {
top: 22vh;
left: 80vw;
background: rgb(234, 0, 255);
animation: meteorflashing 2s infinite linear 1s;
}
.meteor3 {
top: 30vh;
left: 40vw;
animation: meteorflashing 3s infinite linear 2s;
}
.meteor4 {
top: 10vh;
left: 50vw;
animation: meteorflashing 3s infinite linear 1s;
}
.meteor5 {
top: 50vh;
right: 2vw;
animation: meteorflashing 3s infinite linear 3s;
}
@keyframes meteorflashing {
0% {
opacity: 0;
transform: scale(0) translate3d(0, 0, 0);
}
50% {
opacity: 1;
transform: scale(1) translate3d(-200px, 200px, 0);
}
100% {
opacity: 0;
transform: scale(1) translate3d(-500px, 500px, 0);
}
}

好啦,此时便实现了我们所需要的效果啦

中秋节快乐

最后中秋节快到了,我在这里提前祝大家节日快乐,阖家团圆。没什么可送你们的,我就把这轮明月当作节日礼物送给大家了

最新文章

  1. node.js操作mysql数据库之增删改查
  2. 由一段字符串中查找URL引出——正则表达式
  3. tomcat的debug模式启动不了
  4. C语言:十进制进制转换为其他进制(思想:查表法)
  5. gridview 绑定方法中带参数
  6. C#DataGridView 美化
  7. VS2013中自动缩进和注释的快捷键
  8. perl杂项
  9. MS SQLSERVER通用存储过程分页
  10. Csharp多态的实现(接口)
  11. hadoop 磁盘限额配置
  12. Docker 新网络 overlay 网络
  13. springboot~注册bean的方法
  14. SpringBoot启动如何加载application.yml配置文件
  15. next.js学习笔记
  16. eclipse版本对应名称以及下载地址
  17. jQuery层级选择器
  18. http 文件传输
  19. python的变量以及常量介绍
  20. Docker容器学习与分享05

热门文章

  1. .NET ORM框架HiSql实战-第一章-集成HiSql
  2. HDFS存储目录分析
  3. Tapdata Cloud 2.1.5来啦:新增支持Amazon RDS数据库,错误日志查询更便捷,Agent部署细节再优化
  4. Tapdata PDK 生态共建计划启动!Doris、OceanBase、PolarDB、SequoiaDB 等十余家厂商首批加入
  5. JAVA编程练习01作业
  6. C语言项目实现顺序表
  7. 面试突击65:为什么要用HTTPS?它有什么优点?
  8. python requests 使用代理池访问https站点返回乱码
  9. java线程池开启多线程
  10. 4 zookeeper集群和基本命令