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

徐小夕 等级 709 0 0

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案例/学习技巧

dooring更新日志

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

近期规划

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

相关推荐

《前端实战总结》之使用纯css实现网站换肤和焦点图切换动画
今天我们来继续复盘一些工作中常用的css技巧和知识,以便我们可以更加优雅的用css实现富有动感的网站. 你将收获 网站换肤设计方案介绍 :target伪类介绍和用法以及如何使用css实现网站换肤 transition动画以及如何用纯css实现焦点图动画 效果展示 1.网站换肤 (https://imghelloworld.ossc
CSS Modules 解决 react 项目 css 样式互相影响的问题
CSS Modules 解决 react 项目 css 样式互相影响的问题 CSS Modules 解决 react 项目 css 样式互相影响的问题 (http
原来CSS的background还可以这么玩
身为一个前端开发者,背景是开发中的常客。大到整个网站的主题背景,小到一个按钮的背景。CSS 的 background 属性基本上每天开发都会遇到,绝大多数情况下我们都只会使用到了纯色背景或者图片背景。如果你想让你开发的内容看起来更加生动有趣,通过本文让你用纯CSS也可以开发出炫酷的背景。 开始之前在开始之前,先请你回答下面的问题,如果你能全部回答
只听说过CSS in JS,怎么还有JS in CSS?
CSS in JS是一种解决css问题想法的集合,而不是一个指定的库。从CSS in JS的字面意思可以看出,它是将css样式写在JavaScript文件中,而不需要独立出.css、.less之类的文件。将css放在js中使我们更方便的使用js的变量、模块化、treeshaking。还解决了css中的一些问题,譬如:更方便解决基于状态的样式,更容易追溯依赖关
CSS 的优先级机制[总结]
CSS 的优先级机制\[总结\] - 钢钢 - 博客园 [CSS 的优先级机制\[总结\]](https://www.oschina.net/action/GoToLink?url=http%3A%2F%2Fwww.cnblogs.com%2Fxugang%2Farchive%2F2010%2F09%2F24%2F1833760.html) -------
CSS3动画(转自大神制作,很绚丽,纯CSS之作)
绚丽的3D动画(纯CSS实现,代码有点长啊,在这里不知道怎么折叠起来,讲究看看吧) 效果图:[https://bupt-hjm.github.io/css3-3d/](https://www.oschina.net/action/GoToLink?url=https%3A%2F%2Fbupt-hjm.github.io%2Fcss3-3d%2F)(转)
CSS中的滤镜
设计网页时合理的为页面应用滤镜,可以起到非同凡响的效果。CSS滤镜分为基本滤镜和高级滤镜,基本滤镜又称为视觉滤镜,只要将其应用于对象上,便可以立即产生视觉特效,但其效果远不及高级滤镜。css的滤镜标示符是filter,在创建滤镜时首先要对filter进行定义,使用方法同其他css语法。 一、Alpha滤镜:对图像,文字设置透明效果 1、语法 .
CSS基本用法介绍
CSS介绍 ===== css定义如何显示HTML元素. 当浏览器读到一个样式表,它就会按照这个样式表来对文档进行格式化(渲染). CSS语法 ===== ### css实列 每个CSS样式由两个组成部分:选择器和声明。声明又包括属性和属性值。每个声明之后用分号结束。 ### css注释 /*这是注释*/ CSS的几种引入方
CSS基础知识整理
### **1 什么是CSS?** CSS通常称为CSS样式表或层叠样式表(级联样式表),主要用于设置HTML页面中的文本内容(字体、大小、对齐方式等)、图片的外形(宽高、边框样式、边距等)以及版面的布局等外观显示样式。 CSS以HTML为基础,提供了丰富的功能,如字体、颜色、背景的控制及整体排版等,而且还可以针对不同的浏览器设置不同的样式。 ###
SASS入门教程及用法指南
作为前端开发人员,你肯定对css很熟悉,但是你知道css可以自定义吗?大家都知道,js中可以自定义变量,css仅仅是一个标记语言,不是编程语言,因此不可以自定义变量,不可以引用等等。面对这些问题,我们现在来引进一个[SASS](https://www.oschina.net/action/GoToLink?url=http%3A%2F%2Fwww.haoro
CSS定位属性Position详解
CSS中最常用的布局类属性,一个是Float([CSS浮动属性Float详解](https://www.oschina.net/action/GoToLink?url=https%3A%2F%2Fparan.io%2Fcss-float-attribute%2F)),另一个就是CSS定位属性Position。 1\. position:static ---
43个实例xHTML+CSS(DIV+CSS)网页及导航布局教程
在中国,很多前端开发初学者都会把xHTML+CSS页面制作说成DIV+CSS,甚至很多人都还不知道xHTML+CSS是什么意思,只知道盲目的追求DIV+CSS,但在国外,是没有DIV+CSS这个概念的,很明显如果单从字面上去理解,DIV+CSS的网页就要全都是div,很明显是无法达到语义化标准的。请把”DIV+CSS”这个词从脑子中删除,用”xHTML+CS
CSS预处理器SASS用法和koala工具的使用
    最近在学习前端的时候,发现了一个SASS(CSS预处理器),感觉在前端布局写css样式来说是相当强大,效率又高,在用到SASS的时候感觉很爽。     首先说一下传统的CSS,在程序员的眼里感觉是一个很麻烦的东西,没有变量,也没有运算,还没有条件语句,感觉写的相当费事。     在人们都感觉费事的同时,真有牛人把CSS加入了编程的元素,这就是(CS
Less功能特性
(1)变量     我们常常在 CSS 中 看到同一个值重复多次,这样难易于代码维护 const bgColor="skyblue"; $(".post-content").css("background-color",bgColor); $("#wrap").css("background-color",bgColor);
Sass用法指南
学过CSS的人都知道,它不是一种编程语言。 你可以用它开发网页样式,但是没法用它编程。也就是说,CSS基本上是设计师的工具,不是程序员的工具。在程序员眼里,CSS是一件很麻烦的东西。它没有变量,也没有条件语句,只是一行行单纯的描述,写起来相当费事。 很自然地,有人就开始为CSS加入编程元素,这被叫做"CSS预处理器"(css preproces