一直以来不知Android中Loader怎么用,今天晚上特意花了时间来研究,算是基本上搞明白了,现在把相关的注释和代码发出来,以便笔记和给网友一个参考,错误之处还望大家给我留言,共同进步,这个例子采用的是android事例代码,在其中比较难理解的地方,给出注释,代码如下:

public class MainActivity extends FragmentActivity {  
  
    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        //这是使用的android-support-v4.jar兼容包,如果网友使用的android4.0以上的版本  
        //可不使用,改成相应的方法就行  
        FragmentManager fm = getSupportFragmentManager();  
        if (fm.findFragmentById(android.R.id.content) == null) {  
            CursorLoaderListFragment list = new CursorLoaderListFragment();  
            fm.beginTransaction().add(android.R.id.content, list).commit();  
        }  
    }  
      
    public static class CursorLoaderListFragment extends ListFragment  
        implements OnQueryTextListener,OnCloseListener,  
        LoaderCallbacks<Cursor>{  
          
        SimpleCursorAdapter mAdapter;  
        SearchView mSearchView;  
        String mCurFilter;  
          
        @Override  
        public void onActivityCreated(Bundle savedInstanceState) {  
            // TODO Auto-generated method stub  
            super.onActivityCreated(savedInstanceState);  
            //设置没有数据显示的默认文本  
            setEmptyText("No phone numbers");  
            //设置可由fragment创建的菜单  
            setHasOptionsMenu(true);  
            //设置适配器  
            mAdapter = new SimpleCursorAdapter(getActivity(),  
                    android.R.layout.simple_list_item_2, null,  
                    new String[] { Contacts.DISPLAY_NAME, Contacts.CONTACT_STATUS },  
                    new int[] { android.R.id.text1, android.R.id.text2 }, 0);  
            setListAdapter(mAdapter);  
            //设置不显示ListView,等待加载完成以后显示  
            setListShown(false);  
            //初始化加载器  
            getLoaderManager().initLoader(0, null, this);  
        }  
          
        public static class MySearchView extends SearchView {  
            public MySearchView(Context context) {  
                super(context);  
            }  
  
            //正常的SearchView不会清楚搜索文本当SearchView关闭是,所以我们要重写  
            @Override  
            public void onActionViewCollapsed() {  
                //一当关闭就设置查询文本为空  
                setQuery("", false);  
                super.onActionViewCollapsed();  
            }  
        }  
  
        @Override  
        public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {  
            // TODO Auto-generated method stub  
            //将搜索框加入ActionBar  
            MenuItem item = menu.add("Search");  
            //设置SearchView的图标  
            item.setIcon(android.R.drawable.ic_menu_search);  
            //设置ActionItem的显示方式  
            item.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM  
                    | MenuItem.SHOW_AS_ACTION_COLLAPSE_ACTION_VIEW);  
            //使用自定义的SearchView以便更好的控制  
            mSearchView = new MySearchView(getActivity());  
            //设置文本改变的监听器  
            mSearchView.setOnQueryTextListener(this);  
            //设置可删除文本的监听器  
            mSearchView.setOnCloseListener(this);  
            //设置图标是否显示在文本的旁边,还是作为背景  
            mSearchView.setIconifiedByDefault(true);  
            //将SearchView作为ActionItem的选项  
            item.setActionView(mSearchView);   
        }  
  
        @Override  
        public void onListItemClick(ListView l, View v, int position, long id) {  
            // TODO Auto-generated method stub  
            super.onListItemClick(l, v, position, id);  
            Log.i("FragmentComplexList", "Item clicked: " + id);  
        }  
          
        static final String[] CONTACTS_SUMMARY_PROJECTION = new String[] {  
            Contacts._ID,  
            Contacts.DISPLAY_NAME,  
            Contacts.CONTACT_STATUS,  
            Contacts.CONTACT_PRESENCE,  
            Contacts.PHOTO_ID,  
            Contacts.LOOKUP_KEY,  
        };  
          
        @Override  
        public Loader<Cursor> onCreateLoader(  
                int arg0, Bundle arg1) {  
            // TODO Auto-generated method stub  
            Uri baseUri;  
            if (mCurFilter != null) {  
                baseUri = Uri.withAppendedPath(Contacts.CONTENT_FILTER_URI,  
                        Uri.encode(mCurFilter));  
            } else {  
                baseUri = Contacts.CONTENT_URI;  
            }  
            String select = "((" + Contacts.DISPLAY_NAME + " NOTNULL) AND ("  
                    + Contacts.HAS_PHONE_NUMBER + "=1) AND ("  
                    + Contacts.DISPLAY_NAME + " != '' ))";  
            //创建一个新的装载器  
            return new CursorLoader(getActivity(), baseUri,  
                    CONTACTS_SUMMARY_PROJECTION, select, null,  
                    Contacts.DISPLAY_NAME + " COLLATE LOCALIZED ASC");  
        }  
  
        @Override  
        public void onLoadFinished(Loader<Cursor> arg0, Cursor arg1) {  
            // TODO Auto-generated method stub  
            //以前一直不明白这句话的意思,只知道是交换一个新的Cursor,返回一个旧的Cursor,  
            //现在大概明白了,在这里将新的Cursor交给mAdapter,以便ListView能够显示,  
            //细心的朋友可能会发现,在创建mAdapter的时候传入的Cursor为空,其实是没有数据  
            //的,在这里加载好了,就把这个新的Curosr对象传进去,让ListView  
            //显示,这个地方很多网友搞不明白,这里多解释一下  
            mAdapter.swapCursor(arg1);  
  
            //现在显示ListView  
            if (isResumed()) {  
                setListShown(true);  
            } else {  
                setListShownNoAnimation(true);  
            }  
        }  
  
        @Override  
        public void onLoaderReset(Loader<Cursor> arg0) {  
            // TODO Auto-generated method stub  
            //当这个Loader被重置时,也就是调用了restartLoader方法是,使以前的数据无效  
            mAdapter.swapCursor(null);  
        }  
  
        @Override  
        public boolean onClose() {  
            // TODO Auto-generated method stub  
            if (!TextUtils.isEmpty(mSearchView.getQuery())) {  
                mSearchView.setQuery(null, true);  
            }  
            return true;  
        }  
  
        @Override  
        public boolean onQueryTextChange(String newText) {  
            String newFilter = !TextUtils.isEmpty(newText) ? newText : null;  
            if (mCurFilter == null && newFilter == null) {  
                return true;  
            }  
            if (mCurFilter != null && mCurFilter.equals(newFilter)) {  
                return true;  
            }  
            mCurFilter = newFilter;  
            getLoaderManager().restartLoader(0, null, this);  
            return true;  
        }  
  
        @Override  
        public boolean onQueryTextSubmit(String query) {  
            // TODO Auto-generated method stub  
            return true;  
        }  
    }  
}  

  

