广告
返回顶部
首页 > 资讯 > 精选 >使用CSS怎么实现一个波浪效果
  • 407
分享到

使用CSS怎么实现一个波浪效果

2023-06-08 06:06:54 407人浏览 独家记忆
摘要

本篇文章为大家展示了使用CSS怎么实现一个波浪效果,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。css是什么意思css是一种用来表现html或XML等文件样式的计算机语言,主要是用来设计网页的样式,

本篇文章为大家展示了使用CSS怎么实现一个波浪效果,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。

css是什么意思

css是一种用来表现html或XML等文件样式的计算机语言,主要是用来设计网页的样式,使网页更加美化。它也是一种定义样式结构如字体、颜色、位置等的语言,并且css样式可以直接存储于HTML网页或者单独的样式单文件中,而样式规则的优先级由css根据这个层次结构决定,从而实现级联效果,发展至今,css不仅能装饰网页,也可以配合各种脚本对于网页进行格式化。

SVG 实现波浪效果

借助 SVG ,是很容易画出三次贝塞尔曲线的。

使用CSS怎么实现一个波浪效果

<svg width="200px" height="200px" version="1.1" xmlns="Http://www.w3.org/2000/svg">    <text class="liquidFillGaugeText" text-anchor="middle" font-size="42px" transfORM="translate(100,120)" style="fill: #000">50.0%</text>    <!-- Wave -->    <g id="wave">    <path id="wave-2" fill="rgba(154, 205, 50, .8)" d="M 0 100 C 133.633 85.12 51.54 116.327 200 100 A 95 95 0 0 1 0 100 Z">    <animate dur="5s" repeatCount="indefinite" attributeName="d" attributeType="XML" values="M0 100 C90 28, 92 179, 200 100 A95 95 0 0 1 0 100 Z;    M0 100 C145 100, 41 100, 200 100 A95 95 0 0 1 0 100 Z;    M0 100 C90 28, 92 179, 200 100 A95 95 0 0 1 0 100 Z"></animate>    </path>    </g>    <circle cx="100" cy="100" r="80" stroke-width="10" stroke="white" fill="transparent"></circle>    <circle cx="100" cy="100" r="90" stroke-width="20" stroke="yellowgreen" fill="none" class="percentage-pie-svg"></circle></svg>

画出三次贝塞尔曲线的核心在于 <path id="wave-2" fill="rgba(154, 205, 50, .8)" d="M 0 100 C 133.633 85.12 51.54 116.327 200 100 A 95 95 0 0 1 0 100 Z">这一段。感兴趣的可以自行去研究研究

canvas 实现波浪效果

使用 canvas 实现波浪效果的原理与 SVG 一样,都是利用路径绘制出三次贝塞尔曲线并赋予动画效果。

使用CSS怎么实现一个波浪效果

