在适用于所有浏览器和iOS的网站上录制音频

时间:2018-02-08 15:16:41

标签: javascript ios html5 html5-audio audio-recording

我浪费了大量时间在我正在构建的网站中实现多个音频录制选项,但每个网站只能在Chrome中使用,只能在Firefox中使用,两者都可以使用Safari,而且不能在iOS上运行。

网站需要允许用户记录他们的消息并将其保存在表单状态以供提交。

我正在阅读的所有当前文章都有几个月的历史,并提到iOS不会/很快就会支持它。我在iOS上尝试过移动Chrome,但它仍无效。

有没有人找到一种简单的方法来在浏览器和移动网站上录制音频?

我尝试过的事情:

目前使用以下适用于Chrome和Firefox的代码。

HTML

<audio controls src="" id="audio"></audio> <a class="button" id="record">Record</a> <input type="hidden" id="audiofile" name="audiofile" value="" aria-hidden="true"/>

使用Francium语音库:

的Javascript

    // Audio Recording for Phone Calls
  $(document).on("click", "#record:not(.stop)", function(){
  elem = $(this);
    $("#audio").attr("src","");
    $("#audiofile").val("");
  Fr.voice.record($("#live").is(":checked"), function(){
  elem.addClass("stop");
});
    elem.html("Stop <label id='minutes'>00</label>:<label   id='seconds'>00</label>");
    var minutesLabel = document.getElementById("minutes");
    var secondsLabel = document.getElementById("seconds");
    var totalSeconds = 0;
    setInterval(setTime, 1000);

    function setTime() {
        ++totalSeconds;
        secondsLabel.innerHTML = pad(totalSeconds % 60);
        minutesLabel.innerHTML = pad(parseInt(totalSeconds / 60));
    }

    function pad(val) {
        var valString = val + "";
        if (valString.length < 2) {
            return "0" + valString;
        } else {
            return valString;
        }
    }
});

$(document).on("click", ".stop", function(){
    elem = $(this);
    elem.html("Record");
    elem.removeClass("stop");
Fr.voice.export(function(base64){
  $("#audio").attr("src", base64);
        $("#audiofile").val(base64);
        $("#audio")[0].play();
}, "base64");
    Fr.voice.stop();
});  

1 个答案:

答案 0 :(得分:2)

我发现了一种最终适用于Chrome,Firefox和iOS Safari的技术。但是在Safari中存在getUserMedia的问题,但我现在正在研究它。

https://github.com/GersonRosales/Record-Audios-and-Videos-with-getUserMedia