Android開發(fā)中Listview動態(tài)加載數(shù)據(jù)的方法示例
本文實例講述了Android開發(fā)中Listview動態(tài)加載數(shù)據(jù)的方法。分享給大家供大家參考,具體如下:
最近在研究網(wǎng)絡(luò)數(shù)據(jù)加載的問題,比如我有幾百,甚至上千條數(shù)據(jù),這些數(shù)據(jù)如果一次性全部加載到arraylist,然后再加載到Listview中。我們必然會去單獨開線程來做,這樣造成的結(jié)果就是會出現(xiàn)等待時間很長,用戶體驗非常不好。我的想法是動態(tài)加載數(shù)據(jù),第一次加載十條,然后往下面滑動的時候再追加十條,再往下面滑動的時候再去追加,這樣大大減少了用戶等待的時間,同時給處理數(shù)據(jù)留下了時間。網(wǎng)上看到了這樣一個例子,挺好的,我改動了一下,達到了我想要的結(jié)果。
Java代碼:
package org.developerworks.android;
import android.app.Activity;
import android.os.Bundle;
import android.os.Handler;
import android.os.Message;
import android.view.Gravity;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.BaseAdapter;
import android.widget.LinearLayout;
import android.widget.ListView;
import android.widget.ProgressBar;
import android.widget.TextView;
import android.widget.Toast;
import android.widget.AbsListView.OnScrollListener;
import android.widget.LinearLayout.LayoutParams;
public class ListViewForLoading extends Activity implements OnScrollListener {
private listViewAdapter adapter = new listViewAdapter();
ListView listView;
LinearLayout loadingLayout;
private Thread mThread;
/** * 設(shè)置布局顯示屬性 */
private LayoutParams mLayoutParams = new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.WRAP_CONTENT,
LinearLayout.LayoutParams.WRAP_CONTENT);
/** * 設(shè)置布局顯示目標(biāo)最大化屬性 */
private LayoutParams FFlayoutParams = new LinearLayout.LayoutParams(
LinearLayout.LayoutParams.FILL_PARENT,
LinearLayout.LayoutParams.FILL_PARENT);
private ProgressBar progressBar;
/** Called when the activity is first created. */
@Override
public void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.main);
init();
}
private void init() {
// TODO Auto-generated method stub
// 線性布局
LinearLayout layout = new LinearLayout(this);
// 設(shè)置布局 水平方向
layout.setOrientation(LinearLayout.HORIZONTAL);
// 進度條
progressBar = new ProgressBar(this);
// 進度條顯示位置
progressBar.setPadding(0, 0, 15, 0);
// 把進度條加入到layout中
layout.addView(progressBar, mLayoutParams);
// 文本內(nèi)容
TextView textView = new TextView(this);
textView.setText("加載中...");
textView.setGravity(Gravity.CENTER_VERTICAL);
// 把文本加入到layout中
layout.addView(textView, FFlayoutParams);
// 設(shè)置layout的重力方向,即對齊方式是
layout.setGravity(Gravity.CENTER);
// 設(shè)置ListView的頁腳layout
loadingLayout = new LinearLayout(this);
loadingLayout.addView(layout, mLayoutParams);
loadingLayout.setGravity(Gravity.CENTER);
// 得到一個ListView用來顯示條目
listView = (ListView) findViewById(R.id.tv);
// 添加到腳頁顯示
listView.addFooterView(loadingLayout);
// 給ListView添加適配器
listView.setAdapter(adapter);
// 給ListView注冊滾動監(jiān)聽
listView.setOnScrollListener(this);
}
/**
* 要用用于生成顯示數(shù)據(jù)
*
* @author huangbq
*/
class listViewAdapter extends BaseAdapter {
int count = 10;
public int getCount() {
return count;
}
public Object getItem(int pos) {
return pos;
}
public long getItemId(int pos) {
return pos;
}
public View getView(int pos, View v, ViewGroup p) {
TextView view;
if (v == null) {
view = new TextView(ListViewForLoading.this);
} else {
view = (TextView) v;
}
view.setText("ListItem " + pos);
view.setTextSize(20f);
view.setGravity(Gravity.CENTER);
view.setHeight(60);
return view;
}
}
@Override
public void onScroll(AbsListView view, int firstVisibleItem,
int visibleItemCount, int totalItemCount) {
// TODO Auto-generated method stub
if (firstVisibleItem + visibleItemCount == totalItemCount) {
// 開線程去下載網(wǎng)絡(luò)數(shù)據(jù)
if (mThread == null || !mThread.isAlive()) {
mThread = new Thread() {
@Override
public void run() {
try {
// 這里放你網(wǎng)絡(luò)數(shù)據(jù)請求的方法,我在這里用線程休眠5秒方法來處理
Thread.sleep(5000);
} catch (InterruptedException e) {
e.printStackTrace();
}
Message message = new Message();
message.what = 1;
handler.sendMessage(message);
}
};
mThread.start();
}
}
}
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
// TODO Auto-generated method stub
}
private Handler handler = new Handler() {
@Override
public void handleMessage(Message msg) {
// TODO Auto-generated method stub
switch (msg.what) {
case 1:
if (adapter.count <= 41) {
adapter.count += 10;
int currentPage = adapter.count / 10;
Toast.makeText(getApplicationContext(),
"第" + currentPage + "頁", Toast.LENGTH_LONG).show();
} else {
listView.removeFooterView(loadingLayout);
}
// 重新刷新Listview的adapter里面數(shù)據(jù)
adapter.notifyDataSetChanged();
break;
default:
break;
}
}
};
}
main.xml別忘了加這段了
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:layout_width="wrap_content"
android:layout_height="wrap_content">
<ListView android:id="@+id/tv"
android:layout_width="wrap_content"
android:layout_height="wrap_content"/>
</LinearLayout>
更多關(guān)于Android相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Android控件用法總結(jié)》、《Android開發(fā)入門與進階教程》、《Android視圖View技巧總結(jié)》、《Android編程之a(chǎn)ctivity操作技巧總結(jié)》、《Android數(shù)據(jù)庫操作技巧總結(jié)》及《Android資源操作技巧匯總》
希望本文所述對大家Android程序設(shè)計有所幫助。
- Android列表組件ListView使用詳解之動態(tài)加載或修改列表數(shù)據(jù)
- Android 動態(tài)添加view或item并獲取數(shù)據(jù)的實例
- Android 根據(jù)EditText搜索框ListView動態(tài)顯示數(shù)據(jù)
- Android實現(xiàn)listview動態(tài)加載數(shù)據(jù)分頁的兩種方法
- Android實現(xiàn)ListView數(shù)據(jù)動態(tài)加載的方法
- android ListView內(nèi)數(shù)據(jù)的動態(tài)添加與刪除實例代碼
- Android實現(xiàn)動態(tài)添加數(shù)據(jù)與堆疊折線圖詳解流程
相關(guān)文章
Android開發(fā)手冊TextView控件及陰影效果實現(xiàn)
這篇文章主要為大家介紹了Android開發(fā)手冊TextView控件及陰影效果的實現(xiàn)示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-06-06
Android ViewPager制作新手導(dǎo)航頁(動態(tài)加載)
這篇文章主要為大家詳細(xì)介紹了Android ViewPager制作新手導(dǎo)航頁,了解什么是動態(tài)加載指示器,感興趣的小伙伴們可以參考一下2016-05-05

