热门标签 | HotTags
当前位置:  开发笔记 > Android > 正文

AndroidListView数据的分批显示功能

本文通过实例代码给大家分享了AndroidListView数据的分批显示功能,非常不错具有参考借鉴价值,需要的朋友参考下吧

Android ListView数据的分批显示

布局文件activity_call_safe2.xml

<&#63;xml version="1.0" encoding="utf-8"&#63;>

  
    
    

CasllSafeActivity.java

package com.ldw.safe.Activity;
import java.util.List;
import android.app.Activity;
import android.content.Context;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.view.View.OnClickListener;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.EditText;
import android.widget.ImageView;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
import com.ldw.safe.R;
import com.ldw.safe.adapter.MyBaseAdapter;
import com.ldw.safe.bean.BlackNumberInfo;
import com.ldw.safe.db.dao.BlackNumberDao;
public class CallSafeActivity extends Activity {
 private ListView list_view_callsafe;
 private List blackNumberInfos;
 private LinearLayout ll_pb;
 private BlackNumberDao dao;
 private CallSafeAdapter adapter;
 private int totalNumber;//总的条数
 private int mStartIndex = 0;//开始加载的位置
 private int maxCount = 20;//每页加载多少数据
 @Override
  protected void onCreate(Bundle savedInstanceState) {
    super.onCreate(savedInstanceState);
    setContentView(R.layout.activity_call_safe2);
    initUi();
    initData();
 }
 //初始化数据
 private Handler handler = new Handler(){
 @Override
    public void handleMessage(Message msg) {
  //数据初始化结束,关闭家在全的展示
  ll_pb.setVisibility(View.INVISIBLE);
  //防止适配器一直刷新
  if(adapter == null){
  adapter = new CallSafeAdapter(blackNumberInfos, CallSafeActivity.this);
  //配置适配器
  list_view_callsafe.setAdapter(adapter);
  }else{
   adapter.notifyDataSetChanged();
  }
 }
 };
 private EditText et_page_number;
 //初始化数据
 private void initData() {
 //防止阻塞主线程,在子线程中初始化数据(后期数据会很多)
 new Thread(){
  @Override
  public void run(){
  dao = new BlackNumberDao(CallSafeActivity.this);
   //一共有多少条数据
     totalNumber = dao.getTotalNumber();
  //分批加载数据
     if(blackNumberInfos == null){
      //第一次加载
      blackNumberInfos = dao.findPar2(mStartIndex, maxCount);
     }else{
      //把后面的数据。追加到blackNumberInfos集合里面。防止黑名单被覆盖
      blackNumberInfos.addAll(dao.findPar2(mStartIndex, maxCount));
     }
  handler.sendEmptyMessage(0);
  }
 }.start();
 }
 //初始化UI
 private void initUi() {
 ll_pb = (LinearLayout) findViewById(R.id.ll_pb);
    //初始化的时候展示加载的圆圈
    ll_pb.setVisibility(View.VISIBLE);
 list_view_callsafe = (ListView) findViewById(R.id.list_view_callsafe);
 //设置listView的滚动监听器
 list_view_callsafe.setOnScrollListener(new OnScrollListener(){
      //状态改变时候回调的方法
      /*
       * @param scrollState 表示滚动的状态
       *AbsListView.OnScrollListener.SCROLL_STATE_IDLE 闲置状态
       *AbsListView.OnScrollListener.SCROLL_STATE_TOUCH_SCROLL 手指触摸的时候的状态
       *AbsListView.OnScrollListener.SCROLL_STATE_FLING 惯性
       */
  @Override
  public void onScrollStateChanged(AbsListView view, int scrollState) {
        switch (scrollState) {
        case AbsListView.OnScrollListener.SCROLL_STATE_IDLE:
          //获取到最后一条显示的数据条数
          int lastVisiblePosition = list_view_callsafe.getLastVisiblePosition();
          System.out.println("lastVisiblePosition==========" + lastVisiblePosition);
            if(lastVisiblePosition == blackNumberInfos.size() - 1){//判断最后一个数据是不是每页显示的数据-1
              // 加载更多的数据。 更改加载数据的开始位置
              mStartIndex += maxCount;
              if (mStartIndex >= totalNumber) {
                Toast.makeText(getApplicationContext(),
                    "没有更多的数据了。", Toast.LENGTH_SHORT).show();
                return;
              }
              initData();
            }
          break;
      }
  }
  //listview滚动的时候调用的方法
      //时时调用。当我们的手指触摸的屏幕的时候就调用
  @Override
  public void onScroll(AbsListView view, int firstVisibleItem,
   int visibleItemCount, int totalItemCount) {
  // TODO Auto-generated method stub
  }
 });
 }
 //对代码进行优化,继承自定义MyBaseAdapter,MyBaseAdapter继承自BaseAdapter封装一些常用的方法
 private class CallSafeAdapter extends MyBaseAdapter{
 private CallSafeAdapter(List lists, Context mContext){
  super(lists, mContext);
 }
 @Override
 public View getView(int position, View convertView, ViewGroup parent) {
  //谷歌推出的优化方案
  ViewHolder holder;
  if(cOnvertView== null){
  cOnvertView= View.inflate(CallSafeActivity.this, R.layout.item_call_safe, null);
  holder = new ViewHolder();
  holder.tv_number = (TextView) convertView.findViewById(R.id.tv_number);
  holder.tv_mode = (TextView) convertView.findViewById(R.id.tv_mode);
  holder.iv_delete = (ImageView) convertView.findViewById(R.id.iv_delete);
  convertView.setTag(holder);
  }else{
  holder = (ViewHolder) convertView.getTag();
  }
  holder.tv_number.setText(lists.get(position).getNumber());
  String mode = lists.get(position).getMode();
  if(mode.equals("1")){
  holder.tv_mode.setText("电话和短信拦截");
  }else if(mode.equals("2")){
  holder.tv_mode.setText("电话拦截");
  }else if(mode.equals("3")){
  holder.tv_mode.setText("短信拦截");
  }
  final BlackNumberInfo info = lists.get(position);
  //监听删除数据按钮,删除数据
  holder.iv_delete.setOnClickListener(new OnClickListener(){
  @Override
  public void onClick(View v) {
   String number = info.getNumber();
   boolean result = dao.delete(number);
   if(result){
   Toast.makeText(CallSafeActivity.this, "删除成功", Toast.LENGTH_SHORT).show();
   lists.remove(info);
   //更新ListView
   adapter.notifyDataSetChanged();
   }else{
   Toast.makeText(CallSafeActivity.this, "删除失败", Toast.LENGTH_SHORT).show();
   }
  }
  });
  return convertView;
  /*
  //谷歌推出的优化方案
  ViewHolder holder;
  if(cOnvertView== null){
  cOnvertView= View.inflate(CallSafeActivity.this, R.layout.item_call_safe, null);
  holder = new ViewHolder();
  holder.tv_number = (TextView) convertView.findViewById(R.id.tv_number);
  holder.tv_mode = (TextView) convertView.findViewById(R.id.tv_mode);
  convertView.setTag(holder);
  }else{
  holder = (ViewHolder) convertView.getTag();
  }
  holder.tv_number.setText(blackNumberInfos.get(position).getNumber());
  String mode = blackNumberInfos.get(position).getMode();
  if(mode.equals("1")){
  holder.tv_mode.setText("电话和短信拦截");
  }else if(mode.equals("2")){
  holder.tv_mode.setText("电话拦截");
  }else if(mode.equals("3")){
  holder.tv_mode.setText("短信拦截");
  }
  return convertView;
  */
  /*初步的优化
  cOnvertView= View.inflate(CallSafeActivity.this, R.layout.item_call_safe, null);
  TextView tv_number = (TextView) convertView.findViewById(R.id.tv_number);
  TextView tv_mode = (TextView) convertView.findViewById(R.id.tv_mode);
  tv_number.setText(blackNumberInfos.get(position).getNumber());
  String mode = blackNumberInfos.get(position).getMode();
  if(mode.equals("1")){
  tv_mode.setText("电话和短信拦截");
  }else if(mode.equals("2")){
  tv_mode.setText("电话拦截");
  }else if(mode.equals("3")){
  tv_mode.setText("短信拦截");
  }
  return convertView;
  */
  /*传统的方式
  View view = View.inflate(CallSafeActivity.this, R.layout.item_call_safe, null);
  TextView tv_number = (TextView) view.findViewById(R.id.tv_number);
  TextView tv_mode = (TextView) view.findViewById(R.id.tv_mode);
  tv_number.setText(blackNumberInfos.get(position).getNumber());
  String mode = blackNumberInfos.get(position).getMode();
  if(mode.equals("1")){
  tv_mode.setText("电话和短信拦截");
  }else if(mode.equals("2")){
  tv_mode.setText("电话拦截");
  }else if(mode.equals("3")){
  tv_mode.setText("短信拦截");
  }
  return view;
  */
 } 
 }
 static class ViewHolder{
 TextView tv_number;
 TextView tv_mode;
 ImageView iv_delete;
 }
}

