博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android UI学习 - Tab的学习和使用
阅读量:6627 次
发布时间:2019-06-25

本文共 6386 字,大约阅读时间需要 21 分钟。

 本文是参考Android官方提供的sample里面的ApiDemos的学习总结。
 

TabActivity

  首先Android里面有个名为TabActivity来给我们方便使用。其中有以下可以关注的函数
 
 public TabHost getTabHost ()  获得当前TabActivity的TabHost
  
public TabWidget getTabWidget () 获得当前TabActivity的TabWidget
 
  
public void setDefaultTab (String tag) 这两个函数很易懂就是设置默认的Tab
 
 public void setDefaultTab (int index)  通过tab名——tag或者index(从0开始)
  
  
protected void onRestoreInstanceState (Bundle state) 这两个函数的介绍可以
  
protected void onSaveInstanceState (Bundle outState) 参考 Activity的生命周期
 

TabHost

  那么我们要用到的Tab载体是TabHost需要从TabActivity.getTabHost获取。
  现在看看TabHost类它有3个内嵌类1个类TabHost.TabSpec2个接口TabHost.TabContentFactory和TabHost.OnTabChangeListener。后面会介绍这些类和接口。
 
  TabHost类的一些函数
  
public void addTab (TabHost.TabSpec tabSpec) 添加tab参数TabHost.TabSpec通过下面的函数返回得到
  
public TabHost.TabSpec newTabSpec (String tag) 创建TabHost.TabSpec
  
  
public void clearAllTabs () remove所有的Tabs
  
public int getCurrentTab ()
  
public String getCurrentTabTag ()
  
public View getCurrentTabView ()
  
public View getCurrentView ()
  
public FrameLayout getTabContentView () 返回Tab content的FrameLayout
 
 
 public TabWidget getTabWidget ()
  
public void setCurrentTab (int index)       设置当前的Tab by index
  
public void setCurrentTabByTag (String tag) 设置当前的Tab by tag
  
public void setOnTabChangedListener (TabHost.OnTabChangeListener l) 设置TabChanged事件的响应处理
  
public void setup () 这个函数后面介绍
 

TabHost.TabSpec

  从上面的函数可以知道如何添加tab了要注意这里的Tag(标签)不是Tab按钮上的文字。
  而要设置tab的label和content需要设置TabHost.TabSpec类。 引用SDK里面的话——“A tab has a tab indicator, content, and a tag that is used to keep track of it.”TabHost.TabSpec就是管理这3个东西
  
public String getTag ()
  
public TabHost.TabSpec setContent
  
public TabHost.TabSpec setIndicator
 
  我理解这里的
Indicator就是Tab上的label它可以
  
设置label 
setIndicator (CharSequence label)
  或者同时
设置label和icon
setIndicator (CharSequence label, Drawable icon)
  或者直接
指定某个view 
setIndicator (View view)
  
  对于
Content就是Tab里面的内容可以
  
设置View的id 
setContent(int viewId)
  或者
TabHost.TabContentFactory的createTabContent(String tag)来处理
setContent(TabHost.TabContentFactory contentFactory)
  或者用
new Intent来引入其他Activity的内容
setContent(Intent intent)
  
  现在来看官方的Views/Tabs/Content By Id例子

