2011-12-04 24 views
33

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?java.lang.RuntimeException: error en la entrega del resultado ResultInfo {who = null, request = 1888, result = 0, data = null} en la actividad

A continuación se muestra 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 es 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 
+1

En mi caso, se produjo el error debido al giro accidental de la opción 'No mantener actividades' en la opción de desarrollador :) – theapache64

Respuesta

38

La adición de 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); 
     } 
    } 
} 
+3

Esto resolvió el mismo problema para mí. Cheers – Max

+2

es posible que también desee comprobar que los datos! = Null (así como el RESULT_CANCELED) –

+1

+1 funciona en fragmento y actividad, aún más seguro para verificar ** if (data! = Null) **, garantiza las cosas raras de versiones antiguas de Android. – MBH

9

Si el usuario cancela la solicitud, se devolverán los datos como NULL. El hilo lanzará un nullPointerException cuando llame al 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); 
     } 
} 
6

que recomiendan el uso de este:

  1. recuperar el padre Intent.

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

    setResult(RESULT_OK, intentParent); 
    

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

3
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 el resultCode es igual a RESULT_OK, esto solo será el caso si se toma y selecciona una imagen y todo funciona. Esta cláusula if aquí debería verificar cada condición.

0

También me encontré con esta pregunta, he resuelto a través de la adición de dos condiciones se encuentra:

resultCode != null 

el otro es:

resultCode != RESULT_CANCELED 
+0

¿qué tal resultCode! = RESULT_OK ....? De esta forma, comprueba todas las condiciones que no están bien, incluido el nulo – Chris

+2

¡resultCode! = Null no es válido porque resultCode es int! – kylexy1357

0

este es mi caso

startActivityForResult(intent, PICK_IMAGE_REQUEST);

Definí 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 podría también hace que el problema

1

tuve este mensaje de error aparece para mí porque yo 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: "acabado"

AsyncTask<CognitoCachingCredentialsProvider, Integer, Void> task = new AsyncTask<CognitoCachingCredentialsProvider, Integer, Void>() { 

     @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); 
0

Mi problema estaba en la llamada actividad cuando se trata de volver a la actividad anterior Estaba configurando incorrectamente la intención. El siguiente código es Kotlin.

yo 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() 
Cuestiones relacionadas