基本模板

  1. public class MainActivity extends FragmentActivity {
  2.  
  3. private FragmentTabHost mTabHost;
  4. private LayoutInflater mLayoutInflater;
  5.  
  6. private Class mFragmentArray[] = { Fragment1.class, Fragment2.class,
  7. Fragment3.class, Fragment4.class, Fragment5.class };
  8.  
  9. private int mImageArray[] = { R.drawable.tab_home_btn,
  10. R.drawable.tab_message_btn, R.drawable.tab_selfinfo_btn,
  11. R.drawable.tab_square_btn, R.drawable.tab_more_btn };
  12.  
  13. private String mTextArray[] = { "首页", "消息", "好友", "搜索", "更多" };
  14.  
  15. public void onCreate(Bundle savedInstanceState) {
  16. super.onCreate(savedInstanceState);
  17. setContentView(R.layout.activity_main);
  18. initView();
  19. }
  20.  
  21. private void initView() {
  22.  
  23. mLayoutInflater = LayoutInflater.from(this);
  24.  
  25. // 找到TabHost
  26. mTabHost = (FragmentTabHost) findViewById(android.R.id.tabhost);
  27. mTabHost.setup(this, getSupportFragmentManager(), R.id.realtabcontent);
  28.      mTabHost.getTabWidget().setDividerDrawable(null);//去除分割线
  29. // 得到fragment的个数
  30. for (int i = 0; i < mFragmentArray.length; i++) {
  31. // 给每个Tab按钮设置图标、文字和内容
  32. TabSpec tabSpec = mTabHost.newTabSpec(mTextArray[i])
  33. .setIndicator(getTabItemView(i));
  34. // 将Tab按钮添加进Tab选项卡中
  35. mTabHost.addTab(tabSpec, mFragmentArray[i], null);
  36. // 设置Tab按钮的背景
  37. mTabHost.getTabWidget().getChildAt(i)
  38. .setBackgroundResource(R.drawable.selector_tab_background);
  39. }
  40. }
  41.  
  42. //给每个Tab按钮设置图标和文字
  43. private View getTabItemView(int index) {
  44. View view = mLayoutInflater.inflate(R.layout.tab_item_view, null);
  45. ImageView imageView = view.findViewById(R.id.imageview);
  46. //设置图片选择器,选中的tab改变图标
  47. switch (index){
  48. case 0:imageView.setImageResource(R.drawable.main_bottom_image_selector);break;
  49. case 1:imageView.setImageResource(R.drawable.main_bottom_image_selector2);break;
  50. case 2:imageView.setImageResource(R.drawable.main_bottom_image_selector3);break;
  51. case 3:imageView.setImageResource(R.drawable.main_bottom_image_selector4);break;
  52. case 4:imageView.setImageResource(R.drawable.main_bottom_image_selector5);break;
  53. }
  54. TextView textView = view.findViewById(R.id.textview);
  55. textView.setText(mTextArray[index]);
  56. //设置文本选择器,选中的tab文字高亮
  57. textView.setTextColor(getResources().getColorStateList(R.color.main_bottom_text_selector));
  58.  
  59.     return view; } }

acitivity_main.xml

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:layout_width="fill_parent"
  4. android:layout_height="fill_parent"
  5. android:orientation="vertical" >
  6.  
  7. <FrameLayout
  8. android:id="@+id/realtabcontent"
  9. android:layout_width="fill_parent"
  10. android:layout_height="0dip"
  11. android:layout_weight="1" />
  12.  
  13. <android.support.v4.app.FragmentTabHost
  14. android:id="@android:id/tabhost" //必须使用提供的id
  15. android:layout_width="fill_parent"
  16. android:layout_height="wrap_content"
  17. android:background="@drawable/bg_tabhost_bg">
  18.  
  19. <FrameLayout
  20. android:id="@android:id/tabcontent" //必须使用提供的id
  21. android:layout_width="0dp"
  22. android:layout_height="0dp"
  23. android:layout_weight="0" />
  24. </android.support.v4.app.FragmentTabHost>
  25.  
  26. </LinearLayout>

tab_item_view.xml

  1. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  2. android:layout_width="match_parent"
  3. android:layout_height="wrap_content"
  4. android:gravity="center"
  5. android:orientation="vertical">
  6. <ImageView
  7. android:id="@+id/imageview"
  8. android:layout_width="40dp"
  9. android:layout_height="40dp"
  10. android:layout_margin="3dp"
  11. />
  12. <TextView
  13. android:id="@+id/textview"
  14. android:layout_width="wrap_content"
  15. android:layout_height="wrap_content"
  16. android:layout_marginTop="1dp"
  17. android:textSize="12sp"
  18. android:layout_marginBottom="2dp"/>
  19. </LinearLayout>

main_bottom_image_selector图片选择器

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <selector xmlns:android="http://schemas.android.com/apk/res/android">
  3. <item android:state_selected="false" android:drawable="@drawable/ic_launcher" />
  4. <item android:state_selected="true" android:drawable="@drawable/ic_launcher_round" />
  5. </selector>

注:模板有5个tab,需要5个图片选择器,还需要5个文本选择器,还需要创建5个fragment。如果要动态改变文本点击变色,需要用getResources().getColorStateList(R.color.main_bottom_text_selector)才可以,getColor()只会选取一种颜色。

