我在我的MainActivity類中有一個方法,我可以從不同的活動類訪問實例化所有其他活動的應用程序欄中的Tabs。actionBar.addTab拋出NullPointerException
然而,當我正在從一個類調用這個函數在MainActivity類的thwroing一個java.lang.NullPointerException
:
我的功能在MainActivity.Java
public void initiateMenuTabs(ActionBar actionBar) {
try {
actionBar.setDisplayShowTitleEnabled(false);
actionBar.setDisplayUseLogoEnabled(true);
actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
ActionBar.TabListener tabListener = new ActionBar.TabListener() {
@Override
public void onTabUnselected(Tab arg0, FragmentTransaction arg1) {
// TODO Auto-generated method stub
}
@Override
public void onTabSelected(Tab tab, FragmentTransaction arg1) {
int tabPosition = tab.getPosition();
switch (tabPosition) {
case 0:
setContentView(R.layout.event_feed);
break;
case 1: {
Intent startClassActivity = new Intent(MainActivity.this,
ClassWide.class);
startActivity(startClassActivity);
break;
}
case 2:
setContentView(R.layout.event_feed);
break;
}
}
@Override
public void onTabReselected(Tab arg0, FragmentTransaction arg1) {
// TODO Auto-generated method stub
}
};
actionBar.addTab(actionBar.newTab().setText("Event Feed")
.setIcon(R.drawable.ic_action_alarms)
.setTabListener(tabListener));
actionBar.addTab(actionBar.newTab().setText("Wide")
.setIcon(R.drawable.ic_action_Wide)
.setTabListener(tabListener));
actionBar.addTab(actionBar.newTab().setText("Report")
.setIcon(R.drawable.ic_action_location_found)
.setTabListener(tabListener));
} catch (Exception e) {
Log.getStackTraceString(e.getCause().getCause());
}
}
功能從ClassWide.Java
protected void onCreate(final Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.wide_view);
MainActivity cObj = new MainActivity();
cObj.initiateMenuTabs(getActionBar());
.... ....
調用
LogCat
窗口顯示:
09-29 15:21:09.217: E/AndroidRuntime(2549): FATAL EXCEPTION: main
09-29 15:21:09.217: E/AndroidRuntime(2549): java.lang.RuntimeException: Unable to start activity ComponentInfo{com.helloworld.projectone/com.helloworld.projectone.ClassWide}: java.lang.NullPointerException
09-29 15:21:09.217: E/AndroidRuntime(2549): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2211)
09-29 15:21:09.217: E/AndroidRuntime(2549): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2261)
09-29 15:21:09.217: E/AndroidRuntime(2549): at android.app.ActivityThread.access$600(ActivityThread.java:141)
09-29 15:21:09.217: E/AndroidRuntime(2549): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1256)
09-29 15:21:09.217: E/AndroidRuntime(2549): at android.os.Handler.dispatchMessage(Handler.java:99)
09-29 15:21:09.217: E/AndroidRuntime(2549): at android.os.Looper.loop(Looper.java:137)
09-29 15:21:09.217: E/AndroidRuntime(2549): at android.app.ActivityThread.main(ActivityThread.java:5103)
09-29 15:21:09.217: E/AndroidRuntime(2549): at java.lang.reflect.Method.invokeNative(Native Method)
09-29 15:21:09.217: E/AndroidRuntime(2549): at java.lang.reflect.Method.invoke(Method.java:525)
09-29 15:21:09.217: E/AndroidRuntime(2549): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:737)
09-29 15:21:09.217: E/AndroidRuntime(2549): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:553)
09-29 15:21:09.217: E/AndroidRuntime(2549): at dalvik.system.NativeStart.main(Native Method)
09-29 15:21:09.217: E/AndroidRuntime(2549): Caused by: java.lang.NullPointerException
09-29 15:21:09.217: E/AndroidRuntime(2549): at com.helloworld.projectone.MainActivity.initiateMenuTabs(MainActivity.java:79)
09-29 15:21:09.217: E/AndroidRuntime(2549): at com.helloworld.projectone.ClassWide.onCreate(ClassWide.java:21)
09-29 15:21:09.217: E/AndroidRuntime(2549): at android.app.Activity.performCreate(Activity.java:5133)
09-29 15:21:09.217: E/AndroidRuntime(2549): at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087)
09-29 15:21:09.217: E/AndroidRuntime(2549): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2175)
09-29 15:21:09.217: E/AndroidRuntime(2549): ... 11 more
有什麼異常報告任何其他活動?將其編輯到您的問題中。 – tbodt
我如何獲得例外報告?你的意思是logCat輸出? – Maven
補充,現在檢查plz。 – Maven