选项卡TabHost、TabWidget和FrameLayout

时间:2021-03-30 06:25:53

1、布局文件main.xml

必须使用系统的id来为各组件指定id属性,否则将出现异常

<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/tabhost"
android:layout_width="fill_parent"
android:layout_height="fill_parent">

<LinearLayout
android:orientation="vertical"
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"/>
<FrameLayout
android:id="@android:id/tabcontent"
android:layout_width="fill_parent"
android:layout_height="fill_parent"/>
</LinearLayout>
</TabHost>

2、编写各标签页中要显示内容对应的XML布局文件 tab1.xml

<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:id="@+id/LinearLayout01"
android:orientation="vertical"
android:layout_width="wrap_content" android:layout_height="wrap_content">
<TextView
android:text="简约但不简单"
android:layout_width="fill_parent"
android:layout_height="wrap_content" />
<TextView
android:text="绿水罗"
android:layout_width="fill_parent"
android:layout_height="wrap_content" />
</LinearLayout>
3、在Activity中,获取并初始化TabHost组件

<span style="white-space:pre"></span>TabHost tabHost;//声明TabHost组件的对象
tabHost = (TabHost)findViewById(R.id.tabhost);//获取TabHost对象
tabHost.setup();//初始化TabHost组件

4、为TabHost对象添加标签页

<span style="white-space:pre"></span>LayoutInflater inflater = LayoutInflater.from(this);//声明并实例化一个LayoutInflater对象
inflater.inflate(R.layout.tab1,tabHost.getTabContentView());
inflater.inflate(R.layout.tab2,tabHost.getTabContentView());
tabHost.addTab(tabHost.newTabSpec("tab01").setIndicator("未接来电").setContent(R.id.LinearLayout01));//添加第一个标签页
tabHost.addTab(tabHost.newTabSpec("tab01").setIndicator("已接来电").setContent(R.id.LinearLayout02));//添加第二个标签页

选项卡TabHost、TabWidget和FrameLayout

选项卡TabHost、TabWidget和FrameLayout