当前位置: 代码网 > it编程>网页制作>Css > 通过CSS实现逼真水滴动效

通过CSS实现逼真水滴动效

2024年05月18日 Css 我要评论
哈喽哈喽!css真的好好玩啊,哈哈,反正我是爱了,空闲写着玩。画画不好的我乐了,下面就是一个用css3动画完成的模仿水珠的动效,其中主要就是会使用css设置阴影效果以及@keyframes关键帧和一些

哈喽哈喽!css真的好好玩啊,哈哈,反正我是爱了,空闲写着玩。画画不好的我乐了,下面就是一个用css3动画完成的模仿水珠的动效,其中主要就是会使用css设置阴影效果以及@keyframes关键帧和一些选择器的技术,快来学习吧!!!🐬

在这里插入图片描述

实现效果:就很nice
你也通过一下网址进行访问水滴点击进入

在这里插入图片描述

灵感:看到了这张图阴影高亮,这属于美术吧,哈哈,我是小菜鸡

在这里插入图片描述


这里强烈安利github上一个大牛的开源:花式边框半径生成器利用这个可以使这个效果实现的事半功倍,好开始coding

1.html

很简单,只需要一个盒子就ok了

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta http-equiv="x-ua-compatible" content="ie=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>水滴</title>
</head>
<body>
    <div class="shui"></div>
</body>
</html>

2.css

注释已经写在代码中,这里主要学习一下伪元素选择器的使用,box-shadow这个设置阴影的属性,关键帧 @keyframes以及关键帧的使用 animation,和 border-radius: 30% 70% 70% 30% / 30% 35% 65% 70%;这个属性的使用

		/*清除body的影响*/
        *{
            margin: 0;
            padding: 0;
        }
        /*设置背景颜色*/
        body{
            background-color: rgba(40, 134, 241, 0.925);
        }
        /* 初始一下水,大小,弯曲,阴影*/
        .shui{
            width: 400px;
            height: 400px;
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%,-50%);
            /* 测试用的边框 */
            /* border: 1px solid; */
            box-sizing: border-box;
            /* 设置弯曲 */
            border-radius: 30% 70% 70% 30% / 30% 35% 65% 70%;
            /* 设置box-shadow :水平方向阴影  垂直方向阴影  模糊距离  阴影尺寸  阴影颜色  内/外阴影(inset/outset(默认)) 
            盒子阴影可以有多组值,之间用逗号隔开
            水平阴影和垂直阴影必须写,其余4个是可选的*/
            box-shadow: inset 10px 20px 30px rgba(0, 0, 0, 0.5), 10px 10px 20px rgba(0, 0, 0, 0.3), 15px 15px 30px rgba(0, 0, 0, 0.05), 
            inset -10px -10px 15px rgba(255, 255, 254, 0.83);
            /*使用关键帧  watermove  9s播放  匀速 无限循环*/
            animation: watermove 9s linear infinite;
        }
        /* 伪元素选择器:在^之后插入 */
        .shui::after{
            content: "";
            position: absolute;
            width: 35px;
            height: 35px;
            background: rgba(255, 255, 255, 0.82);
            border-radius: 50%;
            left: 60px;
            top: 80px;
            /*使用关键帧  watermove  4s播放  匀速 无限循环*/
            animation: watermove 4s linear infinite;
        }
        /* 伪元素选择器:在当前盒子最前插入一个东西 */
        .shui::before{
            content: "";
            position: absolute;
            width: 20px;
            height: 20px;
            background: rgba(255, 255, 255, 0.82);
            border-radius: 50%;
            left: 120px;
            top: 55px;
            /*使用关键帧  watermove  4s播放  匀速 无限循环*/
            animation: watermove 4s linear infinite;
        }
        /* 关键帧 */
        @keyframes watermove{  
            20%{
                border-radius: 30% 70% 53% 47% / 28% 44% 56% 72%;
            }
           
            40%{
                border-radius: 30% 70% 39% 61% / 34% 39% 61% 66%;
            }
           
            60%{
                border-radius: 25% 75% 45% 55% / 40% 55% 45% 60%;
            }
           
            80%{
                border-radius: 28% 72% 31% 69% / 32% 39% 61% 68%;
            }
        }

3.完整代码

