IT이야기

java.lang.RuntimeException : Result ResultInfo {who = null, request = 1888, result = 0, data = null} 에러

cyworld 2021. 3. 24. 21:32
반응형

java.lang.RuntimeException : 결과 ResultInfo {who = null, request = 1888, result = 0, data = null}을 활동에 전달하지 못했습니다.


내 앱을 사용하면 사용자가 버튼을 누르면 카메라가 열리고 사진을 찍을 수 있으며 이미지보기에 표시됩니다. 카메라가 열려있는 동안 사용자가 뒤로 누르거나 취소하면이 힘이 닫힙니다. 결과를 전달하지 못했습니다. ResultInfo {who = null, request = 1888, result = 0, data = null} to activity ... 그래서 결과를 추측하고 있습니다. = 0이 정지 강제 종료를 위해 삽입해야하는 문제는 무엇입니까?

아래는 내 코드입니다. 나는 내가 무언가를 잊고 있다는 것을 알고 있지만 그것을 알아낼 수 없다! (당연히 저는 안드로이드 개발을 배우는 데 약 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);
    }  

어딘가에 "else"가 필요할 것 같지만 정확히 어떻게해야할지 모르겠습니다.

아래는 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

이 첫 번째 조건을 추가하면 작동합니다.

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

Kotlin 사용자의 경우 추가하는 것을 잊지 마세요. 에서 data: Intent?와 같은

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

사용자가 요청을 취소하면 데이터가 NULL. nullPointerException을 호출하면 스레드에서 a가 발생합니다 data.getExtras().get("data");. 반환 된 데이터가 null인지 확인하기 위해 조건부를 추가해야한다고 생각합니다.

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

이것을 사용하는 것이 좋습니다.

  1. 아버지를 검색하십시오 Intent.

    Intent intentParent = getIntent();
    
  2. 메시지를 직접 전달하십시오.

    setResult(RESULT_OK, intentParent);
    

이는 null 데이터 오류를 생성하는 활동의 손실을 방지합니다.


Kotlin 사용자 용

추가하면 됩니까? 의 의도와 onActivityResult데이터가 될 수 있기 때문에 null사용자가 트랜잭션을 취소 또는 아무것도 잘못되면. 따라서 데이터를 다음과 같이 정의해야합니다 nullable.onActivityResult

onActivityResultSampleActivity의 서명을 아래와 같이 바꾸 십시오.

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

 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 절은 모든 조건을 확인해야합니다.


이것은 내 경우이다

startActivityForResult(intent, PICK_IMAGE_REQUEST);

두 개의 요청 코드 PICK_IMAGE_REQUESTSCAN_BARCODE_REQUEST같은 값을 정의했습니다 .

static final int BARCODE_SCAN_REQUEST = 1;

static final int PICK_IMAGE_REQUEST = 1;

이것은 또한 문제를 일으킬 수 있습니다


메인 스레드에서 네트워크를 사용하고 있었고 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);

나는 또한이 질문에 직면했으며 두 가지 조건을 추가하여 해결했습니다.

resultCode != null

다른 하나는 :

resultCode != RESULT_CANCELED

내 문제는 "마침"을 통해 이전 활동으로 돌아 가려고 할 때 호출 된 활동에있었습니다. 의도를 잘못 설정했습니다. 다음 코드는 Kotlin입니다.

나는 이것을하고 있었다 :

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

내가 이것을해야 할 때 :

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

직렬화 가능한 모델 객체를 전달하려고 할 때이 문제에 직면했습니다. 그 모델 안에서 다른 모델은 변수 였지만 직렬화 할 수 없었습니다. 이것이 제가이 문제에 직면 한 이유입니다. 모델 내부의 모든 모델이 직렬화 가능한지 확인하십시오.


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 년 정답 확인

참조 URL : https://stackoverflow.com/questions/8373755/java-lang-runtimeexception-failure-delivering-result-resultinfowho-null-reque

반응형