使用ListView过程中,如果滚动加载数据的操作比较费时,很容易在滚屏时出现屏幕卡住的现象,一个解决的办法就是不要在滚动时加载数据,而是等到滚动停止后再进行数据的加载。这同样要实现OnScrollListener接口,关于该接口的简要描述见上一篇文章,这里直接进行代码的分析:

  1. package hust.iprai.asce1885;
  2. import android.app.ListActivity;
  3. import android.content.Context;
  4. import android.os.Bundle;
  5. import android.view.LayoutInflater;
  6. import android.view.View;
  7. import android.view.ViewGroup;
  8. import android.widget.AbsListView;
  9. import android.widget.AbsListView.OnScrollListener;
  10. import android.widget.BaseAdapter;
  11. import android.widget.TextView;
  12. public class MainActivity extends ListActivity implements OnScrollListener {
  13. private TextView mStatus; //显示滚屏状态
  14. private boolean mBusy = false; //标识是否存在滚屏操作
  15. /**
  16. * 自定义Adapter,实现ListView中view的显示
  17. *
  18. */
  19. private class SlowAdapter extends BaseAdapter {
  20. private LayoutInflater mInflater;
  21. public SlowAdapter(Context context) {
  22. mInflater = (LayoutInflater) context.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
  23. }
  24. /**
  25. * 列表中元素个数取决于数据的个数
  26. */
  27. public int getCount() {
  28. return mStrings.length;
  29. }
  30. /**
  31. * 我们的模拟数据是从数组中获取的,因此这里直接返回索引值就可以获取相应的数据了
  32. */
  33. public Object getItem(int position) {
  34. return position;
  35. }
  36. /**
  37. * 使用数组的索引作为唯一的id
  38. */
  39. public long getItemId(int position) {
  40. return position;
  41. }
  42. /**
  43. * 获取List中每一行的view
  44. */
  45. public View getView(int position, View convertView, ViewGroup parent) {
  46. TextView text;
  47. //给text赋值
  48. if (null == convertView) {
  49. text = (TextView) mInflater.inflate(android.R.layout.simple_list_item_1, parent, false);
  50. } else {
  51. text = (TextView) convertView;
  52. }
  53. if (!mBusy) {
  54. //当前不处于加载数据的忙碌时期(没有滚屏),则显示数据
  55. text.setText(mStrings[position]);
  56. //这里约定将tag设置为null说明这个view已经有了正确的数据
  57. text.setTag(null);
  58. } else {
  59. //当前处于滚屏阶段,不加载数据,直接显示数据加载中提示
  60. text.setText("Loading...");
  61. //tag非空说明这个view仍然需要进行数据加载并显示
  62. text.setTag(this);
  63. }
  64. return text;
  65. }
  66. }
  67. @Override
  68. public void onCreate(Bundle savedInstanceState) {
  69. super.onCreate(savedInstanceState);
  70. setContentView(R.layout.main);
  71. mStatus = (TextView) findViewById(R.id.status);
  72. mStatus.setText("Idle");
  73. //使用自定义的ListAdapter将数据映射到TextView中
  74. setListAdapter(new SlowAdapter(this));
  75. //设置滚动监听器
  76. getListView().setOnScrollListener(this);
  77. }
  78. public void onScroll(AbsListView view, int firstVisibleItem,
  79. int visibleItemCount, int totalItemCount) {
  80. }
  81. public void onScrollStateChanged(AbsListView view, int scrollState) {
  82. switch (scrollState) {
  83. case OnScrollListener.SCROLL_STATE_IDLE: //Idle态,进行实际数据的加载显示
  84. mBusy = false;
  85. int first = view.getFirstVisiblePosition();
  86. int count = view.getChildCount();
  87. for (int i = 0; i < count; i++) {
  88. TextView tv = (TextView) view.getChildAt(i);
  89. if (tv.getTag() != null) { //非null说明需要加载数据
  90. tv.setText(mStrings[first + i]);
  91. tv.setTag(null);
  92. }
  93. }
  94. mStatus.setText("Idle");
  95. break;
  96. case OnScrollListener.SCROLL_STATE_TOUCH_SCROLL:
  97. mBusy = true;
  98. mStatus.setText("Touch Scroll");
  99. break;
  100. case OnScrollListener.SCROLL_STATE_FLING:
  101. mBusy = true;
  102. mStatus.setText("Fling");
  103. break;
  104. default:
  105. mStatus.setText("Are you kidding me!");
  106. break;
  107. }
  108. }
  109. private String[] mStrings = {
  110. "Abbaye de Belloc", "Abbaye du Mont des Cats", "Abertam",
  111. "Abondance", "Ackawi", "Acorn", "Adelost", "Affidelice au Chablis",
  112. "Afuega'l Pitu", "Airag", "Airedale", "Aisy Cendre",
  113. "Allgauer Emmentaler", "Alverca", "Ambert", "American Cheese",
  114. "Ami du Chambertin", "Anejo Enchilado", "Anneau du Vic-Bilh",
  115. "Anthoriro", "Appenzell", "Aragon", "Ardi Gasna", "Ardrahan",
  116. "Armenian String", "Aromes au Gene de Marc", "Asadero", "Asiago",
  117. "Aubisque Pyrenees", "Autun", "Avaxtskyr", "Baby Swiss", "Babybel",
  118. "Baguette Laonnaise", "Bakers", "Baladi", "Balaton", "Bandal",
  119. "Banon", "Barry's Bay Cheddar", "Basing", "Basket Cheese",
  120. "Bath Cheese", "Bavarian Bergkase", "Baylough", "Beaufort",
  121. "Beauvoorde", "Beenleigh Blue", "Beer Cheese", "Bel Paese",
  122. "Bergader", "Bergere Bleue", "Berkswell", "Beyaz Peynir",
  123. "Bierkase", "Bishop Kennedy", "Blarney", "Bleu d'Auvergne",
  124. "Bleu de Gex", "Bleu de Laqueuille", "Bleu de Septmoncel",
  125. "Bleu Des Causses", "Blue", "Blue Castello", "Blue Rathgore",
  126. "Blue Vein (Australian)", "Blue Vein Cheeses", "Bocconcini",
  127. "Bocconcini (Australian)", "Boeren Leidenkaas", "Bonchester",
  128. "Bosworth"};
  129. }

