Android:TabHost


转自移动开发者社区

前言
  本章内容是 android.widget.TabHost,译为"选项卡容器",版本为Android 2.3 r1,翻译来自"madgoat",欢迎大家访问他的博客:http://madgoat.cn/,再次感谢"madgoat" !期待你加入Android中文翻译组,联系我over140@gmail.com

声明
  欢迎转载,但请保留文章原始出处:)

    移动社区:http://dev.10086.cn
    Android中文翻译组:http://code.taobao.org/project/view/404/


正文
  一、结构
public class TabHost extends FrameLayout implements ViewTreeObserver.OnTouchModeChangeListener
        
java.lang.Object
android.view.View
         android.view.ViewGroup
                 android.widget.FrameLayout
                         android.widget.TabHost

  二、概述
    

提供选项卡(Tab 页)的窗口视图容器。此对象包含两个子对象:一组是用户可以选择指定Tab 页的标签;另一组是FrameLayout 用来显示该Tab 页的内容。个别元素通常控制使用这个容器对象,而不是设置在子元素本身的值。
(译者注:即使使用的是单个元素,也最好把它放到容器对象ViewGroup 里)


  三、内部类
interface TabHost.OnTabChangeListener    
接口定义了当选项卡更改时被调用的回调函数
interface TabHost.TabContentFactory  
当某一选项卡被选中时生成选项卡的内容
class TabHost.TabSpec    
单独的选项卡,每个选项卡都有一个选项卡指示符, 内容和tag 标签, 以便于记录.

  四、公共方法
public void addTab (TabHost.TabSpec tabSpec)
新增一个选项卡
参数
tabSpec     指定怎样创建指示符和内容.

public void clearAllTabs ()
tab widget 中移除所有关联到当前tab host 的选项卡

