0

現在、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");
            }
        }
    }
}
4

1 に答える 1