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

沈阳整站优化厦门seo推广

沈阳整站优化,厦门seo推广,广西建设网怎么查询证件,京东是b2c模式吗先看效果 1、打开页面 2、点击开始录音,弹出权限提示,点击“仅这次访问时允许” 3、录完后,点击停止 4、文件自动下载到默认目录 上代码 js 部分 document.addEventListener(DOMContentLoaded, () > {const startBtn document.getEleme…

先看效果

1、打开页面

2、点击开始录音,弹出权限提示,点击“仅这次访问时允许”

3、录完后,点击停止

4、文件自动下载到默认目录

上代码

 js 部分

document.addEventListener('DOMContentLoaded', () => {const startBtn = document.getElementById('startBtn');const stopBtn = document.getElementById('stopBtn');const audioPlayback = document.getElementById('audioPlayback');let mediaRecorder;let audioChunks = [];startBtn.addEventListener('click', async () => {try {// Request access to the microphoneconst stream = await navigator.mediaDevices.getUserMedia({ audio: { channelCount: 1, sampleRate: 16000 } });if (!stream) {throw new Error('No media stream received.');}// Create a MediaRecorder instance with specific settingsmediaRecorder = new MediaRecorder(stream, {mimeType: 'audio/webm'});mediaRecorder.ondataavailable = event => {audioChunks.push(event.data);};mediaRecorder.onstop = () => {const audioBlob = new Blob(audioChunks, { type: 'audio/webm' });convertWebmToWav(audioBlob);audioChunks = [];};mediaRecorder.start();startBtn.disabled = true;stopBtn.disabled = false;} catch (err) {console.error('Error accessing microphone:', err);alert('Error accessing microphone: ' + err.message);}});stopBtn.addEventListener('click', () => {if (mediaRecorder && mediaRecorder.state !== 'inactive') {mediaRecorder.stop();}startBtn.disabled = false;stopBtn.disabled = true;});function convertWebmToWav(webmBlob) {const reader = new FileReader();reader.onloadend = () => {const arrayBuffer = reader.result;const audioContext = new AudioContext();audioContext.decodeAudioData(arrayBuffer, audioBuffer => {const samples = audioBuffer.getChannelData(0);const buffer = createWav(samples, audioBuffer.sampleRate);const blob = new Blob([buffer], { type: 'audio/wav' });const audioUrl = URL.createObjectURL(blob);audioPlayback.src = audioUrl;// Save or download the blob as a WAV fileconst link = document.createElement('a');link.href = audioUrl;link.download = 'recorded_audio.wav';document.body.appendChild(link);link.click();document.body.removeChild(link);}, error => {console.error('Error decoding audio data:', error);});};reader.readAsArrayBuffer(webmBlob);}function createWav(samples, sampleRate) {const buffer = new ArrayBuffer(44 + samples.length * 2);const view = new DataView(buffer);// RIFF identifierwriteString(view, 0, 'RIFF');// file length minus RIFF identifier length and file description lengthview.setUint32(4, 36 + samples.length * 2, true);// RIFF typewriteString(view, 8, 'WAVE');// format chunk identifierwriteString(view, 12, 'fmt ');// format chunk lengthview.setUint32(16, 16, true);// sample format (raw)view.setUint16(20, 1, true);// channel countview.setUint16(22, 1, true);// sample rateview.setUint32(24, sampleRate, true);// byte rate (sample rate * block align)view.setUint32(28, sampleRate * 2, true);// block align (channel count * bytes per sample)view.setUint16(32, 2, true);// bits per sampleview.setUint16(34, 16, true);// data chunk identifierwriteString(view, 36, 'data');// data chunk lengthview.setUint32(40, samples.length * 2, true);floatTo16BitPCM(view, 44, samples);return buffer;}function floatTo16BitPCM(output, offset, input) {for (let i = 0; i < input.length; i++, offset += 2) {const s = Math.max(-1, Math.min(1, input[i]));output.setInt16(offset, s < 0 ? s * 0x8000 : s * 0x7FFF, true);}}function writeString(view, offset, string) {for (let i = 0; i < string.length; i++) {view.setUint8(offset + i, string.charCodeAt(i));}}
});

html部分

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Audio Recorder</title>
</head>
<body><h1>Audio Recorder</h1><button id="startBtn">Start Recording</button><button id="stopBtn" disabled>Stop Recording</button><br><br><audio id="audioPlayback" controls></audio><script src="recorder.js"></script>
</body>
</html>

http://www.dtcms.com/wzjs/54469.html

相关文章:

  • 上海公司注册流程及费用标准整站排名优化品牌
  • 佛山网站建设模板建站app开发需要哪些技术
  • 代做备案网站北京seo做排名
  • 建站平台网品牌网络推广
  • wordpress制作侧面悬浮图标秦洁婷seo博客
  • 网站整站程序我想学做互联网怎么入手
  • 百度糯米网站怎么做奶盘seo伪原创工具
  • 永久免费crm软件哪个好海阳seo排名
  • 做的好点的外贸网站有哪些整合营销传播策略
  • 模板建站小程序怎样弄一个自己的平台
  • 武汉seo公司排名seopeix
  • 昌吉哪个公司做网站全网营销系统怎么样
  • 深圳网站建设价钱湖南 seo
  • 湖北营销型网站建设怎么做品牌推广和宣传
  • 西安长安网站建设制作凡科建站下载
  • 郑州专业建网站百度sem竞价托管公司
  • 保定公司做网站2345浏览器影视大全
  • 可以做公众号背景图的网站网络营销薪酬公司
  • 辽宁省工程建设信息网官网宁波seo网站推广软件
  • 佛山设计网站设计价格最新新闻事件今天国内大事
  • 软件开发标准seo优化的网站
  • 网站整体策划与设计40个免费靠谱网站
  • ecshop 做企业网站搜索引擎调词工具
  • 新公司做网站有效果吗媒体公关公司
  • 专业的电商网站建设公司搜索引擎优化实训报告
  • 湖北做网站系统哪家好江苏免费关键词排名外包
  • wordpress增加导航深圳seo推广培训
  • 下列属于b2b网站的有知乎推广合作
  • 做淘宝客网站再靠地推青岛谷歌优化公司
  • 广州网站建设哪家比较好营销型网站建设费用