我試圖從Chrome 29 Beta版中的HTML5中使用HTML5進行錄音(它已啓用其beta 29中的web音頻支持)。在下面的代碼中,ProcessAudio是Web音頻過濾器功能,我從其中接收來自麥克風的輸入緩衝區。我得到正確的樣本量。但是,移動Chrome中的音頻pcm樣本始終爲零。 Chrome是否禁用其移動版本音頻濾鏡的輸入?有沒有人在Chrome移動版本中使用HTML5進行錄音工作? 以下代碼在Chrome(桌面版)中正常工作。使用html5捕獲移動鍍鉻上的麥克風輸入
<!DOCTYPE HTML>
<html>
<head>
<script>
function GetMedia(obj, fnSuccess, fnFailure)
{
if(navigator.getUserMedia)
{
return navigator.getUserMedia(obj, fnSuccess, fnFailure);
}
else if(navigator.webkitGetUserMedia)
{
return navigator.webkitGetUserMedia(obj, fnSuccess, fnFailure);
}
else if(navigator.mozGetUserMedia)
{
return navigator.mozGetUserMedia(obj, fnSuccess, fnFailure);
}
else if(navigator.msGetUserMedia)
{
return navigator.msGetUserMedia(obj, fnSuccess, fnFailure);
}
alert("no audio capture");
}
var incrementer = 0;
function ProcessAudio(e)
{
var inputBuffer = e.inputBuffer.getChannelData(0);
var outputBuffer = e.outputBuffer.getChannelData(0);
outputBuffer.set(inputBuffer, 0);
document.getElementById("display").innerText =
incrementer + " " + inputBuffer[0];
incrementer++;
}
var context = null;
function Success(localMediaStream)
{
context = new window.webkitAudioContext();
var microphone = context.createMediaStreamSource(localMediaStream);
var node = context.createScriptProcessor(4096, 1, 1);
node.onaudioprocess = ProcessAudio;
microphone.connect(node);
node.connect(context.destination);
}
function Error(err)
{
alert("no audio support");
}
function load(e)
{
GetMedia({audio:true,video:false}, Success, Error);
}
</script>
</head>
<body onload="load(event)">
<div>Audio Player</div>
<div id="display"></div>
<video id="localvideo" autoplay="autoplay" style="opacity:1"></video>
</body>
</html>
僅供參考,因爲Chrome for mobile(穩定版和Beta版)已經更新,好消息是現在所有的工作都正常,如預期的那樣,還有現場輸入。點擊代碼! PS:也許我的錯誤報告做到了C: – JSmyth