java.lang.RuntimeException: Ошибка доставки результата ResultInfo {who = null, request = 1888, result = 0, data = null} в действие

Мое приложение позволяет пользователю нажимать кнопку, оно открывает камеру, они могут сделать снимок, и он появится в ImageView. Если пользователь нажимает назад или отменяет, пока камера открыта, я получаю это принудительное закрытие - Ошибка доставки результата 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);
        }  

Думаю, мне понадобится где-то еще, но я точно не знаю, как это делать.

ниже логарифм

    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
        

person dabious    schedule 04.12.2011    source источник
comment
В моем случае ошибка возникла из-за случайного включения опции «Не сохранять действия» в опции разработчика :)   -  person theapache64    schedule 09.02.2016


Ответы (11)


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

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);
        }
    }
}
person Jonathan García    schedule 27.04.2012
comment
вы можете также проверить, что data! = null (а также RESULT_CANCELED) - person Martin Marconcini; 30.03.2013
comment
+1 работает во фрагменте и активности, но безопаснее проверять if (data! = Null), это гарантирует странные вещи старых версий Android. - person MBH; 14.10.2015
comment
Этот ответ не имеет отношения к вопросу. Ошибка в вопросе говорит: data = null. Следовательно, доступ к данным без нулевой проверки не выполняется во время выполнения. Фактический ответ ниже @Manto. - person Shripad Bhat; 21.01.2018

Для пользователей Kotlin не забудьте добавить? в data: Intent? нравится

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

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

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);
       }
}  
person Manto    schedule 12.07.2012

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

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

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

override fun onActivityResult(requestCode: Int, resultCode: Int, data: Intent?)
person Nitin Karande    schedule 18.05.2018

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

  1. Верните отца Intent.

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

    setResult(RESULT_OK, intentParent);
    

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

person Alexis Mejia    schedule 21.11.2012

 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, это будет только в том случае, если фотография сделана и выбрана, и все сработало. Это предложение if здесь должно проверять все условия.

person ZeroTek    schedule 24.06.2013

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

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;

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

person User007    schedule 01.05.2015

У меня появилось это сообщение об ошибке, потому что я использовал сеть в основном потоке, а новые версии 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);
person CamHart    schedule 18.08.2016

Я также столкнулся с этим вопросом, я решил его, добавив два условия:

resultCode != null

другой:

resultCode != RESULT_CANCELED
person user2909668    schedule 23.10.2013
comment
как насчет resultCode! = RESULT_OK ....? Таким образом вы проверяете все условия, которые не подходят, включая null - person Chris; 19.08.2014
comment
resultCode! = null недействителен, так как resultCode имеет значение int! - person bashizip; 26.02.2016

Моя проблема заключалась в вызванном действии, когда он пытается вернуться к предыдущему действию путем «завершения». Я неправильно установил намерение. Следующий код - Kotlin.

Я делал это:

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

Когда я должен был это сделать:

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

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

person Shaon    schedule 23.10.2018