在我的应用程序中,我有一个 SherlockFragmentActivity,它托管一个带有 4 个选项卡的操作栏。每个选项卡都是一个 SherlockFragment。使用 startActivityForResult(myIntent1, 0); 从其中一个选项卡(假设 Tab1)调用普通 Activity 可以正常工作;
但是 Tab1 中的 onActivityResult 从未被调用。 在阅读了大量主题后,我了解到我的主要 Activity 的 onActivityResult 首先被调用,确实如此。但我无法获取传递给 fragment 的 onActivityResult 的值。
这是我的代码...
主要 Activity :
public void onActivityResult(int requestCode, int resultCode, Intent data) {
Fragment mFragment = Fragment.instantiate(this, Tab1.class.getName());
mFragment.onActivityResult(requestCode, resultCode, data);
super.onActivityResult(requestCode, resultCode, data);
}
还尝试了第一行中的 super 调用和没有 super 调用的情况。
fragment :
public void onActivityResult(int requestCode, int resultCode, Intent data){
//super.onActivityResult(requestCode, resultCode, data);
Toast.makeText(context, String.valueOf(requestCode), Toast.LENGTH_SHORT).show();
if(requestCode == 0) {
if(resultCode == Activity.RESULT_OK) {
//do some stuff here
}
}
}
还尝试在开始和结束时使用 super 调用。
每次我都会遇到同样的错误:
09-09 14:33:34.230: E/AndroidRuntime(7408): FATAL EXCEPTION: main
09-09 14:33:34.230: E/AndroidRuntime(7408): java.lang.RuntimeException: Failure delivering result ResultInfo{who=null, request=65536, result=-1, data=null} to activity {com.BlubBlub.TimeMate/com.BlubBlub.TimeMate.TimeMateActivity}: java.lang.NullPointerException
09-09 14:33:34.230: E/AndroidRuntime(7408): at android.app.ActivityThread.deliverResults(ActivityThread.java:3267)
09-09 14:33:34.230: E/AndroidRuntime(7408): at android.app.ActivityThread.handleSendResult(ActivityThread.java:3310)
09-09 14:33:34.230: E/AndroidRuntime(7408): at android.app.ActivityThread.access$1100(ActivityThread.java:142)
09-09 14:33:34.230: E/AndroidRuntime(7408): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
09-09 14:33:34.230: E/AndroidRuntime(7408): at android.os.Handler.dispatchMessage(Handler.java:99)
09-09 14:33:34.230: E/AndroidRuntime(7408): at android.os.Looper.loop(Looper.java:137)
09-09 14:33:34.230: E/AndroidRuntime(7408): at android.app.ActivityThread.main(ActivityThread.java:4930)
09-09 14:33:34.230: E/AndroidRuntime(7408): at java.lang.reflect.Method.invokeNative(Native Method)
09-09 14:33:34.230: E/AndroidRuntime(7408): at java.lang.reflect.Method.invoke(Method.java:511)
09-09 14:33:34.230: E/AndroidRuntime(7408): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:791)
09-09 14:33:34.230: E/AndroidRuntime(7408): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:558)
09-09 14:33:34.230: E/AndroidRuntime(7408): at dalvik.system.NativeStart.main(Native Method)
09-09 14:33:34.230: E/AndroidRuntime(7408): Caused by: java.lang.NullPointerException
09-09 14:33:34.230: E/AndroidRuntime(7408): at android.widget.Toast.<init>(Toast.java:92)
09-09 14:33:34.230: E/AndroidRuntime(7408): at android.widget.Toast.makeText(Toast.java:238)
09-09 14:33:34.230: E/AndroidRuntime(7408): at com.BlubBlub.TimeMate.Tab1.onActivityResult(Tab1.java:125)
09-09 14:33:34.230: E/AndroidRuntime(7408): at com.BlubBlub.TimeMate.TimeMateActivity.onActivityResult(TimeMateActivity.java:150)
09-09 14:33:34.230: E/AndroidRuntime(7408): at android.app.Activity.dispatchActivityResult(Activity.java:5192)
09-09 14:33:34.230: E/AndroidRuntime(7408): at android.app.ActivityThread.deliverResults(ActivityThread.java:3263)
让它发挥作用的正确方法是什么?我现在真的很绝望...
最佳答案
您正在创建 Fragment 的新实例。该实例未附加到 Activity,因此 getActivity() 返回 null。它也不是当前在您的选项卡中显示的 fragment 。
从 Fragment 启动 Activity 时,必须使用 Fragment#startActivityForResult(Bundle, int) 。然后 FragmentActivity 将处理将其分派(dispatch)到适合您的 Fragment。您不必手动执行此操作。
使用 startActivityForResult 时,请确保在执行任何操作之前始终检查 resultCode 是否与您传递给 startActivityForResult 的 resultCode 匹配。
关于android - Sherlock ActionBar onActivityResult 未在 Fragment 中调用,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12339184/