TabHost

   代码
 
  1. public class Tabs1 extends TabActivity { 
  2.  
  3.     @Override 
  4.     protected void onCreate(Bundle savedInstanceState) { 
  5.         super.onCreate(savedInstanceState); 
  6.         TabHost tabHost = getTabHost(); 
  7.          
  8.         LayoutInflater.from(this).inflate(R.layout.tabs1, tabHost.getTabContentView(), true); 
  9.  
  10.         tabHost.addTab(tabHost.newTabSpec("tab1"
  11.                 .setIndicator("tab1"
  12.                 .setContent(R.id.view1)); 
  13.         tabHost.addTab(tabHost.newTabSpec("tab3"
  14.                 .setIndicator("tab2"
  15.                 .setContent(R.id.view2)); 
  16.         tabHost.addTab(tabHost.newTabSpec("tab3"
  17.                 .setIndicator("tab3"
  18.                 .setContent(R.id.view3)); 
  19.     } 
   原来在获取TabHost后需要用LayoutInflater来得到LayoutLayoutInflater在后面就详细介绍。R.layout.tabs1的内容
 
  1. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android" 
  2.     android:layout_width="fill_parent" 
  3.     android:layout_height="fill_parent"> 
  4.  
  5.     <TextView android:id="@+id/view1" 
  6.         android:background="@drawable/blue" 
  7.         android:layout_width="fill_parent" 
  8.         android:layout_height="fill_parent" 
  9.         android:text="@string/tabs_1_tab_1"/> 
  10.  
  11.     <TextView android:id="@+id/view2" 
  12.         android:background="@drawable/red" 
  13.         android:layout_width="fill_parent" 
  14.         android:layout_height="fill_parent" 
  15.         android:text="@string/tabs_1_tab_2"/> 
  16.  
  17.     <TextView android:id="@+id/view3" 
  18.         android:background="@drawable/green" 
  19.         android:layout_width="fill_parent" 
  20.         android:layout_height="fill_parent" 
  21.         android:text="@string/tabs_1_tab_3"/> 
  22.  
  23. </FrameLayout> 
  24.  
  25. <! -- strings.xml 
  26.     <string name="tabs_1_tab_1">tab1</string> 
  27.     <string name="tabs_1_tab_2">tab2</string> 
  28.     <string name="tabs_1_tab_3">tab3</string> 
  29. --> 
  原来是用FrameLayout的
  而让Tab1的内容显示tab1且背景为Blue是setContent(R.id.view1)这里引用了TextView1。现在就基本明白如何添加tab以及如何设置label和content了。
 
  接下来看看Views/Tabs/Content By Factory的例子

TabHost2

  代码
 
  1. public class Tabs2 extends TabActivity implements TabHost.TabContentFactory { 
  2.  
  3.     @Override 
  4.     protected void onCreate(Bundle savedInstanceState) { 
  5.         super.onCreate(savedInstanceState); 
  6.  
  7.         final TabHost tabHost = getTabHost(); 
  8.         tabHost.addTab(tabHost.newTabSpec("tab1"
  9.                 .setIndicator("tab1", getResources().getDrawable(R.drawable.star_big_on)) 
  10.                 .setContent(this)); 
  11.         tabHost.addTab(tabHost.newTabSpec("tab2"
  12.                 .setIndicator("tab2"
  13.                 .setContent(this)); 
  14.         tabHost.addTab(tabHost.newTabSpec("tab3"
  15.                 .setIndicator("tab3"
  16.                 .setContent(this)); 
  17.     } 
  18.  
  19.     public View createTabContent(String tag) { 
  20.         final TextView tv = new TextView(this); 
  21.         tv.setText("Content for tab with tag " + tag); 
  22.         return tv; 
  23.     } 
    可以看到通过override重写重新实现父类TabHost.TabContentFactory中的方法View createTabContent(String tag)来实现不同tab的不同content。同时在setContent的参数设置为相应的TabContentFactory。
  
原来createTabContent是在每个tab第一次显示时才调用的随后再次显示该tab就不会再次调用的我自己用Logcat查看到的这一点很关键就是说在createTabContent是在tab没有完全创建前调用的这意味在createTabContent里面是不能调用getCurrentTabView等之类的函数的否则就出错
 
   至于Views/Tabs/Content By Intent例子就只是贴出代码不给截图了
 
  1. public class Tabs3 extends TabActivity { 
  2.  
  3.     @Override 
  4.     protected void onCreate(Bundle savedInstanceState) { 
  5.         super.onCreate(savedInstanceState); 
  6.  
  7.         final TabHost tabHost = getTabHost(); 
  8.  
  9.         tabHost.addTab(tabHost.newTabSpec("tab1"
  10.                 .setIndicator("list"
  11.                 .setContent(new Intent(this, List1.class))); 
  12.  
  13.         tabHost.addTab(tabHost.newTabSpec("tab2"
  14.                 .setIndicator("photo list"
  15.                 .setContent(new Intent(this, List8.class))); 
  16.          
  17.         // This tab sets the intent flag so that it is recreated each time 
  18.         // the tab is clicked. 
  19.         tabHost.addTab(tabHost.newTabSpec("tab3"
  20.                 .setIndicator("destroy"
  21.                 .setContent(new Intent(this, Controls2.class
  22.                         .addFlags(Intent.FLAG_ACTIVITY_CLEAR_TOP))); 
  23.     } 
效果Tab1的内容是List1的ActivityTab2的是List8的ActivityTab3的是controls2.Activity。
 

TabHost.OnTabChangeListener

   TabHost.OnTabChangeListener接口只有一个抽象方法onTabChanged(String tagString)明显地在
onTabChanged(String tagString)方法里面swtich..case..来判断tagString分别处理就行了。
 

TabHost.setup()

  在此贴出SDK doc里面的相关解释
public void setup ()         Since: API Level 1
Call setup() before adding tabs if loading TabHost using findViewById(). 
However,
You do not need to call setup() after getTabHost() in TabActivity. Example:
 
     mTabHost = (TabHost)findViewById(R.id.tabhost);
     mTabHost.setup();
     mTabHost.addTab(TAB_TAG_1, "Hello, world!", "Tab 1");
 
//我的理解是如果要用到findViewById来获取TabHost然后add tabs的话需要在addTab前call setup();
 
public void setup (LocalActivityManager activityGroup)         Since: API Level 1
If you are using 
setContent(android.content.Intent), this must be called since the activityGroup is needed to launch the local activity. 
This is done for you if you extend TabActivity.
 
Parameters
activityGroup
Used to launch activities for tab content.
本文转自 Icansoft 51CTO博客原文链接 http://blog.51cto.com/android/315208

转载地址:http://awhpo.baihongyu.com/

你可能感兴趣的文章
如何成为一个好的包工头
查看>>
EasyUI树和Ztree树冲突问题
查看>>
针对PIL中ImageDraw.py报错的解决方案
查看>>
Hibernate 二级缓存配置
查看>>
关于配置服务器(IIS7)
查看>>
[C# 网络编程系列]专题十一:实现一个基于FTP协议的程序——文件上传下载器...
查看>>
在Linux-PC上建立kdump调试环境
查看>>
redis.conf for Chinese
查看>>
语法》第四章 字符串
查看>>
神奇的CSS3混合模式转载
查看>>
第一次作业-准备篇
查看>>
软件构架实践阅读笔记1
查看>>
光学字符识别OCR-4
查看>>
Testing - 软件测试知识梳理 - 测试模型
查看>>
[USACO13NOV]No Change
查看>>
android开发(35) fragment和actionbar组合使用。解决不触发onOptionsItemSelected的问题,获得actionbar 的默认 get icon...
查看>>
eclipse 配置CDT,eclipse配置C语言开发环境
查看>>
性能测试工具Locust+HttpRunner问题汇总
查看>>
hdu 5398 动态树LCT
查看>>
51nod 1376 最长递增子序列的数量(线段树)
查看>>