1. package com.example.fragmenttabdemo;
  2.  
  3. import java.util.ArrayList;
  4. import java.util.List;
  5.  
  6. import android.annotation.SuppressLint;
  7. import android.os.Bundle;
  8. import android.support.v4.app.Fragment;
  9. import android.support.v4.app.FragmentActivity;
  10. import android.support.v4.app.FragmentManager;
  11. import android.support.v4.app.FragmentPagerAdapter;
  12. import android.support.v4.app.FragmentTabHost;
  13. import android.support.v4.view.ViewPager;
  14. import android.support.v4.view.ViewPager.OnPageChangeListener;
  15. import android.view.LayoutInflater;
  16. import android.view.View;
  17. import android.view.ViewGroup;
  18. import android.widget.ImageView;
  19. import android.widget.TabHost.OnTabChangeListener;
  20. import android.widget.TabHost.TabSpec;
  21. import android.widget.TabWidget;
  22. import android.widget.TextView;
  23.  
  24. @SuppressLint("InflateParams")
  25. public class MainActivity extends FragmentActivity {
  26. // 定义FragmentTabHost对象
  27. private FragmentTabHost mTabHost;
  28. // 定义一个布局
  29. private LayoutInflater layoutInflater;
  30. // 定义数组来存放Fragment界面
  31. @SuppressWarnings("rawtypes")
  32. private Class fragmentArray[] = { FragmentPage1.class, FragmentPage1.class,
  33. FragmentPage1.class, FragmentPage1.class, FragmentPage1.class };
  34. // 定义数组来存放按钮图片
  35. private int mImageViewArray[] = { R.drawable.ic_launcher,
  36. R.drawable.ic_launcher, R.drawable.ic_launcher,
  37. R.drawable.ic_launcher, R.drawable.ic_launcher };
  38. // Tab选项卡的文字
  39. private String mTextviewArray[] = { "首页", "消息", "好友", "广场", "更多" };
  40. private ViewPager vp;
  41. private List<Fragment> list = new ArrayList<Fragment>();
  42.  
  43. public void onCreate(Bundle savedInstanceState) {
  44. super.onCreate(savedInstanceState);
  45. setContentView(R.layout.activity_main);
  46. initView();
  47. initPager();
  48. }
  49.  
  50. /**
  51. * 初始化组件
  52. */
  53. private void initView() {
  54. vp = (ViewPager) findViewById(R.id.pager);
  55. vp.setOnPageChangeListener(new ViewPagerListener());
  56. // MyAdapter adapter = new MyAdapter();
  57. // vp.setAdapter(adapter);
  58. // 实例化布局对象
  59. layoutInflater = LayoutInflater.from(this);
  60. // 实例化TabHost对象,得到TabHost
  61. mTabHost = (FragmentTabHost) findViewById(android.R.id.tabhost);
  62. // 得到对象后,初始化
  63. // mTabHost.getTabWidget().setDividerDrawable(android.R.color.transparent);
  64. mTabHost.setup(this, getSupportFragmentManager(), R.id.pager);
  65. mTabHost.setOnTabChangedListener(new TabHostListener());
  66. // 得到fragment的个数
  67. int count = fragmentArray.length;
  68.  
  69. for (int i = 0; i < count; i++) {
  70. // 为每一个Tab按钮设置图标、文字和内容
  71. TabSpec tabSpec = mTabHost.newTabSpec(mTextviewArray[i])
  72. .setIndicator(getTabItemView(i));
  73. // 将Tab按钮添加进Tab选项卡中
  74. mTabHost.addTab(tabSpec, fragmentArray[i], null);
  75. mTabHost.setTag(i);
  76. mTabHost.getTabWidget().setDividerDrawable(
  77. android.R.color.transparent);
  78. // 设置Tab按钮的背景
  79. // mTabHost.getTabWidget().getChildAt(i)
  80. // .setBackgroundResource(R.drawable.selector_tab_background);
  81. }
  82. }
  83.  
  84. //初始化viewpager
  85. private void initPager() {
  86. FragmentPage1 p1 = new FragmentPage1();
  87. FragmentPage1 p2 = new FragmentPage1();
  88. FragmentPage1 p3 = new FragmentPage1();
  89. FragmentPage1 p4 = new FragmentPage1();
  90. FragmentPage1 p5 = new FragmentPage1();
  91. list.add(p1);
  92. list.add(p2);
  93. list.add(p3);
  94. list.add(p4);
  95. list.add(p5);
  96. vp.setAdapter(new MyAdapter(getSupportFragmentManager()));
  97. }
  98.  
  99. /**
  100. * 给Tab按钮设置图标和文字
  101. */
  102. private View getTabItemView(int index) {
  103. View view = layoutInflater.inflate(R.layout.btn_bottom, null);
  104. ImageView imageView = (ImageView) view.findViewById(R.id.imageview);
  105. imageView.setImageResource(mImageViewArray[index]);
  106. TextView textView = (TextView) view.findViewById(R.id.textview);
  107. textView.setText(mTextviewArray[index]);
  108. return view;
  109. }
  110.  
  111. private class TabHostListener implements OnTabChangeListener {
  112. @Override
  113. public void onTabChanged(String tabId) {
  114. int position = mTabHost.getCurrentTab();
  115. vp.setCurrentItem(position);
  116. }
  117. }
  118.  
  119. class MyAdapter extends FragmentPagerAdapter {
  120.  
  121. public MyAdapter(FragmentManager fm) {
  122. super(fm);
  123. // TODO Auto-generated constructor stub
  124. }
  125.  
  126. @Override
  127. public Fragment getItem(int arg0) {
  128. return list.get(arg0);
  129. }
  130.  
  131. @Override
  132. public int getCount() {
  133. return list.size();
  134. }
  135.  
  136. }
  137.  
  138. class ViewPagerListener implements OnPageChangeListener {
  139.  
  140. public void onPageScrollStateChanged(int arg0) {
  141.  
  142. }
  143.  
  144. public void onPageScrolled(int arg0, float arg1, int arg2) {
  145.  
  146. }
  147.  
  148. public void onPageSelected(int index) {
  149. TabWidget widget = mTabHost.getTabWidget();
  150. int oldFocusability = widget.getDescendantFocusability();
  151. widget.setDescendantFocusability(ViewGroup.FOCUS_BLOCK_DESCENDANTS);
  152. mTabHost.setCurrentTab(index);
  153. widget.setDescendantFocusability(oldFocusability);
  154. }
  155. }
  156. }

