欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品

主頁 > 知識庫 > HTML5聲音錄制/播放功能的實(shí)現(xiàn)代碼

HTML5聲音錄制/播放功能的實(shí)現(xiàn)代碼

熱門標(biāo)簽:鎮(zhèn)江智能外呼系統(tǒng)有效果嗎 四川點(diǎn)撥外呼系統(tǒng) 南寧點(diǎn)撥外呼系統(tǒng)哪家公司做的好 電銷機(jī)器人電話用什么卡 云南大理400電話申請官方 江蘇智能電銷機(jī)器人哪家好 黃島區(qū)地圖標(biāo)注 成都智能外呼系統(tǒng)平臺 當(dāng)涂高德地圖標(biāo)注

html代碼:

<!DOCTYPE html>
<html>
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
        <title>火星黑洞</title>
    </head>
    <body>
        <div>
            <audio autoplay></audio>
            <input onclick="startRecording()" type="button" value="錄音" />
            <input onclick="stopRecording()" type="button" value="停止" />
            <input onclick="playRecording()" type="button" value="播放" />
            <input onclick="uploadAudio()" type="button" value="提交" />
            <br />
            <div id="recordingslist"></div>
        </div>
        <script type="text/javascript" src="js/HZRecorder.js"></script>
        <script>
            var recorder;
            var audio = document.querySelector('audio');
            function startRecording() {
                HZRecorder.get(function(rec) {
                    recorder = rec;
                    recorder.start();
                }, {
                    sampleBits: 16,
                    sampleRate: 16000
                });
            }
            function stopRecording() {
                recorder.stop();
                var blob = recorder.getBlob();
                var url = URL.createObjectURL(blob);
                var div = document.createElement('div');
                var au = document.createElement('audio');
                var hf = document.createElement('a');
                au.controls = true;
                au.src = url;
                hf.href = url;
                hf.download = new Date().toISOString() + '.wav';
                hf.innerHTML = hf.download;
                div.appendChild(au);
                div.appendChild(hf);
                recordingslist.appendChild(div);
            }
            function playRecording() {
                recorder.play(audio);
            }
            function uploadAudio() {
                recorder.upload("Handler1.ashx", function(state, e) {
                    switch(state) {
                        case 'uploading':
                            //var percentComplete = Math.round(e.loaded * 100 / e.total) + '%';
                            break;
                        case 'ok':
                            //alert(e.target.responseText);
                            alert("上傳成功");
                            break;
                        case 'error':
                            alert("上傳失敗");
                            break;
                        case 'cancel':
                            alert("上傳被取消");
                            break;
                    }
                });
            }
        </script>
    </body>
</html>

HZRecorder.js

