加入收藏 | 设为首页 | 会员中心 | 我要投稿 聊城站长网 (https://www.0635zz.com/)- 智能语音交互、行业智能、AI应用、云计算、5G!
当前位置: 首页 > 综合聚焦 > 编程要点 > 语言 > 正文

用CSS如何实现动态的乌云天气图标

发布时间:2023-09-21 14:31:20 所属栏目:语言 来源:
导读:这篇文章给大家分享的是用CSS怎么实现动态的乌云天气图标。小编觉得挺实用的,因此分享给大家做个参考,文中的介绍得很详细,而要易于理解和学习,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。

实现
这篇文章给大家分享的是用CSS怎么实现动态的乌云天气图标。小编觉得挺实用的,因此分享给大家做个参考,文中的介绍得很详细,而要易于理解和学习,有需要的朋友可以参考,接下来就跟随小编一起了解看看吧。
 
实现思路
 
使用box-shadow属性画几个灰色的圆,将这些圆错落的组合在一起,形成乌云图案
 
after伪元素写乌云下的投影
 
增加动画
 
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,搞定。按着步骤来,你也可以在你的页面上实现乌云的天气图标咯~
 
 

(编辑:聊城站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章