public boolean dispatchKeyEvent (KeyEvent event)
分发按键事件到焦点传递路线上的下一视图。焦点传递路线从视图树的顶层开始一直到当前获取焦点的视图停止。如果此视图已经获取焦点, 将分发给它自身。否则,将分发到焦点传递路线的下一节点。此方法会触发任何一个按键监听器.
(译者注:关于focus path, 可以参考以下地址:
http://blog.csdn.net/maxleng/archive/2010/05/04/5557758.aspx
参数
event         分发的按键事件
返回值
如果事件已经处理则返回true, 否则返回false.

public void dispatchWindowFocusChanged (boolean hasFocus)
当窗口包含的此视图获取或丢失焦点时触发此方法.ViewGroups 应该重写以路由到他的子元素
参数
hasFocus 如果窗口包含的此view 依获取焦点, 返回true, 否则返回false.

public int getCurrentTab ()
(译者注:获取当前选项卡的id

public String getCurrentTabTag ()
(译者注:当前选项卡的Tag 标签内容)

public View getCurrentTabView ()
(译者注:获取当前选项卡的视图view

public View getCurrentView ()
(译者注:获取当前的视图view

public FrameLayout getTabContentView ()
获取保存tab 内容的FrameLayout

public TabWidget getTabWidget ()
(译者注:根据系统规定的id tabs 来找到TabWidget ,并返回,注意,这里的ID 必须是tabs 。源代码中表示如下:
private TabWidget mTabWidget;
mTabWidget=(TabWidget)findViewById(com.android.internal.R.id.tabs);

public TabHost.TabSpec newTabSpec (String tag)
获取一个新的TabHost.TabSpec ,并关联到当前tab host
参数
tag   所需的选项卡标签(tag)

public void onTouchModeChanged (boolean isInTouchMode)
当触摸模式发生改变时调用的回调函数.
参数
isInTouchMode         如果视图结构当前处于触摸模式, 返回true, 否则返回false.

public void setCurrentTab (int index)
(译者注:设置当前的选项卡
参数
Index         为当前选项卡的索引。)

public void setCurrentTabByTag (String tag)
(译者注:根据选项卡的Tab 标签来设置当前的选项卡
                             参数
tag 想要被设置为当前选项卡的tag 标签值。)

public void setOnTabChangedListener (TabHost.OnTabChangeListener l)
注册一个回调函数,当选项卡中的任何一个tab 的选中状态发生改变时调用。
(译者注:setCurrentTab(index) 时会触发调用)
参数
l         将运行的回调函数
        
public void setup ()
如果使用findViewById() 加载TabHost ,那么在新增一个选项卡tab 之前,需要调用setup() 。然而,当你在一个TabActivity 里使用getTabHost() 获取TabHost ,你就不再需要调用setup() 了。(译者注:实现tab 窗口的两种方法:继承activity 时,使用findViewById() 查找TabHost ,然后调用setup() ;继承TabActivity ,通过getTabHost() 查找,此时不用调用setup() )例子:
    


public void setup (LocalActivityManager activityGroup)
如果你使用setContent( android.content.Intent) ,那么当activityGroup 用于加载本地activity 之时,必须调用此方法。如果你拓展(继承)TabActivity 将自动调用setup() 方法。
参数
activityGroup   用来为选项卡内容加载activities ativityGroup

  五、受保护方法
protected void onAttachedToWindow ()
视图附加到窗口上时被调用。在这个点的表面进行绘制。注意此函数确保在onDraw(Cancas) 之前调用,然而它可能在第一次执行onDraw 之前的任何时间被调用——包括的onMeasure(int,int) 的之前或之后。
protected void onDetachedFromWindow ()
视图从窗口分离时被调用。在这个点的表面不再有画面绘制。

  六、补充
文章链接
             Android 控件之TabHost Tab

    示例代码
      截图:
        
      JAVA文件:
  1. public class Tabs1 extends TabActivity {
  2.     @Override
  3.     protected void onCreate(Bundle savedInstanceState) {
  4.         super.onCreate(savedInstanceState);
  5.         TabHost tabHost = getTabHost();
  6.         
  7.         LayoutInflater.from(this).inflate(R.layout.tabs1, tabHost.getTabContentView(), true);
  8.         tabHost.addTab(tabHost.newTabSpec("tab1")
  9.                 .setIndicator("tab1")
  10.                 .setContent(R.id.view1));
  11.         tabHost.addTab(tabHost.newTabSpec("tab3")
  12.                 .setIndicator("tab2")
  13.                 .setContent(R.id.view2));
  14.         tabHost.addTab(tabHost.newTabSpec("tab3")
  15.                 .setIndicator("tab3")
  16.                 .setContent(R.id.view3));
  17.     }
  18. }
  19.       XML文件:
  20. <?xml version="1.0" encoding="utf-8"?>
  21. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"
  22.     android:layout_width="match_parent"
  23.     android:layout_height="match_parent">
  24.     <TextView android:id="@+id/view1"
  25.         android:background="@drawable/blue"
  26.         android:layout_width="match_parent"
  27.         android:layout_height="match_parent"
  28.         android:text="@string/tabs_1_tab_1"/>
  29.     <TextView android:id="@+id/view2"
  30.         android:background="@drawable/red"
  31.         android:layout_width="match_parent"
  32.         android:layout_height="match_parent"
  33.         android:text="@string/tabs_1_tab_2"/>
  34.     <TextView android:id="@+id/view3"
  35.         android:background="@drawable/green"
  36.         android:layout_width="match_parent"
  37.         android:layout_height="match_parent"
  38.         android:text="@string/tabs_1_tab_3"/>
  39. </FrameLayout>




    详细参见apidemo/view/tabs1


结束
  翻译组人数刚刚突破100人,人员组织也刚刚调整完,下一步再确定审核员已经翻译手册的修改,完善整个组织结构和流程规则,希望翻译组能健健康康的持续下去,感谢大家热心参与,再次感谢"madgoat"为大家带来优秀的翻译稿。



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值