javascript - 从数据:url google chrome mobile播放音频

标签 javascript android html google-chrome

我使用此代码从字节生成音频元素,它创建一个简单的 wav 声音,我可以在桌面版的 google chrome 或 firefox 中播放它,但是当我想在 Google Chrome Mobile 中播放它时,它会播放没什么,问题出在哪里,我可以轻松播放 wav 文件,但无法在 google chrome mobile 中播放二进制数据中的音乐:

<!DOCTYPE html>
<html>
    <head>
        <title>Explosion Generator</title>
        <script type = "text/javascript" src="../../js/jquery-1.8.3.js" ></script>
        <script>

            function encodeAudio16bit(data, sampleRate) {
                var n = data.length;
                var integer = 0, i;

                // 16-bit mono WAVE header template
                var header = "RIFF<##>WAVEfmt \x10\x00\x00\x00\x01\x00\x01\x00<##><##>\x02\x00\x10\x00data<##>";

                // Helper to insert a 32-bit little endian int.
                function insertLong(value) {
                    var bytes = "";
                    for (i = 0; i < 4; ++i) {
                        bytes += String.fromCharCode(value % 256);
                        value = Math.floor(value / 256);
                    }
                    header = header.replace('<##>', bytes);
                }

                // ChunkSize
                insertLong(36 + n * 2);

                // SampleRate
                insertLong(sampleRate);

                // ByteRate
                insertLong(sampleRate * 2);

                // Subchunk2Size
                insertLong(n * 2);

                // Output sound data
                for (var i = 0; i < n; ++i) {
                    var sample = Math.round(Math.min(1, Math.max(-1, data[i])) * 32767);
                    if (sample < 0) {
                        sample += 65536; // 2's complement signed
                    }
                    header += String.fromCharCode(sample % 256);
                    header += String.fromCharCode(Math.floor(sample / 256));
                }

                return 'data:audio/wav;base64,' + btoa(header);
            }


            function generateTone(freq, sampleRate, duration){
                var tone = []
                for(var i = 0; i < duration * sampleRate; ++i){
                    tone.push(Math.sin(2 * Math.PI * i / (sampleRate/freq)));
                }
                return tone;
            }

            $(document).ready(function(){
                $("#body").html("Sounds...");

                var sampleRate = 44100; // hz
                var freq = 400;   // hz
                var duration = 2; // seconds
                var tone = generateTone(freq, sampleRate, duration);
                var base64EnodedTone = encodeAudio16bit(tone, sampleRate);
                var audioPlayer = $('<audio>').attr({ src: base64EnodedTone,
                    controls:true
                });
                $("#body").append(audioPlayer);

                $("#body").append("<p>done<p>");
            });    
        </script>
    </head>

    <body>
        <div id="body" ></div>
    </body>
</html>

最佳答案

这肯定是一个错误。每当您在桌面上运行它,而在 Android 版 Chrome 上运行失败时,99.5% 的可能性就是一个错误。

我在这里提出了错误:https://code.google.com/p/chromium/issues/detail?id=253466此处有错误演示:http://jsbin.com/ajocid/latest

桌面上还有另一种解决方案,可将音频编码为 Blob 并播放,遗憾的是,该解决方案在 Android 版 Chrome 上不起作用,需要修复。

在这两个错误得到修复之前,您目前所能期望的最好的结果就是将其上传到服务器并从那里播放。

关于javascript - 从数据:url google chrome mobile播放音频,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17130673/

相关文章:

javascript - 如何解析和提取javascript类方法?

Android Speex 回声消除问题

javascript - 具有不同 html 结构的 materializecss 可折叠面板

javascript - Bootstrap - 使菜单扩展到页面高度

android - 在 Android 中以编程方式添加 TableRow

JavaScript - 如何获得第三个 "sub variable"

javascript - 从较低的 div 获取背景图像 url 以将它们添加到较高的 div

javascript - 为某些元素设置相同事件的简单方法

javascript - 将时间输入设置为数据库中的日期时间

android - 通过OTA安装,应用程序在最小化并重新进入时启动