FragmentTabHost+ViewPager实现底部按钮的更多相关文章

  1. Android 底部按钮BottomNavigationView + Fragment + viewPager 的使用(一)

    实现的效果,左右滑动,底部栏跟着滑动,中间加的是分帧的页面        上代码:主页面activity_main.xml <?xml version="1.0" encod ...

  2. 我的长大app开发教程第二弹:完成ContentFragment底部按钮

    在开始之前,先上一张效果图 突然发现有点知乎的味道...的确..知乎灰#989898,知乎蓝15,136,235(逃.... 1.学P图 想我大一的时候也用过不少Adobe的软件,昨天重新打开我的Ph ...

  3. Android 底部按钮BottomNavigationView + Fragment 的使用(二)

    这里来试验BottomNavigationView + Fragment 底部按钮通过点击底部选项,实现中间的Fragment进行页面的切换. 使用BottomNavigationView 控件,实现 ...

  4. Android控件Gridview实现仿支付宝首页,Fragment底部按钮切换和登录圆形头像

    此案例主要讲的是Android控件Gridview(九宫格)完美实现仿支付宝首页,包含添加和删除功能:Fragment底部按钮切换的效果,包含四个模块,登录页面圆形头像等,一个小项目的初始布局. 效果 ...

  5. react native 底部按钮切换

    在react   native  中底部按钮的切换  主要的是运用的是<TabBarNavigator/>这个组件,具体的代码实现如下: render() { return ( <T ...

  6. h5软键盘弹起 底部按钮被顶起问题解决

    解决思路: 当键盘弹起时隐藏掉按钮,键盘隐藏时按钮显示 监测键盘是否弹起(浏览器页面是否发生变化) 代码: 1.定义一个底部按钮 <div class="returnbtn" ...

  7. Android典型界面设计——FragmentTabHost+Fragment实现底部tab切换

    一.问题描述 在上次博文中,我们使用RadioGroup+ViewPage+Fragmen实现了顶部滑动导航(查看文章:http://www.cnblogs.com/jerehedu/p/460759 ...

  8. Android studio 基本布局-底部按钮

    在使用Android studio 的时候,准备弄的基本的布局出来,底部按钮,按了中间会显示. 来上代码: 页面menu_main.xml 这里弄控件的浮动耗费了点我的时间.原因是因为对其各种问题, ...

  9. jquery判断滚动到某个div显示底部按钮

    判读滚动某个div显示底部按钮 <!DOCTYPE html> <html lang="zh-CN"> <head> <meta char ...

随机推荐

  1. 解决IE apk变成zip:Android 手机应用程序文件下载服务器 配置解决方法

    APK文件其实是zip格式,但后缀名被修改为apk,通过UnZip解压后,可以看到Dex文件,Dex是Dalvik VM executes的全称,即Android Dalvik执行程序,并非Java ...

  2. ci中如何私有化方法

    私有方法 在某些情况下,你可能想要隐藏一些方法使之无法对外查阅.将方法私有化很简单,只要在方法名字前面加一个下划线("_")做前缀就无法通过 URL 访问到了.例如,如果你有一个像 ...

  3. 大理石在哪?(Where is the Marble?,UVa 10474)

    参考:ACM紫书 第五章 P108 [排序与检索] 下面的代码中有些 提示性输出,想Ac 需删除提示性输出语句,读者自行修改. #include <cstdio> #include < ...

  4. ASP.NET MVC 站点设置.html 为起始页

    1.  删除 controller="XX" 2. 确保你的工程根目录下的*.htm或*.html文件名在IIS默认文档中存在 搞定

  5. 修改linux最大文件句柄数

    大家知道在linux服务器大并发调优时,往往需要预先调优linux参数,其中修改linux最大文件句柄数是最常修改的参数之一. 在linux中执行ulimit -a 即可查询linux相关的参数,如下 ...

  6. CrtCtl (客户端认证的证书、私钥)的控制

    crt (证书文件) 编辑 本词条缺少名片图,补充相关内容使词条更完整,还能快速升级,赶紧来编辑吧! 客户端认证的证书.私钥. 中文名 crt 性    质 证书文件 类    型 客户端认证的证书. ...

  7. JS设置cookie,删除cookie

    js设置cookie有很多种方法. 第一种:(这个是w3c官网的代码) <script> //设置cookie function setCookie(cname, cvalue, exda ...

  8. 备份还原mysql数据库

    Windows下cmd命令行中备份还原mysql数据库 先cmd 上cd  到mysql的安装bin目录下,然后再运行下面的命令. 例如:cd C:\Program Files\MySQL\MySQL ...

  9. HNU 12827 NASSA’s Robot

    题目链接:http://acm.hnu.cn/online/?action=problem&type=show&id=12827&courseid=268 #include&l ...

  10. [codeforces 241]A. Old Peykan

    [codeforces 241]A. Old Peykan 试题描述 There are n cities in the country where the Old Peykan lives. The ...