纯css实现粒子效果

本文介绍如何利用CSS3(Sass)创建粒子效果,通过box-shadow生成粒子,结合animation和transform 3d的translateZ实现动画。详细阐述了思路与实现步骤,并提供了在线研究和源码下载链接。
前端开发whqet,csdn,王海庆,whqet,前端开发专家

好久没有更新的CSS3演武场系列,半年前搁浅的一篇文章赋予新年新气象闪亮登场了,研究一下利用css(sass)实现粒子效果,主要使用box-shadow生成粒子,利用css3 animation和translateZ实现动画

------------------------------------------------------------

--我参加了博客之星评选,如果你喜欢我的博客,求投票,您的支持是我的动力之源走起!

-----------------------------------------------------------------------------------------

看效果先


思路解析

1.box-shadow生成粒子,赋予随机位置、随机颜色,利用sass的for循环和random()实现。

2.animation实现动画。

3.transform 3d实现深度动画,主要使用translateZ。

实现

下面我们分别来实现一下,源码我放在了codepen,请大家移步

----------------

----------------------------------------

在线研究点击这里,下载收藏点击这里。

----------------------------------------

---------------

1.html部分非常简单就是一个div。

<div class="stars"></div>

2.css部分是重点,我们首先设置全局的css,我们使用normallize和prefix free。然后对html和body作如下设置。

$stars: 100;         // 粒子数
$depth: 300;         // 深度
$speed: 1s;          // 动画时间
$width: 1500;        // 宽
$height: 960;        // 高

html, body {
  height: 100%;
  overflow: hidden;
}
body {
  perspective: 340px;
  background:#000 url(https://img-my.csdn.net/uploads/201501/02/1420174857_3649.png) center center no-repeat;
  background-size:28% 30%;
}

对于.stars,我们设置大小、位置,宽、高各位5px,位置居中,圆角边框。

.stars {
  position: absolute;
  top: 50%;
  left: 50%;
  width:5px;
  height:5px;
  border-radius:100%;
}

然后我们使用box-shadow生成粒子。box-shadow一个很好玩的特性,生成效果如下。

.stars {
  position: absolute;
  top: 50%;
  left: 50%;
  width:5px;
  height:5px;
  border-radius:100%;
  /*box-shadow生成粒子*/
  $box-shadow: ();
  @for $i from 0 through $stars {
    $box-shadow: $box-shadow, (random($width)-$width/2 + px) (random($height)-$height/2 + px) adjust-hue(#ff0000, random(360));
  }
  box-shadow: $box-shadow;
}


然后这个数量有点少,同时层次感不足,我们利用:before和:after伪对象搞定这些事情。

.stars {
  position: absolute;
  top: 50%;
  left: 50%;
  width:5px;
  height:5px;
  border-radius:100%;
  $box-shadow: ();
  @for $i from 0 through $stars {
    $box-shadow: $box-shadow, (random($width)-$width/2 + px) (random($height)-$height/2 + px) adjust-hue(#ff0000, random(360));
  }
  box-shadow: $box-shadow;
  /*伪对象更多粒子、更多层次*/
  &:before, &:after {
    content: "";
    position: absolute;
    width: inherit;
    height: inherit;
    box-shadow: inherit;
  }
  &:before {
    transform: translateZ(-$depth + px);
    opacity: .3;
  }
  &:after {
    transform: translateZ(-$depth * 2 + px);
    opacity: .1;
  }
}

添加粒子和深度之后效果如下图所示。


然后添加动画。

.stars {
  position: absolute;
  top: 50%;
  left: 50%;
  width:5px;
  height:5px;
  border-radius:100%;
  /*box-shadow生成粒子*/
  $box-shadow: ();
  @for $i from 0 through $stars {
    $box-shadow: $box-shadow, (random($width)-$width/2 + px) (random($height)-$height/2 + px) adjust-hue(#ff0000, random(360));
  }
  box-shadow: $box-shadow;
  /* 添加动画 */
  animation: fly $speed linear infinite;
  transform-style:preserve-3d;
  /* 伪对象更多粒子、更多层次 */
  &:before, &:after {
    content: "";
    position: absolute;
    width: inherit;
    height: inherit;
    box-shadow: inherit;
  }
  &:before {
    transform: translateZ(-$depth + px);
    opacity: .3;
  }
  &:after {
    transform: translateZ(-$depth * 2 + px);
    opacity: .1;
  }
}

@keyframes fly {
  from {
    transform: translateZ(0px);
    opacity:.1;
  }
  to {
    transform: translateZ($depth + px);
    opacity:0.8;
  }
}

然后,就可以欣赏效果了。最后给大家附带完整的css源码。

$stars: 100;         // 粒子数
$depth: 300;         // 深度
$speed: 1s;          // 动画时间
$width: 1500;        // 宽
$height: 960;        // 高

html, body {
  height: 100%;
  overflow: hidden;
}
body {
  perspective: 340px;
  background:#000 url(https://img-my.csdn.net/uploads/201501/02/1420174857_3649.png) center center no-repeat;
  background-size:28% 30%;
}
.stars {
  position: absolute;
  top: 50%;
  left: 50%;
  width:5px;
  height:5px;
  border-radius:100%;
  $box-shadow: ();
  @for $i from 0 through $stars {
    $box-shadow: $box-shadow, (random($width)-$width/2 + px) (random($height)-$height/2 + px) adjust-hue(#ff0000, random(360));
  }
  box-shadow: $box-shadow;
 /* 
  animation: fly $speed linear infinite;
  transform-style:preserve-3d;
  */
  &:before, &:after {
    content: "";
    position: absolute;
    width: inherit;
    height: inherit;
    box-shadow: inherit;
  }
  &:before {
    transform: translateZ(-$depth + px);
    opacity: .3;
  }
  &:after {
    transform: translateZ(-$depth * 2 + px);
    opacity: .1;
  }
}

@keyframes fly {
  from {
    transform: translateZ(0px);
    opacity:.1;
  }
  to {
    transform: translateZ($depth + px);
    opacity:0.8;
  }
}

感谢您耐心读完,如果对您有帮助,请支持我

----------------------------------------------------------

前端开发whqet,关注web前端开发,分享相关资源,欢迎点赞,欢迎拍砖。
---------------------------------------------------------------------------------------------------------

评论 22
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值