写在前面的话
七月份的第一周的小目标感觉不是很满意啊 😀 吐槽前来张妹子图:
项目中用到FFmpeg 在github上面搜索了一下 用的是:
com.github.adrielcafe:AndroidAudioConverter:0.0.8
这个依赖 是针对
com.writingminds:FFmpegAndroid:0.3.2
进行的封装。而 FFmpegAndroid:0.3.2 里面是编译的 FFmpeg 3.0版本。据说 3.3版本添加了硬件加速。 目前项目中 使用的FFmpeg 3.0在对音频指定位置合成的时候 感觉达不到预期 指定位置 合成8句语音 在4~5秒左右 这个加进度条的话 用户一般还能接受 但是 如果是比较长的 譬如说 20-30句的话 时间上 需要12-15秒。 具体的看 Android 机型和硬件。ios那边比较快 他们系统有相应的方法,所以想尝试这 编译最新的FFmpeg 3.3 版本 添加jni ndk支持 看能不能速度上更快一些。网上参考了 之前的一些旧文章 成功编译so文件 但编译之后 jni那块卡住了 具体还需要花费时间和精力 在学习研究。
多段音频指定位置 混合插入:
<code>
public void mergeAudio(String totalFile, List<String> filePath, List<String> fileName, String outputFile, ExecuteBinaryResponseHandler responseHandler) {
new Thread() {
@Override
public void run() {
try {
Runtime.getRuntime().gc();
File file = new File(outputFile);
if (file.exists()) {
file.delete();
}
String cmd = "-i " + totalFile;
String input_file = "";
String adelay = "";
String s = "";
for (int i = 0; i < filePath.size(); i++) {
input_file = input_file + " -i " + filePath.get(i);
adelay = adelay + "[" + (i + 1) + ":a]adelay=" + fileName.get(i) + "[aud" + (i + 1) + "];";
s = s + "[aud" + (i + 1) + "]";
}
//cmd = cmd + input_file + " -preset superfast -async 10 -filter_complex " + adelay + "[0:a]" + s + "amix=inputs=" + (filePath.size() + 1) + ":duration=first:dropout_transition=0 -threads 0 " + outputFile;
cmd = cmd + input_file + " -preset ultrafast -async 1 -filter_complex " + adelay + "[0:a]" + s + "amix=inputs=" + (filePath.size() + 1) + ":duration=first:dropout_transition="+(filePath.size() + 1)+" -threads 0 " + outputFile;
Log.d("打印出的字符串是", "mergeAudio: " + cmd);
String[] command = cmd.split(" ");
ffmpeg.execute(command, responseHandler);
} catch (Exception e) {
e.printStackTrace();
}
}
}.start();
}
</code>
最后
这里给大家安利一款谷歌浏览器插件 最近被问到 那么多相同类型的妹子图是怎么找到的 😀
关于FFmpeg 3.3的具体编译 见下篇文章。 总之 遇到无数的坑。。。 目前还没有太大突破。