В основном я хочу знать, есть ли фундаментальный конфликт, связанный с тем, что я не могу использовать один и тот же ресурс с библиотекой, если да, мне нужно будет использовать другой подход.
Моя цель — получить видео низкого качества с одновременным сохранением метаданных детектора, чтобы я мог выполнять некоторую постобработку и нарезку без особых задержек.
На основе CameraDetectorDemo - детектор камеры
Я инициализировал MediaRecorder, но он сохраняет черный экран, если я запускаю его до детектора, и вылетает при запуске (с кодом -19), если я запускаю его после детектора. Детектор прикрепляет превью, может быть из-за этого.
Я добавил несколько кнопок для управления этими функциями:
protected void cameraInit() {
String state = Environment.getExternalStorageState();
if (!Environment.MEDIA_MOUNTED.equals(state)) {
Log.d(LOG_TAG, "Drive not mounted - cannot write video");
return;
}
File file = new File(getExternalFilesDir(Environment.DIRECTORY_MOVIES), "demo.gp3");
Log.d(LOG_TAG, String.format("Camera Initializing. Setting output to: %s", file.getAbsolutePath()));
// Set sources
recorder.setAudioSource(MediaRecorder.AudioSource.MIC);
recorder.setVideoSource(MediaRecorder.VideoSource.CAMERA);
// Set profile
recorder.setProfile(CamcorderProfile.get(CamcorderProfile.QUALITY_LOW));
// Set output profile
recorder.setOutputFile(file.getAbsolutePath());
// Set preview output
recorder.setPreviewDisplay(cameraPreview.getHolder().getSurface());
try {
this.recorder.prepare();
} catch (IOException e) {
Log.e(LOG_TAG, "IO exception on camera Initialization");
e.printStackTrace();
} catch (IllegalStateException e) {
// This is thrown if the previous calls are not called with the
// proper order
Log.e(LOG_TAG, "Failed to initialize things properly :( ");
e.printStackTrace();
}
}
protected void cameraStart() {
Log.d(LOG_TAG, "Camera Start");
this.recorder.start();
}
protected void cameraStop() {
Log.d(LOG_TAG, "Camera Stop");
this.recorder.stop();
}