zoukankan      html  css  js  c++  java
  • Fragment 和 FragmentActivity的使用

    今天学习下 Android中的 Fragment 和 FragmentActivity,因为没有4.0手机,平台是2.3.3 所以我是使用 v4 support 包来进行学习。

    要想用Fragment 功能必须先让activity继承FragmentActivity,其原因是里面包含了Fragment运作的FragmentManager接口的实现类 FragmentManagerImpl ,由这个类管理所有Fragment的显示、隐藏

    1.使用最简单的Fragment,我们只要继承Fragment就可以

    [java] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. public class TextFragment extends Fragment{  
    2.       
    3.     private String mMsg;  
    4.       
    5.     public void setMessage(String message){  
    6.         this.mMsg = message;  
    7.     }  
    8.       
    9.     @Override  
    10.     public View onCreateView(LayoutInflater inflater, ViewGroup container,  
    11.             Bundle savedInstanceState) {  
    12.         // TODO Auto-generated method stub  
    13.         final Context context = getActivity();  
    14.         FrameLayout root = new FrameLayout(context);  
    15.         root.setBackgroundColor(Color.YELLOW);  
    16.         TextView tv = new TextView(context);  
    17.         tv.setText(mMsg);  
    18.         tv.setGravity(Gravity.CENTER);  
    19.         root.addView(tv, new FrameLayout.LayoutParams(  
    20.                 ViewGroup.LayoutParams.FILL_PARENT, ViewGroup.LayoutParams.FILL_PARENT));  
    21.         return root;  
    22.     }  
    23.   
    24. }  

    首先Fragment 就可以把它当作一个view , 只不过这个view 与 activity一样有了生命周期函数



    Fragment.onCreateView() 函数就是用于生成这个Fragment布局的view的,类似baseadapter.getView()

    这样一个包含一个TextView的简单布局就完成了。

    2.重写我们自己的FragmentActivity.

    这里面主要要通过FragmentManager 来进行Fragment的添加和删除:

    [java] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. public class DoorFragmentActivity extends FragmentActivity{  
    2.   
    3.     public static final String FRAG_SMS = "sms_list_frag";  
    4.     public static final String FRAG_TEXT = "text_frag";  
    5.       
    6.     private Fragment mSMSFragment;  
    7.     private Fragment mTextFragment;  
    8.     private FragmentManager mFragMgr;  
    9.       
    10.     private Button mMenuBtn;  
    11.       
    12.     @Override  
    13.     protected void onCreate(Bundle savedInstanceState) {  
    14.         // TODO Auto-generated method stub  
    15.         super.onCreate(savedInstanceState);  
    16.         setContentView(R.layout.door_fragment_activity_layout);  
    17.         mFragMgr = getSupportFragmentManager();  
    18.         mMenuBtn = (Button) findViewById(R.id.door_menu_btn);  
    19.         mMenuBtn.setOnClickListener(new OnClickListener() {  
    20.               
    21.             @Override  
    22.             public void onClick(View v) {  
    23.                 // TODO Auto-generated method stub  
    24.                 showFragments(FRAG_TEXT, true);  
    25.             }  
    26.         });  
    27.         mMenuBtn.setOnLongClickListener(new OnLongClickListener() {  
    28.               
    29.             @Override  
    30.             public boolean onLongClick(View v) {  
    31.                 // TODO Auto-generated method stub  
    32.                   
    33.                 return false;  
    34.             }  
    35.         });  
    36.         initFragments();  
    37.         showFragments(FRAG_SMS, false);  
    38.     }  
    39.       
    40.     private void initFragments(){  
    41.         mSMSFragment = new SMSListFragment();  
    42.         TextFragment textfrag = new TextFragment();  
    43.         textfrag.setMessage("这是 菜单界面");  
    44.         mTextFragment = textfrag;  
    45.           
    46.     }  
    47.       
    48.     private void showFragments(String tag, boolean needback){  
    49.         FragmentTransaction trans = mFragMgr.beginTransaction();  
    50.         if(needback){  
    51.             trans.setCustomAnimations(R.anim.frag_enter,    
    52.                     R.anim.frag_exit);  
    53.             trans.add(R.id.door_root_content_fl, getFragmentByTag(tag), tag);  
    54.             trans.addToBackStack(tag);  
    55.         }else{  
    56.             trans.replace(R.id.door_contents_fl, getFragmentByTag(tag), tag);  
    57.         }  
    58.         trans.commit();  
    59.     }  
    60.       
    61.     private Fragment getFragmentByTag(String tag){  
    62.         if(FRAG_SMS.equals(tag)){  
    63.             return mSMSFragment;  
    64.         }  
    65.         if(FRAG_TEXT.equals(tag)){  
    66.             return mTextFragment;  
    67.         }  
    68.         return null;  
    69.     }  
    70. }  
    • 首先我们获取FragmentManager实现:直接调用 FragmentActivity.getSupportFragmentManager(),看源码可以知道这返回的是FragmentManager内部定义的实现类FragmentManagerImpl。
    • 我们获取了FragmentManagerImpl后我们其实不咋操作这个类,只调用FragmentManager.beginTransation(),这个获取FragmentTransation接口的实现类(里面具体是BackStackRecord类的实例),我们关于Fragment的所有操作都是通过它来完成的,因为没仔细研究,我只了解直接自己在代码里面定义Fragment而没有在xml里面写(xml写觉得有点别扭)
    我们主要通过 FragmentTransation的一些方法来处理Fragment的:

    1) trans.add(fragment, tag);  这个实际是 containerViewId = 0 调用的3)
    2) trans.add(containerViewId, fragment);  这个实际是 tag = null 调用的 3)
    3) trans.add(containerViewId, fragment, tag);  如果containerViewId != 0实际上调用的是获取到

       fragment的 onCreateView方法返回的view 并加入到containerViewId这个viewgroup中去即                  viewgroup.addView(fragment.onCreateView());

    未解决问题:containerViewId = 0 的时候代表什么??

    4) trans.replace(containerViewId, fragment)  一样是null tag调用 5)
    5) trans.replace(containerViewId, fragment, tag)  这个一样是添加一个fragment到对应的container中去,只不过比add多了一步对相同containerViewId中已有的fragment检索,进行removeFragment操作,再去添加这个新来的fragment

    6) trans.addToBackStack(tag); 如果你的fragment对于back键有类似activity的回退响应,就要记得把它加入到里面去,trans里面模拟了栈,但是我的回退没有响应我设置的exit anim 这个无语还没解决

    3.再使用下ListFragment,我这里写的是SMSListFragment继承了ListFragment:

    [java] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. public class SMSListFragment extends ListFragment{  
    2.       
    3.     private ConversationListAdapter mAdapter;  
    4.     private ConversationQuery mQuery;  
    5.     private long startTime;  
    6.       
    7.     @Override  
    8.     public void onCreate(Bundle savedInstanceState) {  
    9.         // TODO Auto-generated method stub  
    10.         super.onCreate(savedInstanceState);  
    11.         mAdapter = new ConversationListAdapter(getActivity());  
    12.         mQuery = new ConversationQuery(getActivity().getContentResolver());  
    13.     }  
    14.       
    15.     @Override  
    16.     public void onActivityCreated(Bundle savedInstanceState) {  
    17.         // TODO Auto-generated method stub  
    18.         super.onActivityCreated(savedInstanceState);  
    19.         setListAdapter(mAdapter);  
    20.     }  
    21.       
    22.     @Override  
    23.     public void onStart() {  
    24.         // TODO Auto-generated method stub  
    25.         super.onStart();  
    26.         startAsyncQuery();  
    27.     }  
    28.       
    29.     @Override  
    30.     public void onStop() {  
    31.         // TODO Auto-generated method stub  
    32.         super.onStop();  
    33.         mAdapter.getCursor().close();  
    34.         mAdapter.changeCursor(null);  
    35.     }  
    36.       
    37.     public void startAsyncQuery() {  
    38.         startTime = System.currentTimeMillis();  
    39.         mQuery.startQuery(1, null, Conversation.sAllThreadsUri,  
    40.                 Conversation.ALL_THREADS_PROJECTION, null, null,  
    41.                 Conversation.CONVERSATION_ORDER);  
    42.     }  
    43.       
    44.     private final class ConversationQuery extends AsyncQueryHandler {  
    45.   
    46.         public ConversationQuery(ContentResolver cr) {  
    47.             super(cr);  
    48.             // TODO Auto-generated constructor stub  
    49.         }  
    50.   
    51.         @Override  
    52.         protected void onQueryComplete(int token, Object cookie, Cursor cursor) {  
    53.             // TODO Auto-generated method stub  
    54.             System.out.println("conversation cursor size : "  
    55.                     + cursor.getCount());  
    56.             mAdapter.changeCursor(cursor);  
    57.             Toast.makeText(  
    58.                     getActivity(),  
    59.                     "查询短信会话个数:" + cursor.getCount() + ",花费"  
    60.                             + (System.currentTimeMillis() - startTime) + " ms",  
    61.                     Toast.LENGTH_LONG).show();  
    62.         }  
    63.   
    64.     }  
    65.   
    66. }  
    代码中可以知道和使用普通的ListActivity完全没区别,

    onCreate()中完成自己要一次性初始的东西,我在里面主要是初始化一个adapter和一个对sms数据库的查询

    在onActivityCreated()中将adapter设置给listview,这个不确定有没有更好的位置,

    然后进入我们熟悉的生命周期方法:

    onStart()中,开启查询

    onStop()中,我们界面已经不在显示了,所以我们不关心数据库变化了,close cursor

    4.主页面的布局文件:

    [html] view plaincopy在CODE上查看代码片派生到我的代码片
     
    1. <?xml version="1.0" encoding="utf-8"?>  
    2. <FrameLayout xmlns:android="http://schemas.android.com/apk/res/android"  
    3.     android:id="@+id/door_root_content_fl"  
    4.     android:layout_width="match_parent"  
    5.     android:layout_height="match_parent" >  
    6.   
    7.     <LinearLayout  
    8.         android:layout_width="match_parent"  
    9.         android:layout_height="match_parent"  
    10.         android:orientation="vertical" >  
    11.   
    12.         <FrameLayout  
    13.             android:id="@+id/door_contents_fl"  
    14.             android:layout_width="match_parent"  
    15.             android:layout_height="0dp"  
    16.             android:layout_weight="1" />  
    17.   
    18.         <LinearLayout  
    19.             android:layout_width="match_parent"  
    20.             android:layout_height="55dp"  
    21.             android:orientation="horizontal" >  
    22.   
    23.             <Button  
    24.                 android:id="@+id/door_menu_btn"  
    25.                 android:layout_width="match_parent"  
    26.                 android:layout_height="match_parent"  
    27.                 android:gravity="center"  
    28.                 android:text="菜单" />  
    29.         </LinearLayout>  
    30.     </LinearLayout>  
    31.   
    32. </FrameLayout>  
    5.运行效果图:



    版权声明:本文为博主原创文章,未经博主允许不得转载。

     
  • 相关阅读:
    Photoshop 图文并茂常用快捷键
    程序员放松的8个好网站推荐
    Ehcache详细解读
    IT人士必去的10个网站
    [javascript]避免悲剧 密码生成器
    jQuery创建实例与原型继承揭秘
    [javascript]快速交换javascript变量的值
    [javascript]web216安全色拾色器colorpicker 支持浏览器边缘碰撞翻转(原生js)
    [Javascript]单例模式(singleton )
    duffsDevice 高速版
  • 原文地址:https://www.cnblogs.com/xgjblog/p/4619088.html
Copyright © 2011-2022 走看看