Fragment允许将Activity拆分成多个完全独立封装的可重用的组件,每个组件有它自己的生命周期和UI布局。Fragment最大的优点是为不同屏幕大小创建灵活的UI。每个Fragment都是独立的模块,多个Activity可以共用一个Fragment,可以在Activity中进行Fragment的添加,删除,更换。

创建Fragment

继承Fragment类创建新的Fragment。

public class TestFragment extends Fragment {
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
//创建或者填充Fragment的UI,并且返回
//如果这个Fragment没有UI,返回null
return inflater.inflate(R.layout.fragment_page, container, false);
}
}

Fragment不需要在Manifest中进行注册。它的生命周期依赖于它所嵌入的Activity。

Fragment生命周期

Fragment和Activity的生命周期类似,但是有自己特有的生命周期处理程序。Fragment还包含一些Callback,用来标识它父Activity之间的绑定和解绑定关系、它自己View的创建和销毁情况以及它父Activity的创建过程完成情况。

public class TestFragment extends Fragment {

    //调用该方法Fragment会被连接到它的父Activity上
@Deprecated
@Override
public void onAttach(Activity activity) {
super.onAttach(activity);
} //调用该方法Fragment会被连接到它的父Activity上
@Override
public void onAttach(Context context) {
super.onAttach(context);
//获取对context的引用
} //调用该方法进行Fragment的初始创建
@Override
public void onCreate(@Nullable Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
} //创建自己的用户界面
@Nullable
@Override
public View onCreateView(LayoutInflater inflater, @Nullable ViewGroup container, @Nullable Bundle savedInstanceState) {
return inflater.inflate(R.layout.fragment_page, container, false);
} //父Activity和Fragment已经创建
@Override
public void onActivityCreated(@Nullable Bundle savedInstanceState) {
super.onActivityCreated(savedInstanceState);
//完成Fragment的初始化,尤其那些父Activity被初始化完成后或者Fragment的View被完全填充后才能做的事情
} //在可见生命周期开始时调用
@Override
public void onStart() {
super.onStart();
} //在活动周期开始时调用
@Override
public void onResume() {
super.onResume();
} //在活动生命周期结束时调用
@Override
public void onPause() {
super.onPause();
} //保存UI状态
@Override
public void onSaveInstanceState(Bundle outState) {
super.onSaveInstanceState(outState);
//outState会传递给onCreate、onCreateView和onActivityCreate方法中
} //在可见生命周期结束时调用
@Override
public void onStop() {
super.onStop();
} //当Fragment的View被分离时,调用
@Override
public void onDestroyView() {
//清除资源相关的View
super.onDestroyView();
} //在整个生命周期结束时调用该方法
@Override
public void onDestroy() {
//清除所有资源,结束线程和关闭数据库连接等
super.onDestroy();
} //当Fragment从它的父Activity上分离时,调用该方法
@Override
public void onDetach() {
super.onDetach();
}
}

Activity管理Fragment

每一个Activity都包含一个FragmentManager来管理它所包含的Fragment。可以通过使用getFragmentManager或者getSupportFragmentManager()来访问FragmentManager:

FragmentManager fragmentManager = getSupportFragmentManager();

FragmentManager提供很多方法来访问Fragment,通过执行FragmentTransaction来添加、删除和替换Fragment。

静态添加

在Activity布局文件中使用fragment标签来包含要添加的fragment:

<fragment
android:name="com.fengwei23.PageFragment"
android:layout_width="match_parent"
android:layout_height="match_parent"/>

动态添加

在Activity的布局文件中使用FrameLayout来当作Fargment的容器:

<FrameLayout
android:id="@+id/fl_container"
android:layout_width="match_parent"
android:layout_height="match_parent"/>

然后在Activity中使用FragmentTransaction来创建相应的Fragment,并添加到对应的容器中:

FragmentManager fragmentManager = getSupportFragmentManager();
FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
PageFragment pageFragment = new PageFragment();
fragmentTransaction.add(R.id.fl_container,pageFragment);
//指定动画
//可以添加到回退栈中
fragmentTransaction.commit();

添加、替换和删除Fragment

添加:

FragmentManager fragmentManager = getSupportFragmentManager();
FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
PageFragment pageFragment = new PageFragment();
fragmentTransaction.add(R.id.fl_container,pageFragment);
fragmentTransaction.commit();

替换:

FragmentManager fragmentManager = getSupportFragmentManager();
FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
PageFragment pageFragment = new PageFragment();
fragmentTransaction.replace(R.id.page_fragment,pageFragment);
fragmentTransaction.commit();

删除:

FragmentManager fragmentManager = getSupportFragmentManager();
FragmentTransaction fragmentTransaction = fragmentManager.beginTransaction();
PageFragment pageFragment = fragmentManager.findFragmentById(R.id.page_fragment);
fragmentTransaction.remove(pageFragment);
fragmentTransaction.commit();

查找Fragment

通过XML布局方式把Fragment加到Activity中,使用fragmentManager.findFragmentById(R.id.page_fragment)查找。如果添加的Fragment有加入TAG,可使用fragmentManager.findFragmentByTag(FRAGMENT_TAG)

Fragment Back栈

