Tab形式的菜单实现总结TabHost 和 FragmentTabHost

TabHost

    命名空间:
        android.widget.TabHost
    初始化函数(必须在addTab之前调用):
        setup(); 
    包含两个子元素:
        1.Tab标签容器TabWidget(@android:id/tabs)
        2.Tab内容容器FrameLayout(@android:id/tabcontent)

FragmentTabHost
    命名空间:
        android.support.v4.app.FragmentTabHost
        android.support.v13.app.FragmentTabHost
    初始化函数(必须在addTab之前调用):
        setup(this, getSupportFragmentManager(), R.id.realtabcontent);
    包含三个子元素:
        1.Tab标签 容器TabWidget(@android:id/tabs)
        2.Tab内容 容器FrameLayout [宽高皆为0dp](@android:id/tabcontent)
        3.Tab内容 容器FrameLayout [真正的容器](@+id/RealTabContent)

疑问为什么同时存在TabContent 和 RealTabContent 两个FrameLayout?
答疑:《关于FragmentTabHost中TabWidget不能移到屏幕下面的Bug》
        http://blog.csdn.net/wklbeta/article/details/11329207

资料:《Android开发:使用Fragment改造TabActivity》
        http://www.blogjava.net/amplifier/archive/2012/12/27/393409.html

经验 - 实现Tab功能的几种方式        1.(废弃)继承自TabActivity + TabHost 布局 + Activity 内容
                1.1:TabActivity为ActivityGroup[在版本13里被放弃]子类
                1.2:使用getTabHost() 获得TabHost 对象
                1.3:使用 newTabSpec(...).setContent(Intent) 添加Tab标签与内容

        2.(废弃)继承自ActivityGroup + TabHost布局 + Activity 内容
                2.1:ActivityGroup在版本13里被放弃
                2.2:使用findViewById 获得TabHost 对象
                2.3:使用setup(new LocalActivityManager(this, true))初始化
                2.4:使用 newTabSpec(...).setContent(Intent) 添加Tab标签与内容

        3.(简单)继承自FragmentActivity + FragmentTabHost 布局 + Fragment 内容
                3.1:使用findViewById 获得FragmentTabHost 对象
                3.2:使用setup(this, getSupportFragmentManager(), R.id.realtabcontent)初始化
                3.3:使用addTab(newTabSpec().setIndicator(),Fragment.class, null) 添加Tab标签与内容

        4.(复杂)继承自FragmentActivity + TabHost 布局 + ViewPager布局 + Fragment 内容
                4.1:使用findViewById 获得TabHost 对象
                4.2:使用setup()初始化
                4.3:使用TabHost.addTab(tabSpec.setContent(DummyTabFactory));添加Tab标签与空内容
                4.4:在TabHost.onTabChanged中控制ViewPager的实际显示
                4.5:滑动时在ViewPager.onPageSelected 中控制Tab标签的选择。
                PS:当Tab标签数量固定且不追求和系统保持一致的标签效果,的情况下这里的TabHost布局有些多余。
                如 :特有应用需要的Tab标签固定,且有自己的一套显示效果,那么这里完全无需TabHost布局。

        5.(DIY)继承自FragmentActivity + 自定义布局 + ViewPager布局 + Fragment 内容
                5.1:自定义布局中嵌入固定Tab标签元素
                5.2:在标签元素点击事件中控制ViewPager的实际显示
                5.3:滑动时在ViewPager.onPageSelected 中控制标签元素的选择。
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值