(function (window) {
    //兼容
    window.URL = window.URL || window.webkitURL;
    navigator.getUserMedia = navigator.getUserMedia || navigator.webkitGetUserMedia || navigator.mozGetUserMedia || navigator.msGetUserMedia;
    var HZRecorder = function (stream, config) {
        config = config || {};
        config.sampleBits = config.sampleBits || 8      //采樣數(shù)位 8, 16
        config.sampleRate = config.sampleRate || (44100 / 6);   //采樣率(1/6 44100)
        var context = new (window.webkitAudioContext || window.AudioContext)();
        var audioInput = context.createMediaStreamSource(stream);
        var createScript = context.createScriptProcessor || context.createJavaScriptNode;
        var recorder = createScript.apply(context, [4096, 1, 1]);
        var mp3ReceiveSuccess, currentErrorCallback;
        var audioData = {
            size: 0          //錄音文件長度
            , buffer: []     //錄音緩存
            , inputSampleRate: context.sampleRate    //輸入采樣率
            , inputSampleBits: 16       //輸入采樣數(shù)位 8, 16
            , outputSampleRate: config.sampleRate    //輸出采樣率
            , oututSampleBits: config.sampleBits       //輸出采樣數(shù)位 8, 16
            , input: function (data) {
                this.buffer.push(new Float32Array(data));
                this.size += data.length;
            }
            , compress: function () { //合并壓縮
                //合并
                var data = new Float32Array(this.size);
                var offset = 0;
                for (var i = 0; i < this.buffer.length; i++) {
                    data.set(this.buffer[i], offset);
                    offset += this.buffer[i].length;
                }
                //壓縮
                var compression = parseInt(this.inputSampleRate / this.outputSampleRate);
                var length = data.length / compression;
                var result = new Float32Array(length);
                var index = 0, j = 0;
                while (index < length) {
                    result[index] = data[j];
                    j += compression;
                    index++;
                }
                return result;
            }
            , encodeWAV: function () {
                var sampleRate = Math.min(this.inputSampleRate, this.outputSampleRate);
                var sampleBits = Math.min(this.inputSampleBits, this.oututSampleBits);
                var bytes = this.compress();
                var dataLength = bytes.length * (sampleBits / 8);
                var buffer = new ArrayBuffer(44 + dataLength);
                var data = new DataView(buffer);
                var channelCount = 1;//單聲道
                var offset = 0;
                var writeString = function (str) {
                    for (var i = 0; i < str.length; i++) {
                        data.setUint8(offset + i, str.charCodeAt(i));
                    }
                }
                // 資源交換文件標(biāo)識符 
                writeString('RIFF'); offset += 4;
                // 下個(gè)地址開始到文件尾總字節(jié)數(shù),即文件大小-8 
                data.setUint32(offset, 36 + dataLength, true); offset += 4;
                // WAV文件標(biāo)志
                writeString('WAVE'); offset += 4;
                // 波形格式標(biāo)志 
                writeString('fmt '); offset += 4;
                // 過濾字節(jié),一般為 0x10 = 16 
                data.setUint32(offset, 16, true); offset += 4;
                // 格式類別 (PCM形式采樣數(shù)據(jù)) 
                data.setUint16(offset, 1, true); offset += 2;
                // 通道數(shù) 
                data.setUint16(offset, channelCount, true); offset += 2;
                // 采樣率,每秒樣本數(shù),表示每個(gè)通道的播放速度 
                data.setUint32(offset, sampleRate, true); offset += 4;
                // 波形數(shù)據(jù)傳輸率 (每秒平均字節(jié)數(shù)) 單聲道×每秒數(shù)據(jù)位數(shù)×每樣本數(shù)據(jù)位/8 
                data.setUint32(offset, channelCount * sampleRate * (sampleBits / 8), true); offset += 4;
                // 快數(shù)據(jù)調(diào)整數(shù) 采樣一次占用字節(jié)數(shù) 單聲道×每樣本的數(shù)據(jù)位數(shù)/8 
                data.setUint16(offset, channelCount * (sampleBits / 8), true); offset += 2;
                // 每樣本數(shù)據(jù)位數(shù) 
                data.setUint16(offset, sampleBits, true); offset += 2;
                // 數(shù)據(jù)標(biāo)識符 
                writeString('data'); offset += 4;
                // 采樣數(shù)據(jù)總數(shù),即數(shù)據(jù)總大小-44 
                data.setUint32(offset, dataLength, true); offset += 4;
                // 寫入采樣數(shù)據(jù) 
                if (sampleBits === 8) {
                    for (var i = 0; i < bytes.length; i++, offset++) {
                        var s = Math.max(-1, Math.min(1, bytes[i]));
                        var val = s < 0 ? s * 0x8000 : s * 0x7FFF;
                        val = parseInt(255 / (65535 / (val + 32768)));
                        data.setInt8(offset, val, true);
                    }
                } else {
                    for (var i = 0; i < bytes.length; i++, offset += 2) {
                        var s = Math.max(-1, Math.min(1, bytes[i]));
                        data.setInt16(offset, s < 0 ? s * 0x8000 : s * 0x7FFF, true);
                    }
                }
                return new Blob([data], { type: 'audio/wav' });
            }
        };
        //開始錄音
        this.start = function () {
            audioInput.connect(recorder);
            recorder.connect(context.destination);
        }
        //停止
        this.stop = function () {
            recorder.disconnect();
        }
        //獲取音頻文件
        this.getBlob = function () {
            this.stop();
            return audioData.encodeWAV();
        }
        //回放
        this.play = function (audio) {
            audio.src = window.URL.createObjectURL(this.getBlob());
        }
        //上傳
        this.upload = function (url, callback) {
            var fd = new FormData();
            fd.append("audioData", this.getBlob());
            var xhr = new XMLHttpRequest();
            if (callback) {
                xhr.upload.addEventListener("progress", function (e) {
                    callback('uploading', e);
                }, false);
                xhr.addEventListener("load", function (e) {
                    callback('ok', e);
                }, false);
                xhr.addEventListener("error", function (e) {
                    callback('error', e);
                }, false);
                xhr.addEventListener("abort", function (e) {
                    callback('cancel', e);
                }, false);
            }
            xhr.open("POST", url);
            xhr.send(fd);
        }
        //音頻采集
        recorder.onaudioprocess = function (e) {
            audioData.input(e.inputBuffer.getChannelData(0));
            //record(e.inputBuffer.getChannelData(0));
        }
    };
    //拋出異常
    HZRecorder.throwError = function (message) {
        alert(message);
        throw new function () { this.toString = function () { return message; } }
    }
    //是否支持錄音
    HZRecorder.canRecording = (navigator.getUserMedia != null);
    //獲取錄音機(jī)
    HZRecorder.get = function (callback, config) {
        if (callback) {
            if (navigator.getUserMedia) {
                navigator.getUserMedia(
                    { audio: true } //只啟用音頻
                    , function (stream) {
                        var rec = new HZRecorder(stream, config);
                        callback(rec);
                    }
                    , function (error) {
                        switch (error.code || error.name) {
                            case 'PERMISSION_DENIED':
                            case 'PermissionDeniedError':
                                HZRecorder.throwError('用戶拒絕提供信息。');
                                break;
                            case 'NOT_SUPPORTED_ERROR':
                            case 'NotSupportedError':
                                HZRecorder.throwError('瀏覽器不支持硬件設(shè)備。');
                                break;
                            case 'MANDATORY_UNSATISFIED_ERROR':
                            case 'MandatoryUnsatisfiedError':
                                HZRecorder.throwError('無法發(fā)現(xiàn)指定的硬件設(shè)備。');
                                break;
                            default:
                                HZRecorder.throwError('無法打開麥克風(fēng)。異常信息:' + (error.code || error.name));
                                break;
                        }
                    });
            } else {
                HZRecorder.throwErr('當(dāng)前瀏覽器不支持錄音功能。'); return;
            }
        }
    }
    window.HZRecorder = HZRecorder;
})(window);

