java.lang.RuntimeException: error en la entrega del resultado ResultInfo {who = null, request = 1888, result = 0, data = null} en la actividad

Mi aplicación permite al usuario presionar un botón, abre la cámara, puede tomar una foto y se mostrará en una vista de imagen. Si el usuario presiona hacia atrás o cancela mientras la cámara está abierta obtengo esta fuerza cerca – Error al entregar el resultado ResultInfo {who = null, request = 1888, result = 0, data = null} en la actividad … entonces estoy adivinando el resultado = 0 es el problema, ¿qué tendría que insertar para hacer que este cierre de fuerza de detención?

A continuación está mi código. Sé que estoy olvidando algo, ¡pero no puedo entenderlo! (Es cierto que tengo aproximadamente 2 semanas para aprender sobre el desarrollo de Android). ¡Gracias por cualquier ayuda!

private static final int CAMERA_REQUEST = 1888; private ImageView imageView; @Override public void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.main); this.imageView = (ImageView)this.findViewById(R.id.photostrippic1); ImageView photoButton = (ImageView) this.findViewById(R.id.photostrippic1); photoButton.setOnClickListener(new View.OnClickListener() { public void onClick(View v) { Intent cameraIntent = new Intent(android.provider.MediaStore.ACTION_IMAGE_CAPTURE); startActivityForResult(cameraIntent, CAMERA_REQUEST); } }); protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (requestCode == CAMERA_REQUEST) { Bitmap photo = (Bitmap) data.getExtras().get("data"); imageView.setImageBitmap(photo); } 

Supongo que necesitaría un “else” en alguna parte, pero no sé exactamente cómo hacerlo.

a continuación está el logcat

  java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=1888, result=0, data=null} to activity {photo.booth.app/photo.booth.app.PhotoboothActivity}: java.lang.NullPointerException at android.app.ActivityThread.deliverResults(ActivityThread.java:2934) at android.app.ActivityThread.handleSendResult(ActivityThread.java:2986) at android.app.ActivityThread.access$2000(ActivityThread.java:132) at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1068) at android.os.Handler.dispatchMessage(Handler.java:99) at android.os.Looper.loop(Looper.java:150) at android.app.ActivityThread.main(ActivityThread.java:4293) at java.lang.reflect.Method.invokeNative(Native Method) at java.lang.reflect.Method.invoke(Method.java:507) at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:849) at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:607) at dalvik.system.NativeStart.main(Native Method) Caused by: java.lang.NullPointerException at photo.booth.app.PhotoboothActivity.onActivityResult(PhotoboothActivity.java:76) at android.app.Activity.dispatchActivityResult(Activity.java:4108) at android.app.ActivityThread.deliverResults(ActivityThread.java:2930) ... 11 more 

Agregar este primer condicional debería funcionar:

 protected void onActivityResult(int requestCode, int resultCode, Intent data) { if(resultCode != RESULT_CANCELED){ if (requestCode == CAMERA_REQUEST) { Bitmap photo = (Bitmap) data.getExtras().get("data"); imageView.setImageBitmap(photo); } } } 

Si el usuario cancela la solicitud, los datos se devolverán como NULL . El hilo arrojará una nullPointerException cuando llame a data.getExtras().get("data"); . Creo que solo necesita agregar un condicional para verificar si los datos devueltos son nulos.

 protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (requestCode == CAMERA_REQUEST) { if (data != null) { Bitmap photo = (Bitmap) data.getExtras().get("data"); imageView.setImageBitmap(photo); } } 

Recomiendo usar esto:

  1. Recuperar el Intent del padre.

     Intent intentParent = getIntent(); 
  2. Transmite el mensaje directamente.

     setResult(RESULT_OK, intentParent); 

Esto evita la pérdida de su actividad que generaría un error de datos nulo.

  protected void onActivityResult(int requestCode, int resultCode, Intent data) { if (requestCode == CAMERE_REQUEST && resultCode == RESULT_OK && data != null) { Bitmap photo = (Bitmap) data.getExtras().get("data"); imageView.setImageBitmap(photo); } } 

Puede verificar si resultCode es igual a RESULT_OK, solo será el caso si se toma y se selecciona una imagen y todo funciona. Esta cláusula if aquí debería verificar cada condición.

Para los usuarios de Kotlin, ¿no te olvides de agregar? en data: Intent? me gusta

 public override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {} 

Para los usuarios de Kotlin

Solo necesitas agregar ? con Intent en onActivityResult ya que los datos pueden ser null si el usuario cancela la transacción o si algo sale mal. Entonces, necesitamos definir los datos como nullable en onActivityResult

Simplemente reemplace la firma de SampleActivity de ActivityResult por la siguiente:

 override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) 

este es mi caso

startActivityForResult(intent, PICK_IMAGE_REQUEST);

PICK_IMAGE_REQUEST dos códigos de solicitud PICK_IMAGE_REQUEST y SCAN_BARCODE_REQUEST con el mismo valor, por ej.

static final int BARCODE_SCAN_REQUEST = 1;

static final int PICK_IMAGE_REQUEST = 1;

esto también podría causar el problema

Me apareció este mensaje de error porque estaba usando la red en el hilo principal y las nuevas versiones de Android tienen una política “estricta” para evitar eso. Para evitarlo, solo lanza cualquier llamada de conexión de red a una AsyncTask.

Ejemplo:

  AsyncTask task = new AsyncTask() { @Override protected Void doInBackground(CognitoCachingCredentialsProvider... params) { AWSSessionCredentials creds = credentialsProvider.getCredentials(); String id = credentialsProvider.getCachedIdentityId(); credentialsProvider.refresh(); Log.d("wooohoo", String.format("id=%s, token=%s", id, creds.getSessionToken())); return null; } }; task.execute(credentialsProvider); 

También encontré esta pregunta, la resolví agregando dos condiciones: una es:

 resultCode != null 

el otro es:

 resultCode != RESULT_CANCELED 

Mi problema estaba en la actividad llamada cuando intenta regresar a la actividad anterior al “finalizar”. Estaba configurando incorrectamente la intención. El siguiente código es Kotlin.

Estaba haciendo esto:

  intent.putExtra("foo", "bar") finish() 

Cuando debería haber estado haciendo esto:

  val result = Intent() result.putExtra("foo", "bar") setResult(Activity.RESULT_OK, result) finish() 
 AsyncTask task = new AsyncTask() { @Override protected Void doInBackground(CognitoCachingCredentialsProvider... params) { AWSSessionCredentials creds = credentialsProvider.getCredentials(); String id = credentialsProvider.getCachedIdentityId(); credentialsProvider.refresh(); Log.d("wooohoo", String.format("id=%s, token=%s", id, creds.getSessionToken())); return null; } }; task.execute(credentialsProvider); 

Verificar clave de respuesta 2018