理解android中ListFragment和Loader的更多相关文章

  1. 【转】Android菜单详解——理解android中的Menu--不错

    原文网址:http://www.cnblogs.com/qingblog/archive/2012/06/08/2541709.html 前言 今天看了pro android 3中menu这一章,对A ...

  2. 深入理解Android中View

    文章目录   [隐藏] 一.View是什么? 二.View创建的一个概述: 三.View的标志(Flag)系统 四.MeasureSpec 五.几个重要方法简介 5.1 onFinishInflate ...

  3. Android菜单详解(一)——理解android中的Menu

    前言 今天看了pro android 3中menu这一章,对Android的整个menu体系有了进一步的了解,故整理下笔记与大家分享. PS:强烈推荐<Pro Android 3>,是我至 ...

  4. 深入理解Android中ViewGroup

    文章目录   [隐藏] 一.ViewGroup是什么? 二.ViewGroup这个容器 2.1 添加View的算法 2.1.1 我们先来分析addViewInner方法: 2.1.2 addInArr ...

  5. 彻底理解 Android 中的阴影

    如果我们想创造更好的 Android App,我相信我们需要遵循 Material Design 的设计规范.一般而言,Material Design 是一个包含光线,材质和投影的三维环境.如果我们想 ...

  6. 一个demo让你彻底理解Android中触摸事件的分发

    注:本文涉及的demo的地址:https://github.com/absfree/TouchDispatch 1. 触摸动作及事件序列 (1)触摸事件的动作 触摸动作一共有三种:ACTION_DOW ...

  7. 绝对让你理解Android中的Context

    这个问题是StackOverFlow上面一个热门的问题What is Context in Android? 整理这篇文章的目的是Context确实是一个非常抽象的东西.我们在项目中随手都会用到它,但 ...

  8. 理解Android中的注解与反射

    反射 Java反射(Reflection)定义 Java反射机制是指在运行状态中 对于任意一个类,都能知道这个类的所有属性和方法:对于任何一个对象,都能够调用它的任何一个方法和属性: 这样动态获取新的 ...

  9. 【转】深入理解Android中的SharedPreferences

    SharedPreferences作为Android中数据存储方式的一种,我们经常会用到,它适合用来保存那些少量的数据,特别是键值对数据,比如配置信息,登录信息等.不过要想做到正确使用SharedPr ...

