【问题标题】:Web Audio- streaming file from server to client从服务器到客户端的网络音频流文件
【发布时间】:2015-06-02 21:06:04
【问题描述】:

我正在尝试使用 BinaryJS 将音频从包含音频文件的服务器流式传输到客户端。我的代码受到这个问题中代码的启发:Playing PCM stream from Web Audio API on Node.js

这是我的服务器代码的样子:

// create a BinaryServer using BinaryJS
var BinaryServer = require('binaryjs').BinaryServer;
// gotta be able to access the filesystem
var fs = require('fs');

// create our server listening on a specific port
var server = BinaryServer({port: 8080});

// do this when a client makes a request
server.on('connection', function(client){
    // get the audio file
    var file = fs.createReadStream(__dirname + '/JDillaLife.mp3');

    // convert to int16
    var len = file.length;
    var buf = new Int16Array(len);

    while(len--){
        buf[len] = data[len]*0xFFFF;
    }

    var Stream = client.send();
    Stream.write(buf.buffer);

    console.log("Server contacted and file sent");
});
console.log('Server running on port 8080');

还有我的客户代码:

var Speaker = require('speaker');
var speaker = new Speaker({
    channels: 2,
    bitDepth: 32,
    sampleRate: 44100,
    signed: true
});

var BinaryClient = require('binaryjs').BinaryClient;
var client = BinaryClient('http://localhost:8080');
client.on('stream', function(stream, meta){
    stream.on('data', function(data){
        speaker.write(data);
    });
});

这是一个非常粗略的草稿,我几乎可以肯定它不会立即播放得很好,但是现在当我运行时它会抛出一个错误,这似乎与 var buf = new Int16Array(len); 行有问题,我是不知道为什么会这样。它说存在“类型错误”,但我不确定为什么在将新对象分配给空变量时会发生这种情况。我是 JS 的新手(以及整个无类型语言的东西)所以这是我分配的问题吗?

【问题讨论】:

    标签: javascript audio types web-audio-api


    【解决方案1】:

    我认为这里的问题是您正在访问 file.length,而 file 是一个 Stream 对象,我认为它没有长度属性。所以你所做的基本上是在说

     new Int16Array(undefined);
    

    因此出现类型错误。

    fs.createReadStream 记录在这里; https://nodejs.org/api/fs.html#fs_fs_createreadstream_path_options

    您可以使用 Stream 对象通过 stream.read(256) 读取块中的数据,如此处所述; https://nodejs.org/api/stream.html#stream_readable_read_size

    希望这可以为您提供足够的指导!

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 1970-01-01
      • 2010-10-17
      • 2021-02-18
      • 1970-01-01
      • 2014-01-19
      • 1970-01-01
      • 1970-01-01
      • 2020-11-16
      相关资源
      最近更新 更多