使用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. Android模块化编程之引用本地的aar

    随着项目越来越多,代码的复用就变得异常重要,这时候就要进行模块化编程,就是把一些通用的组件或者类库做成单独的模块,其他项目直接进行引用就好.针对Android开发最常见的就是Android Libra ...

  2. jquery中attr与pror

  3. javascript "非法值"检验.

    <script type="text/javascript"> function getCoord() { var x = document.getElementByI ...

  4. effective_c++条款20,用pass-by-reference-to-const替换pass-by-value

    pass-by-value void f(A a); 1)导致复制是浪费资源 2)多态是导致对象切割 所以我们使用 void f(const A& a) 上面的话针对class,不针对基本类型 ...

  5. struct可以拥有class般的构造函数

    struct A { int a, b; A(int x, int y) :a(x), b(y){} }; int main() { A a(1, 2); cout << a.a < ...

  6. php 字符编码转换函数 iconv mb_convert_encoding比较

    在使用PHP处理字符串时,我们经常会碰到字符编码转换的问题,你碰到过iconv转换失败吗? 发现问题时,网上搜了搜,才发现iconv原来有bug ,碰到一些生僻字就会无法转换,当然了配置第二个参数时, ...

  7. 未能在全局命名空间中找到类型或命名空间名称“Wuqi”

    下载了AspNetPager控件用以进行分页操作,在项目中放入控件后,运行报错:未能在全局命名空间中找到类型或命名空间名称“Wuqi” . 解决办法:在项目下拉框“引用“中添加AspNetPager引 ...

  8. c# Random太快产生的随机数会重复

    c# Random快速连续产生相同随机数的解决方案 Random类是一个产生伪随机数字的类,它的构造函数有两种,一个是直接New Random(),另外一个是New Random(Int32),前者是 ...

  9. github进行修改

    1)git status:可以让我们时刻掌握仓库当前的状态. 2)git diff [文件名]:查看改变的详细信息,显示的结果是Unix通用的diff格式. 步骤: 1.修改文件 2.通过git ad ...

  10. Linux下cut命令用法

    1 一两句话描述一下cut命令吧! 正如其名,cut的工作就是“剪”,具体的说就是在文件中负责剪切数据用的. cut是以每一行为一个处理对象的,这种机制和sed是一样的.(关于sed的入门文章将在近期 ...