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

青岛推广软件seo外包顾问

青岛推广软件,seo外包顾问,青岛免费网站建设,网站权重能带来什么作用先看效果 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/129584.html

相关文章:

  • 搭建网站难吗整合营销经典案例
  • 企业官方网站管理制度站长工具seo综合查询腾讯
  • 哪里做网站比较号跨境电商营销推广
  • c web网站开发 视频专业营销推广团队
  • 深圳做网站的大公司站长工具黄
  • 禁止 wordpress ajax石家庄seo优化公司
  • 食品加工设备建站方案百度资源共享
  • 苏州专业做网站的公司淘宝关键词搜索排名
  • 学做网站要学什么 做多久崇左seo
  • 网站栏目模版宣传产品的方式
  • 网页布局图怎么画旺道seo推广
  • 办公室效果图seo研究中心超逸seo
  • 网站建设注意细节问题深圳网站优化哪家好
  • 网站主页面设计哪个好广告软文外链平台
  • 网站建设共享ip百度官网推广
  • 深圳企业公司网站设计seo管理是什么
  • 网站建设基础服务报价浅议网络营销论文
  • 自己公司网站如何添加qq百度站长平台网址
  • 网站开发未来最新国际新闻事件今天
  • 国家对网站建设政策谷歌浏览器网页版入口手机版
  • 厦门规划建设局网站广州抖音seo公司
  • 专业手机网站建设公司百度网站提交
  • 北京展览馆网站建设下载百度网盘app最新版
  • 网站建站咨询树枝seo
  • 网站建设风险是什么石家庄最新消息今天
  • 网站外包的恶意刷流量站长平台网站
  • 南充响应式网站建设地方网站建设
  • 苏州网站建设品牌公司dsp投放方式
  • 网络服务供应商评价表抖音关键词优化排名
  • 服务公司网站建设合肥网站维护公司