我的编程空间,编程开发者的网络收藏夹
学习永远不晚

详解Android TabHost的多种实现方法 附源码下载

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

详解Android TabHost的多种实现方法 附源码下载

最近仔细研究了下TabHost,主要是为了实现微信底部导航栏的功能,最后也给出一个文章链接,大家不要着急

正文:

TabHost的实现分为两种,一个是不继承TabActivity,一个是继承自TabActivity;当然了选用继承自TabActivity的话就相对容易一些,下面来看看分别是怎样来实现的吧。

方法一、定义tabhost:不用继承TabActivity
 1、布局文件:activity_main.xml


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 xmlns:tools="http://schemas.android.com/tools" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" 
 android:orientation="vertical" 
 tools:context=".MainActivity" > 
 <Button 
 android:id="@+id/button1" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content" 
 android:text="Button" /> 
 <TabHost 
 android:id="@+id/tabhost" 
 android:layout_width="match_parent" 
 android:layout_height="wrap_content"> 
 <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" > 
  </TabWidget> 
  <FrameLayout 
  android:id="@android:id/tabcontent" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent" > 
  <!-- 第一个tab的布局 --> 
  <LinearLayout 
   android:id="@+id/tab1" 
   android:layout_width="match_parent" 
   android:layout_height="match_parent" > 
   <TextView 
   android:id="@+id/textView1" 
   android:layout_width="wrap_content" 
   android:layout_height="wrap_content" 
   android:text="林炳东" /> 
  </LinearLayout> 
  <!-- 第二个tab的布局 --> 
  <LinearLayout 
   android:id="@+id/tab2" 
   android:layout_width="match_parent" 
   android:layout_height="match_parent" > 
   <TextView 
   android:id="@+id/textView2" 
   android:layout_width="wrap_content" 
   android:layout_height="wrap_content" 
   android:text="张小媛" /> 
  </LinearLayout> 
  <!-- 第三个tab的布局 --> 
  <LinearLayout 
   android:id="@+id/tab3" 
   android:layout_width="match_parent" 
   android:layout_height="match_parent" > 
   <TextView 
   android:id="@+id/textView3" 
   android:layout_width="wrap_content" 
   android:layout_height="wrap_content" 
   android:text="马贝贝" /> 
  </LinearLayout> 
  </FrameLayout> 
 </LinearLayout> 
 </TabHost> 
</LinearLayout> 

2、JAVA代码


public class MainActivity extends Activity { 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
 super.onCreate(savedInstanceState); 
 setContentView(R.layout.activity_main); 
 TabHost th=(TabHost)findViewById(R.id.tabhost); 
 th.setup();  //初始化TabHost容器 
 //在TabHost创建标签,然后设置:标题/图标/标签页布局 
 th.addTab(th.newTabSpec("tab1").setIndicator("标签1",getResources().getDrawable(R.drawable.ic_launcher)).setContent(R.id.tab1)); 
 th.addTab(th.newTabSpec("tab2").setIndicator("标签2",null).setContent(R.id.tab2)); 
 th.addTab(th.newTabSpec("tab3").setIndicator("标签3",null).setContent(R.id.tab3)); 
 //上面的null可以为getResources().getDrawable(R.drawable.图片名)设置图标 
 } 
} 

效果图:

此例源码地址:Demo1

方法二、Tab的内容分开:不用继承TabActivity
1、第一个tab的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:layout_width="wrap_content" 
 android:layout_height="wrap_content"> 
 <TextView 
  android:text="我是标签1的内容喔" 
  android:id="@+id/TextView01" 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content"> 
 </TextView> 
 </LinearLayout> 

2、第二个tab的XML布局文件,tab2.xml:


<?xml version="1.0" encoding="UTF-8"?> 
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 android:id="@+id/LinearLayout02" 
 android:layout_width="wrap_content" 
 android:layout_height="wrap_content"> 
 <TextView android:text="标签2" 
   android:id="@+id/TextView01" 
   android:layout_width="wrap_content" 
   android:layout_height="wrap_content" /> 
</LinearLayout> 

3、主布局文件,activity_main.xml:


<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 android:layout_width="fill_parent" 
 android:layout_height="fill_parent" 
 android:orientation="vertical" > 
 <TabHost 
 android:id="@+id/tabhost"  
 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" > 
  </TabWidget> 
  <FrameLayout 
  android:id="@android:id/tabcontent" 
  android:layout_width="match_parent" 
  android:layout_height="match_parent" > 
  </FrameLayout> 
 </LinearLayout> 
 </TabHost> 
</LinearLayout> 

