java.lang.RuntimeException: ошибка доставки результата ResultInfo {who = null, request = 1888, result = 0, data = null} в действие - PullRequest
49 голосов
/ 04 декабря 2011

Мое приложение позволяет пользователю нажимать кнопку, оно открывает камеру, они могут сделать снимок, и оно будет отображаться в режиме просмотра изображений. Если пользователь нажимает назад или отменяет, когда камера открыта, я получаю эту силу близко - ошибка доставки результата ResultInfo {who = null, request = 1888, result = 0, data = null} в действие ... поэтому я угадываю результат = 0 - это проблема, которую мне нужно вставить, чтобы заставить эту силу остановки закрываться?

Ниже мой код. Я знаю, что забыл что-то, но просто не могу понять это! (По общему признанию я занимаюсь разработкой Android около 2 недель). Спасибо за любую помощь!

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

Полагаю, мне нужно где-то там "другое", но я точно не знаю, как это сделать.

ниже 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

Ответы [ 12 ]

52 голосов
/ 28 апреля 2012

Добавление этого первого условия должно работать:

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);
        }
    }
}
14 голосов
/ 25 апреля 2018

Для Kotlin Пользователи не забыли добавить?в data: Intent? как

public override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?) {}
12 голосов
/ 12 июля 2012

Если пользователь отменит запрос, данные будут возвращены как NULL.Поток выдаст nullPointerException, когда вы позвоните data.getExtras().get("data");.Я думаю, вам просто нужно добавить условное выражение, чтобы проверить, являются ли возвращенные данные нулевыми.

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 голосов
/ 22 ноября 2012

Я рекомендую использовать это:

  1. Отыщите отца Intent.

    Intent intentParent = getIntent();
    
  2. Передача сообщения напрямую.

    setResult(RESULT_OK, intentParent);
    

Это предотвращает потерю активности, которая может привести к ошибке нулевых данных.

5 голосов
/ 18 мая 2018

Для пользователей Kotlin

Вам просто нужно добавить ? с намерением в onActivityResult, поскольку данные могут быть null, если пользователь отменяет транзакцию иливсе идет не такПоэтому нам нужно определить данные как nullable в onActivityResult

Просто замените onActivityResult подпись SampleActivity следующим:

override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?)
4 голосов
/ 24 июня 2013
 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);
        } 
}

Вы можете проверить, равен ли resultCode RESULT_OK, это будет иметь место, только если снимок сделан и выбран, и все работает. Это если условие здесь должно проверять каждое условие.

1 голос
/ 18 августа 2016

У меня появилось это сообщение об ошибке, потому что я использовал сеть в главном потоке, а в новых версиях Android существует «строгая» политика, предотвращающая это.Чтобы обойти это, просто бросьте любой вызов сетевого подключения в AsyncTask.

Пример:

    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 голос
/ 01 мая 2015

это мой случай

startActivityForResult(intent, PICK_IMAGE_REQUEST);

Я определил два кода запроса PICK_IMAGE_REQUEST и SCAN_BARCODE_REQUEST с одинаковым значением, например.

static final int BARCODE_SCAN_REQUEST = 1;

static final int PICK_IMAGE_REQUEST = 1;

это также может вызвать проблему

0 голосов
/ 23 октября 2018

Я столкнулся с этой проблемой, когда попытался передать объект сериализуемой модели.Внутри этой модели другая модель была переменной, но она не была сериализуемой.Вот почему я сталкиваюсь с этой проблемой.Убедитесь, что все модели внутри модели являются сериализуемыми.

0 голосов
/ 06 августа 2018
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);

Проверка Ключ ответа 2018

...