TabHost组件的功能用法

TabHost是一个提供选项卡的窗口视图容器,它包含两个两个对象:一组是用户可以选择指定Tab页的标签,另一个是FrameLayout用来显示Tab页的内容。

这里写图片描述

1. 布局文件介绍

<?xml version="1.0" encoding="utf-8"?>
<!--
    选项卡默认是显示在手机屏幕的上方,
    如果想要显示在下方,可以通过
    android:layout_alignParentBottom="true"属性
    设置位置
-->
<TabHost xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:id="@android:id/tabhost">
    <RelativeLayout 
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:padding="5dp">
        <TabWidget 
            android:id="@android:id/tabs"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_alignParentBottom="true"
            android:background="#cccccc">
        </TabWidget>
        <FrameLayout 
            android:id="@android:id/tabcontent"
            android:layout_width="match_parent"
            android:layout_height="match_parent"
            android:padding="5dp"
            android:layout_above="@android:id/tabs"
            ></FrameLayout>
    </RelativeLayout >
</TabHost>

界面的布局的根节点是TabHost, 在TabHost节点下必须包含一个TabWidget和FrameLayout节点,其中TabWidget节点用来显示供用户切换的Tab视图,它的id系统默认为@android:id/tabs,而FrameLayout用于显示Tab的内容,所以它的id系统默认是@android:id/tabcontent

2. 使用TabHost

使用TabHost有两种方式

  • 继承在TabActivity
  • 不继承自TabActivity
    这里使用第一种方式:
public class MainActivity extends TabActivity

3. 加载布局文件

和加载普通的布局文件一样,采用

setContentView(R.layout.tab)

的方式来加载之前定义的文件。

4. 设置选项卡

既然是使用TabHost,当然首先要获取到TabHost对象:

TabHost tabHost = getTabHost();

在获取到对象之后,就需要向选项卡中添加内容了。通过

tabHost.addTab(TabHost.TabSpec)

方法来添加一个选项卡,而参数TabHost.TabSpec就表示一个单独的选项卡,那么如何获取到这个选项卡呢?

tabHost.newTabSpec();

通过这个方法就可以获取到,然后就可以设置选项卡的内容了

tabHost.newTabSpec().setIndicator("标题名","选项卡显示的图片")

如果不想要要显示图片,只设置标题就可以了。那么如何来显示内容呢?
这里就需要setContent(intent)方法了,点击栏目时需要相应的intent来响应。比如,点击了消息栏目,就会在内容区域显示消息栏目所对应的内容。

tabHost.addTab(tabHost.newTabSpec("消息").setIndicator("消息",this.getResources().getDrawable(R.drawable.message)).setContent(new Intent(this, MessageActivity.class)));

5. 真的达到效果了么

如果发现图片没有显示出来,可以尝试如下的方法。
定义一个布局文件:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:orientation="vertical">

   <ImageView 
       android:id="@+id/tab_icon"
       android:layout_width="match_parent"
       android:layout_height="32.0dp"
       android:scaleType="fitCenter"
       android:paddingTop="10dp"/>
   <TextView 
       android:id="@+id/tab_title"
       android:textSize="11.0sp"
       android:gravity="center"
       android:layout_width="match_parent"
       android:layout_height="wrap_content"
      />
</LinearLayout>

然后在程序中加载这个文件

View tabInflater = LayoutInflater.from(this).inflate(R.layout.activity_main, getTabWidget(), false);
ImageView icon = (ImageView)tabInflater.findViewById(R.id.tab_icon);
TextView title = (TextView)tabInflater.findViewById(R.id.tab_title);
title.setText(label);       
icon.setImageResource(drawableId);

6. 其实….

其实官方已经不推荐这种方式了(TabActivity)
这里写图片描述
推荐使用 Fragment 建立 Tab 取代 TabActivity

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
TabHostAndroid 应用程序中常用的选项卡控件,用于在多个选项卡之间切换。以下是 Android Studio 中使用 TabHost 控件的步骤: 1. 在布局文件中添加 TabHost 控件 ``` <TabHost android:id="@+id/tab_host" android:layout_width="match_parent" android:layout_height="match_parent"> <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"> <!-- 添加选项卡内容布局 --> <LinearLayout android:id="@+id/tab1_layout" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Tab 1" /> </LinearLayout> <LinearLayout android:id="@+id/tab2_layout" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <TextView android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="Tab 2" /> </LinearLayout> </FrameLayout> </LinearLayout> </TabHost> ``` 2. 在 Java 代码中获取 TabHost 控件并设置选项卡 ```java TabHost tabHost = findViewById(R.id.tab_host); tabHost.setup(); // 添加选项卡 TabHost.TabSpec tab1 = tabHost.newTabSpec("Tab1"); tab1.setIndicator("Tab 1"); tab1.setContent(R.id.tab1_layout); tabHost.addTab(tab1); TabHost.TabSpec tab2 = tabHost.newTabSpec("Tab2"); tab2.setIndicator("Tab 2"); tab2.setContent(R.id.tab2_layout); tabHost.addTab(tab2); ``` 在以上代码中,我们首先获取 TabHost 控件,并通过 `setup()` 方法初始化。然后,我们使用 `newTabSpec()` 方法创建选项卡,并设置选项卡的标签和内容布局。最后,我们使用 `addTab()` 方法将选项卡添加到 TabHost 控件中。 以上就是使用 TabHost 控件的基本步骤。你可以根据自己的需要自定义选项卡的样式和内容。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值