4、JAVA代码:


public class MainActivity extends Activity { 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
 super.onCreate(savedInstanceState); 
 setContentView(R.layout.activity_main); 
 TabHost m = (TabHost)findViewById(R.id.tabhost); 
 m.setup(); 
 LayoutInflater i=LayoutInflater.from(this); 
 i.inflate(R.layout.tab1, m.getTabContentView()); 
 i.inflate(R.layout.tab2, m.getTabContentView());//动态载入XML,而不需要Activity 
 m.addTab(m.newTabSpec("tab1").setIndicator("标签1").setContent(R.id.LinearLayout01)); 
  m.addTab(m.newTabSpec("tab2").setIndicator("标签2").setContent(R.id.LinearLayout02)); 
 } 
} 

效果图:


此例源码地址:Demo2

方法三、继承自TabActivity
1、主布局文件,activity_main.xml:


<?xml version="1.0" encoding="utf-8"?> 
<FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" 
 android:layout_width="fill_parent" 
 android:layout_height="fill_parent"> 
 <!-- 第一个布局 --> 
 <LinearLayout 
 android:id="@+id/view1" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" > 
 <TextView 
  android:id="@+id/textView1" 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content" 
  android:text="张小媛" /> 
 </LinearLayout> 
 <!-- 第二个布局 --> 
 <LinearLayout 
 android:id="@+id/view2" 
 android:layout_width="match_parent" 
 android:layout_height="match_parent" > 
 <TextView 
  android:id="@+id/textView2" 
  android:layout_width="wrap_content" 
  android:layout_height="wrap_content" 
  android:text="马贝贝" /> 
 </LinearLayout> 
 <!-- 第三个布局 --> 
 <TextView android:id="@+id/view3" 
 android:background="#00ff00" 
 android:layout_width="fill_parent" 
 android:layout_height="fill_parent" 
 android:text="Tab3"/> 
</FrameLayout> 

2、JAVA代码:
先将派生自Activity改为TabActivity,然后代码如下: 


public class MainActivity extends TabActivity { 
 @Override 
 protected void onCreate(Bundle savedInstanceState) { 
 super.onCreate(savedInstanceState); 
 setTitle("TabDemoActivity"); 
 TabHost tabHost = getTabHost(); 
 LayoutInflater.from(this).inflate(R.layout.activity_main, 
  tabHost.getTabContentView(), true); 
 tabHost.addTab(tabHost.newTabSpec("tab1").setIndicator("tab1", getResources().getDrawable(R.drawable.ic_launcher)) 
  .setContent(R.id.view1)); 
 tabHost.addTab(tabHost.newTabSpec("tab3").setIndicator("tab2") 
  .setContent(R.id.view2)); 
 tabHost.addTab(tabHost.newTabSpec("tab3").setIndicator("tab3") 
  .setContent(R.id.view3)); 
  //标签切换事件处理,setOnTabChangedListener 
 tabHost.setOnTabChangedListener(new OnTabChangeListener(){ 
  @Override 
  public void onTabChanged(String tabId) { 
  if (tabId.equals("tab1")) { //第一个标签 
  } 
  if (tabId.equals("tab2")) { //第二个标签 
  } 
  if (tabId.equals("tab3")) { //第三个标签 
  } 
  }  
 }); 
 } 
} 

效果图:

 

此例源码地址:Demo3

四、实现微信底部导航栏

效果:

 

参看:Android仿微信底部菜单栏功能显示未读消息数量

原文地址:http://blog.csdn.net/harvic880925/article/details/17120325

您可能感兴趣的文章:Android组件TabHost实现页面中多个选项卡切换效果android TabHost(选项卡)的使用方法android 选项卡(TabHost)如何放置在屏幕的底部Android组件必学之TabHost使用方法详解Android控件之TabHost用法实例分析Android 使用FragmentTabhost代替Tabhost详解Android应用中使用TabHost组件进行布局的基本方法Android编程实现设置TabHost当中字体的方法Android Tabhost使用方法详解Android TabHost组件使用方法详解Android TabHost选项卡标签图标始终不出现的解决方法


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

详解Android TabHost的多种实现方法 附源码下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

详解Android TabHost的多种实现方法 附源码下载

最近仔细研究了下TabHost,主要是为了实现微信底部导航栏的功能,最后也给出一个文章链接,大家不要着急 正文:TabHost的实现分为两种,一个是不继承TabActivity,一个是继承自TabActivity;当然了选用继承自TabAc
2022-06-06

Android TreeView效果实现方法(附demo源码下载)

