我正在修改播放音频数据的应用程序,以便将数据写入文件。当前实现时,会动态填充字节数组,并且每次填充时,此缓冲区的内容都会写入SourceDataLine。我基本上想要将缓冲区写入指定格式的文件中。
我已阅读this official tutorial,并发现此代码已剪切为将音频数据写入文件:
File fileOut = new File(someNewPathName);
AudioFileFormat.Type fileType = fileFormat.getType();
if (AudioSystem.isFileTypeSupported(fileType,
audioInputStream)) {
AudioSystem.write(audioInputStream, fileType, fileOut);
}
我从API文档中看到我可以使用TargetDataLine构造一个AudioInputStream,但在我的例子中我有一个SourceDataLine。我不知道如何从我的字节数组中获取数据到TargetDataLine,因为它实现了read()方法而不是write()。 AudioInputStream的其他用途和其他文档将其视为从文件中读取的一种方式,因此我对它与AudioSystem.write()的使用感到有些困惑。
那么,如何将数据从SourceDataLine或直接从缓冲区获取到TargetDataLine或AudioInputStream中,以便将其写入文件?
答案 0 :(得分:2)
byte[]
建立ByteArrayInputStream
AudioSystem.getAudioInputStream(InputStream)
AudioSystem.write(..)