<!doctype html>
<html lang="en">
<head>
    <meta charset="utf-8">
    <meta http-equiv="x-ua-compatible" content="ie=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>水滴</title>
    <style>
        /*清除body的影响*/
        *{
            margin: 0;
            padding: 0;
        }
        /*设置背景颜色*/
        body{
            background-color: rgba(40, 134, 241, 0.925);
        }
        /* 初始一下水,大小,弯曲,阴影*/
        .shui{
            width: 400px;
            height: 400px;
            position: absolute;
            top: 50%;
            left: 50%;
            transform: translate(-50%,-50%);
            /* 测试用的边框 */
            /* border: 1px solid; */
            box-sizing: border-box;
            /* 设置弯曲 */
            border-radius: 30% 70% 70% 30% / 30% 35% 65% 70%;
            /* 设置box-shadow :水平方向阴影  垂直方向阴影  模糊距离  阴影尺寸  阴影颜色  内/外阴影(inset/outset(默认)) 
            盒子阴影可以有多组值,之间用逗号隔开
            水平阴影和垂直阴影必须写,其余4个是可选的*/
            box-shadow: inset 10px 20px 30px rgba(0, 0, 0, 0.5), 10px 10px 20px rgba(0, 0, 0, 0.3), 15px 15px 30px rgba(0, 0, 0, 0.05), 
            inset -10px -10px 15px rgba(255, 255, 254, 0.83);
            /*使用关键帧  watermove  9s播放  匀速 无限循环*/
            animation: watermove 9s linear infinite;
        }
        /* 伪元素选择器:在^之后插入 */
        .shui::after{
            content: "";
            position: absolute;
            width: 35px;
            height: 35px;
            background: rgba(255, 255, 255, 0.82);
            border-radius: 50%;
            left: 60px;
            top: 80px;
            /*使用关键帧  watermove  4s播放  匀速 无限循环*/
            animation: watermove 4s linear infinite;
        }
        /* 伪元素选择器:在当前盒子最前插入一个东西 */
        .shui::before{
            content: "";
            position: absolute;
            width: 20px;
            height: 20px;
            background: rgba(255, 255, 255, 0.82);
            border-radius: 50%;
            left: 120px;
            top: 55px;
            /*使用关键帧  watermove  4s播放  匀速 无限循环*/
            animation: watermove 4s linear infinite;
        }
        /* 关键帧 */
        @keyframes watermove{  
            20%{
                border-radius: 30% 70% 53% 47% / 28% 44% 56% 72%;
            }
           
            40%{
                border-radius: 30% 70% 39% 61% / 34% 39% 61% 66%;
            }
           
            60%{
                border-radius: 25% 75% 45% 55% / 40% 55% 45% 60%;
            }
           
            80%{
                border-radius: 28% 72% 31% 69% / 32% 39% 61% 68%;
            }
        }

    </style>
</head>
<body>
    <div class="shui"></div>
</body>
</html>

ok,简简单单,快快乐乐,欢迎交流探讨,白白了你

到此这篇关于通过css实现逼真水滴动效的文章就介绍到这了,更多相关css实现水滴效果内容请搜索代码网以前的文章或继续浏览下面的相关文章希望大家以后多多支持代码网!

(0)

相关文章:

  • 利用CSS制作3D动画

    css 3d 基础知识本文默认读者掌握一定的 css 3d 知识,能够绘制初步的 3d 动画效果。当然这里会再简单过一下 css 3d 的基础知识。使用 transform-sty…

    2024年05月18日 网页制作
  • 带你了解CSS基础知识,样式

    带你了解CSS基础知识,样式

    什么是csscss(cascading style sheet):层叠样式表语言。css的作用是:修饰html页面,设置html页面中的某些元素的样式,让htm... [阅读全文]
  • HTML相关知识点总结

    简介html超文本标记语言(hyper text markup language),它是互联网上应用最广泛的标记语言。不要把html语言和c、java等编程语言混淆起来。简单的说,…

    2024年05月18日 网页制作
  • 浅谈CSS不规则边框的生成方案

    需求背景,给不规则图形添加边框在我们日常开发中,时长会遇到一些非矩形、非圆形的图案。类似下面这些:使用纯 css,搭配一些技巧,是可以制作出上面的图形的,当然这只是需求的第一步。紧…

    2024年05月18日 网页制作
  • HTML-Canvas的优越性能以及实际应用

    html绘图届的前辈:svgcanvas是html5时代引入的“新”标签。与很多标签不同,canvas不具有自己的行为,只将一组api 展现给客户端 javascript ,让开发…

    2024年05月18日 网页制作
  • 详解CSS故障艺术

    概述本文的主题是 glitch art,故障艺术。什么是故障艺术?我们熟知的抖音的 logo 正是故障艺术其中一种表现形式。它有一种魔幻的感觉,看起来具有闪烁、震动的效果,很吸引人…

    2024年05月18日 网页制作

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com