"Ошибка доставки результата 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
по умолчанию в вашем новом процессе.