【问题标题】:Audio context not working properly on android音频上下文在 android 上无法正常工作
【发布时间】:2016-08-16 05:37:09
【问题描述】:

我在使用 android 时遇到了这个问题(对于 android 浏览器或适用于 android 的 chrome):getByteFrequencyData 方法返回 0 值。

有人说 android 移动设备不支持 Web Audio Api(IOS 确实支持它),但我刚刚检查了这个link,它说 chrome 49 支持 Audio Api。

有人说是老issue

还有人说问题出在媒体元素上,如果你可以将带有XHR的媒体加载到缓冲区中并播放,它会work(我测试过,但没有用)

我正在尝试使用 Audio APi + Canvas 制作一个在 android cordova 上工作的音频可视化器 有什么帮助吗?

【问题讨论】:

标签: javascript android cordova html5-audio chromium


【解决方案1】:

我让它工作了,带有两个参数的 createBuffer() 方法不再适用于 chrome 版本,所以我不得不使用 decodeAudioData 来获取缓冲区源:

// Create AudioContext and buffer source
var audioCtx = new AudioContext();
source = audioCtx.createBufferSource();
// load in an audio track via XHR and decodeAudioData
function getData() {
request = new XMLHttpRequest();
request.open('GET', 'Test.mp3', true);
request.responseType = 'arraybuffer';
request.onload = function() {
var audioData = request.response;

audioCtx.decodeAudioData(audioData, function(buffer) {
myBuffer = buffer;   
source.buffer = myBuffer;

analyser = audioCtx.createAnalyser(); // AnalyserNode method
canvas = document.getElementById('CanvasDiv');
canvasContext = canvas.getContext('2d');
source.connect(analyser);
analyser.connect(audioCtx.destination);

frameLooper(); 
},
function(e){"Error with decoding audio data" + e.err});
}
request.send();
}
function frameLooper(){
ionic.requestAnimationFrame(frameLooper); //You can use window instead of ionic
fbc_array = new Uint8Array(analyser.frequencyBinCount);
analyser.getByteFrequencyData(fbc_array);
canvasContext.clearRect(0, 0, canvas.width, canvas.height); // Clear the canvas
canvasContext.fillStyle = '#00CCFF'; // Color of the bars
bars = 100;

for (var i = 0; i < bars; i++) {
    bar_x = i * 3;
    bar_width = 2;
    bar_height = -(fbc_array[i] / 2);
    //  fillRect( x, y, width, height ) // Explanation of the parameters below
    canvasContext.fillRect(bar_x, canvas.height, bar_width, bar_height);
}
}
getData();
var audio = document.getElementById('audioTagId');
Callback = function(){
        source.start();
    }
document.getElementById("PlayButton").addEventListener("click", Callback);

【讨论】:

    猜你喜欢
    • 2021-12-14
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-10-22
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多