所以我只是学习编写Android应用程序,没有什么特别的,但主要是四处寻找,看看它们是如何工作的。我试图在操作栏中根据我发现的教程做一些标签,但是在应用程序启动之前我得到了一个空指针异常。
以下是代码:
@Override
protected void onCreate(Bundle savedInstanceState)
{
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
viewPager = (ViewPager) findViewById(R.id.pager);
actionBar = getActionBar();
mAdapter = new TabsPagerAdapter(getSupportFragmentManager());
viewPager.setAdapter(mAdapter);
actionBar.setHomeButtonEnabled(false);
actionBar.setNavigationMode(ActionBar.NAVIGATION_MODE_TABS);
for(String tab_names : tabs)
{
actionBar.addTab(actionBar.newTab().setText(tab_names).setTabListener(this));
}
viewPager.setOnPageChangeListener(new ViewPager.OnPageChangeListener()
{
@Override
public void onPageSelected(int position)
{
actionBar.setSelectedNavigationItem(position);
}
@Override
public void onPageScrolled(int arg0,float arg1,int arg2)
{
}
@Override
public void onPageScrollStateChanged(int arg0)
{
}
});
}
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,Bundle savedInstanceState)
{
View rootView = inflater.inflate(R.layout.web_fragment, container, false);
return rootView;
}
onCreateView还有另外两个具有不同布局的类,但完全相同。这是xml,第一个是片段的主要和下一个:
<android.support.v4.view.ViewPager xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:id="@+id/pager"
android:layout_width="match_parent"
android:layout_height="match_parent"/>
<RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:orientation="vertical"
android:background="#ff8400">
<TextView
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:gravity="center"
android:text="@string/hello_world"
android:textSize="20sp"
android:layout_centerInParent="true"/>
我似乎无法弄清楚导致抛出异常的原因。我似乎也无法将logcat导出到日志文件中,因此我也会尝试在此处进行操作。
logcat的
02-28 01:36:42.431: I/Process(1629): Sending signal. PID: 1629 SIG: 9
02-28 01:37:27.401: D/AndroidRuntime(1668): Shutting down VM
02-28 01:37:27.401: W/dalvikvm(1668): threadid=1: thread exiting with uncaught exception (group=0xb4a1fb90)
02-28 01:37:27.471: E/AndroidRuntime(1668): FATAL EXCEPTION: main
02-28 01:37:27.471: E/AndroidRuntime(1668): Process: com.example.tolerablenausea, PID: 1668
02-28 01:37:27.471: E/AndroidRuntime(1668): java.lang.RuntimeException: Unable to instantiate activity ComponentInfo{com.example.tolerablenausea/com.example.tolerablenausea.MainActivity}: java.lang.NullPointerException
02-28 01:37:27.471: E/AndroidRuntime(1668): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2102)
02-28 01:37:27.471: E/AndroidRuntime(1668): at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2226)
02-28 01:37:27.471: E/AndroidRuntime(1668): at android.app.ActivityThread.access$700(ActivityThread.java:135)
02-28 01:37:27.471: E/AndroidRuntime(1668): at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1397)
02-28 01:37:27.471: E/AndroidRuntime(1668): at android.os.Handler.dispatchMessage(Handler.java:102)
02-28 01:37:27.471: E/AndroidRuntime(1668): at android.os.Looper.loop(Looper.java:137)
02-28 01:37:27.471: E/AndroidRuntime(1668): at android.app.ActivityThread.main(ActivityThread.java:4998)
02-28 01:37:27.471: E/AndroidRuntime(1668): at java.lang.reflect.Method.invokeNative(Native Method)
02-28 01:37:27.471: E/AndroidRuntime(1668): at java.lang.reflect.Method.invoke(Method.java:515)
02-28 01:37:27.471: E/AndroidRuntime(1668): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:777)
02-28 01:37:27.471: E/AndroidRuntime(1668): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:593)
02-28 01:37:27.471: E/AndroidRuntime(1668): at dalvik.system.NativeStart.main(Native Method)
02-28 01:37:27.471: E/AndroidRuntime(1668): Caused by: java.lang.NullPointerException
02-28 01:37:27.471: E/AndroidRuntime(1668): at android.content.ContextWrapper.getResources(ContextWrapper.java:89)
02-28 01:37:27.471: E/AndroidRuntime(1668): at android.view.ContextThemeWrapper.getResources(ContextThemeWrapper.java:78)
02-28 01:37:27.471: E/AndroidRuntime(1668): at android.content.Context.getString(Context.java:343)
02-28 01:37:27.471: E/AndroidRuntime(1668): at com.example.tolerablenausea.MainActivity.<init>(MainActivity.java:29)
02-28 01:37:27.471: E/AndroidRuntime(1668): at java.lang.Class.newInstanceImpl(Native Method)
02-28 01:37:27.471: E/AndroidRuntime(1668): at java.lang.Class.newInstance(Class.java:1208)
02-28 01:37:27.471: E/AndroidRuntime(1668): at android.app.Instrumentation.newActivity(Instrumentation.java:1061)
02-28 01:37:27.471: E/AndroidRuntime(1668): at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2093)
02-28 01:37:27.471: E/AndroidRuntime(1668): ... 11 more
答案 0 :(得分:1)
如果使用了每个循环,则无法看到正在初始化的“标签”。如果它为null并且其中没有“String”。
检查:
如果你的android:minSdkVersion设置为8(API-8),它不提供getActionBar()(仅限API-11)。
如果抑制了lint警告,则不会出现编译时错误。
尝试http://actionbarsherlock.com/ - 向后兼容性有帮助。
如果你想检查, 看看是否有效:
if (android.os.Build.VERSION.SDK_INT >= 11)
getActionBar().setDisplayHomeAsUpEnabled(true);
答案 1 :(得分:0)
我认为getActionbar()方法返回null值,您可以按照下面提供的链接。
NullPointException with getActionBar,
它可能对你有所帮助。 如果它对您有帮助,请标记为答案。