Fragment的回退栈类似于Activity的栈,当想要管理Fragment的时候可以使用fragmentTransaction.addToBackStack(tag),这样在可见的Fragment返回时会回到上一个可见的Fragment。

FragmentTransaction加载动画

使用fragmentTransaction.setTransition(FragmentTransaction.TRANSIT_FRAGMENT_OPEN)可以添加过渡动画、使用fragmentTransaction.setCustomAnimations()可以添加自定义动画。

Fragment和Activity交互

Fragment获得Activity的引用:getActivity(),Fragment传递事件给Activity可以使用接口回调等。

Fragment初探的更多相关文章

  1. Android Fragment初探:静态Fragment组成Activity

    一直习惯了在Activity中写所有事件处理代码,直到认真学习Fragment时,才发现,Activity完全可以由多个Fragment组成. 对Fragment的了解还不够深入,先从静态Fragme ...

  2. Android Fragment完全解析

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/8881711 我们都知道,Android上的界面展示都是通过Activity实现的, ...

  3. ViewPager+Fragment再探:和TAB滑动条一起三者结合

    Fragment前篇: <Android Fragment初探:静态Fragment组成Activity> ViewPager前篇: <Android ViewPager初探:让页面 ...

  4. Android Fragment完全解析,关于碎片你所需知道的一切

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/8881711 我们都知道,Android上的界面展示都是通过Activity实现的, ...

  5. Android Fragment完全解析,关于碎片你所需知道的一切 (转)。

    我们都知道,Android上的界面展示都是通过Activity实现的,Activity实在是太常用了,我相信大家都已经非常熟悉了,这里就不再赘述. 但是Activity也有它的局限性,同样的界面在手机 ...

  6. Android开发:碎片Fragment完全解析fragment_main.xml/activity_main.xml(转)

    注明:这个转的,见谅未能标明原始出处 我们都知道,Android上的界面展示都是通过Activity实现的,Activity实在是太常用了,我相信大家都已经非常熟悉了,这里就不再赘述. 但是Activ ...

  7. Android系列之Fragment(一)----Fragment加载到Activity当中

    Android上 的界面展示都是通过Activity实现的,Activity实在是太常用了.但是Activity也有它的局限性,同样的界面在手机上显示可能很好看, 在平板上就未必了,因为平板的屏幕非常 ...

  8. Android开发:碎片Fragment完全解析fragment_main.xml/activity_main.xml

    Android开发:碎片Fragment完全解析   为了让界面可以在平板上更好地展示,Android在3.0版本引入了Fragment(碎片)功能,它非常类似于Activity,可以像 Activi ...

  9. 二、fragment使用

    转载请注明出处:http://blog.csdn.net/guolin_blog/article/details/8881711 我们都知道,Android上的界面展示都是通过Activity实现的, ...

随机推荐

  1. Java线程池的选择

    在java的concurrent.Executors主要提供两种线程池:无固定线程数但有限制任务队列的cachedThreadPool与有固定线程数但无任务队列限制的fixedThreadPool,这 ...

  2. 2018焦作网络赛 - Poor God Water 一道水题的教训

    本题算是签到题,但由于赛中花费了过多的时间去滴吧格,造成了不必要的浪费以及智商掉线,所以有必要记录一下坑点 题意:方格从1到n,每一格mjl可以选择吃鱼/巧克力/鸡腿,求走到n格时满足 1.每三格不可 ...

  3. Jenkins 源代码编译

    最近一直想写一个关于 Jenkins 管理的 InelliJ 插件,但是尝试很多次总是在登录认证上面失败,各种办法都不起作用,而且官方的文档含糊不清,就动起了从源代码编译在开发环境中进行调试. 废话少 ...

  4. Hadoop2.5.0伪分布式环境搭建

    本章主要介绍下在Linux系统下的Hadoop2.5.0伪分布式环境搭建步骤.首先要搭建Hadoop伪分布式环境,需要完成一些前置依赖工作,包括创建用户.安装JDK.关闭防火墙等. 一.创建hadoo ...

  5. Mac下使用Wine安装Notepad++

    下载: (链接: https://pan.baidu.com/s/1miOjLXY 密码: 2egg) 安装: 1.安装Wine 参考:http://www.cnblogs.com/EasonJim/ ...

  6. ACM练习网站

    1.http://www.acmerblog.com/ Acm之家 2.http://acm.nyist.net/JudgeOnline/problemset.php 南阳理工学院

  7. 前后端完全分离开发模式Tomcat跨域问题处理

    公司新项目实现方案采用前后端完全分离架构,后端采用spring boot框架,前端纯HTML5开发部署会采用同一台服务器,但是在实现过程中分工开发出现ajax请求跨域问题故为解决开发问题发现如下解决方 ...

  8. SymbolTable

    在ClassReader中有两个重要的属性,如下定义: /** A hashtable containing the encountered top-level and member classes, ...

  9. 深度学习(五)正则化之L1和L2

    监督机器学习问题无非就是“minimizeyour error while regularizing your parameters”,也就是在规则化参数的同时最小化误差.最小化误差是为了让我们的模型 ...

  10. 在超链接href中实现form的提交

    <form name="form1" method="post" action=""> <div class=" ...