Android中两种实现底部Tab的方法

  1.        android:layout\_height\="match\_parent"     
    
  2.        android:layout\_weight\="1"   
    
  3.        \>    
    
  4.        <TextView   
    
  5.            android:id\="@+id/view1" 
    
  6.            android:layout\_width\="wrap\_content" 
    
  7.            android:layout\_height\="wrap\_content" 
    
  8.            android:text\="nihao" 
    
  9.            /> 
    
  10.        <TextView   
    
  11.            android:id\="@+id/view2" 
    
  12.            android:layout\_width\="wrap\_content" 
    
  13.            android:layout\_height\="wrap\_content" 
    
  14.            android:text\="nihenhao" 
    
  15.            /> 
    
  16.    </FrameLayout\>     
    
  17.    <TabWidget   
    
  18.        android:id\="@android:id/tabs"     
    
  19.        android:layout\_width\="fill\_parent"      
    
  20.        android:layout\_height\="wrap\_content"   
    
  21.        />     
    
  22.  </LinearLayout\>     
    
  23. </TabHost>

main.xml

  1. <?xml version\="1.0" encoding\="utf-8"?>
  2. <LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”

  3.  android:orientation\="vertical" 
    
  4.  android:layout\_width\="fill\_parent" 
    
  5.  android:layout\_height\="fill\_parent" 
    
  6.  \> 
    
  7. <TextView

  8.  android:layout\_width\="fill\_parent"   
    
  9.  android:layout\_height\="wrap\_content"   
    
  10.  android:text\="@string/hello" 
    
  11.  /> 
    
  12. </LinearLayout>

TestHostActivity.java

  1. package com.lingdududu.test;

  2. import android.app.TabActivity;

  3. import android.os.Bundle;

  4. import android.widget.TabHost;

  5. public class TestHostActivity extends TabActivity {

  6.  /\*\* Called when the activity is first created. \*/ 
    
  7.  @Override 
    
  8.  public void onCreate(Bundle savedInstanceState) {  
    
  9.      super.onCreate(savedInstanceState);  
    
  10.      setContentView(R.layout.tabs);  
    
  11.      TabHost tabhost =  getTabHost();    
    
  12.      tabhost.addTab(tabhost.newTabSpec("111").setIndicator("view1").setContent(R.id.view1));    
    
  13.      tabhost.addTab(tabhost.newTabSpec("222").setIndicator("view2").setContent(R.id.view2));    
    
  14.  }  
    
  15. }

效果:

第二种:

在LinerLayout布局里面嵌套FrameLayout和RelativeLayout布局,将TabWidget放置在RelativeLayout里面,之后设置RelativeLayout的android:layout_alignParentBottom=“true” 属性,这个属性的功能是将TabWidget置于父元素(也就是LinerLayout)的底部。这样就能将Tab置于底部了。

  1. <?xml version\="1.0" encoding\="utf-8"?>
  2. <LinearLayout

  3.  xmlns:android\="http://schemas.android.com/apk/res/android" 
    
  4.  android:orientation\="vertical" 
    
  5.  android:layout\_width\="fill\_parent" 
    
  6.  android:layout\_height\="fill\_parent"\> 
    
  7.  <TabHost 
    
  8.      android:id\="@+id/tabhost" 
    
  9.      android:layout\_width\="fill\_parent" 
    
  10.      android:layout\_height\="fill\_parent"\> 
    
  11.      <FrameLayout 
    
  12.          android:id\="@android:id/tabcontent" 
    
  13.          android:layout\_width\="fill\_parent" 
    
  14.          android:layout\_height\="fill\_parent" 
    
  15.          android:paddingBottom\="62px" 
    
  16.          \> 
    
  17.          <TextView 
    
  18.              android:id\="@+id/tab1" 
    
  19.              android:layout\_width\="fill\_parent" 
    
  20.              android:layout\_height\="fill\_parent" 
    
  21.              android:text\="这是TabOne" 
    
  22.              /> 
    
  23.          <TextView 
    
  24.              android:id\="@+id/tab2" 
    
  25.              android:layout\_width\="fill\_parent" 
    
  26.              android:layout\_height\="fill\_parent" 
    
  27.              android:text\="这是TabTwo"/> 
    
  28.      </FrameLayout\> 
    
  29.      <RelativeLayout 
    
  30.          android:layout\_width\="fill\_parent" 
    
  31.          android:layout\_height\="fill\_parent" 
    
  32.          \> 
    
  33.          <TabWidget 
    
  34.              android:id\="@android:id/tabs" 
    
  35.              android:layout\_alignParentBottom\="true" 
    
  36.              android:layout\_width\="fill\_parent" 
    
  37.              android:layout\_height\="65.0px"   
    
  38.              android:background\="@drawable/tab\_bg"             
    
  39.              /> 
    
  40.      </RelativeLayout\> 
    
  41.  </TabHost\> 
    
  42. </LinearLayout>

main.xml

  1. <?xml version\="1.0" encoding\="utf-8"?>
  2. <LinearLayout xmlns:android=“http://schemas.android.com/apk/res/android”

  3.  android:orientation\="vertical" 
    
  4.  android:layout\_width\="fill\_parent" 
    
  5.  android:layout\_height\="fill\_parent" 
    
  6.  \> 
    
  7. <TextView

  8.  android:layout\_width\="fill\_parent"   
    
  9.  android:layout\_height\="wrap\_content"   
    
  10.  android:text\="@string/hello" 
    

最后

自我介绍一下,小编13年上海交大毕业,曾经在小公司待过,也去过华为、OPPO等大厂,18年进入阿里一直到现在。

深知大多数初中级Android工程师,想要提升技能,往往是自己摸索成长或者是报班学习,着实压力不小。自己不成体系的自学效果低效又漫长,而且极易碰到天花板技术停滞不前!

因此收集整理了一份《2024年Android移动开发全套学习资料》,初衷也很简单,就是希望能够帮助到想自学提升又不知道该从何学起的朋友,同时减轻大家的负担。

img

img

img

img

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

片转存中…(img-344GbGOd-1715024760944)]

[外链图片转存中…(img-iePqaZJL-1715024760944)]

既有适合小白学习的零基础资料,也有适合3年以上经验的小伙伴深入学习提升的进阶课程,基本涵盖了95%以上Android开发知识点,真正体系化!

由于文件比较大,这里只是将部分目录截图出来,每个节点里面都包含大厂面经、学习笔记、源码讲义、实战项目、讲解视频,并且会持续更新!

如果你觉得这些内容对你有帮助,需要这份全套学习资料的朋友可以戳我获取!!

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值