当前位置: 首页 > news >正文

成都网站建设名录seo 优化公司

成都网站建设名录,seo 优化公司,建设银行春招网站,韩国美食做视频网站有哪些前言 这两天写项目刚好遇到Ai对话相关的需求,需要录音功能,绘制录制波形图,写了一个函数用canvas实现可视化,保留分享一下,有需要的直接粘贴即可,使用时传入一个1024长的,0-255大小的Uint8Arra…
前言

这两天写项目刚好遇到Ai对话相关的需求,需要录音功能,绘制录制波形图,写了一个函数用canvas实现可视化,保留分享一下,有需要的直接粘贴即可,使用时传入一个1024长的,0-255大小的Uint8Array类型音频数据源

<canvas ref="canvasRef" width="800" height="200"></canvas>
const drawWaveform = (audioArray) => {const canvas = canvasRef.value;if (!canvas || !audioArray) return;const ctx = canvas.getContext('2d');if (!ctx) return;const width = canvas.width;const height = canvas.height;const bufferLength = audioArray.length;// 清除画布ctx.clearRect(0, 0, width, height);// 设置线条样式ctx.strokeStyle = '#4f35b5';ctx.lineWidth = 2;ctx.beginPath();const sliceWidth = width / bufferLength;let x = 0;for (let i = 0; i < bufferLength; i++) {const value = audioArray[i] / 255.0;  // 将0-255的值归一化为0-1const y = value * height;if (i === 0) {ctx.moveTo(x, y);} else {ctx.lineTo(x, y);}x += sliceWidth;}ctx.stroke();
};

通过requestAnimationFrame调用即可

示例:

// 持续更新波形
const updateWaveform = () => {ensureRecorder(() => {audioArray.value = recorder!.getRecordAnalyseData();drawWaveform(audioArray.value);animationFrameId = requestAnimationFrame(updateWaveform);});
};
http://www.hkea.cn/news/61843/

相关文章:

  • 菏泽网站获客网站建设公司中国站长网入口
  • 黄冈网站建设推荐seo查询排名软件
  • 自己怎么做百度网站广州seo网站公司
  • 京东企业的电子网站建设百度seo教程网
  • 弥勒网站设计公司share群组链接分享
  • 网站建设栏目管理百度推广搜索排名
  • 企业管理类的网站全球搜是什么公司
  • 网站开发自我介绍seo报告
  • 网站应用软件设计海口seo网络公司
  • 武汉站建设深圳网站开发制作
  • 网站建设的平台分析北京seo技术
  • 手表价格网站百度推广天津总代理
  • 如何将域名和网站绑定排名seo怎么样
  • 旅游网站推广方案色盲测试图
  • 现在开发个网站多少钱安全优化大师
  • 网站开发工程师工资多少百度统计工具
  • 征信报告优化大师好用吗
  • 一个ip地址做多个网站网络营销公司是做什么的
  • 赤峰网站建设公司旅行网站排名
  • seo网站优化工具软件拉新推广平台
  • 政府网站设计方案无锡网站制作优化
  • 社交网站盈利吗如何在各种网站投放广告
  • 建设工程合同民法典东莞快速优化排名
  • 泗县口碑营销互联网营销推荐咨询青岛seo计费
  • 做电影网站用什么服务器中文域名注册官网入口
  • 做网站那里好win10系统优化工具
  • 做外贸上哪些网站找客户口碑营销的概念是什么
  • 外贸建站magento百度地图推广
  • 做网站和管理系统全网热度指数
  • 网站的压力测试怎么做网络营销的目的是什么