用 radial-gradient 实现波浪效果

栏目: CSS · 发布时间: 4年前

内容简介:简单画一下原理图中的波浪线 L 就是我们要的,它是沿着上下两排相切圆的切线画出来的,只要画出 A 段然后重复,就可以得到我们想要的波浪效果。
用 radial-gradient 实现波浪效果

codepen: https://codepen.io/linghucq1/pen/zQjqZv?editors=1100

简单画一下原理

用 radial-gradient 实现波浪效果

图中的波浪线 L 就是我们要的,它是沿着上下两排相切圆的切线画出来的,只要画出 A 段然后重复,就可以得到我们想要的波浪效果。

首先要解决怎么画圆的问题,这里就要用到 css3 radial-gradient 属性,不了解这个属性的可以看一下mdn或者 10个demo示例学会CSS3 radial-gradient径向渐变 。我们这里要做的,就是画出两种颜色的圆并让它们相切。

先搞一个装波浪的框

<div class="wave"></div>
复制代码
.wave {
  height: 100px;
  background-color: blue;
  margin-top: 100px;
}
复制代码
用 radial-gradient 实现波浪效果

得到一个蓝色的长方形,现在我们在它的上边缘画一个圆。

.wave {
  height: 100px;
  background-color: blue;
  margin-top: 100px;
  position: relative;
  
  &::before {
    content: '';
    position: absolute;
    height: 100px;
    width: 100%;
    top: -50px;
    background: radial-gradient(50px circle, blue 50px, transparent)
  }
}
复制代码
用 radial-gradient 实现波浪效果

用 background-size 让它重复

&::before {
    content: '';
    position: absolute;
    height: 100px;
    width: 100%;
    top: -50px;
    background: radial-gradient(50px circle, blue 50px, transparent) repeat-x;
    background-size: 100px;
  }
复制代码
用 radial-gradient 实现波浪效果

这里已经可以看到雏形了,如果我们把间隔拉大然后在中间加入白色圆

&::before {
    content: '';
    position: absolute;
    height: 100px;
    width: 100%;
    top: -50px;
    background: radial-gradient(50px circle at 50px 50px, #fff 50px, transparent), radial-gradient(50px circle at 150px 50px, blue 50px, transparent);
    background-size: 200px 100px;
  }
复制代码
用 radial-gradient 实现波浪效果

一个圆圆的波浪就完成了,现在我们要做的,就是调整圆的位置。根据开始的手绘图,我们可以计算出上下圆圆心的水平和垂直距离。其中水平距离为圆的半径 R,垂直距离为 √3R 也就是 1.732R。而且我们只要画出一个周期的波段(A)然后重复就行了。

&::before {
    @height: 50px * 1.732;
    content: '';
    position: absolute;
    height: 100px;
    width: 100%;
    top: -@height/2;
    background: radial-gradient(50px circle at 0 0, #f0f 50px, transparent), radial-gradient(50px circle at 50px @height, blue 50px, transparent), radial-gradient(50px circle at 100px 0, #f0f 50px, transparent);
    background-size: 100px 100px;
    background-repeat: no-repeat;
  }
复制代码

我们先把背景重复关掉来看单独的一段长什么样,

用 radial-gradient 实现波浪效果

这里特意用了一个颜色作为区分,需要注意的是 top 的值为上下圆心垂直距离的一半。

把上面颜色改成白色就是一个波浪效果了。

用 radial-gradient 实现波浪效果

现在再加一个平移动画和另一层波浪和半透明,就可以实现最开始的效果。

但是,如果你去尝试把 codepen 代码里面的 wave2 往上移,就会发现这个方案并不完美,目前还没有想到解决方案,不知道各位有什么好点子?

这里顺便安利一个 chrome 插件:web maker,可以实时预览 html css js 编辑效果,还可以在线保存之前的代码,没事的时候就鼓捣鼓捣,很好用。


以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

引爆社群:移动互联网时代的新4C法则(第2版)

引爆社群:移动互联网时代的新4C法则(第2版)

唐兴通 / 机械工业出版社 / 69.00元

社群已经被公认为是这个时代的商业新形态,原有的商业逻辑和方法被颠覆,新的基于社群的商业体系和规则亟待构建,今天几乎所有的企业都在为此而努力,都在摸索中前行。 本书提出的“新4C法则”为社群时代的商业践行提供了一套科学的、有效的、闭环的方法论,第1版上市后获得了大量企业和读者的追捧,“新4C法则”在各行各业被大量解读和应用,积累了越来越多的成功案例,被公认为是社群时代通用的方法论。也因此,第1......一起来看看 《引爆社群:移动互联网时代的新4C法则(第2版)》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

XML、JSON 在线转换
XML、JSON 在线转换

在线XML、JSON转换工具

html转js在线工具
html转js在线工具

html转js在线工具