博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Android Loader详解四:回调及完整例子
阅读量:6689 次
发布时间:2019-06-25

本文共 3852 字,大约阅读时间需要 12 分钟。

From:

 

onLoadFinished

这个方法是在前面已创建的装载器已经完成其加载过程后被调用.这个方法保证会在应用到装载器上的数据被释放之前被调用.在此方法中,你必须删除所有对旧数据的使用(因为它将很快会被删除),但是不要自己去释放它们,因为它们的装载器会做这些事情.

装载器一旦了解到应用不再使用数据时,将马上释放这些数据.例如,如果数据是一个从CursorLoader来的游标,你不应调用游标的close().如果游标被放置在一个CursorAdapter中,你应使用swapCursor()方法,以使旧的游标不被关闭.例如:

 

[java] 
  1. //这个Adapter被用于显示列表的数据.  
  2. SimpleCursorAdapter mAdapter;  
  3. ...  
  4.   
  5. public void onLoadFinished(Loader<Cursor> loader, Cursor data) {  
  6.     // Swap the new cursor in.  (The framework will take care of closing the  
  7.     // old cursor once we return.)  
  8.     mAdapter.swapCursor(data);  
  9. }  

 

 

onLoaderReset

当一个已创建的装载器被重置从而使其数据无效时,此方法被调用.此回调使你能发现什么时候数据将被釋放于是你可以釋放对它的引用.

下面这个实现调用参数为nullswapCursor()

 

[java] 
  1. // 这个Adapter被用于显示列表的数据.  
  2. SimpleCursorAdapter mAdapter;  
  3. ...  
  4.   
  5. public void onLoaderReset(Loader<Cursor> loader) {  
  6.     //此处是用于上面的onLoadFinished()的游标将被关闭时执行, 我们需确保我们不再使用它.  
  7.     mAdapter.swapCursor(null);  
  8. }  

 

 

例子

作为一个例子,这里完整实现了一个Fragment显示一个包含从联系人contentprovider 返回查询数据的ListView的内容的功能.它使用一个CursorLoader来管理对provider的查询.

为了能从用户的联系人中取得数据,本例的manifest必须包含READ_CONTACTS权限.

 

