ti-enxame.com

java.lang.RuntimeException: Falha ao entregar resultado ResultInfo {who = null, request = 1888, result = 0, data = null} à atividade

Meu aplicativo permite que o usuário pressione um botão, ele abre a câmera, eles podem tirar uma foto e ela será exibida em uma visualização de imagem. Se o usuário pressiona de volta ou cancela enquanto a câmera está aberta, eu fecho essa força - Falha na entrega do resultado ResultInfo {who = null, request = 1888, result = 0, data = null} na atividade ... então eu estou supondo que o resultado = 0 é o problema que eu precisaria inserir para fazer isso parar de forçar o fechamento?

Abaixo está o meu código. Eu sei que estou esquecendo alguma coisa, mas apenas não consigo descobrir! (Admito que eu sou cerca de 2 semanas para aprender desenvolvimento Android). Obrigado por qualquer ajuda! 

    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);
    }  

Eu acho que eu precisaria de um "else" em algum lugar, mas eu não sei exatamente fazer isso.

abaixo está o 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
43
dabious

Adicionar este primeiro condicional deve 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);
        }
    }
}
49
Jonathan García

Para Kotlin Usuários não se esqueça de adicionar? em data: Intent? como 

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

Se o usuário cancelar a solicitação, os dados serão retornados como NULL. O encadeamento lançará um nullPointerException quando você chamar data.getExtras().get("data");. Eu acho que você só precisa adicionar um condicional para verificar se os dados retornados são 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);
       }
}  
10
Manto

Eu recomendo usar isso:

  1. Recupere o pai Intent.

    Intent intentParent = getIntent();
    
  2. Transmitir a mensagem diretamente.

    setResult(RESULT_OK, intentParent);
    

Isso evita a perda de sua atividade, o que geraria um erro de dados nulo.

6
Alexis Mejia

Para usuários de Kotlin  

Você só precisa adicionar? com Intent em onActivityResult como os dados podem ser null se o usuário cancelar a transação ou algo der errado. Então, precisamos definir dados como nullable em onActivityResult

Apenas substitua a assinatura onActivityResult de SampleActivity com o seguinte:

override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?)
5
Nitin Karande
 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);
        } 
}

Você pode verificar se o resultCode é igual a RESULT_OK este será apenas o caso se uma foto for tirada e selecionada e tudo funcionou. Esta cláusula if aqui deve verificar todas as condições.

4
ZeroTek

este é o meu caso

startActivityForResult(intent, PICK_IMAGE_REQUEST);

Eu defini dois códigos de solicitação PICK_IMAGE_REQUESTand SCAN_BARCODE_REQUEST com o mesmo valor, por exemplo. 

static final int BARCODE_SCAN_REQUEST = 1;

static final int PICK_IMAGE_REQUEST = 1;

isso também pode causar o problema

1
User007

Eu tive essa mensagem de erro aparecer para mim porque eu estava usando a rede no segmento principal e novas versões do Android têm uma política "estrita" para evitar isso. Para contornar isso, basta lançar qualquer chamada de conexão de rede em um AsyncTask.

Exemplo:

    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);
1
CamHart

Eu também encontrei esta questão, eu resolvi através da adição de duas condições, uma é:

resultCode != null

o outro é:

resultCode != RESULT_CANCELED
0
user2909668

Meu problema estava na atividade chamada quando ela tenta retornar à atividade anterior "terminando". Eu estava definindo incorretamente a intenção. O código a seguir é Kotlin.

Eu estava fazendo isso:

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

Quando eu deveria estar fazendo isso:

        val result = Intent()
        result.putExtra("foo", "bar")
        setResult(Activity.RESULT_OK, result)
        finish()
0
Mike Miller

Enfrentei esse problema quando tentei passar um objeto de modelo serializável. Dentro desse modelo, outro modelo era uma variável, mas não serializável. É por isso que enfrento esse problema. Certifique-se de que todo o modelo dentro de um modelo seja serializável.

0
Shaon