$(function() {    let canvas = $("canvas");    let ctx = canvas[0].getContext('2d');    let radians = (Math.PI / 180) * 180;    let startTime = Date.now();    let time = 2000;    let clockwise = 1;    let cp1x, cp1y, cp2x, cp2y;    // 初始状态    // ctx.bezierCurveTo(90, 28, 92, 179, 200, 100);    // 末尾状态    // ctx.bezierCurveTo(145, 100, 41, 100, 200, 100);    requestAnimationFrame(function waveDraw() {         let t = Math.min(1.0, (Date.now() - startTime) / time);        if(clockwise) {            cp1x = 90 + (55 * t);            cp1y = 28 + (72 * t);            cp2x = 92 - (51 * t);            cp2y = 179 - (79 * t);        } else {            cp1x = 145 - (55 * t);            cp1y = 100 - (72 * t);            cp2x = 41 + (51 * t);            cp2y = 100 + (79 * t);        }        ctx.clearRect(0, 0, 200, 200);         ctx.beginPath();        ctx.moveTo(0, 100);        // 绘制三次贝塞尔曲线        ctx.bezierCurveTo(cp1x, cp1y, cp2x, cp2y, 200, 100);        // 绘制圆弧        ctx.arc(100, 100, 100, 0, radians, 0);        ctx.fillStyle = "rgba(154, 205, 50, .8)";        ctx.fill();        ctx.save();         if( t == 1 ) {            startTime = Date.now();            clockwise = !clockwise;        }        requestAnimationFrame(waveDraw);    });})

主要是利用了动态绘制 ctx.bezierCurveTo() 三次贝塞尔曲线实现波浪的运动效果,感兴趣的可以自行研究。

CSS实现波浪效果

最开始不是说css不能实现吗?是,我们没有办法直接绘制出三次贝塞尔曲线,但是我们可以利用一些讨巧的方法,模拟达到波浪运动时的效果,下面来看看这种方法。

原理

原理十分简单,我们都知道,一个正方形,给它添加 border-radius: 50%,将会得到一个圆形。

使用CSS怎么实现一个波浪效果

width: 240px;height: 240px;background: #f13f84;border-radius: 50%;

好的,如果 border-radius 没到 50%,但是接近 50% ,我们会得到一个这样的图形(注意边角,整个图形给人的感觉是有点圆,却不是很圆。)

使用CSS怎么实现一个波浪效果

width: 240px;height: 240px;background: #f13f84;border-radius: 40%;

好的,那整这么个图形又有什么用?还能变出波浪来不成?

我们让上面这个图形滚动起来(rotate) ,看看效果:

使用CSS怎么实现一个波浪效果

CSS实现波浪效果

@keyframes rotate{    from{transform: rotate(0deg)}    to{transform: rotate(359deg)}}.ripple{    width: 240px;    height: 240px;    background: #f13f84;    border-radius: 40%;    animation: rotate 3s linear infinite;}

上述内容就是使用CSS怎么实现一个波浪效果,你们学到知识或技能了吗?如果还想学到更多技能或者丰富自己的知识储备,欢迎关注编程网精选频道。

--结束END--

本文标题: 使用CSS怎么实现一个波浪效果

本文链接: https://www.lsjlt.com/news/252474.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 使用CSS怎么实现一个波浪效果
    本篇文章为大家展示了使用CSS怎么实现一个波浪效果,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。css是什么意思css是一种用来表现HTML或XML等文件样式的计算机语言,主要是用来设计网页的样式,...
    99+
    2023-06-08
  • 使用css3怎么实现一个动感波浪效果
    使用css3怎么实现一个动感波浪效果?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一根矢量的波浪<svg viewBox="0 0&nb...
    99+
    2023-06-08
  • 怎么在CSS中利用Houdini实现一个动态波浪纹效果
    怎么在CSS中利用Houdini实现一个动态波浪纹效果?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。css是什么意思css是一种用来表现HTML或XML等文件样式的计算机语...
    99+
    2023-06-08
  • 纯CSS怎么实现波浪移动效果
    这篇文章给大家分享的是有关纯CSS怎么实现波浪移动效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。分析波浪效果上面是作者完成的波浪效果的其中一种(不会做 gif,就用多张图片拼贴在一起代替吧),它有两个波峰,这...
    99+
    2023-06-08
  • CSS怎么制作波浪效果
    这篇文章主要讲解了“CSS怎么制作波浪效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“CSS怎么制作波浪效果”吧!本文将会介绍一种使用 CSS 实现的波浪...
    99+
    2022-10-19
  • css实现波浪效果的方法
    本篇内容主要讲解“css实现波浪效果的方法”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“css实现波浪效果的方法”吧!css实现波浪效果的方法:首先创建一个HTML示例文件;然后创建一个正方形的...
    99+
    2023-06-14
  • HTML怎么实现波浪效果
    这篇文章主要介绍了HTML怎么实现波浪效果,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。  <div> <hgr...
    99+
    2022-10-19
  • 如何使用css实现圆形波浪效果图
    这篇文章将为大家详细讲解有关如何使用css实现圆形波浪效果图 ,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在移动端经常看到一些圆形波浪图来显示金额,刚开始我认为这种效果只能用canvas写的,后来发现用...
    99+
    2023-06-08
  • html5怎么实现波浪效果图
    这篇文章主要介绍了html5怎么实现波浪效果图的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇html5怎么实现波浪效果图文章都会有所收获,下面我们一起来看看吧。   先画个最...
    99+
    2022-10-19
  • 聊聊怎么利用CSS实现波浪进度条效果
    (学习视频分享:web前端)以上就是聊聊怎么利用CSS实现波浪进度条效果的详细内容,更多请关注编程网其它相关文章!...
    99+
    2023-05-14
    前端 CSS JavaScript
  • 如何使用CSS制作波浪效果
    这篇文章主要介绍如何使用CSS制作波浪效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!从定积分实现曲边三角形面积说起在进入主题之前,先看看这个,在高等数学中,我们可以通过定积分求二次函数曲边图形面积。我们可以将曲线...
    99+
    2023-06-15
  • 如何利用CSS实现波浪进度条效果
    本篇内容介绍了“如何利用CSS实现波浪进度条效果”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!CSS Painting API再简单快速的过...
    99+
    2023-07-04
  • CSS实现文字下波浪线动画效果
    这篇文章主要介绍“CSS实现文字下波浪线动画效果”,在日常操作中,相信很多人在CSS实现文字下波浪线动画效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”CSS实现文字下波浪...
    99+
    2022-10-19
  • 如何使用CSS滤镜实现圆角及波浪效果
    本篇内容主要讲解“如何使用CSS滤镜实现圆角及波浪效果”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何使用CSS滤镜实现圆角及波浪效果”吧!首先,我们来看这样...
    99+
    2022-10-19
  • 使用css3怎么实现一个冲击波效果
    使用css3怎么实现一个冲击波效果?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。实现思路:观察波由小变大,涉及的css3属性变化有width,height,left,top,o...
    99+
    2023-06-08
  • 怎么用android实现贝塞尔曲线之波浪效果
    这篇文章主要介绍“怎么用android实现贝塞尔曲线之波浪效果”的相关知识,小编通过实际案例向大家展示操作过程,操作方法简单快捷,实用性强,希望这篇“怎么用android实现贝塞尔曲线之波浪效果”文章能帮助大家解决问题。1 前言贝塞尔曲线的...
    99+
    2023-07-02
  • 使用Canvas怎么绘制一个波浪花环
    使用Canvas怎么绘制一个波浪花环?针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。<!DOCTYPE html><html lang=...
    99+
    2023-06-09
  • 使用CSS怎么实现一个火焰效果
    这篇文章将为大家详细讲解有关使用CSS怎么实现一个火焰效果,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。1、先用边框画出三角形 要知道,如果 width是0,height也是0,只用边框的话...
    99+
    2023-06-08
  • 如何使用CSS滤镜构建圆角和波浪效果
    这篇文章主要介绍“如何使用CSS滤镜构建圆角和波浪效果”,在日常操作中,相信很多人在如何使用CSS滤镜构建圆角和波浪效果问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”如何使用CSS滤镜构建圆角和波浪效果”的疑...
    99+
    2023-07-04
  • 使用css怎么实现一个幻灯片效果
    本篇文章给大家分享的是有关使用css怎么实现一个幻灯片效果,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。实现方法:首先定义多张幻灯片元素;然后使用“@keyframes”规则和...
    99+
    2023-06-14
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作