Frament基础知识
Frament介绍
Frament应用
如何创建Frament
加载Frament的两种方式
Frament的声明周期
动态加载
静态加载
Frament的生命周期
创建Fragment类
为了创建Fragment,我们需要继承Fragment类。跟Activity一样,我们可以重写跟自定义的Fragment生命周期相关的方法。
跟Activity不同的是,Fragment在onCreateView()回调函数中定义自己的布局。实际上,我们只要在onCreateView()中定义Fragment布局,就可以使用Fragment了,这是唯一一个我们必须要实现的方法。举个例子,下面我们将简单地定义一个Fragment的布局(布局文件article_view.xml可以从文章下方的示例代码中找)。
复制代码
package com.bang.testfragment;
import android.os.Bundle;
import android.support.v4.app.Fragment;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
public class ArticleFragment extends Fragment{
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container,
Bundle savedInstanceState) {
//在这里定义Fragment的布局
return inflater.inflate(R.layout.article_view, container,false);
}
}
使用XML布局文件向Activity添加Fragment
因为fragment是可重用、模块化的UI控件,每一个Fragment类的实例都必须跟一个父FragmentActivity关联起来。你可以通过在你的activity的XML布局文件中定义每一个fragment实现他们之间的关联。
注:FragmentActivity是Support Library中提供的特殊的Activity,它主要用来兼容在API level11之前的系统中fragment的使用问题。如果你需要支持的最低系统版本是API level11或更高,那么你可以使用普通的 Activity.
下面的布局文件定义了在屏幕比较大的情况下,如何添加两个fragment到Activity上(在路径名中带有large的修饰符)
res/layout-large/news_articles.xml
复制代码
<fragment android:name="com.example.android.fragments.HeadlinesFragment"
android:id="@+id/headlines_fragment"
android:layout_weight="1"
android:layout_width="0dp"
android:layout_height="match_parent" />
<fragment android:name="com.example.android.fragments.ArticleFragment"
android:id="@+id/article_fragment"
android:layout_weight="2"
android:layout_width="0dp"
android:layout_height="match_parent" />
复制代码
建议:如果你想要了解更多如何兼容不同大小的设备的方法,可以看一下Supporting Different Screen Sizes.
复制代码
package com.bang.testfragment;
import android.os.Bundle;
import android.support.v4.app.FragmentActivity;
public class MainActivity extends FragmentActivity {
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.news_articles);
}
}
复制代码
然后,我们需要将这个布局文件应用到我们的Activity中。
如果你用的是v7 appcompat library,你的Activity应该继承ActionBarActivity而不是FragmentActivity,因为ActionBarActivity是Fragment的子类。
onAttach()
这个是回调函数
这个时候 activity已经传进来了,获得activity的传递的值
就可以进行 与activity的通信里
当然也可以使用getActivity(),前提是这个fragment已经和宿主的activity关联,
并且没有脱离
他只调用一次。
onCreate()
系统创建fragment的时候回调他,在他里面实例化一些变量
这些个变量主要是:当你 暂停 停止的时候 你想保持的数据
如果我们要为fragment启动一个后台线程,可以考虑将代码放于此处。
参数是:Bundle savedInstance, 用于保存 Fragment 参数,
Fragement也可以重写 onSaveInstanceState(BundleoutState)方法,
保存Fragement状态;可以用于 文件保护
他也只调用一次。
onCreateView()
第一次使用的时候 fragment会在这上面画一个layout出来,
为了可以画控件 要返回一个 布局的view,也可以返回null
当系统用到fragment的时候 fragment就要返回他的view,越快越好,
所以尽量在这里不要做耗时操作,比如从数据库加载大量数据显示listview,当然线程还是可以的。
给当前的fragment绘制ui布局,可以使用线程更新UI
说白了就是加载fragment的布局的。
这里一般都先判断是否为null
if(text==null){
Bundle args=getArguments();
text=args.getString(“text”);
}
if (view == null) {
view = inflater.inflate(R.layout.hello, null);
}
这样进行各判断省得每次都要加载,减少资源消耗
onActivityCreated()
当Activity中的onCreate方法执行完后调用。
注意了:
从这句官方的话可以看出:当执行onActivityCreated()的时候 activity的onCreate才刚完成。
所以在onActivityCreated()调用之前 activity的onCreate可能还没有完成,
所以不能再onCreateView()中进行 与activity有交互的UI操作,UI交互操作可以砸onActivityCreated()里面进行。
所以呢:这个方法主要是初始化那些你需要你的父Activity或者Fragment的UI已经被完整初始化才能初始化的元素。
如果在onCreateView里面初始化空间 会慢很多,比如listview等
onStart()
和activity等同
启动, Fragement 启动时回调, 此时Fragement可见;
onResume()
和activity等同
在activity中运行是可见的激活, Fragement 进入前台, 可获取焦点时激活;
onPause()
和activity等同
其他的activity获得焦点,这个仍然可见第一次调用的时候,
指的是 用户 离开这个fragment(并不是被销毁)
通常用于 用户的提交(可能用户离开后不会回来了)
onStop()
和activity等同
fragment不可见的,可能情况:activity被stopped了 OR fragment被移除但被加入到回退栈中
一个stopped的fragment仍然是活着的如果长时间不用也会被移除
onDestroyView()
Fragment中的布局被移除时调用。
表示fragemnt销毁相关联的UI布局清除所有跟视图相关的资源,
以前以为这里没什么用处其实 大有文章可做,
相信大家都用过ViewPager+Fragment,由于ViewPager的缓存机制,每次都会加载3页。
例如:有四个 fragment 当滑动到第四页的时候 第一页执行onDestroyView(),但没有执行onDestroy。
他依然和activity关联。当在滑动到第一页的时候又执行了 onCreateView()。 生命周期可以自己试一下。
那么问题来了。会出现重复加载view的局面,所以这么做(下面是先人的代码)
@Override
public void onDestroyView() {
if(view!=null){
((ViewGroup)view.getParent()).removeView(view);
}
super.onDestroyView();
}
onDestroy()
销毁fragment对象
跟activity类似了。
onDetach()
Fragment和Activity解除关联的时候调用。