css+js实现水波纹效果

22 篇文章 0 订阅
6 篇文章 0 订阅

 效果如下

新建HTML文件,把下面的代码直接贴进来,浏览器打开看效果。 在线运行

<!DOCTYPE html>
<html lang="en">
<head>
  <meta charset="UTF-8" />
  <meta name="viewport" content="width=device-width, initial-scale=1.0" />
  <meta http-equiv="X-UA-Compatible" content="ie=edge" />
  <title>点击水波纹</title>
  <style>
    .content {
      display: flex;
      justify-content: center;
      align-items: center;
      color: #fff;
      width: 200px;
      height: 50px;
      background: #409eff;
      cursor: pointer;
    }

    /* 水波纹样式-开始 */
    .ripple {
      position: relative;
      overflow: hidden;
    }

    .ripple-div {
      position: absolute;
      z-index: 10;
      background: hsla(0, 0%, 100%, 0.3);
      border-radius: 50%;
      opacity: 1;
      top: 0;
      left: 0;
      -ms-transform: scale(0);
      -moz-transform: scale(0);
      -o-transform: scale(0);
      -webkit-transform: scale(0);
      transform: scale(0);
      pointer-events: none;
    }

    .ripple-div.rippling {
      /* -ms-animation: rippleAnima 0.6s linear;
      -moz-animation: rippleAnima 0.6s linear;
      -o-animation: rippleAnima 0.6s linear;
      -webkit-animation: rippleAnima 0.6s linear;
      animation: rippleAnima 0.6s linear; */
    }

    @-ms-keyframes rippleAnima {
      to {
        opacity: 0;
        -ms-transform: scale(3);
        -moz-transform: scale(3);
        -o-transform: scale(3);
        -webkit-transform: scale(3);
        transform: scale(3);
      }
    }

    @-moz-keyframes rippleAnima {
      to {
        opacity: 0;
        -ms-transform: scale(3);
        -moz-transform: scale(3);
        -o-transform: scale(3);
        -webkit-transform: scale(3);
        transform: scale(3);
      }
    }

    @-o-keyframes rippleAnima {
      to {
        opacity: 0;
        -ms-transform: scale(3);
        -moz-transform: scale(3);
        -o-transform: scale(3);
        -webkit-transform: scale(3);
        transform: scale(3);
      }
    }

    @-webkit-keyframes rippleAnima {
      to {
        opacity: 0;
        -ms-transform: scale(3);
        -moz-transform: scale(3);
        -o-transform: scale(3);
        -webkit-transform: scale(3);
        transform: scale(3);
      }
    }

    @keyframes rippleAnima {
      to {
        opacity: 0;
        -ms-transform: scale(3);
        -moz-transform: scale(3);
        -o-transform: scale(3);
        -webkit-transform: scale(3);
        transform: scale(3);
      }
    }

    /* 水波纹样式-结束 */
  </style>
</head>

<body>
  <div class="content ripple">点击水波纹一</div>
  <div class="content ripple" style="background: #67c23a">点击水波纹二</div>
</body>
<script>
  // 对要添加水波纹效果的元素添加ripple类
  let eles = document.getElementsByClassName("ripple");
  for (let index = 0; index < eles.length; index++) {
    const element = eles[index];
    // 添加点击事件
    element.addEventListener("click", (e) => {
      let createDiv = document.createElement("div");
      createDiv.className = "ripple-div rippling";
      let maxHW = Math.max(e.target.offsetWidth, e.target.offsetHeight);
      createDiv.style.width = `${maxHW}px`;
      createDiv.style.height = `${maxHW}px`;
      // 动态设置动画时间,容器越大,动画时间越长
      createDiv.style.animation = `rippleAnima ${maxHW / 200}s linear`;
      // 重新计算水波纹的中心位置
      createDiv.style.top = `${e.offsetY - maxHW / 2}px`;
      createDiv.style.left = `${e.offsetX - maxHW / 2}px`;
      // 追加到元素中
      element.appendChild(createDiv);
      setTimeout(() => {
        // 删除元素
        element.removeChild(createDiv);
      }, 600);
    });
  }
</script>
</html>

  • 9
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 5
    评论
