Я работаю над приложением для редактирования изображений для Android. В одной из моих действий я вызываю намерение выбрать изображение из галереи в onCreate следующим образом:
Intent intent = new Intent();
intent.setType("image/*");
intent.setAction(Intent.ACTION_GET_CONTENT);
startActivityForResult(Intent.createChooser(intent, "Select Picture"), PICK_IMAGE);
Затем я получаю данные следующим образом:
@Override
public void onActivityResult(int requestCode, int resultCode, Intent data) {
Crashlytics.log("onActivityResult called");
super.onActivityResult(requestCode, resultCode, data);
if (requestCode == PICK_IMAGE && resultCode == Activity.RESULT_OK && data != null) {
Crashlytics.log("Data received from image pick intent");
imageUri = data.getData();
loadImage();
} else {
//if we do not select a picture, go back to the dashboard
Crashlytics.log("Data not received");
onBackPressed();
Log.d(TAG, "no picture selected");
}
}
Метод loadImage
:
private void loadImage() {
try {
photoBitmap = MediaStore.Images.Media.getBitmap(this.getContentResolver(), imageUri);
} catch (IOException e) {
Crashlytics.log("IOException from getBitmap");
Log.d(TAG, e.getMessage());
showToastAndPressBack();
return;
}
if (photoBitmap == null) {
Crashlytics.log("photoBitmap is null in onActivityResult");
showToastAndPressBack();
return;
}
Display display = getWindowManager().getDefaultDisplay();
Point size = new Point();
display.getSize(size);
imgVWidth = size.x;
int height = size.y;
imgVHeight = (int) (((float) imgVWidth / photoBitmap.getWidth()) * photoBitmap.getHeight());
photoInImgViewBitmap = Bitmap.createScaledBitmap(photoBitmap, imgVWidth, imgVHeight, true);
imageAlreadyPicked = true;
}
Теперь моя проблема в том, что иногда я вижу NPE-s в Crashlytics, утверждающем, что photoBitmap имеет значение null, когда пользователь нажимает следующую кнопку.
@OnClick(R.id.toolbar_next)
void onToolbarNextClick() {
float originalScale = (float) (previewImageView.getHeight()) / (float) (photoBitmap.getHeight());
...
}
Единственный журнал Crashlytics, который я вижу, - это то, что пользователь уходит за цель (я разместил журнал Crashlytics внутри onPause
). Нет журнала для onActivityResult
, поэтому лучше всего предположить, что onActivityResult
не вызывается, поэтому мое растровое изображение не загружается, поэтому оно будет пустым, когда пользователь нажимает следующий.
Вопрос: почему onActivityResult
называется иногда, а иногда нет? Существуют ли другие возможные причины photoBitmap
, равные нулю?