Android - FragmentTabHost 与 Fragment 制作页面切换效果
使用 FragmentTabHost 与 Fragment 制作页面切换效果
API 19
TabHost已经不建议使用了。用 FragmentTabHost 来代替TabHost。实际上 FragmentTabHost 继承自 TabHost
效果图:

主文件是FragmentTabHostDemo.java
- 继承自FragmentActivity;
- 设置3个底部标签,自定义了标签切换时的标签变化;
- 添加标签页有多种方式,每个标签页对应一个fragment
- 每次切换fragment,都会调用fragment的
onCreateView()和onResume()方法; - v4包使用
getSupportFragmentManager(); - 动态加载fragment,不用在xml中注册;
- 其他的大体和TabHost一样;比如xml文件中的id要用android指定的id;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
import android.support.v4.app.FragmentTabHost;
import android.view.LayoutInflater;
import android.view.View;
import android.widget.ImageView;
import android.widget.TabHost;
import android.widget.TextView;
import com.rust.aboutview.fragment.TabFragment1;
import com.rust.aboutview.fragment.TabFragment2;
import com.rust.aboutview.fragment.TabFragment3;
import java.util.HashMap;
public class FragmentTabHostDemo extends FragmentActivity {
public static final int COLOR_GRAY_01 = 0xFFADADAD; //自定义的颜色
public static final int COLOR_GREEN_01 = 0xFF73BF00;
public static final String TAB1 = "tab1";
public static final String TAB2 = "tab2";
public static final String TAB3 = "tab3";
public static final String TABS[] = {TAB1, TAB2, TAB3};
public static HashMap<String, Integer> mTabMap;
public static FragmentTabHost mTabHost;
LayoutInflater mLayoutInflater;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_fragment_tab_host);
mTabMap = new HashMap<>();
mTabMap.put(TAB1, 0);
mTabMap.put(TAB2, 1);
mTabMap.put(TAB3, 2);
mLayoutInflater = LayoutInflater.from(getApplicationContext());
mTabHost = (FragmentTabHost) findViewById(android.R.id.tabhost);
mTabHost.setup(this, getSupportFragmentManager(), R.id.realtabcontent);
mTabHost.getTabWidget().setMinimumHeight(120);// 设置tab的高度
mTabHost.getTabWidget().setDividerDrawable(null);
TabHost.TabSpec tabSpec = mTabHost.newTabSpec(TABS[0]);
View tabView1 = mLayoutInflater.inflate(R.layout.tab_item, null);
final ImageView tabImage1 = (ImageView) tabView1.findViewById(R.id.tab_image);
final TextView tabText1 = (TextView) tabView1.findViewById(R.id.tab_text);
tabImage1.setImageResource(R.drawable.a4a);
tabText1.setText(getString(R.string.tab_label_1));
tabText1.setTextColor(COLOR_GREEN_01);
tabSpec.setIndicator(tabView1);
mTabHost.addTab(tabSpec, TabFragment1.class, null);
View tabView2 = mLayoutInflater.inflate(R.layout.tab_item, null);
final ImageView tabImage2 = (ImageView) tabView2.findViewById(R.id.tab_image);
tabImage2.setImageResource(R.drawable.a49);
final TextView tabText2 = (TextView) tabView2.findViewById(R.id.tab_text);
tabText2.setText(getString(R.string.tab_label_2));
mTabHost.addTab(mTabHost.newTabSpec(TABS[1]).setIndicator(tabView2),
TabFragment2.class, null);
View tabView3 = mLayoutInflater.inflate(R.layout.tab_item, null);
final ImageView tabImage3 = (ImageView) tabView3.findViewById(R.id.tab_image);
tabImage3.setImageResource(R.drawable.a49);
final TextView tabText3 = (TextView) tabView3.findViewById(R.id.tab_text);
tabText3.setText(getString(R.string.tab_label_3));
mTabHost.addTab(mTabHost.newTabSpec(TABS[2])
.setIndicator(tabView3), TabFragment3.class, null);
mTabHost.setCurrentTab(0);
mTabHost.setOnTabChangedListener(new TabHost.OnTabChangeListener() {
@Override
public void onTabChanged(String tabId) {
int child = mTabMap.get(tabId);
tabImage1.setImageResource(R.drawable.a49);
tabImage2.setImageResource(R.drawable.a49);
tabImage3.setImageResource(R.drawable.a49);
tabText1.setTextColor(COLOR_GRAY_01);
tabText2.setTextColor(COLOR_GRAY_01);
tabText3.setTextColor(COLOR_GRAY_01);
switch (child) {
case 0:
tabImage1.setImageResource(R.drawable.a4a);
tabText1.setTextColor(COLOR_GREEN_01);
break;
case 1:
tabImage2.setImageResource(R.drawable.a4a);
tabText2.setTextColor(COLOR_GREEN_01);
break;
case 2:
tabImage3.setImageResource(R.drawable.a4a);
tabText3.setTextColor(COLOR_GREEN_01);
break;
}
}
});
}
}
activity_fragment_tab_host.xml,使用FragmentTabHost;
标签放在页面底部;注意这里的id,以及layout的宽高设置
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="fill_parent"
android:layout_height="fill_parent"
android:orientation="vertical" >
<FrameLayout
android:id="@+id/realtabcontent"
android:layout_width="fill_parent"
android:layout_height="0dip"
android:layout_weight="1" />
<android.support.v4.app.FragmentTabHost
android:id="@android:id/tabhost"
android:layout_width="fill_parent"
android:layout_height="wrap_content"
android:background="@color/colorYellow01">
<FrameLayout
android:id="@android:id/tabcontent"
android:layout_width="0dp"
android:layout_height="0dp"
android:layout_weight="0" />
</android.support.v4.app.FragmentTabHost>
</LinearLayout>
因为切换标签时会重载fragment,可以在fragment中判断一下,已经加载过的,不需要重新加载;
TabFragment1.java 中定义了一个rootView
public class TabFragment1 extends Fragment {
private View rootView;// cache fragment view
TextView centerTV;
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
Log.d("rust", "TabFragment1 onCreateView");
if (rootView == null) {
rootView = inflater.inflate(R.layout.fragment_tab1, null);
}
ViewGroup parent = (ViewGroup) rootView.getParent();
// if root view had a parent, remove it.
if (parent != null) {
parent.removeView(rootView);
}
centerTV = (TextView) rootView.findViewById(R.id.center_tv);
centerTV.setOnClickListener(new View.OnClickListener() {
// @Override
public void onClick(View v) {
centerTV.setText(String.format("%s","Tab1 clicked"));
centerTV.setTextColor(Color.BLACK);
}
});
return rootView;
}
@Override
public void onResume() {
super.onResume();
Log.d("rust", "TabFragment1 onResume");
}
}
已点击的效果图:

