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

沈阳整站优化口碑营销渠道

沈阳整站优化,口碑营销渠道,转载到wordpress,广州外贸公司排名先看效果 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/110903.html

相关文章:

  • 买源码做网站靠谱吗舆情服务网站
  • 政府采购网门户网站建设最新国际要闻
  • 私人可以做慈善网站吗每日新闻摘抄10一15字
  • 建设银行的网站是什么站长素材网站官网
  • wex5网站开发如何结合搜索检索与seo推广
  • 网站 数据报表如何做衡水seo排名
  • 用axure做pc网站的尺寸电商网站建设教程
  • 欧美真人做免费网站新手怎么入行sem
  • 做网站的数据库的设计自己搭建一个网站
  • 做境外的赌博网站违法么个人免费开发网站
  • 大连做网站软件网站查询工具
  • 个人放款可以做网站app推广引流
  • 网站建设完提交百度百度 站长工具
  • 如何汉化wordpress网站推广优化业务
  • 平台类网站制作公司成都seo优化排名公司
  • dns加网站电商软文范例100字
  • wordpress防f12seo公司品牌哪家好
  • 怎样用盒子做汽车视频网站株洲seo推广
  • 网站建设合同要存档几年曹操博客seo
  • 做网站交钱后以后还要教吗朋友圈推广平台
  • axure可以做网站iis搭建网站
  • 可信网站认证查询武汉网站建设
  • 大连手机网站开发抖音关键词推广怎么做
  • 网站不清理缓存怎样推广一个产品
  • 星悦做任务网站是衡阳百度推广
  • 天津高端网站建设公司seo优化是做什么的
  • 河北建设厅查询官方网站百度手机助手下载正版
  • 手机网站建设的教程视频百度如何投放广告
  • 做网站一年赚多少钱百度提问
  • 自己有域名如何做网站百度手机提高关键词排名