Android使用listview實現(xiàn)分頁刷新(線程休眠模擬)
當要顯示的數(shù)據(jù)過多時,為了更好的提升用戶感知,在很多APP中都會使用分頁刷新顯示,比如瀏覽新聞,向下滑動到當前ListView的最后一條信息(item)時,會提示刷新加載,然后加載更新后的內(nèi)容。此過程大致分以下幾步:
1.當前Activity implements OnScallListenner;
2.實現(xiàn)接口的方法;
3.ListView注冊滾動監(jiān)聽;
4. Adapter(自定義或者安卓自帶)為每個item填充數(shù)據(jù);
5.獲得第二頁以后的數(shù)據(jù)后,adater增加數(shù)據(jù)并刷新notifyDateSetChanged();(需要用到Handler)
現(xiàn)在我們就通過線程休眠的的方式模擬ListView頁面刷新的實現(xiàn)(每次加載10條信息,向下滑動會分頁刷新加載)
顯示效果(設(shè)置顯示十條后開啟刷新,添加使用AlertDialog瀏覽示例):

Layout中ListView布局activity_main.xml文件:
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools="http://schemas.android.com/tools" android:id="@+id/activity_main" android:layout_width="match_parent" android:layout_height="match_parent" tools:context="com.example.administrator.day08.MainActivity"> <ListView android:id="@+id/lv" android:layout_width="match_parent" android:layout_height="match_parent" android:layout_alignParentTop="true" android:layout_alignParentStart="true" /> </RelativeLayout>
Layout中item(填充ListView每行)布局item.xml文件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="vertical" android:layout_width="match_parent"
android:layout_height="match_parent">
<TextView
android:text="Tile"
android:textSize="30dp"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/textView" />
<TextView
android:text="Message"
android:textSize="20dp"
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:id="@+id/textView2" />
</LinearLayout>
Layout中頁面刷新提示布局(頁腳)login_item.xml文件:
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
android:orientation="horizontal" android:layout_width="match_parent"
android:layout_height="match_parent" android:gravity="center">
<ProgressBar
style="?android:attr/progressBarStyle"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:layout_gravity="center"
android:id="@+id/progressBar" />
<TextView
android:text="玩命加載中"
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:id="@+id/textView3" />
</LinearLayout>
Java中自定義對象類(每條新聞有對應(yīng)的標題以及內(nèi)容)
public class News {
String title;
String message;
}
Java中功能實現(xiàn)類(通過實現(xiàn)OnScrollListener接口)
import android.content.DialogInterface;
import android.os.Handler;
import android.os.Message;
import android.support.v7.app.AlertDialog;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.view.View;
import android.view.ViewGroup;
import android.widget.AbsListView;
import android.widget.AdapterView;
import android.widget.BaseAdapter;
import android.widget.ListView;
import android.widget.TextView;
import java.util.ArrayList;
import java.util.List;
/**
* Created by panchengjia on 2016/11/29.
*/
public class MainActivity extends AppCompatActivity implements AbsListView.OnScrollListener{
private ListView lv;
private List<News> news;//聲明存儲新聞標題與內(nèi)容的List
private int total=1;//計數(shù)器(設(shè)置默認從1開始)用于集合內(nèi)數(shù)據(jù)初始化
MyAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
lv= (ListView) findViewById(R.id.lv);
//為當前ListView設(shè)置OnScrollListener實現(xiàn)分頁刷新
lv.setOnScrollListener(this);
//將login_item(下拉刷新效果的item)通過布局 填充器聲明
View v = getLayoutInflater().inflate(R.layout.login_item,null);
//將login_item設(shè)置到ListView頁腳
lv.addFooterView(v);
//實例化存儲內(nèi)容資源的List
news = new ArrayList<>();
//調(diào)用初始化List的方法
initList();
adapter = new MyAdapter();
//設(shè)置單擊item的事件
lv.setOnItemClickListener(new AdapterView.OnItemClickListener() {
@Override
public void onItemClick(AdapterView<?> parent, View view, int position, long id) {
show(view);//事件處理為調(diào)用show方法(顯示AlertDialog對話框)
}
});
lv.setAdapter(adapter);
}
//AlertDialog對話框的調(diào)用這里就不多說了,前期有專門的博文解釋
public void show(View v){
AlertDialog.Builder builder = new AlertDialog.Builder(this);
TextView title = (TextView) v.findViewById(R.id.textView);
TextView message = (TextView) v.findViewById(R.id.textView2);
builder.setTitle(title.getText().toString());
builder.setMessage(message.getText().toString());
builder.setPositiveButton("已經(jīng)瀏覽完畢", new DialogInterface.OnClickListener() {
@Override
public void onClick(DialogInterface dialog, int which) {
}
});
builder.show();
}
//初始化List內(nèi)的元素,模擬每次可刷新10條信息
private void initList() {
for(int i=1;i<=10;i++){
News n = new News();
//加total是因為total在刷新頁面后不會繼續(xù)從一開始
n.title = "Title--"+total;
n.message="Message"+total;
news.add(n);
total++;
}
}
// int currenVisibleItemCount;//聲明截止當前頁面看到的item總數(shù)(演示用)
boolean isLastRow=false;//判斷是否到ListView的最后一個item
@Override
public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {
//firstVisibleItem位可見頁面的第一條在Arraylist中的下標,visibleItemCount為當前頁面item數(shù)
// currenVisibleItemCount = firstVisibleItem+visibleItemCount-1=totalItemCount;(演示用)
if(firstVisibleItem+visibleItemCount==totalItemCount&&totalItemCount>0){
isLastRow=true;//判斷已經(jīng)到最后一個item(即為footerView)
}
}
@Override
public void onScrollStateChanged(AbsListView view, int scrollState) {
/*判斷是否刷新頁面之前,解釋一下scrollState的三種狀態(tài)
* 1.scrollState = SCROLL_STATE_TOUCH_SCROLL為手指按住屏幕滾動(未脫離屏幕);
* 2.scrollState = SCROLL_STATE_FLING可以理解為手指離開屏幕前,用力滑了一下,
* 手指離開后,頁面已然保持滾動;
* 3.scrollState = SCROLL_STATE_IDLE手指未接觸屏幕,且屏幕頁面保持靜止
* 開啟刷新頁面的線程前,確保ListView已經(jīng)到最后一行(Item)并且屏幕頁面保持靜止
* */
if(isLastRow&&scrollState==SCROLL_STATE_IDLE){
new Thread(new MyThread()).start();
}
}
//創(chuàng)建分頁刷新線程(模擬刷新)
class MyThread implements Runnable{
@Override
public void run() {
try {
Thread.sleep(500);//設(shè)置線程休眠時間為500毫秒刷新一次
} catch (InterruptedException e) {
e.printStackTrace();
}
initList();//重新初始化List
//線程內(nèi)調(diào)用Handler執(zhí)行頁面刷新(后面會寫文對handler進行詳細剖析)
handler.sendEmptyMessage(1);
}
}
Handler handler = new Handler(){
@Override
public void handleMessage(Message msg) {
super.handleMessage(msg);
switch (msg.what){
case 1:
//強制調(diào)用適配器的getView來刷新每個Item的內(nèi)容。
adapter.notifyDataSetChanged();
break;
}
}
};
//自定義適配器
class MyAdapter extends BaseAdapter{
@Override
public int getCount() {
return news.size();
}
@Override
public Object getItem(int position) {
return news.get(position);
}
@Override
public long getItemId(int position) {
return position;
}
@Override
public View getView(int position, View convertView, ViewGroup parent) {
ViewHolder vh;
if(convertView==null){
convertView = getLayoutInflater().inflate(R.layout.item,null);
vh=new ViewHolder();
vh.message = (TextView) convertView.findViewById(R.id.textView2);
vh.title= (TextView) convertView.findViewById(R.id.textView);
convertView.setTag(vh);
}
vh= (ViewHolder) convertView.getTag();
vh.title.setText(news.get(position).title);
vh.message.setText(news.get(position).message);
return convertView;
}
class ViewHolder{
TextView title;
TextView message;
}
}
}
至此ListView的分頁刷新源碼已全部展示完成,個人認為實現(xiàn)此功能的核心為判斷是否達到當前ListView中的最后一條item(包含頁腳刷新提示)以及理解scrollState的狀態(tài),理解了這兩點,該功能的實現(xiàn)起來事半功倍。
以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Android apk完整性檢測的實現(xiàn)思路和代碼實現(xiàn)
這篇文章主要介紹了Android apk完整性檢測的實現(xiàn)思路和代碼實現(xiàn),本文通過示例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2023-12-12
Android實現(xiàn)倒計時CountDownTimer使用詳解
這篇文章主要為大家詳細介紹了Android實現(xiàn)倒計時CountDownTimer的使用方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12
Android中ActionBar和ToolBar添加返回箭頭的實例代碼
這篇文章主要介紹了Android中ActionBar和ToolBar添加返回箭頭的實例代碼,需要的朋友可以參考下2017-09-09
關(guān)于Android發(fā)送短信獲取送達報告的問題(推薦)
最近公司開發(fā)一個項目,要求app能夠發(fā)送短信并獲取送達報告。實現(xiàn)代碼非常簡單的,下面小編給大家分享關(guān)于Android發(fā)送短信獲取送達報告的問題,感興趣的朋友一起看看吧2017-03-03

