其实也很简单。只要学的进去明白了一点就可以明白很多。
安卓默认的TabHost样式是比较朴素的,可以对它进行样式美化。对布局进行美化的时候需要在布局文件中体现出来。TabHost标签应由一个TabWidget和一个FrameLayout组成。其中TabWidget定义了标签的属性,而frameLayout定义了标签的内容。
一、最普通tabHost
我们将
activity_main.xml修改为:
<?xml version="1.0"encoding="utf-8"?>
<TabHostxmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/tabhost"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<TabWidgetandroid:id="@android:id/tabs"
android:layout_width="fill_parent"
android:layout_height="wrap_content">
</TabWidget>
<FrameLayoutandroid:id="@android:id/tabcontent"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
</FrameLayout>
</TabHost>
注意点:1.各个标签的id基本是必须要交这个名字的;
MainActivity.java中代码如下:
public class MainActivity extends TabActivity {
TabHost tabHost;
@Override
public voidonCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//获取TabHost对象
tabHost = getTabHost();
//新建一个newTabSpec,设置标签和图标(setIndicator),设置内容(setContent)
tabHost.addTab(tabHost.newTabSpec("Main_page")
.setIndicator("",getResources()
.getDrawable(android.R.drawable.ic_menu_call))
.setContent(new Intent(this,Main.class)));
tabHost.addTab(tabHost.newTabSpec("Search")
.setIndicator("",getResources()
.getDrawable(android.R.drawable.ic_menu_camera))
.setContent(new Intent(this,Main.class)));
......
//设置当前现实哪一个标签
tabHost.setCurrentTab(0); //0为标签ID
}
}
注意点:1.TabHost定义需要全局,方便在其他acitivity中调用;
2.tabHost = getTabHost()方法可以获取一个tabhost对象;
3.tabHost.addTab添加一个标签,注意后面的一堆set和get...然后其中的Main.class是自己新建的一个acitivity,这样四个标签页可以跳转到四个acitivity(在这个demo中是跳转到同一个activity)。
2.下至在底部
下置在底下版(如大家普遍使用的app,微信、微博等)
将TabHost下置在屏幕下方只需要在xml布局文件中添加一句话:
android:layout_alignParentBottom="true"
这是TabWidget的属性。
但是为了使这个alignParentBottom生效,必须将整个tabs封装在一个RelativeLayout中。
所以xml文件变为:
<?xml version="1.0" encoding="utf-8"?>
<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@android:id/tabhost"
android:orientation="vertical"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<RelativeLayout
android:layout_width="fill_parent"
android:layout_height="fill_parent">
<TabWidget android:id="@android:id/tabs"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:layout_alignParentBottom="true">
</TabWidget>
<FrameLayout android:id="@android:id/tabcontent"
android:layout_width="fill_parent"
android:layout_height="fill_parent">
</FrameLayout>
</RelativeLayout>
</TabHost>
.java文件是不变的。