總結(jié)

以上所述是小編給大家介紹的HTML5聲音錄制/播放功能的實(shí)現(xiàn)代碼,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時(shí)回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

標(biāo)簽:酒泉 佳木斯 廣西 十堰 咸寧 南京 西寧 淮安

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《HTML5聲音錄制/播放功能的實(shí)現(xiàn)代碼》,本文關(guān)鍵詞  HTML5,聲音,錄制,播放,功能,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《HTML5聲音錄制/播放功能的實(shí)現(xiàn)代碼》相關(guān)的同類信息!
  • 本頁收集關(guān)于HTML5聲音錄制/播放功能的實(shí)現(xiàn)代碼的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章
    欧美阿v视频在线大全_亚洲欧美中文日韩V在线观看_www性欧美日韩欧美91_亚洲欧美日韩久久精品
  • <rt id="w000q"><acronym id="w000q"></acronym></rt>
  • <abbr id="w000q"></abbr>
    <rt id="w000q"></rt>
    亚洲综合色丁香婷婷六月图片| 天天操天天色综合| 激情综合网激情| 大尺度做爰床戏呻吟舒畅| 91国产视频在线观看| 国产精品污网站| 国产一区二区三区四区五区入口| 亚洲a v网站| 精品精品欲导航| 蜜桃精品视频在线| www.色天使| 日韩精品中午字幕| 久久精品国产免费| 免费福利视频网站| 国产午夜三级一区二区三| 国产在线精品一区在线观看麻豆| 中文字幕被公侵犯的漂亮人妻| 精品国偷自产国产一区| 国产一区三区三区| 成年人免费视频播放| 中文一区一区三区高中清不卡| 国产69精品久久99不卡| 老湿机69福利| 亚洲另类色综合网站| 亚洲成人福利视频| 欧美高清视频不卡网| 日本伊人色综合网| 国产免费无遮挡吸奶头视频| 国产日韩欧美高清在线| 高清视频一区二区| 91国模大尺度私拍在线视频| 亚洲成人黄色小说| 久久精品国产亚洲av麻豆| 久久综合色播五月| 国产成人欧美日韩在线电影| 一本久道久久综合中文字幕| 亚洲综合色自拍一区| jizz日本免费| 国产偷国产偷亚洲高清人白洁| 成人免费看黄yyy456| 91久久精品国产91性色tv| 亚洲成人免费看| 手机看片福利视频| 中文字幕在线观看一区二区| 亚洲美女高潮久久久| 精品久久久久久久久久久久久久久久久| 国产一区二区在线观看视频| 一本大道久久精品懂色aⅴ| 亚洲国产精品久久久久秋霞影院 | 亚洲已满18点击进入久久| 97人妻精品一区二区三区免费 | 无码人妻丰满熟妇区毛片蜜桃精品| 欧美性色黄大片| 美日韩黄色大片| 成年人二级毛片| 亚洲一区二区三区视频在线| 中文字幕人妻一区二区| 中文字幕制服丝袜一区二区三区| 偷偷色噜狠狠狠狠的777米奇| 久久精子c满五个校花| 国产人妻精品久久久久野外| 欧美电影免费观看高清完整版在线 | 国产在线视频一区二区三区| 色婷婷av一区二区| 日本中文字幕不卡| 国产suv一区二区三区| 首页国产丝袜综合| 疯狂试爱三2浴室激情视频| 午夜精品视频一区| 国产传媒免费在线观看| 图片区日韩欧美亚洲| 国产美女福利视频| 日韩精品每日更新| 色综合久久久久久久久| 麻豆一区二区在线| 欧美在线免费观看亚洲| 国内精品伊人久久久久影院对白| 欧美三级三级三级爽爽爽| 国内精品免费**视频| 欧美老女人第四色| 高清国产一区二区| 精品久久久久香蕉网| 18深夜在线观看免费视频| 久久久久久99精品| 国产性生活毛片| 亚洲视频中文字幕| 亚洲成人黄色av| 亚洲亚洲人成综合网络| 二区三区四区视频| 蜜桃久久久久久久| 欧美精品v日韩精品v韩国精品v| 高清不卡在线观看| 精品日韩99亚洲| 欧美久久久久久久久久久| 国产精品久久久久aaaa| 国产特级黄色录像| 亚洲一区二区三区不卡国产欧美| 91麻豆精品成人一区二区| 蜜桃视频一区二区| 这里只有精品免费| 91美女在线看| 中文字幕一区二区三区四区| 国产18无套直看片| 蜜桃精品视频在线| 欧美一二三区在线| 色婷婷狠狠18禁久久| 亚洲三级在线观看| 情侣偷拍对白清晰饥渴难耐| 九色综合国产一区二区三区| 日韩一区二区三区精品视频| 黄色激情在线观看| 亚洲中国最大av网站| 色就色 综合激情| 成人性生交大合| 欧美国产乱子伦| 四虎影视一区二区| 国产综合久久久久影院| 日韩精品一区二区三区视频在线观看| 中文字幕人妻一区二区三区 | 三上悠亚作品在线观看| 激情综合亚洲精品| 欧美精品一区二区三区在线| 免费在线观看你懂的| 免费在线成人网| 日韩欧美亚洲一区二区| 久久久久麻豆v国产精华液好用吗 在线观看国产免费视频 | 久久影院电视剧免费观看| 成年人网站免费看| 免费看日韩a级影片| 日韩精品一区二区三区蜜臀| 亚洲熟妇无码av| 蜜桃av一区二区在线观看 | 欧美精品视频www在线观看| 性生交大片免费看l| 亚洲图片一区二区| 欧美精品久久久久久久多人混战| 韩国三级hd中文字幕有哪些| 亚洲线精品一区二区三区八戒| 精品视频一区二区不卡| 免费不卡的av| 免费观看久久久4p| 2024国产精品视频| 99成人在线观看| 成人午夜av电影| 亚洲人成在线观看一区二区| 欧美亚洲动漫制服丝袜| 日本精品一二三区| 青青草97国产精品免费观看无弹窗版 | japan高清日本乱xxxxx| 亚洲成人资源网| 日韩精品中文字幕在线不卡尤物| 69视频在线观看免费| 国产成人在线网站| 亚洲精品亚洲人成人网| 欧美高清dvd| 蜜臀久久99精品久久久久久| 国产成人av电影在线| 亚洲人成亚洲人成在线观看图片| 欧美日本精品一区二区三区| 三级黄色片网站| 国产精品中文有码| 日韩码欧中文字| 3d成人h动漫网站入口| 成人片黄网站色大片免费毛片| 亚洲福利视频一区| 日韩欧美123| 情侣偷拍对白清晰饥渴难耐| 秋霞午夜鲁丝一区二区| 日韩中文字幕区一区有砖一区| 久久久三级国产网站| 色综合天天天天做夜夜夜夜做| 久久久久亚洲av成人网人人软件| 青草av.久久免费一区| 日本一区二区视频在线| 欧美亚洲国产一区二区三区va| 亚洲av无码国产精品久久| 国产91露脸合集magnet| 午夜欧美电影在线观看| 久久久午夜电影| 欧美日韩在线一区二区| av电影网站在线观看| 91美女蜜桃在线| 精品一区二区三区久久| 亚洲免费在线看| 精品国产91乱码一区二区三区 | 久久国产乱子精品免费女| 国产精品国产精品国产专区不蜜| 欧美麻豆精品久久久久久| 精品手机在线视频| 性一交一黄一片| 国内精品在线播放| 亚洲va国产va欧美va观看| 欧美国产一区视频在线观看| 777亚洲妇女| 小泽玛利亚一区二区免费| 亚洲综合自拍网| av一区二区三区在线| 久久国产生活片100| 一区二区高清免费观看影视大全 | 精品人在线二区三区|