最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 轻松教你使用纯css实现H5-Doorin编辑器中的水波动画

    正文概述 掘金(徐小夕)   2021-02-09   689

    css3给我们前端开发带来了很便利, 我们可以使用css3 的新特性实现各种形状和动效, 接下来笔者就来带大家介绍如何用css3实现 H5-Dooring编辑器 中的水波动画.

    轻松教你使用纯css实现H5-Doorin编辑器中的水波动画

    由于生成gif的工具比较弱(在线求好用的macgif录频生成工具...), 我不得不上传个原图, 大家自行脑补.轻松教你使用纯css实现H5-Doorin编辑器中的水波动画

    接下来我们来研究实现原理和实现方式.

    动画拆解

    要想用纯css实现曲线, 我们第一反应就是用border-radius这个属性, 比如说实现一个圆, 我们只需要如下设置:

    .circle {
      border-radius: 50%;
    }
    

    实现椭圆,扇形, 半椭圆这些, 只需要设置不同边的圆角即可, 如下:

    .circle {
      border-radius: 50% 100% 40% 60%;
    }
    

    以上的代码效果如下: 轻松教你使用纯css实现H5-Doorin编辑器中的水波动画

    我们再发挥一下想象, 如果是闭合曲线, 是不是也能用同样的方法实现呢? 轻松教你使用纯css实现H5-Doorin编辑器中的水波动画 我们只需要将background换成border, 调整border-radius参数即可. 接下来给大家看一下我用css画的一个图形, 各位可以参考学习一下: 轻松教你使用纯css实现H5-Doorin编辑器中的水波动画

    当然使用相同的原理我们可以实现更多有意思的图案, 笔者这里就不一一举例了.

    回归正题, 我们来看看水波动画的实现原理. 首先不规则动画我们实现了, 剩下的工作就是如何实现波浪波浪动画, 参考上面不规则图形的实现方案, 波浪线的制作可以采用类似裁切来实现, 如下: 轻松教你使用纯css实现H5-Doorin编辑器中的水波动画 由上图可以看出, 我们使用cssborder-radius做一个矩形和一个圆角矩形, 使用transform来设置偏移和旋转, 就可以实现底部裁切后的曲面. 最后我们使用animation动画让其运动来看看效果:

    轻松教你使用纯css实现H5-Doorin编辑器中的水波动画

    我们只需要优化上面的动画, 让背景更柔和, 比如说圆形, 容器溢出隐藏, 这样就可以实现H5-Dooring编辑器 中的水波动画了, css源码如下:

    .dragPay {
          position: absolute;
          z-index: 99999;
          left: 414px;
          top: 156px;
          width: 60px;
          height: 60px;
          border-radius: 50%;
          border: 3px solid #20c961;
          background: #ffffff;
          overflow: hidden;
          padding: 5px;
          box-sizing: border-box;
    }
    .dragPay .wave {
        position: relative;
        left: -8px;
        width: 60px;
        height: 60px;
        background-image: linear-gradient(-180deg, #8dec8a 13%, #70cf23 91%);
        border-radius: 50%;
        line-height: 60px;
        text-align: center;
        font-size: 32px;
        cursor: pointer;
    }
    .dragPay .waveMask {
        position: absolute;
        width: 120px;
        height: 120px;
        top: 0;
        left: 50%;
        border-radius: 40%;
        background-color: rgba(255, 255, 255, 0.9);
        transform: translate(-50%, -82%) rotate(0);
        animation: toRotate 10s linear -5s infinite;
        z-index: 20;
        pointer-events: none;
    }
    @keyframes toRotate {
        50% {
        transform: translate(-50%, -70%) rotate(180deg);
        }
        100% {
        transform: translate(-50%, -70%) rotate(360deg);
        }
    }
    

    html结构如下:

    <div class="dragPay">
        <div class="wave">
          <span>⛽️</span>
        </div>
        <div class="waveMask"></div>
    </div>
    

    当然我们可以使用伪元素来优化dom结构. 大家可以亲自感受一下.

    更多css3案例/学习技巧

    • 巧用css圆角实现有点意思的加载动画
    • 手撸一个在线css三角形生成器
    • 如何使用css3实现一个类在线直播的队列动画
    • 《前端实战总结》之使用CSS3实现酷炫的3D旋转透视
    • 《css大法》之使用伪元素实现超实用的图标库(附源码)
    • 用css3实现惊艳面试官的背景即背景动画(高级附源码)

    最后

    目前H5-Dooring还在飞速迭代,

    • github地址: github.com/MrXujiang/h…
    • ℹ️ issue地址: github.com/MrXujiang/h…
    • 官方文档

    dooring更新日志

    1. 图片库支持自定义图片上传
    2. 修复预览页面方法隐藏bug
    3. dooring文档添加部署和二次开发文档,具体包括:
    1. dooring开发文档迭代
    2. 表单组件支持布局概念
    3. 支持表单数据批量导入,删除
    4. 图标组件支持自定义上传
    

    近期规划

    1. 完善api接口文档
    2. pc端页面编辑器
    3. beta版初版

    起源地下载网 » 轻松教你使用纯css实现H5-Doorin编辑器中的水波动画

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元