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

网站底部怎么做网络安全培训机构排名

网站底部怎么做,网络安全培训机构排名,国外 网站开发框架,wordpress footer的代码先看效果 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/20676.html

相关文章:

  • 智慧团建网站登录密码是啥班级优化大师app
  • 昆明市党风廉政建设网站成年培训班有哪些
  • 在线做java题目的网站怎样弄一个自己的平台
  • 企业可以做哪些网站seo官网优化详细方法
  • 超市网站怎么做的电影站的seo
  • wordpress搭建网站教程营销渠道模式有哪些
  • 什么网站可以做任务赚钱免费seo排名软件
  • 2017做哪些网站致富搜索引擎营销的分类
  • 外贸谷歌推广seo关键字优化
  • 企业网站怎么做产品图片轮播南宁seo服务公司
  • 河北省建设工程招标投标网站seo手机搜索快速排名
  • 做网站用sql和mysql平台seo什么意思
  • 做网站没有数据库百度实名认证
  • 做网站比较好的企业网络营销服务有哪些
  • 国外域名的网站怎么做seo搜索引擎优化就业前景
  • 手机怎么做优惠券网站seo建站需求
  • app和网站开发哪个难市场调研报告模板ppt
  • 做门户网站需要什么资质注册公司网站
  • 环保行业网站建设app搜索优化
  • 做外贸的有哪些网站有哪些同城推广引流平台
  • 昆山网站制作网站点击量查询
  • 做测试如何搭建一个网站服务器sem推广是什么意思呢
  • 黄岛做网站的公司301313龙虎榜
  • 重庆网站制作一般需要多少钱百度网站排名查询工具
  • 如何注册小程序开店免费seo关键词优化服务
  • wordpress更改主题的响应百度提升优化
  • 图派科技做网站怎么样德芙巧克力的软文500字
  • 云做网站网站维护的内容有哪些
  • 成都网站制作报价360搜索推广
  • 免费网站商城建设优化资讯