Android - FragmentTabHost 与 Fragment 制作页面切换效果的更多相关文章
- Android - TabHost 与 Fragment 制作页面切换效果
Android - TabHost 与 Fragment 制作页面切换效果 Android API 19 , API 23 三个标签页置于顶端 效果图: 在文件BoardTabHost.java中定义 ...
- 【CSS3】纯CSS3制作页面切换效果
此前写的那个太复杂了,来点简单的核心 <html> <head> <title></title> <style type="text/c ...
- 使用ViewPager+Fragment实现选项卡切换效果
实现效果 本实例主要实现用ViewPage和Fragment实现选项卡切换效果,选项卡个数为3个,点击选项卡或滑动屏幕会切换Fragment并实现选项卡下方下边框条跟随移动效果. 本程序用androi ...
- jquery mobile页面切换效果(Flip toggle switch)(注:jQuery移动使用的数据属性的列表。 )
1.页面切换(data-transition)
- html5各种页面切换效果和模态对话框
页面动画:data-transition 属性可以定义页面切换是的动画效果.例如:<a href="index.html" data-transition="pop ...
- 基于html5和css3响应式全屏滚动页面切换效果
分享一款全屏响应式的HTML5和CSS3页面切换效果.这个页面布局效果对于那些页面要求固定100%高度和宽度的网站和APP来说是十分有用的.效果图如下: 在线预览 源码下载 HTML wrappe ...
- WP8 NavigationInTransition实现页面切换效果
NavigationInTransition这个是实现页面切换效果,而且没控件来拖,要自己手动写, 将App.xaml.cs中InitializePhoneApplication()函数里的RootF ...
- 在uwp仿IOS的页面切换效果
有时候我们需要编写一些迎合IOS用户使用习惯的uwp应用,我在这里整理一下仿IOS页面切换效果的代码. 先分析IOS的页面切换.用户使用左右滑动方式进行前进和后退,播放类似于FlipView的切换动画 ...
- [Swift通天遁地]九、拔剑吧-(7)创建旋转和弹性的页面切换效果
★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★★➤微信公众号:山青咏芝(shanqingyongzhi)➤博客园地址:山青咏芝(https://www.cnblogs. ...
随机推荐
- 可视化之AQICN
上一篇和大家分享了<可视化之Berkeley Earth>,这次看一看下面这个网站---aqicn.org.先做一个提示:文末有惊喜~ 该网站在中国有一定的权威性,PM2.5数据有一点敏感 ...
- 【原创+史上最全】Nginx+ffmpeg实现流媒体直播点播系统
#centos6.6安装搭建nginx+ffmpeg流媒体服务器 #此系统实现了视频文件的直播及缓存点播,并支持移动端播放(支持Apple和Android端) #系统需要自行安装,流媒体服务器配置完成 ...
- 用 Hexo + Github 搭建自己的博客
扯在前面 在很久很久以前,一直就想搭建属于自己的一个博客,但由于各种原因,最终都不了了之,恰好最近突然有了兴趣,于是就自己参照网上的教程,搭建了属于自己的博客. 至于为什么要搭建自己的博客了?哈哈,大 ...
- Cordova各个插件使用介绍系列(四)—canvas2ImagePlugin保存二维码到手机本地
详情链接地址:http://www.ncloud.hk/%E6%8A%80%E6%9C%AF%E5%88%86%E4%BA%AB/cordova-4-canvas2imageplugin/ 在前面几篇 ...
- Spring boot 1: 使用IDEA创建Spring boot项目
项目用到的环境: Windows 10 JDK8 IntelliJ IDEA 2017.1.3 Apache Tomcat 8 Maven 3.3.3 使用IDEA新建spring boot项目 新建 ...
- 高效率遍历Map以及在循环过程中移除 remove指定key
//高效率遍历Map以及在循环过程中移除 remove指定key //使用iter循环的时候 可以在循环中移除key,for在循环的过程中移除会报错哦 //本方法效率高 Iterator iter = ...
- php中的冒泡排序算法
<?php //php中的冒泡排序算法 //从大到小的排序方式 ,$arr[$j]>$arr[$j+1](这里换成了从小到大的排序方式) $arr=array(); $arr=array( ...
- 【Android Developers Training】 8. 定义Action Bar风格
注:本文翻译自Google官方的Android Developers Training文档,译者技术一般,由于喜爱安卓而产生了翻译的念头,纯属个人兴趣爱好. 原文链接:http://developer ...
- 5.Smart使用内置函数或者自定义函数
1.使用内置函数 例如使用date函数 {"Y-m-d"|date:$time}格式{第一个参数|方法:第二个参数:第三个参数}即可转换成 2016-07-19 2.使用resi ...
- SVN仓库迁移到Git遇到的两个问题和解决办法
OS: CentOS 7.0 准备: git svn git-svn sudo yum install git sudo yum install subversion sudo yum install ...