Android 简单的选项卡

简单选项卡

选项卡其实就是多标签页,选择一个标签就能查看对应的页面

主xml

主要是确定TabHost、TabWidget、TabContent。前两者都有具体的标签,而TabContent我们使用FrameLayout来实现:


<TabHost
    android:id="@android:id/tabhost"
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context=".MainActivity">

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical">

        <TabWidget
            android:id="@android:id/tabs"
            android:layout_width="match_parent"
            android:layout_height="wrap_content" />
        <FrameLayout
            android:id="@android:id/tabcontent"
            android:layout_width="match_parent"
            android:layout_height="match_parent">
        FrameLayout>
    LinearLayout>


TabHost>
子xml

子xml这里只写两个,分别表示两个标签页:


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/left"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <TextView
        android:text="Hello"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>

LinearLayout>

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:id="@+id/right"
    android:layout_width="match_parent"
    android:layout_height="match_parent">

    <TextView
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:text="Nihao"/>

LinearLayout>

两个xml其实差不多。

MainActivity
public class MainActivity extends AppCompatActivity {
     

    @Override
    protected void onCreate(Bundle savedInstanceState) {
     
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);

        TabHost tabHost = findViewById(android.R.id.tabhost);
        tabHost.setup();

        LayoutInflater inflater = LayoutInflater.from(this);
        inflater.inflate(R.layout.tab1, tabHost.getTabContentView());
        inflater.inflate(R.layout.tab2, tabHost.getTabContentView());

        tabHost.addTab(tabHost.newTabSpec("Tab1").setIndicator("Hello").setContent(R.id.left));
        tabHost.addTab(tabHost.newTabSpec("Tab1").setIndicator("nihao").setContent(R.id.right));
    }
}

首先获取TabHost对象,然后对其进行初始化。

要为TabHost添加标签页,首先需要声明一个LayoutInflater对象,然后加载两个页面,之后把两个标签页添加到tabHost中即可。

效果

Android 简单的选项卡_第1张图片

Android 简单的选项卡_第2张图片

点击上面的标签即可切换两个页面。

你可能感兴趣的:(Android,android,java)