下面是布局文件main.xml:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
  3. android:orientation="vertical"
  4. android:layout_width="match_parent"
  5. android:layout_height="match_parent">
  6. <ListView android:id="@android:id/list"
  7. android:layout_width="match_parent"
  8. android:layout_height="0dip"
  9. android:layout_weight="1"
  10. android:drawSelectorOnTop="false"/>
  11. <TextView android:id="@+id/status"
  12. android:layout_width="match_parent"
  13. android:layout_height="wrap_content"
  14. android:paddingLeft="8dip"
  15. android:paddingRight="8dip"/>
  16. </LinearLayout>

程序运行结果如下图所示:

Android开源代码解读のOnScrollListener实现ListView滚屏时不加载数据的更多相关文章

  1. jQuery+Ajax滚屏异步加载数据实现(附源码)

    一.CSS样式 body { font:12px/1.0em Microsoft Yahei; line-height:1.6em; background:#fff; line-height:1.2e ...

  2. Android开源代码解读-基于SackOfViewAdapter类实现类似状态通知栏的布局

    一般来说,ListView的列表项都会采用相同的布局,只是填充的内容不同而已,这种情况下,Android提供了convertView帮我们缓存列表项,达到循环利用的目的,开发者也会使用ViewHold ...

  3. Listview滑动时不加载数据,停下来时加载数据,让App更优

    http://blog.csdn.net/yy1300326388/article/details/45153813

  4. material design 的android开源代码整理

    material design 的android开源代码整理 1 android (material design 效果的代码库) 地址请点击:MaterialDesignLibrary 效果: 2 ...

  5. 22个值得收藏的Android开源代码-UI篇

    本文介绍了android开发者中比较热门的开源代码,这些代码绝大多数可以直接应用到项目中. FileBrowserView 一个强大的文件选择控件.界面比较漂亮,使用也很简单.特点:可以自定义UI:支 ...

  6. android开源代码

    Android开源项目--分类汇总 转自:https://github.com/Trinea/android-open-project Android开源项目第一篇——个性化控件(View)篇 包括L ...

  7. 160多个android开源代码汇总

    第一部分 个性化控件(View) 主要介绍那些不错个性化的View,包括ListView.ActionBar.Menu.ViewPager.Gallery.GridView.ImageView.Pro ...

  8. 22个值得收藏的Android开源代码——cool

    转自http://www.jcodecraeer.com/a/anzhuokaifa/androidkaifa/2014/1020/1808.html 本文介绍了android开发者中比较热门的开源代 ...

  9. 优秀开源代码解读之JS与iOS Native Code互调的优雅实现方案

    简介 本篇为大家介绍一个优秀的开源小项目:WebViewJavascriptBridge. 它优雅地实现了在使用UIWebView时JS与ios 的ObjC nativecode之间的互调,支持消息发 ...

随机推荐

  1. SearchBox( 搜索框) 组件

    一. 加载方式//class 加载方式<input id="ss" class="easyui-searchbox" style="width: ...

  2. css伪类选择器详细解析及案例使用-----伪类选择器(1)

    动态伪类选择器:E:link :选择匹配的E元素,并且匹配元素被定义了超链接并未被访问过.E:visited :选择匹配的E元素,而且匹配的元素被定义了连接并已被访问过.E:active :选择匹配的 ...

  3. iOS分享 - 对象间的通信之delegate、notificationCenter与block

    在项目开发中,常常会涉及到对象之间的通信,而为了降低对象间的耦合,会采用delegate.notificationCenter.block三种方式来进行实现,对于他们的使用,也许大家都能熟练掌握,但是 ...

  4. 验证码 Demo

    //设置响应头 response.setCharacterEncoding("image/jpeg"); int width=160; int height=40; Buffere ...

  5. uva 846 - Steps

    找出步數與距離的關係即可得解. 0步最多能抵達的距離是0 1步最多能抵達的距離是1(1) 2步最多能抵達的距離是2(1 1) 3步最多能抵達的距離是4(1 2 1) 4步最多能抵達的距離是6(1 2 ...

  6. Linux修改时间时区并在Tomcat中生效

    Linux查看当前时间时区linux:~ # datelinux:~ # date –Rlinux:~ # zdump -v /usr/share/zoneinfo/Asia/Beijing ---- ...

  7. 智能的PHP缩图类

    *作者:落梦天蝎(beluckly)*完成时间:2006-12-18*类名:CreatMiniature*功能:生成多种类型的缩略图*基本参数:$srcFile,$echoType*方法用到的参数:$ ...

  8. CSS - 针对不同浏览器的写法

    火狐浏览器: @-moz-document url-prefix() { /*这段区域的样式代码只在firefox起作用*/ .x{ width: 100px; height: 100px; back ...

  9. jQuery的Autocomplete插件的远程url取json数据的问题

    关于远程返回的json数据的展示,以前一样的代码,如果是本地写好的json串数据,插件显示就没有问题,一旦换成ulr方式读取一样的数据,插件就不能正常显示问题了. 今天偶然搜索资料找到一篇csdn上有 ...

  10. Swift--存储属性-备

    Swift中的属性分为存储属性和计算属性,存储属性就是Objective-C中的数据成员,计算属性不存储数据,但可以通过计算其他属性返回数据. 存储属性可以存储数据,分为常量属性(用关键字let定义) ...