Web Audio API: decodeAudioData не декодирует опусы в Chrome
В настоящее время я пытаюсь заставить пакеты Opus работать с Web Audio API. Однако проблема заключается в том, что, хотя FireFox и Chrome должны изначально поддерживать его, только FireFox может декодировать поток образцов OPUS с использованием decodeAudioData из API Web Audio. Chrome распознает файл, когда я перетаскиваю файл opus в браузер, а также воспроизводит его! Поэтому мне интересно, что я могу делать что-то не так, вызывая сбой в Chrome.
Затем я использовал пример кода из http://awm.jp/~yoya/js/audio/meow.html просто загрузил файл opus и попытался его декодировать. Снова Firefox делает, а Chrome нет. Поэтому мне интересно, может ли кто-нибудь подтвердить мою находку или сказать, что я делаю здесь неправильно. Ниже приведена модифицированная версия из предыдущей ссылки. Спасибо!
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-15">
<title> decodeAudioData sample </title>
</head>
<script src="http://code.jquery.com/jquery-1.9.1.min.js"></script>
<script type="text/javascript">
//$(document).ready(function() {
var catMeowingBuffer = null;
window.AudioContext = window.AudioContext||window.webkitAudioContext;
var context = new AudioContext();
function onError(err) {
console.log("unable to decode");
}
function loadCatSound(url) {
var request = new XMLHttpRequest();
request.open('GET', url, true);
request.responseType = 'arraybuffer';
// Decode asynchronously
request.onload = function() {
context.decodeAudioData(request.response, function(buffer) {
catMeowingBuffer = buffer;
var src = context.createBufferSource();
src.buffer = catMeowingBuffer
src.connect(context.destination);
src.start(0);
}, onError);
}
request.send();
}
loadCatSound("opus.opus");
function playCatSound() {
if (catMeowingBuffer !== null) {
var src = context.createBufferSource();
src.buffer = catMeowingBuffer
src.connect(context.destination);
src.start(0);
}
}
//});
</script>
<body>
<h1> decodeAudioData sample </h1>
<button onclick="playCatSound();"> playCatSound </button>
<hr>
<address></address>
</body> </html>
1 ответ
Это ошибка в Chrome. См. https://code.google.com/p/chromium/issues/detail?id=409402.