delete temp file after audio jointing

delete temp file after audio  jointing
pull/166/head
xufulong 4 years ago
parent 414935382c
commit 856d44f31f
  1. 37
      app/src/main/java/com/frank/ffmpeg/activity/AudioHandleActivity.java
  2. 8
      app/src/main/java/com/frank/ffmpeg/util/FileUtil.java

@ -41,6 +41,10 @@ public class AudioHandleActivity extends BaseActivity {
private int viewId; private int viewId;
private FFmpegHandler ffmpegHandler; private FFmpegHandler ffmpegHandler;
private String outputPath1 = PATH + File.separator + "output1.mp3";
private String outputPath2 = PATH + File.separator + "output2.mp3";
private boolean isJointing = false;
private final static boolean useFFmpeg = true; private final static boolean useFFmpeg = true;
@SuppressLint("HandlerLeak") @SuppressLint("HandlerLeak")
@ -56,6 +60,11 @@ public class AudioHandleActivity extends BaseActivity {
case MSG_FINISH: case MSG_FINISH:
layoutProgress.setVisibility(View.GONE); layoutProgress.setVisibility(View.GONE);
layoutAudioHandle.setVisibility(View.VISIBLE); layoutAudioHandle.setVisibility(View.VISIBLE);
if (isJointing) {
isJointing = false;
FileUtil.deleteFile(outputPath1);
FileUtil.deleteFile(outputPath2);
}
break; break;
case MSG_PROGRESS: case MSG_PROGRESS:
int progress = msg.arg1; int progress = msg.arg1;
@ -134,13 +143,10 @@ public class AudioHandleActivity extends BaseActivity {
String transformFile = PATH + File.separator + "transformAudio.mp3"; String transformFile = PATH + File.separator + "transformAudio.mp3";
commandLine = FFmpegUtil.transformAudio(srcFile, transformFile); commandLine = FFmpegUtil.transformAudio(srcFile, transformFile);
} else { //use MediaCodec and libmp3lame to transform } else { //use MediaCodec and libmp3lame to transform
new Thread(new Runnable() { new Thread(() -> {
@Override String transformInput = PATH + File.separator + "transformAudio.mp3";
public void run() { Mp3Converter mp3Converter = new Mp3Converter();
String transformInput = PATH + File.separator + "transformAudio.mp3"; mp3Converter.convertToMp3(srcFile, transformInput);
Mp3Converter mp3Converter = new Mp3Converter();
mp3Converter.convertToMp3(srcFile, transformInput);
}
}).start(); }).start();
} }
break; break;
@ -176,20 +182,10 @@ public class AudioHandleActivity extends BaseActivity {
commandLine = FFmpegUtil.mixAudio(srcFile, appendFile, mixFile); commandLine = FFmpegUtil.mixAudio(srcFile, appendFile, mixFile);
break; break;
case R.id.btn_play_audio://use AudioTrack to play audio case R.id.btn_play_audio://use AudioTrack to play audio
new Thread(new Runnable() { new Thread(() -> new AudioPlayer().play(srcFile)).start();
@Override
public void run() {
new AudioPlayer().play(srcFile);
}
}).start();
return; return;
case R.id.btn_play_opensl://use OpenSL ES to play audio case R.id.btn_play_opensl://use OpenSL ES to play audio
new Thread(new Runnable() { new Thread(() -> new AudioPlayer().playAudio(srcFile)).start();
@Override
public void run() {
new AudioPlayer().playAudio(srcFile);
}
}).start();
return; return;
case R.id.btn_audio_encode://audio encode case R.id.btn_audio_encode://audio encode
String pcmFile = PATH + File.separator + "concat.pcm"; String pcmFile = PATH + File.separator + "concat.pcm";
@ -224,8 +220,7 @@ public class AudioHandleActivity extends BaseActivity {
if (ffmpegHandler == null || selectedPath.isEmpty() || appendFile.isEmpty()) { if (ffmpegHandler == null || selectedPath.isEmpty() || appendFile.isEmpty()) {
return; return;
} }
String outputPath1 = PATH + File.separator + "output1.mp3"; isJointing = true;
String outputPath2 = PATH + File.separator + "output2.mp3";
String targetPath = PATH + File.separator + "concatAudio.mp3"; String targetPath = PATH + File.separator + "concatAudio.mp3";
String[] transformCmd1 = FFmpegUtil.transformAudio(selectedPath, "libmp3lame", outputPath1); String[] transformCmd1 = FFmpegUtil.transformAudio(selectedPath, "libmp3lame", outputPath1);
String[] transformCmd2 = FFmpegUtil.transformAudio(appendFile, "libmp3lame", outputPath2); String[] transformCmd2 = FFmpegUtil.transformAudio(appendFile, "libmp3lame", outputPath2);

@ -218,4 +218,12 @@ public class FileUtil {
return true; return true;
} }
public static boolean deleteFile(String path) {
if (TextUtils.isEmpty(path)) {
return false;
}
File file = new File(path);
return file.exists() && file.delete();
}
} }

Loading…
Cancel
Save