在调用startActivityForResult()后,后续代码仍然运行

时间:2016-07-13 05:36:36

标签: java android android-intent activity-lifecycle

所以基本上我希望应用程序:按下按钮后打开图库,用户选择一个图像,然后将uri保存在变量中。这就是它需要做的全部,但我发现在调用startActivityForResult()后,后续代码仍在后台运行,产生NullPointerException错误,因为我想要的变量尚未从intent中检索。

public class MainActivity extends AppCompatActivity {

    final static int PICK_IMAGE_REQUEST = 1;

    private String imageUriStr;

    SharedPreferences prefs;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        prefs = this.getSharedPreferences("MyPreferences",MODE_PRIVATE);

        ImageView addImgButton = (ImageView) findViewById(R.id.add_img_button);

        addImgButton.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View v) {

                Intent intent = new Intent();
                intent.setType("image/*");
                intent.setAction(Intent.ACTION_GET_CONTENT);
                startActivityForResult(Intent.createChooser(intent, "Select Picture"), PICK_IMAGE_REQUEST);

                if (prefs.contains(imageUriStr)) {
                    imageUriStr = prefs.getString("imageUriStr", ""); //Get the data from prefs
                }

                Log.d("Value",imageUriStr); //verify if it is correct

                prefs.edit().clear();
            }
        });
    }

    @Override
    protected void onActivityResult(int requestCode, int resultCode, Intent data) {
        super.onActivityResult(requestCode, resultCode, data);

        if (requestCode == PICK_IMAGE_REQUEST && resultCode == RESULT_OK && data != null && data.getData() != null) {

            imageUriStr = data.getData().toString(); //convert to string to use it with SharedPreferences

            prefs.edit().putString("imageUriStr",imageUriStr).apply();

        }

    }
}

一个解决方案是在onActivityresult中做所有事情,但我也希望以后用户另一个基于该uri裁剪图像的意图,但我认为onActivityresult中的Intent会太乱或者是否可以接受?我想我错过了一些东西。

保持我的代码将生成此

E/AndroidRuntime: FATAL EXCEPTION: main
Process: com.example.android.prototypeapp, PID: 17826
java.lang.NullPointerException: println needs a message
    at android.util.Log.println_native(Native Method)
    at android.util.Log.d(Log.java:154)
    at com.example.android.prototypeapp.MainActivity$1$override.onClick(MainActivity.java:41)
    at com.example.android.prototypeapp.MainActivity$1$override.access$dispatch(MainActivity.java)
    at com.example.android.prototypeapp.MainActivity$1.onClick(MainActivity.java:0)
    at android.view.View.performClick(View.java:5264)
    at android.view.View$PerformClick.run(View.java:21297)
    at android.os.Handler.handleCallback(Handler.java:743)
    at android.os.Handler.dispatchMessage(Handler.java:95)
    at android.os.Looper.loop(Looper.java:150)
    at android.app.ActivityThread.main(ActivityThread.java:5546)
    at java.lang.reflect.Method.invoke(Native Method)
    at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:794)
    at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:684)

2 个答案:

答案 0 :(得分:0)

您的private String imageUriStr;为null。因为它为null,您将获得空指针异常。使用空字符串分配它,例如:private String imageUriStr = "";

签入共享首选项,例如: if(prefs.contains("imageUriStr"))

答案 1 :(得分:0)

您的代码在此行崩溃:

 Log.d("Value",imageUriStr); 

原因:imageUriStr值为null,打印日志需要有效消息

您可以使用Log as:

 Log.d("Value","Image URI Value: "+imageUriStr); 

或者您可以将您的日志放入内部,如下所示:

      if (prefs.contains(imageUriStr)) {
                        imageUriStr = prefs.getString("imageUriStr", "");//Get the data from prefs
          Log.d("Value",imageUriStr); //verify if it is correct
                                       }