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

Мне пришлось обновить мое приложение, чтобы оно работало вместе с новыми версиями Android, ориентируясь на версию N, я обновил:

от:

Uri.fromFile();

чтобы:

FileProvider.getUriForFile();

Я сделал это следующим образом:

Основано на: ( android.os.FileUriExposedException: файл:///storage/emulated/0/test.txt, доступный за пределами приложения через Intent.getData ())

<provider
    android:name="android.support.v4.content.FileProvider"
    android:authorities=" com.mydomain.fileprovider"
    android:exported="false"
    android:grantUriPermissions="true">
    <meta-data
        android:name="android.support.FILE_PROVIDER_PATHS"
        android:resource="@xml/provider_paths"/>
</provider>

provider_paths:

<paths xmlns:android="http://schemas.android.com/apk/res/android">
<external-cache-path name="external_files" path="."/>
</paths>

FntTakePicture:

@Override
    public void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState)

//......
//......

btnTakePicture.setOnClickListener(new View.OnClickListener() {
    @Override
    public void onClick(View v) {
        Intent takePictureIntent = new Intent(MediaStore.ACTION_IMAGE_CAPTURE);

        if (takePictureIntent.resolveActivity(getContext().getPackageManager()) != null) {


            outputFileName = null;
            try {

                /*if(fragmentPosition == 0 || fragmentPosition == 4)
                    outputFileName = Images.createImageFile2();//PNG
                else
                    outputFileName = Images.createImageFile3();//JPG*/

                outputFileName = Images.createImageFile3();

                //takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT,Uri.fromFile(outputFileName));
                Uri photoURI = FileProvider.getUriForFile(getContext(),"com.mydomain.fileprovider",outputFileName);
                takePictureIntent.putExtra(MediaStore.EXTRA_OUTPUT,photoURI);
                takePictureIntent.addFlags(Intent.FLAG_GRANT_WRITE_URI_PERMISSION);

                startActivityForResult(takePictureIntent, RC_IMAGE_CAPTURE);

            } catch (IOException e) {
                e.printStackTrace();
                FirebaseCrash.report(e);
            }

        }
    }
});

}

@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {

    if (requestCode == RC_IMAGE_CAPTURE && resultCode == RESULT_OK) {

        loadImage(outputFileName.getAbsolutePath());//outputFileName.getAbsolutePath()

        if (android.os.Build.VERSION.SDK_INT >= android.os.Build.VERSION_CODES.N) {
            txtInstructions.setText(Html.fromHtml(
                    String.format(
                            getResources().getString(R.string.validate_picture2),
                            defaultValidateText
                    ),Html.FROM_HTML_MODE_LEGACY
            ));

        } else {
            txtInstructions.setText(Html.fromHtml(
                    String.format(
                            getResources().getString(R.string.validate_picture2),
                            defaultValidateText
                    )), TextView.BufferType.SPANNABLE);
        }

        btnTakePicture.setText(getString(R.string.take_photo_again));
        //this.data.setImage(Images.compressImage(picture),fragmentPosition);
        this.data.setImage(outputFileName.getAbsolutePath(),fragmentPosition);
        Log.e("Data Picture"," Vin: "+this.data.getVin()+" lon: "+this.data.getLon()+ " lat: "+this.data.getLat());


        if(lastPage)
        validateContinueBoton();
        listener.save(this.data);
    }
}

public void loadImage(final String path){
    new AsyncTask<Void,Void,Bitmap>(){

        @Override
        protected Bitmap doInBackground(Void... params) {

            return Images.decodeSampledBitmapFromFile(path,
                    getResources().getDimensionPixelSize(R.dimen.ancho_default)/2);
        }

        @Override
        protected void onPostExecute(Bitmap bitmap) {
            super.onPostExecute(bitmap);
            imgPictureTaken.setScaleType(ImageView.ScaleType.CENTER_CROP);
            imgPictureTaken.setImageBitmap(bitmap);
        }
    }.execute(null,null,null);
}

Класс изображений:

public class Images{


    static File createImageFile3() throws IOException {
        // Create an image file name
        String timeStamp = new SimpleDateFormat("yyyyMMdd_HHmmss",Locale.US).format(new Date());
        String imageFileName = "NTS_Image_" + timeStamp + "_";
        File storageDir = ContextCompat.getExternalCacheDirs(App.getContext())[0];

        File nf = File.createTempFile(
                imageFileName,  // prefix
                ".jpg",         // suffix
                storageDir      // directory
        );

        nf.deleteOnExit();
        return nf;
    }
}

Кроме того, это событие фрагментарно, я не знаю, имеет ли это значение.

После запуска установите приложение, дайте ему разрешение, затем выведите его из строя, как только оно заработает нормально…

Исключение я получил это так:

04-17 15: 00: 10.058 669-669 /? E / cnss-daemon: устаревшие или недоступные соседи, состояние ndm: 4 04-17 15:00:10.202 13596-13596/com.mydomain E/AndroidRuntime: ОСНОВНОЕ ИСКЛЮЧЕНИЕ: основной процесс: com.mydomain, PID: 13596 java.lang.RuntimeException: сбой при доставке результата ResultInfo{who=null, request=74538, result=-1, data=Intent { act=inline-data (has extras) }} в действие {com.mydomain/com.mydomain.CaptureWizard}: java.lang.NullPointerException: попытка вызвать виртуальный метод 'java.lang.String java.io.File.getAbsolutePath()' для нулевой ссылки на объект в android.app.ActivityThread.deliverResults(ActivityThread.java:4094) в android.app.ActivityThread.handleSendResult(ActivityThread.java:4137) на android.app.ActivityThread.-wrap20(ActivityThread.java) на android.app.ActivityThread$H.handleMessage(ActivityThread.java:1529) на android.os.Handler.dispatchMessage(Handler.java:102) в android.os.Looper.loop(Looper.java:154) в android.app.ActivityThread.main(ActivityThread.java:6123) в java.lang.reflect.Method.invoke(родной Method) на com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867) на com.android.internal.os.ZygoteInit.main(ZygoteInit.java:757). Вызвано: java.lang.NullPointerException: Попытка вызвать виртуальный метод "java.lang.String java.io.File.getAbsolutePath ()" для ссылки на пустой объект в com.mydomain.FntTakePicture.onActivityResult(FntTakePicture.java:201) в android.support.v4.app.FragmentActivity.onActivityResult(FragmentActivity.java:164) в com.mydomain.CaptureWizard.onActivityResult(CaptureWizard.java:133) в android.app.Activity.dispatchActivityResult(Activity.java:6931) в android.app.ActivityThread.deR ActivityThread.java:4090) в android.app.ActivityThread.handleSendResult (ActivityThread.java:4137) в android.app.ActivityThread.-wrap20(ActivityThread.java) в android.app.ActivityThread $ H.handleMessage (ActivityThread.java: 1529) на android.os.Handler.dispatchMessage (Handler.java:102) на android.os.Looper.loop(Looper.java:154) на android.app.Activi tyThread.main (ActivityThread.java:6123) в java.lang.reflect.Method.invoke(собственный метод) в com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:867) в com.android. internal.os.ZygoteInit.main (ZygoteInit.java:757)

1 ответ

Решение

Убедитесь, что вы экономите outputFileName в вашем сохраненном состоянии экземпляра Bundle, Ваш процесс может быть прерван, пока ваше приложение находится в фоновом режиме, что может привести к тому, что это поле станет null по умолчанию в вашем новом процессе.

Другие вопросы по тегам