Ошибка доставки результата ResultInfo при запуске камеры на Android

Я пытаюсь использовать внешнюю камеру Android, чтобы поместить изображение в ImageView, но получаю сообщение об ошибке «Ошибка доставки результата ResultInfo». Вот мой код:

Нажатие кнопки для запуска приложения камеры

public void takePhoto(View v) {


    Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);
    if (takePictureIntent.resolveActivity(getPackageManager()) != null) {
        // Creating the File where the photo should go
        File photoFile = null;
        try {
            photoFile = createImageFile();
        } catch (IOException ex) {
            // Error occurred while creating the File
            Log.e(TAG,"something went wrong", ex);
            return;
        }
        // Continue only if the File was successfully created
        if (photoFile != null) {
            takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT,
                    Uri.fromFile(photoFile));
            startActivityForResult(takePictureIntent, REQUEST_CODE);
        }
    }
}

Именование и создание временного файла. файл:

    String mCurrentPhotoPath;

private File createImageFile() throws IOException {
    // Create an image file name
    String timeStamp = new SimpleDateFormat("yyyyMMddHHmmss").format(new Date());
    String imageFileName = "JPEG" + timeStamp + "";
    File storageDir = Environment.getExternalStoragePublicDirectory(
            Environment.DIRECTORY_PICTURES);
    File image = File.createTempFile(
        imageFileName,  /* prefix */
        ".jpg",         /* suffix */
        storageDir      /* directory */
    );
    if(image.exists() == false) {
        image.getParentFile().mkdirs();
        image.createNewFile();
    }


    // Save a file: path for use with ACTION_VIEW intents
    mCurrentPhotoPath = "file:" + image.getAbsolutePath();
    Log.d(TAG,mCurrentPhotoPath);
    return image;
}

результат активности:

    protected void onActivityResult(int requestCode, int resultCode, Intent data) {

// bla bla bla... I never get to this point.

Log.d(TAG,"request code: " + requestCode + "result code: " + resultCode);



}

Моя ошибка:

06-03 14:35:50.121: E/AndroidRuntime(19125): FATAL EXCEPTION: main
06-03 14:35:50.121: E/AndroidRuntime(19125): Process: com.example.moimeme, PID: 19125
06-03 14:35:50.121: E/AndroidRuntime(19125): java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=1, result=-1, data=null} to activity {com.example.moimeme/com.example.moimeme.MainActivity}: java.lang.NullPointerException
06-03 14:35:50.121: E/AndroidRuntime(19125):    at android.app.ActivityThread.deliverResults(ActivityThread.java:3365)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at android.app.ActivityThread.handleSendResult(ActivityThread.java:3408)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at android.app.ActivityThread.access$1300(ActivityThread.java:135)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1244)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at android.os.Handler.dispatchMessage(Handler.java:102)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at android.os.Looper.loop(Looper.java:136)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at android.app.ActivityThread.main(ActivityThread.java:5017)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at java.lang.reflect.Method.invokeNative(Native Method)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at java.lang.reflect.Method.invoke(Method.java:515)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at dalvik.system.NativeStart.main(Native Method)
06-03 14:35:50.121: E/AndroidRuntime(19125): Caused by: java.lang.NullPointerException
06-03 14:35:50.121: E/AndroidRuntime(19125):    at com.example.moimeme.MainActivity.onActivityResult(MainActivity.java:75)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at android.app.Activity.dispatchActivityResult(Activity.java:5423)
06-03 14:35:50.121: E/AndroidRuntime(19125):    at android.app.ActivityThread.deliverResults(ActivityThread.java:3361)
06-03 14:35:50.121: E/AndroidRuntime(19125):    ... 11 more

Я проверил довольно много вопросов о стеке и соответствующим образом изменил свой код, но не смог заставить его работать, извините, если что-то пропустил. кстати - отлажено и протестировано на нексусе 5.

заранее спасибо, и... я только начинаю работать с платформой Android, так что извините за нубский вопрос/ошибки в коде :)


person Jacob    schedule 03.06.2014    source источник


Ответы (1)


Ну, в конце концов я нашел решение. Выкладываю сюда, если кому нужно.

При использовании:

intent.putExtra(MediaStore.EXTRA_OUTPUT,
outputFileUri);

вы передаете дополнительный "EXTRA_OUTPUT". Когда вы передаете это дополнение, вы уже указываете, где хранить захваченное изображение. Поскольку вы уже знаете местоположение, Intent, переданный в onActivityResult(), будет нулевым. то есть данные будут нулевыми.

Вот почему, когда вы пытаетесь получить Fetch Uri с помощью

Uri uri = data.getData();

Это вызовет исключение NullPointerException. Итак, вам просто нужно использовать исходный путь в onActivityResult вместо того, чтобы запрашивать его из getData.

person Jacob    schedule 05.06.2014
comment
Есть такая же проблема. Ваше решение здесь не работает для меня: даже когда я комментирую все ссылки на параметр data из onActivityresult(req, res, data), эта ошибка все равно возникает. - person 1111161171159459134; 26.08.2015