【发布时间】:2017-04-06 14:48:57
【问题描述】:
我正在尝试播放存储在我的 Meteor Android 应用程序的 LocalForage 中的音频文件。
LocalForage.getItem(track_id, (err, value)=>{
if(err)
throw err;
//the loaded value is an arraybuffer of an m4a file
let blob = new Blob([value]);
let url = (window.URL || window.webkitURL || window || {}).createObjectURL(blob);
let testAudio = new Audio(url);
testAudio.play().then(()=>{console.log("play successful")}).catch((err)=>{console.error(err)});
});
之前,我将 url 传递给 Howler.js 的实例,但为了更容易理解发生了什么,我添加了 testAudio。
在浏览器 (Chrome) 中进行测试时,代码可以正常工作。网址已创建并正在播放音频。
Android(使用 Chromium 作为所有 Meteor Android 应用程序)但是,似乎不喜欢我的方法: 创建对象 URL 时,Chromium 会返回如下 URL:
blob:http%3A//localhost%3A12128/4de4516a-2989-4e99-9269-0beff4517fc4
如您所见,这不是一个可用的 URL,即使我这样做了
url = url.replace(/%3A/g, ':');
得到的控制台输出是
DOMException: Failed to load because no supported source was found.
有谁知道为什么这在 Android 上不起作用?我在这里查看了其他有同样问题的问题,但我的代码在我看来是正确的,并且在 Chrome 中测试时可以工作,所以我真的不知道如何解决这个问题。
顺便说一下,Audiobuffer是这样保存的:
const request = new window.XMLHttpRequest();
request.addEventListener('readystatechange', () => {
if (request.readyState === 4) {
LocalForage.setItem(track.file_id, request.response, (err, value) => {
console.log('Successfully saved to locale forage: ' + track.name);
})
}
});
request.open('GET', track.audioLink, true);
request.responseType = 'arraybuffer';
request.send();
【问题讨论】:
-
我遇到了音频播放在 Android 4 及更低版本上无法正常工作的问题。您使用的是 Android 5+ 吗?
标签: javascript android blob chromium meteor-react