这不会那样.
请记住,JAVE只是充当ffmpeg可执行文件的包装器,
那就是你提供参数,比如目标编码,响度等等
然后基本上告诉JAVE调用fmpeg并传递设置,你输入了
使用Java方法作为ffmpeg可执行文件的参数.
此步骤需要您指定的设置
1.可序列化
2.已知ffmpeg可执行文件
现在你可以争论至少一些InputStream,比如FileInputStream
以某种方式可序列化,因为有一个低级别的文件描述符对应
到这个InputStream,但考虑一个ByteArrayInputStream – 我不知道如何
Java在每个平台上实现,但我有点怀疑,有一个
相应的文件描述符.
然而关键的一点是,ffmpeg可执行文件不会也不应该
不知道InputStream类型的Java对象是什么.它能做的最好
(至少在posix系统上)取一个整数(文件描述符)
并尝试从中读取数据.但是,很多事情都可能出错
使用文件描述符.例如,它可能是可寻找的,如果是的话
例如,文件是否实际表示从套接字读取的数据.
很高兴,在Posix系统上,每个进程至少有3个文件描述符,
那就是STDIN,STDOUT和STDERR.这对应于您可以的概念
管道输入/输出从一个过程到另一个过程.我不知道这是否或如何运作
在Windows上,但在OSX或Linux上,您可以将数据传输到ffmpeg可执行文件中.这个
实际上意味着,你指示ffmpeg从STDIN文件描述符中读取.
可悲的是,JAVE没有实现ffmpeg的这个特殊功能,也就是说
没有方法,将数据传输到ffmpegs STDIN.
FWIW.您可以编写一些本机(c / c)代码并使用传递Java对象’DecodeFeed’
JNI同时拥有一个输入流
和一个OutputStream
您必须编写的本机代码可以包含ffmpeg源并使用它们
解码/转码从DecodeFeed.in读取然后写回的输入
DecodeFeed.out.
或者,您可以自行分叉JAVE并实现此功能.
您可能知道Java提供了一种通过调用来运行可执行文件的方法
的Runtime.exec.此调用将返回Process类的实例
提供Process.getOutputStream.如果你写这个Outputstream,你
实际上写入刚刚创建的进程的STDIN.