纯css如何实现乌云密布的天气图标效果

每到春天,红得如火的木棉花,粉得如霞的芍药花,白得如玉的月季花竞相开放。它们有的花蕾满枝,有的含苞初绽,有的昂首怒放。一阵沁人心肺的花香引来了许许多多的小蜜蜂,嗡嗡嗡地边歌边舞。

效果

效果如下

实现思路

  1. 使用box-shadow属性画几个灰色的圆,将这些圆错落的组合在一起,形成乌云图案
  2. after伪元素写乌云下的投影
  3. 增加动画

dom结构

用两个嵌套的div容器,父容器来控制图标显示的位置,子容器用来写乌云的样式。

<div class="container">
    <div class="cloudy"></div>
</div>

css样式

1、父容器样式,顺便给整个页面加一个背景色,方便预览

body{
    background: rgba(73, 74, 95, 1);
}
.container{
    width: 170px;
    height: 170px;
    position: relative;
    margin: 250px auto;
}

2、乌云的样式,乌云有一个上下移动的动画。这儿关键是box-shadow属性的使用,白色的话就可以当作多云的天气图标啦~

.cloudy{
    width: 50px;
    height: 50px;
    position: absolute;
    top: 70px;
    left: 80px;
    margin-left: -60px;
    background: #ccc;
    border-radius: 50%;
    box-shadow: #ccc 65px -10px 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: translateY(-20px);
    }
}

3、投影的样式,可以使用after伪元素,别忘了同样是有移动动画的

.cloudy::after{
    content: '';
    width: 120px;
    height: 15px;
    position: absolute;
    bottom: -60px;
    left: 5px;
    background: #000;
    border-radius: 50%;
    opacity: 0.2;
    animation: cloudy-shadow 5s ease-in-out infinite;
    transform: scale(0.7);
}

@keyframes cloudy-shadow{
    50%{
        transform: translateY(20px) scale(1);
        opacity: 0.05;
    }
}

OK,搞定。按着步骤来,你也可以在你的页面上实现乌云的天气图标咯~

总结

以上所述是小编给大家介绍的纯css实现乌云密布的天气图标效果,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!

以上就是纯css如何实现乌云密布的天气图标效果。所有成功的企业必须有非常强烈的企业文化,用这个企业文化把所有人凝聚在一起。上百年的企业,不知道有多少东西都变化了,惟独它的企业精神百年不变,这非常能够说明问题。所以企业文化就是企业精神,企业精神就是企业灵魂,而这个灵魂如果是永远不衰、永远常青的,企业就永远存在。更多关于纯css如何实现乌云密布的天气图标效果请关注haodaima.com其它相关文章!

您可能有感兴趣的文章
CSS如何使用Flex和Grid布局如何实现3D骰子

纯CSS打字动画的如何实现示例

CSS中如何使用grid布局如何实现一套模板多种布局

css3手动如何实现pc端横向滚动

css如何实现右上角飘带效果的完整代码