[java] 
  1. public static class CursorLoaderListFragment extends ListFragment  
  2.         implements OnQueryTextListener, LoaderManager.LoaderCallbacks<Cursor> {  
  3.   
  4.     // 这是用于显示列表数据的Adapter  
  5.     SimpleCursorAdapter mAdapter;  
  6.   
  7.     // 如果非null,这是当前的搜索过虑器  
  8.     String mCurFilter;  
  9.   
  10.     @Override public void onActivityCreated(Bundle savedInstanceState) {  
  11.         super.onActivityCreated(savedInstanceState);  
  12.   
  13.         // 如果列表中没有数据,就给控件一些文字去显示.在一个真正的应用  
  14.         // 中这应用资源中取得.  
  15.         setEmptyText("No phone numbers");  
  16.   
  17.         // 我们在动作栏中有一个菜单项.  
  18.         setHasOptionsMenu(true);  
  19.   
  20.         // 创建一个空的adapter,我们将用它显示加载后的数据  
  21.         mAdapter = new SimpleCursorAdapter(getActivity(),  
  22.                 android.R.layout.simple_list_item_2, null,  
  23.                 new String[] { Contacts.DISPLAY_NAME, Contacts.CONTACT_STATUS },  
  24.                 new int[] { android.R.id.text1, android.R.id.text2 }, 0);  
  25.         setListAdapter(mAdapter);  
  26.   
  27.         // 准备loader.可能是重连到一个已存在的或开始一个新的  
  28.         getLoaderManager().initLoader(0nullthis);  
  29.     }  
  30.   
  31.     @Override public void onCreateOptionsMenu(Menu menu, MenuInflater inflater) {  
  32.         // 放置一个动作栏项用于搜索.  
  33.         MenuItem item = menu.add("Search");  
  34.         item.setIcon(android.R.drawable.ic_menu_search);  
  35.         item.setShowAsAction(MenuItem.SHOW_AS_ACTION_IF_ROOM);  
  36.         SearchView sv = new SearchView(getActivity());  
  37.         sv.setOnQueryTextListener(this);  
  38.         item.setActionView(sv);  
  39.     }  
  40.   
  41.     public boolean onQueryTextChange(String newText) {  
  42.         // 在动作栏上的搜索字串改变时被调用.更新  
  43.         //搜索过滤器,并重启loader来执行一个新的查询  
  44.         mCurFilter = !TextUtils.isEmpty(newText) ? newText : null;  
  45.         getLoaderManager().restartLoader(0nullthis);  
  46.         return true;  
  47.     }  
  48.   
  49.     @Override public boolean onQueryTextSubmit(String query) {  
  50.         // 我们不关心这个方法  
  51.         return true;  
  52.     }  
  53.   
  54.     @Override public void onListItemClick(ListView l, View v, int position, long id) {  
  55.         // 写入你想写的代码  
  56.         Log.i("FragmentComplexList""Item clicked: " + id);  
  57.     }  
  58.   
  59.     // 这是我们想获取的联系人中一行的数据.  
  60.     static final String[] CONTACTS_SUMMARY_PROJECTION = new String[] {  
  61.         Contacts._ID,  
  62.         Contacts.DISPLAY_NAME,  
  63.         Contacts.CONTACT_STATUS,  
  64.         Contacts.CONTACT_PRESENCE,  
  65.         Contacts.PHOTO_ID,  
  66.         Contacts.LOOKUP_KEY,  
  67.     };  
  68.     public Loader<Cursor> onCreateLoader(int id, Bundle args) {  
  69.         // 当一个新的loader需被创建时调用.本例仅有一个Loader,  
  70.         //所以我们不需关心ID.首先设置base URI,URI指向的是联系人  
  71.         Uri baseUri;  
  72.         if (mCurFilter != null) {  
  73.             baseUri = Uri.withAppendedPath(Contacts.CONTENT_FILTER_URI,  
  74.                     Uri.encode(mCurFilter));  
  75.         } else {  
  76.             baseUri = Contacts.CONTENT_URI;  
  77.         }  
  78.   
  79.         // 现在创建并返回一个CursorLoader,它将负责创建一个  
  80.         // Cursor用于显示数据  
  81.         String select = "((" + Contacts.DISPLAY_NAME + " NOTNULL) AND ("  
  82.                 + Contacts.HAS_PHONE_NUMBER + "=1) AND ("  
  83.                 + Contacts.DISPLAY_NAME + " != '' ))";  
  84.         return new CursorLoader(getActivity(), baseUri,  
  85.                 CONTACTS_SUMMARY_PROJECTION, select, null,  
  86.                 Contacts.DISPLAY_NAME + " COLLATE LOCALIZED ASC");  
  87.     }  
  88.   
  89.     public void onLoadFinished(Loader<Cursor> loader, Cursor data) {  
  90.         // 将新的cursor换进来.(框架将在我们返回时关心一下旧cursor的关闭)  
  91.         mAdapter.swapCursor(data);  
  92.     }  
  93.   
  94.     public void onLoaderReset(Loader<Cursor> loader) {  
  95.         //在最后一个Cursor准备进入上面的onLoadFinished()之前.  
  96.         // Cursor要被关闭了,我们需要确保不再使用它.  
  97.         mAdapter.swapCursor(null);  
  98.     }  
  99. }  

 本文转自老Zhan博客园博客,原文链接:http://www.cnblogs.com/mybkn/articles/2485230.html,如需转载请自行联系原作者

你可能感兴趣的文章
MySQL5.6优化了派生子查询
查看>>
谈一谈Mybatis分页查询
查看>>
记linux shell的两个小技巧:shell数组和字符串判断
查看>>
Cisco3550交换机配置DHCP;vlan,acl经典应用
查看>>
把C#.NET程序移植到DB2上的经验浅谈(C#连接DB2可以用IBM.Data.DB2.dll)
查看>>
学焊接专业的编程爱好者应用好通用权限管理系统写出了自己工作中需要的小软件...
查看>>
rhel5+dhcp+vsftp+pxe+tftp+kickstart环境配置脚本
查看>>
不同换行符的差异处理
查看>>
解决:由于本机限制,该操作已被取消‏
查看>>
Capital One World MasterCard Cashback
查看>>
Intel(R) 82579V网卡驱动程序 for Windows Server 2003 x64
查看>>
统一一个文件中bit位 1 的个数
查看>>
nginx+keepalived以及nginx反向代理实现
查看>>
企业为什么抛弃传统电话?
查看>>
centos7.2源码安装php7.0.9和nginx1.10.3服务器
查看>>
[php]php连mysql出错:Call to undefined function mysql_connect()
查看>>
strtolower() 函数
查看>>
MongoDB查询返回指定键
查看>>
SQL Server 2017 AlwaysOn on Linux 配置和维护(12)
查看>>
SQL Server 2017 AlwaysOn on Linux 配置和维护(18)
查看>>