首先是Fragment的文件
activity_fragment_tabxml
接下来是主Activity的布局文件
activity_fragment_tabxml
Fragment的类文件
ContextFragmentjava
Activity的类文件
FragmentTabActivityjava
第一步、需要先获取FragmentManager,该对象可以对Fragment进行管理
第二步、获得FragmentTranscation,FragmentManage对Fragment的一系列事务 *** 作主要由FragmentTranscation来执行
第三步、实例化Fragment,这步没什么好说的
第四步、将Fragment添加到容器中,这里用的是add()方法,其中replace()也可以实现,目前还没有了解这两个方法的区别
第五步、用Bundle来通信,实现向Fragment传递数据,这里主要传的是文本的值
第六步、提交事务,如果忘了这一步,之前所做的都没有效果,就跟执行更新数据,却没有提交一样
第一步、需要先获取FragmentManager,该对象可以对Fragment进行管理
第二步、获得FragmentTranscation,FragmentManage对Fragment的一系列事务 *** 作主要由FragmentTranscation来执行
显示Fragment
隐藏Fragment
最后一步、提交事务
Fragment是android30以上才引入的类,如果需要在30以下版本中使用,那么需要使用v4包,目前的Android开发工具,默认都会在libs目录下创建一个android-support-v4jar包。只有这个support-v4,即可使用Fragment了。
以下为使用Fragment的说明:
Fragment是android30引入的新控件,果应用使用在30以下、16及以上的版本,需要引入v4包。
Fragment支持在不同的Activity中使用并且可以处理自己的输入事件以及生命周期方法等。
Fragment的生命周期方法依赖于Activity的生命周期,例如一个Activity的onPause()的生命周期方法被调用的时候这个Activity中的所有的Fragment的onPause()方法也将被调用。
FragmentManager提供了对Activity运行时的Fragment的添加、删除、替换的 *** 作。在Activity运行期间可以添加Fragment而不是在XML布局文件中进行定义。如果打算在Activity中改变Fragment的生命过程。如果要执行添加、删除、修改的 *** 作,必须通过FragmentManager的对象获得一个FragmentTransaction对象,通过它的API来执行这些 *** 作。
两个单独的Fragment之间是不应该进行通信的。应该使用他们所存在的Activity作为沟通的纽带。
静态内部类仅能直接访问外部类的静态成员。可以设置一个静态的上下文变量或返回上下文的静态方法,只要在获取前保证得到的上下文已经实例化就好了。举个例子:
public class A extends Activity{
private static Context ct;
public void onCreate(Bundle savedInstanceState){
super
ct = this;
}
public static Context getContext(){
return ct;
}
static class B{
public void sample(){
Systemoutprint(ctoString);
Systemoutprint(getContext());
}
}
}你就是想在fragment调用父activity的方法对吧,很简单的,你在fragment里面定义一个接口,在onatt这个方法里面得到activity,然后在activity实现接口方法,然后你就可以调用了在使用fragment时首先要知道fragment的生命周期,我们能在生命周期方法中做什么 *** 作
onAttch(Activity activity):这个方法是在fragment与activity关联之后调用,我们能在这个方法中获取这个关联的activity的实例。但是当你的sdk更新到android60(api-23)是就会显示这个方法是过时的,使用onAttach(Context context)这个方法代替,但在看fragment的生命周期时,这个方法好像不调用,所以你获取的Context是null
onCreate:这个方法是在fragment初始化的时候调用,我们通常在这个方法中使用getArgument获取activity传来的初始化fragment的参数。
注意:在 这个方法中我们不能获取activity中的控件,下面的这段代码是在fragment的onCreate中的,你发现activity不是空,但是text是null。因为,这是activity的onCreate还没有执行完,即activity还没有创建完,要想获取activity相关的资源应该在onActivityCreated中获取。
[java] view plain copy
MainActivity activity=(MainActivity) getActivity();//activity不是null
TextView text=activityfindViewById(Ridtextview);//text是null
onCreateView:这个方法中我们主要是通过布局填充器获取fragment布局。我们在这个方法中通过viewfindViewById初始化fragment中的控件,
[java] view plain copy
@Override
public View onCreateView(LayoutInflater inflater, ViewGroup container, Bundle savedInstanceState) {
view=inflaterinflate(Rlayouttext_content, null);//获取布局
text=(TextView) viewfindViewById(Ridtextview);//初始化fragment的控件
return view;
}
onActivityCreated:这个方法是在activity的onCreate方法执行完执行这个方法,通知fragment,关联的activity的onCreate方法执行完了,即activity创建完了,可以在这个方法中获取activity中的资源。例如下面,可以获取activity布局中的TextView控件
[java] view plain copy
@Override
public void onActivityCreated(Bundle savedInstanceState) {
superonActivityCreated(savedInstanceState);
TextView text=getActivity()findViewById(Ridtextview);//获取activity布局中的TextView控件
}
onStart:这个是在activity的onstart执行完立即执行,这个方法执行完fragment界面就显示出来了,但是现在还没有获取焦点,用户是不能 *** 作。
onResume:这个方法是在activity的onResume方法执行完立即执行,此时fragment的获取了界面,用户可以 *** 作。
onPause:fragment失去焦点,此时用户是不能 *** 作的,执行完立即执行activity的onPause方法。
onStop:fragment不可见,执行完立即执行activity的onStop方法。
onDestroyView:在onCreateView中创建的fragment视图会被销毁。Fragment的视图被回收。
onDestroy:当这个fragment不再使用时调用。需要注意的是,它即使经过了onDestroy()阶段,但仍然能从Activity中找到,因为它还没有Detach
onDetach:fragment与activity解除关联,fragment的所有的资源都被回收。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)