实现录音水波纹动态效果的思路如下: 1. 使用HTML5的`<canvas>`标签创建画布,用于绘制水波纹效果。 2. 使用CSS3的`animation`属性,定义动画效果。 3. 使用JavaScript控制录音功能,并将录音数据传递给canvas绘制出水波纹效果。 下面是实现的详细步骤: 1. HTML代码 ``` <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>录音水波纹动态效果</title> <style> #canvas { width: 300px; height: 300px; margin: 50px auto; display: block; background-color: #ccc; border-radius: 50%; overflow: hidden; } #canvas:after { content: ""; display: block; position: absolute; width: 100%; height: 100%; top: 0px; left: 0px; background-color: #fff; opacity: 0.5; z-index: 1; } #canvas:before { content: ""; display: block; position: absolute; width: 100%; height: 100%; top: 0px; left: 0px; background-image: radial-gradient(ellipse at center, #fff, #222); background-size: 100% 100%; z-index: 2; } </style> </head> <body> <canvas id="canvas"></canvas> <script src="https://cdn.bootcdn.net/ajax/libs/jquery/3.6.0/jquery.min.js"></script> </body> </html> ``` 2. CSS代码 在CSS样式中,我们为`<canvas>`标签设置了宽度、高度和边框半径等属性,用于显示圆形的水波纹效果。同时,我们使用了`overflow: hidden`属性,以隐藏画布中超出边界的部分。 ``` #canvas { width: 300px; height: 300px; margin: 50px auto; display: block; background-color: #ccc; border-radius: 50%; overflow: hidden; } ``` 接着,我们使用`:before`和`:after`伪元素,分别绘制一个半透明的白色背景和一个黑色的圆形渐变背景。这些背景将作为水波纹的底部和顶部。 ``` #canvas:after { content: ""; display: block; position: absolute; width: 100%; height: 100%; top: 0px; left: 0px; background-color: #fff; opacity: 0.5; z-index: 1; } #canvas:before { content: ""; display: block; position: absolute; width: 100%; height: 100%; top: 0px; left: 0px; background-image: radial-gradient(ellipse at center, #fff, #222); background-size: 100% 100%; z-index: 2; } ``` 3. JavaScript代码 在JavaScript中,我们使用`<canvas>`标签的`getContext()`方法创建一个2D画布上下文,并定义一个`draw()`函数用于绘制水波纹效果。 ``` var canvas = document.getElementById("canvas"); var ctx = canvas.getContext("2d"); var audioContext = new AudioContext(); var analyser = audioContext.createAnalyser(); navigator.mediaDevices.getUserMedia({ audio: true }).then(function(stream) { var source = audioContext.createMediaStreamSource(stream); source.connect(analyser); analyser.connect(audioContext.destination); }); function draw() { var canvasWidth = canvas.width; var canvasHeight = canvas.height; var centerX = canvasWidth / 2; var centerY = canvasHeight / 2; var radius = canvasWidth / 3; var bars = 200; var barWidth = 2; var angle = Math.PI * 2 / bars; var dataArray = new Uint8Array(analyser.frequencyBinCount); analyser.getByteFrequencyData(dataArray); ctx.clearRect(0, 0, canvasWidth, canvasHeight); ctx.beginPath(); for (var i = 0; i < bars; i++) { var barHeight = dataArray[i] / 2; var x = centerX + Math.cos(angle * i) * (radius + barHeight); var y = centerY + Math.sin(angle * i) * (radius + barHeight); ctx.fillStyle = "rgba(0, 0, 0, 0.3)"; ctx.fillRect(x - barWidth / 2, y - barWidth / 2, barWidth, barHeight); ctx.save(); ctx.globalCompositeOperation = "lighter"; ctx.fillStyle = "rgba(255, 255, 255, 0.5)"; ctx.beginPath(); ctx.arc(x, y, 10, 0, Math.PI * 2, true); ctx.closePath(); ctx.fill(); ctx.restore(); } requestAnimationFrame(draw); } draw(); ``` 在`draw()`函数中,我们首先获取画布的宽度和高度,以及画布中心点的坐标和半径等信息。接着,我们使用`AudioContext`和`createAnalyser()`方法创建音频分析器,并在`getUserMedia()`方法中打开录音设备,并将录音数据传递给分析器。 在绘制水波纹时,我们使用`getByteFrequencyData()`方法获取分析器中的频率数据,并遍历数据数组,依次绘制出每个音频条的位置和高度。同时,我们使用`globalCompositeOperation`属性设置混合模式,实现水波纹效果。 最后,我们通过`requestAnimationFrame()`方法实现动态效果,并在函数结束时再次调用`draw()`函数,以保持动态效果的持续性。 以上就是实现录音水波纹动态效果的完整代码。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小小•愿望

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值