本文实例讲述了Android TreeView效果实现方法。分享给大家供大家参考,具体如下: 应该说很多的操作系统上面都提供了TreeView空间,实现树形结构,这个树形结构的应用时很广泛的,而Google开发Android的时候出于And
2022-06-06

Android编程之ICS式下拉菜单PopupWindow实现方法详解(附源码下载)

本文实例讲述了Android编程之ICS式下拉菜单PopupWindow实现方法。分享给大家供大家参考,具体如下: 运行效果截图如下:右边这个就是下拉菜单啦,看见有的地方叫他 ICS式下拉菜单,哎哟,不错哦! 下面先讲一下实现原理: 这种菜
2022-06-06

Android实现下载zip压缩文件并解压的方法(附源码)

前言 其实在网上有很多介绍下载文件或者解压zip文件的文章,但是两者结合的不多,所以这篇文章在此记录一下下载zip文件并直接解压的方法,直接上代码,文末有源码下载。下载:import java.io.BufferedInputStream;
2022-06-06

Android重写TextView实现文字整齐排版的方法(附demo源码下载)

本文实例讲述了Android重写TextView实现文字整齐排版的方法。分享给大家供大家参考,具体如下: XRTextView类package rong.android.test; import org.json.JSONArray; im
2022-06-06

Android编程实现手绘及保存为图片的方法(附demo源码下载)

本文实例讲述了Android编程实现手绘及保存为图片的方法。分享给大家供大家参考,具体如下: 运行效果图预览:应 yzuo_08 要求做了此Demo,跟以前那个手写板Demo不同的是可以将画布的内容保存为图片。 附上关键代码: MainVi
2022-06-06

Android编程滑动效果之倒影效果实现方法(附demo源码下载)

本文实例讲述了Android编程滑动效果之倒影效果实现方法。分享给大家供大家参考,具体如下: 前面介绍了使用《Android编程实现3D滑动旋转效果的方法》,现在介绍图片倒影实现,先看效果图这里主要通过自定义Gallery和ImageAda
2022-06-06

Windows下获取Android 源码方法的详解

前言:略!获取源码的原因千千万~~~ 1.安装GIT工具。GIT是林纳斯·托瓦兹大神为了管理器Linux内核开发而创立的分布式版本控制软件。下载地址:http://code.google.com/p/msysgit/一路next将安装进行到
2022-06-06

Android仿英语流利说取词放大控件的实现方法(附demo源码下载)

本文实例讲述了Android仿英语流利说取词放大控件的实现方法。分享给大家供大家参考,具体如下: 1 取词放大控件 英语流利说是一款非常帮的口语学习app,在app的修炼页面长按屏幕,会弹出一个放大镜,当手指移到某个单词的附近,可以看到该英
2022-06-06

Android程序自动更新功能模块的实现方法【附完整demo源码下载】

本文实例讲述了Android程序自动更新功能模块的实现方法。分享给大家供大家参考,具体如下: 在程序启动的时候检测服务器上有没有对应版本更新,如果有更新,提示用户是否更新。 在程序启动的时候首先调用更新模块检测服务器上存放的版本号跟当前程序
2022-06-06

Android实现放大镜效果的方法实例(附源码)

