博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
用 radial-gradient 实现波浪效果
阅读量:5788 次
发布时间:2019-06-18

本文共 1963 字,大约阅读时间需要 6 分钟。

先上效果图

简单画一下原理

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

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

先搞一个装波浪的框

复制代码
.wave {  height: 100px;  background-color: blue;  margin-top: 100px;}复制代码

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

.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)  }}复制代码

用 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;  }复制代码

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

&::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;  }复制代码

一个圆圆的波浪就完成了,现在我们要做的,就是调整圆的位置。根据开始的手绘图,我们可以计算出上下圆圆心的水平和垂直距离。其中水平距离为圆的半径 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;  }复制代码

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

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

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

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

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

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

转载于:https://juejin.im/post/5ce945e95188252a4f229454

你可能感兴趣的文章
BeanShell变量和方法的作用域
查看>>
LINUX下防恶意扫描软件PortSentry
查看>>
由数据库对sql的执行说JDBC的Statement和PreparedStatement
查看>>
springmvc+swagger2
查看>>
软件评测-信息安全-应用安全-资源控制-用户登录限制(上)
查看>>
我的友情链接
查看>>
Java Web Application 自架构 一 注解化配置
查看>>
如何 debug Proxy.pac文件
查看>>
Python 学习笔记 - 面向对象(特殊成员)
查看>>
Kubernetes 1.11 手动安装并启用ipvs
查看>>
Puppet 配置管理工具安装
查看>>
Bug多,也别乱来,别被Bug主导了开发
查看>>
sed 替换基础使用
查看>>
高性能的MySQL(5)创建高性能的索引一B-Tree索引
查看>>
oracle备份与恢复--rman
查看>>
图片变形的抗锯齿处理方法
查看>>
Effective C++ Item 32 确保你的 public 继承模子里出来 is-a 关联
查看>>
phpstorm安装laravel-ide-helper实现自动完成、代码提示和跟踪
查看>>
python udp编程实例
查看>>
TortoiseSVN中图标的含义
查看>>