随机推荐

  1. 【杂题】[LibreOJ 2541] 【PKUWC2018】猎人杀【生成函数】【概率与期望】

    Description 猎人杀是一款风靡一时的游戏"狼人杀"的民间版本,他的规则是这样的: 一开始有 n个猎人,第 i 个猎人有仇恨度 wi.每个猎人只有一个固定的技能:死亡后必须 ...

  2. Python pip离线部署

    因为生产环境不能联网,必须使用离线部署pip包,倒也不用部署Pypi镜像那么大工作量,其实蛮简单的,贴出了备忘 pip download -r requirements.txt -d packages ...

  3. 删除数据库的数据后让id从1开始算

    delete from t_AttendanceRecorddbcc checkident('t_AttendanceRecord',reseed,0) truncate table  表名称

  4. (转)深入剖析Redis主从复制

    一.主从概述 Redis 支持 Master-Slave(主从)模式,Redis Server 可以设置为另一个 Redis Server 的主机(从机),从机定期从主机拿数据.特殊的,一个从机同样可 ...

  5. 【Maven学习】maven基本命令

    maven最主要的命令如下: mvn clean compile:告诉Maven编译项目主代码 mvn clean test:执行src/test/main下面的test方法,在执行测试之前,会自动执 ...

  6. Javac的命令(-Xlint)

    在OptionName类中的枚举定义如下: XLINT("-Xlint"), XLINT_CUSTOM("-Xlint:"), -Xlint     Enabl ...

  7. CC2530串口工作

    前言 嘿嘿,我只是写给我自己的一篇博客,今天研究了一天的CC2530,感觉好累,虽然是已经落伍的技术了,但是我觉得不要小看它,还是能够学到点东西的,随着学习的深入,渐渐感觉有点突破的苗头了!哈哈 CC ...

  8. C/C++编码规范

    C/C++编码规范 今天人们越来越明白软件设计更多地是一种工程,而不是一种个人艺术.由于大型产品的开发通常由很多的人协同作战,如果不统一编程规范,最终合到一起的程序,其可读性将较差,这不仅给代码的理解 ...

  9. PHP命名规则

    参考: http://nowhisky.diandian.com/post/2012-08-12/40033898638 就一般约定而言,类.函数和变量的名字应该是能够让代码阅读者能够容易地知道这些代 ...

  10. i.mx6 Android6.0.1分析input子系统:测试

    getevent与sendevent工具 Android系统提供了getevent与sendevent两个工具供开发者从设备节点中直接读取输入事件或写入输入事件. 在这里,我们测试音量加和音量减按键 ...