以上所述是小编给大家介绍的Android ListView数据的分批显示功能,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!


推荐阅读
  • Android 九宫格布局详解及实现:人人网应用示例
    本文深入探讨了人人网Android应用中独特的九宫格布局设计,解析其背后的GridView实现原理,并提供详细的代码示例。这种布局方式不仅美观大方,而且在现代Android应用中较为少见,值得开发者借鉴。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • Android LED 数字字体的应用与实现
    本文介绍了一种适用于 Android 应用的 LED 数字字体(digital font),并详细描述了其在 UI 设计中的应用场景及其实现方法。这种字体常用于视频、广告倒计时等场景,能够增强视觉效果。 ... [详细]
  • RecyclerView初步学习(一)
    RecyclerView初步学习(一)ReCyclerView提供了一种插件式的编程模式,除了提供ViewHolder缓存模式,还可以自定义动画,分割符,布局样式,相比于传统的ListVi ... [详细]
  • 本文详细介绍了如何使用PHP检测AJAX请求,通过分析预定义服务器变量来判断请求是否来自XMLHttpRequest。此方法简单实用,适用于各种Web开发场景。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 本文探讨了 RESTful API 和传统接口之间的关键差异,解释了为什么 RESTful API 在设计和实现上具有独特的优势。 ... [详细]
  • 本文详细介绍了如何使用Spring Boot进行高效开发,涵盖了配置、实例化容器以及核心注解的使用方法。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • Python自动化处理:从Word文档提取内容并生成带水印的PDF
    本文介绍如何利用Python实现从特定网站下载Word文档,去除水印并添加自定义水印,最终将文档转换为PDF格式。该方法适用于批量处理和自动化需求。 ... [详细]
  • 在当前众多持久层框架中,MyBatis(前身为iBatis)凭借其轻量级、易用性和对SQL的直接支持,成为许多开发者的首选。本文将详细探讨MyBatis的核心概念、设计理念及其优势。 ... [详细]
  • 将Web服务部署到Tomcat
    本文介绍了如何在JDeveloper 12c中创建一个Java项目,并将其打包为Web服务,然后部署到Tomcat服务器。内容涵盖从项目创建、编写Web服务代码、配置相关XML文件到最终的本地部署和验证。 ... [详细]
  • XNA 3.0 游戏编程:从 XML 文件加载数据
    本文介绍如何在 XNA 3.0 游戏项目中从 XML 文件加载数据。我们将探讨如何将 XML 数据序列化为二进制文件,并通过内容管道加载到游戏中。此外,还会涉及自定义类型读取器和写入器的实现。 ... [详细]
  • 本文介绍如何在 Unity 的 XML 配置文件中,将参数传递给自定义生命周期管理器的构造函数。我们将详细探讨 CustomLifetimeManager 类的实现及其配置方法。 ... [详细]
  • 本文详细介绍了 Java 中 org.apache.xmlbeans.SchemaType 类的 getBaseEnumType() 方法,提供了多个代码示例,并解释了其在不同场景下的使用方法。 ... [详细]
author-avatar
手机用户2502858405
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有