現在、Inspire 1 からすべての画像をダウンロードする Android アプリケーションを作成しています。最新バージョンの SDK (v3.2.1) を使用しています。これを行うために DJIPlaybackManager を使用しています。ただし、すべての画像をダウンロードする際に問題が発生しています。
以下のコードを実行するたびに、「ファイルが選択されていません」というメッセージが表示されますが、そのすぐ上に SD カード上のすべてのファイルが選択されていると思います。このエラーは、CameraFileDownloadCallback の onError メソッドでスローされます。selectAllFiles() から返されたエラーは null なので、正しく選択されたことを意味すると思います。誰かが私が間違っていることを教えてもらえますか? 私は多くのことを試しましたが、何もうまくいかないようです。
どんな助けでも大歓迎です。
private static String TAG = "MediaManager";
public static void downloadAllMedia(final Context mContext) {
Log.d(TAG, "Downloading media...");
final String fileDirPath = mContext.getFilesDir().getPath();
DJIBaseProduct product = DJIDemoApplication.getProductInstance();
if (product != null && product.isConnected()) {
if (product instanceof DJIAircraft) {
final DJICamera camera = product.getCamera();
if (camera != null) {
camera.setCameraMode(DJICameraSettingsDef.CameraMode.Playback, new DJIBaseComponent.DJICompletionCallback() {
@Override
public void onResult(DJIError djiError) {
if (djiError == null) {
final DJIPlaybackManager playbackManager = camera.getPlayback();
DJICameraError enterPreviewModeError = playbackManager.enterMultiplePreviewMode();
if(enterPreviewModeError != null) {
Log.e(TAG, "Failed to enter mutliple preview mode");
}
DJICameraError enterEditModeError = playbackManager.enterMultipleEditMode();
if(enterEditModeError != null) {
Log.e(TAG, "Failed to enter multiple edit mode: " + enterEditModeError.getDescription());
return;
}
DJIError selectFilesError = playbackManager.selectAllFiles();
if (selectFilesError != null) {
Log.e(TAG, "Failed to select files on device: " + selectFilesError.getDescription());
return;
} else {
Log.d(TAG, "Successfully selected all media");
}
playbackManager.downloadSelectedFiles(new File(fileDirPath), new DJIPlaybackManager.CameraFileDownloadCallback() {
@Override
public void onStart() {
Log.d(TAG, "Starting fetch of media");
}
@Override
public void onEnd() {
Log.d(TAG, "Finished downloading media");
}
@Override
public void onError(Exception e) {
Log.e(TAG, "Failed downloading media: " + e.getMessage());
}
@Override
public void onProgressUpdate(int i) {
Log.d(TAG, "Media download from drone: " + i + "%");
}
});
} else {
Log.e(TAG, "Could not set the Camera mode to playback");
}
}
});
} else {
Log.e(TAG, "Camera is not available");
}
}
}
}