分批加载

每次滑动至底端,从数据库中获取10条数据,并加载于ListView中

数据库

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
package com.example.listviewbatchloading;
  
import android.content.Context;
import android.database.sqlite.SQLiteDatabase;
import android.database.sqlite.SQLiteDatabase.CursorFactory;
import android.database.sqlite.SQLiteOpenHelper;
  
public class PersonDb extends SQLiteOpenHelper {
  
   public PersonDb(Context context) {
     super (context, "creature" , null , 1 );
     // TODO Auto-generated constructor stub
   }
  
   @Override
   public void onCreate(SQLiteDatabase db) {
     // TODO Auto-generated method stub
     db.execSQL( "create table people(_id integer primary key autoincrement,name char,number char)" );
   }
  
   @Override
   public void onUpgrade(SQLiteDatabase db, int oldVersion, int newVersion) {
     // TODO Auto-generated method stub
     db.execSQL( "drop table people" );
     onCreate(db);
   }
  
}

数据库的业务封装,其中获取更多数据的是核心代码

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
package com.example.listviewbatchloading;
  
/**
  * 数据库的业务封装类
  */
  
import java.util.ArrayList;
import java.util.List;
  
import android.content.ContentValues;
import android.content.Context;
import android.database.Cursor;
import android.database.sqlite.SQLiteDatabase;
  
public class PersonList {
    
   PersonDb personDb;
    
   public PersonList(Context context){
     this .personDb = new PersonDb(context);
   }
    
   /**
    *   获取一定条目的数据
    * @param startIndex
    *   开始取数据的位置
    * @param num
    *   取多少条数据
    */
   public List<Person> getMoreDatas( int startIndex, int num){
      
     List<Person> list = new ArrayList<Person>();
     SQLiteDatabase db = personDb.getWritableDatabase();
     Cursor cursor = db.rawQuery( "select name,number from people order by _id desc limit ?,?" ,
         new String[]{startIndex + "" ,num + "" });
      
     while (cursor.moveToNext()){
       Person person = new Person();
       person.setName(cursor.getString(cursor.getColumnIndex( "name" )));
       person.setNumber(cursor.getString(cursor.getColumnIndex( "number" )));
       list.add(person);
     }
      
     cursor.close();
     db.close();
      
      
     return list;
      
   }
    
   /**
    *   添加数据库条目
    * @param name
    * @param number
    */
   public void add(String name,String number){
      
     SQLiteDatabase db = personDb.getWritableDatabase();
      
     ContentValues cv = new ContentValues();
     cv.put( "name" , name);
     cv.put( "number" , number);
      
     db.insert( "people" , null , cv);
     db.close();
   }
    
}

功能实现

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
package com.example.listviewbatchloading;
  
import java.util.ArrayList;
import java.util.List;
  
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.AbsListView.OnScrollListener;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;
import android.widget.Toast;
  
public class MainActivity extends Activity {
    
   private ListView lv ;
   private List<Person> datas = new ArrayList<Person>();
   private static int PERPAGE = 10 ; //每页加载数目
   private static final int FINISH = 0 ; //数据加载完成
   private List<Person> moreDatas; //每次加载的数据
   private MyAdapter adapter;
   private PersonList personList ;
    
   //若数据较多,耗时较长,数据加载完成时,发送FINISH至handler,并通知ListView更新数据
   private Handler handler = new Handler(){
     public void handleMessage(android.os.Message msg) {
        
       switch (msg.what) {
       case FINISH:
         if (moreDatas.size() != 0 ) {
           System.out.println(moreDatas.toString());
           adapter.notifyDataSetChanged();
         } else {
           Toast.makeText(MainActivity. this , "没有更多数据" , Toast.LENGTH_SHORT).show();
         }
         break ;
  
       default :
         break ;
       }
        
        
     };
   };
    
   @Override
   protected void onCreate(Bundle savedInstanceState) {
     super .onCreate(savedInstanceState);
     setContentView(R.layout.activity_main);
     initView();
     initData();
     initEvent();
   }
   /**
    *   为ListView添加滚动监听事件,但滚动至最后一行时,加载更多数据
    */
   private void initEvent() {
     lv.setOnScrollListener( new OnScrollListener() {
        
       @Override
       public void onScrollStateChanged(AbsListView view, int scrollState) {
         // TODO Auto-generated method stub
         if (scrollState == OnScrollListener.SCROLL_STATE_IDLE) {
           int lastVisiblePosition = lv.getLastVisiblePosition();
           if (lastVisiblePosition == datas.size() - 1 ) {
             initData();
             System.out.println( "加载更多数据" );
           }
         }
       }
        
       @Override
       public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
         // TODO Auto-generated method stub
          
       }
     });
   }
  
   private void initView() {
      
     setContentView(R.layout.activity_main);
      
     lv = (ListView) findViewById(R.id.lv);
     personList = new PersonList(getApplicationContext());
     adapter = new MyAdapter();
     lv.setAdapter(adapter);
   }
    
   /**
    * 在子线程中加载数据,避免主线程阻塞
    */
   private void initData() {
     new Thread() {
  
       public void run() {
  
         // 加载更多数据
         moreDatas = personList.getMoreDatas(datas.size(), PERPAGE);
  
         datas.addAll(moreDatas); // 把一个容器的所有数据加进来
         // 取数据完成,发消息通知取数据完成
         handler.obtainMessage(FINISH).sendToTarget();
  
       };
     }.start();
   }
    
   private class ItemView{
     private TextView tv_name;
     private TextView tv_num;
   }
    
   /**
    *   ListView的适配器
    * @author lian
    *
    */
   private class MyAdapter extends BaseAdapter{
  
     @Override
     public int getCount() {
       // TODO Auto-generated method stub
       return datas.size();
     }
  
     @Override
     public Object getItem( int position) {
       // TODO Auto-generated method stub
       return null ;
     }
  
     @Override
     public long getItemId( int position) {
       // TODO Auto-generated method stub
       return 0 ;
     }
  
     @Override
     public View getView( int position, View convertView, ViewGroup parent) {
        
       ItemView itemView = null ;
       if (convertView == null ) {
         itemView = new ItemView();
         convertView = View.inflate(getApplicationContext(), R.layout.item_lv, null );
         itemView.tv_name = (TextView) convertView.findViewById(R.id.tv_name);
         itemView.tv_num = (TextView) convertView.findViewById(R.id.tv_num);
         convertView.setTag(itemView);
       } else {
         itemView = (ItemView) convertView.getTag();
       }
        
       Person person = datas.get(position);
       itemView.tv_name.setText(person.getName());
       itemView.tv_num.setText(person.getNumber());
        
       return convertView;
     }
      
   }
    
}


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值