前言 应该有很多用过英语应用的同学都看多一个放大镜的效果,就是选中一段文字后,会有一个放大镜,这个究竟怎么实现的呢,我们今天来分析分析。 源码分析public class ShaderView extends View {private f
2022-06-06

Android编程实现可滑动的开关效果(附demo源码下载)

本文实例讲述了Android编程实现可滑动的开关效果。分享给大家供大家参考,具体如下: 闲着没事,把之前写的一个Demo放上来分享下。就是一个开关,实现可滑动和动画效果。不是图片切换。 好了,先上图:完整实例代码点击此处本站下载。 直接把自
2022-06-06

Android编程实现WebView全屏播放的方法(附源码)

本文实例讲述了Android编程实现WebView全屏播放的方法。分享给大家供大家参考,具体如下: 最近因为项目要用webview加载html5的视频,开始不能全屏播,做了很久才做出来!那按我的理解说下怎么实现全屏吧。 首先写布局文件act
2022-06-06

Android AutoCompleteTextView连接数据库自动提示的方法(附demo源码下载)

本文实例讲述了Android AutoCompleteTextView连接数据库自动提示的方法。分享给大家供大家参考,具体如下: 这个简单例子也体现MVC的思想。AutoCompleteTextView 就是View,而SimpleCurs
2022-06-06

js实现下载(文件流式)方法详解与完整实例源码

这篇文章主要介绍了js实现下载(文件流式)的方法,需要的朋友可以参考下
2022-12-10

Android 实现监听的四种方法详解实例代码

直接上代码,大家可以参考下 (1)自身类作为事件监听器package cn.edu.gdmec.s07150745.work5; import android.support.v7.app.AppCompatActivity; import
2022-06-06

Android开发进阶自定义控件之滑动开关实现方法【附demo源码下载】

本文实例讲述了Android开发进阶自定义控件之滑动开关实现方法。分享给大家供大家参考,具体如下: 自定义开关控件Android自定义控件一般有三种方式 1、继承Android固有的控件,在Android原生控件的基础上,进行添加功能和逻辑
2022-06-06

Android实现多线程下载文件的方法

本文实例讲述了Android实现多线程下载文件的方法。分享给大家供大家参考。具体如下: 多线程下载大概思路就是通过Range 属性实现文件分段,然后用RandomAccessFile 来读写文件,最终合并为一个文件 首先看下效果图:创建工程
2022-06-06

Android实现基于滑动的SQLite数据分页加载技术(附demo源码下载)

本文实例讲述了Android实现基于滑动的SQLite数据分页加载技术。分享给大家供大家参考,具体如下: main.xml如下:2022-06-06

Android实现多线程下载图片的方法

很多时候我们需要在Android设备上下载远程服务器上的图片进行显示,今天整理出两种比较好的方法来实现远程图片的下载。 方法一、直接通过Android提供的Http类访问远程服务器,这里AndroidHttpClient是SDK 2.2中新
2022-06-06

编程热搜

  • Android:VolumeShaper
    VolumeShaper(支持版本改一下,minsdkversion:26,android8.0(api26)进一步学习对声音的编辑,可以让音频的声音有变化的播放 VolumeShaper.Configuration的三个参数 durati
    Android:VolumeShaper
  • Android崩溃异常捕获方法
    开发中最让人头疼的是应用突然爆炸,然后跳回到桌面。而且我们常常不知道这种状况会何时出现,在应用调试阶段还好,还可以通过调试工具的日志查看错误出现在哪里。但平时使用的时候给你闹崩溃,那你就欲哭无泪了。 那么今天主要讲一下如何去捕捉系统出现的U
    Android崩溃异常捕获方法
  • android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
    系统的设置–>电池–>使用情况中,统计的能耗的使用情况也是以power_profile.xml的value作为基础参数的1、我的手机中power_profile.xml的内容: HTC t328w代码如下:
    android开发教程之获取power_profile.xml文件的方法(android运行时能耗值)
  • Android SQLite数据库基本操作方法
    程序的最主要的功能在于对数据进行操作,通过对数据进行操作来实现某个功能。而数据库就是很重要的一个方面的,Android中内置了小巧轻便,功能却很强的一个数据库–SQLite数据库。那么就来看一下在Android程序中怎么去操作SQLite数
    Android SQLite数据库基本操作方法
  • ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
    工作的时候为了方便直接打开编辑文件,一些常用的软件或者文件我们会放在桌面,但是在ubuntu20.04下直接直接拖拽文件到桌面根本没有效果,在进入桌面后发现软件列表中的软件只能收藏到面板,无法复制到桌面使用,不知道为什么会这样,似乎并不是很
    ubuntu21.04怎么创建桌面快捷图标?ubuntu软件放到桌面的技巧
  • android获取当前手机号示例程序
    代码如下: public String getLocalNumber() { TelephonyManager tManager =
    android获取当前手机号示例程序
  • Android音视频开发(三)TextureView
    简介 TextureView与SurfaceView类似,可用于显示视频或OpenGL场景。 与SurfaceView的区别 SurfaceView不能使用变换和缩放等操作,不能叠加(Overlay)两个SurfaceView。 Textu
    Android音视频开发(三)TextureView
  • android获取屏幕高度和宽度的实现方法
    本文实例讲述了android获取屏幕高度和宽度的实现方法。分享给大家供大家参考。具体分析如下: 我们需要获取Android手机或Pad的屏幕的物理尺寸,以便于界面的设计或是其他功能的实现。下面就介绍讲一讲如何获取屏幕的物理尺寸 下面的代码即
    android获取屏幕高度和宽度的实现方法
  • Android自定义popupwindow实例代码
    先来看看效果图:一、布局
  • Android第一次实验
    一、实验原理 1.1实验目标 编程实现用户名与密码的存储与调用。 1.2实验要求 设计用户登录界面、登录成功界面、用户注册界面,用户注册时,将其用户名、密码保存到SharedPreference中,登录时输入用户名、密码,读取SharedP
    Android第一次实验

目录