android FragmentTabhost导航分页的更多相关文章

  1. Android底部导航栏——FrameLayout + RadioGroup

    原创文章,转载请注明出处http://www.cnblogs.com/baipengzhan/p/6285881.html Android底部导航栏有多种实现方式,本文详细介绍FrameLayout ...

  2. Android底部导航栏创建——ViewPager + RadioGroup

    原创文章,引用请注明出处:http://www.cnblogs.com/baipengzhan/p/6270201.html Android底部导航栏有多种实现方式,本文详解其中的ViewPager ...

  3. Android底部导航栏

    Android底部导航栏 今天简单写了一个底部导航栏,封装了一个库,用法比较简单 效果图 Github地址:https://github.com/kongqw/KqwBottomNavigation ...

  4. VS 2015 开发Android底部导航条----[实例代码,多图]

      1.废话背景介绍  在Build 2016开发者大会上,微软宣布,Xamarin将被整合进所有版本的Visual Studio之中. 这也就是说,Xamarin将免费提供给所有购买了Visual ...

  5. Android车载导航的一些困境

    车载导航从最初的用解码芯片,过渡到用WinCE系统,已经形成了一个较大的产业.车载导航使用上的一些大原则,基本上被固定了下来.如今WinCE走到了尽头,Android车载导航開始发力,但由于Andro ...

  6. 如何使用RadioGroup和RadioButton实现FragmentTabHost导航效果?

    目录: 一.概述 最近在做一个新闻类结合社区的APP的时候,需要添加一个侧滑菜单的效果,考虑到可以使用DrawerLayout布局,但是问题是使用了 DrawerLayout布局后,主页内容应该是一个 ...

  7. java攻城狮之路(Android篇)--widget_webview_metadata_popupwindow_tabhost_分页加载数据_菜单

    一.widget:桌面小控件1 写一个类extends AppWidgetProvider 2 在清单文件件中注册: <receiver android:name=".ExampleA ...

  8. Android tab导航的几种方法:ActionBar tab +fragment,Viewpager+pagerTitleStrip,开源框架ViewPageIndicator 和 ViewPager

    action来实现tab标签 并跟fragment结合 因为要写新闻客户端这个tab导航是必须的 这里我写几个小练习,希望大家融会贯通. 1actionbar设置tab +fragment 布局是个l ...

  9. Android -- FragmentTabHost实现微信底部切换

    1,在商城类的项目中我们开始一个项目的时候经常出现这样的需求,如下图所示: 下面使用户可以切换的模块,上面是对应的模块的详细内容,实现这个效果有很多方式,可以使用radiobutton+fragmen ...

随机推荐

  1. 1 小时 SQL 极速入门(二)

    上篇我们说了 SQL 的基本语法,掌握了这些基本语法后,我们可以对单表进行查询及计算分析.但是一个大的系统,往往会有数十上百张表,而业务关系又错综复杂.我们要查的数据往往在好几张表中,而要从多张表中来 ...

  2. CSS3 阴影模拟灯照效果

    效果如下: 代码如下: <!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset= ...

  3. 大量示例彻底搞懂Linux查找,which,whereis,locate,find

    前言 Linux常用命令中,有些命令可以帮助我们查找二进制文件,帮助手册或源文件的位置,也有的命令可以帮助我们查找磁盘上的任意文件,今天我们就来看看这些命令如何使用. which which命令会在P ...

  4. [Swift]LeetCode319. 灯泡开关 | Bulb Switcher

    There are n bulbs that are initially off. You first turn on all the bulbs. Then, you turn off every ...

  5. java.lang.AbstractMethodError: org.mybatis.spring.transaction.SpringManagedTransaction.getTimeout()Ljava/lang/Integer; 报错解决

    我的妈呀  真的是各种报错..... 这个问题    解决方法: https://www.cnblogs.com/beppezhang/p/6118661.html

  6. 【git】idea /git bash命令 操作分支

    1.需求 因为目前要对项目做一些改动,而项目又即将上线,这些新的改动又不需要一起上线,所以这个时候需要在原有的master分支上重新拉出一个分支进行开发. 2.分支操作 打开git bash工具→切换 ...

  7. java反射取private字段

    Class clazz = bean.getClass();Field[] fields = clazz.getDeclaredFields();String sign = ""; ...

  8. BBS论坛(四)

    4.1.cms登录页面csrf保护 (1)Perfect_bbs.py from flask_wtf import CSRFProtect CSRFProtect(app) 添加csrf保护后,现在再 ...

  9. Java接口的实例应用:致敬我的偶像——何塞·穆里尼奥

    文/沉默王二 曹操在<短歌行>中为杜康酒打过一个价值一亿个亿的广告——“何以解忧,唯有杜康”,我替曹操感到惋惜的是他本人并不会收到这笔不菲的代言费.想一想,要是三国时期的明星人物们有这个代 ...

  10. Django中的templates(你的HTML页面放哪里)

    本文回答Django里面的HTML文件应该怎么放,以及Django是如何查找模板文件的. 到目前为止我们没有使用HTML页面,在之前的说明中所有内容都是写死在程序里的,如果你想改变内容就要修改代码.但 ...