Android ListView分頁簡單實(shí)現(xiàn)
Android ListView分頁簡單實(shí)現(xiàn)
分頁,開發(fā)應(yīng)用中必不可少。那么,現(xiàn)在就來實(shí)現(xiàn)分頁功能。
首先來想想實(shí)現(xiàn)它要有哪些步驟,
1, 實(shí)現(xiàn)的組件,
2、初始化第一頁數(shù)據(jù),
3,底部布局 ,
4,加載數(shù)據(jù)的條件
5、獲取下一頁的數(shù)據(jù)。
有了思路,我們一步步來實(shí)現(xiàn)就行了。先來想想我們用什么組件實(shí)現(xiàn),我們知道列表UI我們常用ListView或者RecyclerView,初始化數(shù)據(jù),我們就在通過一個(gè)for循環(huán)來準(zhǔn)備數(shù)據(jù),底部布局我們直接使ProgressBar控件和一個(gè)TextView來顯示就可以了。至于,加載的數(shù)據(jù),我們就使用OnScrollListener來監(jiān)聽滑動(dòng)事件,然后在滿足加載條件時(shí),我們就可以加載下一頁的數(shù)據(jù)了。
先來看看ListView實(shí)現(xiàn):
自定義ListView (LoadListView.Java):
public class LoadListView extends ListView implements AbsListView.OnScrollListener{ private LayoutInflater mInflater; //判斷是否滾動(dòng)最后一行 private boolean isLastRow = false; //底部View布局 private View mFooter; //實(shí)現(xiàn)接口加載更多數(shù)據(jù) public OnLoadMoreListener moreListener; public void setLoadMoreListener(OnLoadMoreListener moreListener){ this.moreListener = moreListener; } public LoadListView(Context context) { super(context); initView(); } public LoadListView(Context context, AttributeSet attrs) { super(context, attrs); initView(); } public LoadListView(Context context, AttributeSet attrs, int defStyleAttr) { super(context, attrs, defStyleAttr); initView(); } private void initView(){ mInflater = LayoutInflater.from(getContext()); mFooter = mInflater.inflate(R.layout. listview_footer,null); this.addFooterView(mFooter); mFooter.setVisibility(View.GONE); setOnScrollListener(this); } @Override public void onScrollStateChanged(AbsListView absListView, int scrollState) { //正在滾動(dòng)時(shí)回調(diào),回調(diào)2-3次,手指沒拋則回調(diào)2次。scrollState = 2的這次不回調(diào) //回調(diào)順序如下 //第1次:scrollState = SCROLL_STATE_TOUCH_SCROLL(1) 正在滾動(dòng) //第2次:scrollState = SCROLL_STATE_FLING(2) 手指做了拋的動(dòng)作(手指離開屏幕前,用力滑了一下) //第3次:scrollState = SCROLL_STATE_IDLE(0) 停止?jié)L動(dòng) //當(dāng)屏幕停止?jié)L動(dòng)時(shí)為0;當(dāng)屏幕滾動(dòng)且用戶使用的觸碰或手指還在屏幕上時(shí)為1; //由于用戶的操作,屏幕產(chǎn)生慣性滑動(dòng)時(shí)為2 //當(dāng)滾到最后一行且停止?jié)L動(dòng)時(shí),執(zhí)行加載 if(isLastRow&&scrollState== OnScrollListener.SCROLL_STATE_IDLE){ mFooter.setVisibility(View.VISIBLE); isLastRow = false; if(moreListener!=null){ moreListener.loadMore(); } } } @Override public void onScroll(AbsListView absListView, int firstVisibleItem, int visibleItemCount, int totalItemCount) { //滾動(dòng)時(shí)一直回調(diào),直到停止?jié)L動(dòng)時(shí)才停止回調(diào)。單擊時(shí)回調(diào)一次。 //firstVisibleItem:當(dāng)前能看見的第一個(gè)列表項(xiàng)ID(從0開始) //visibleItemCount:當(dāng)前能看見的列表項(xiàng)個(gè)數(shù)(小半個(gè)也算) //totalItemCount:列表項(xiàng)共數(shù) //判斷是否滾到最后一行 if (firstVisibleItem + visibleItemCount == totalItemCount && totalItemCount > 0) { isLastRow = true; } } public interface OnLoadMoreListener{ void loadMore(); } }
底部布局listfooter.xml
<?xml version="1.0" encoding="utf-8"?> <RelativeLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="wrap_content" android:orientation="vertical"> <ProgressBar android:layout_width="wrap_content" android:layout_height="wrap_content" android:layout_toLeftOf="@+id/id_loadmore" android:layout_marginRight="5dp" /> <TextView android:id="@+id/id_loadmore" android:layout_width="wrap_content" android:layout_height="wrap_content" android:text="加載更多" android:layout_centerHorizontal="true" android:layout_centerVertical="true"/> </RelativeLayout>
MainActivity.java的源碼:
public class MainActivity extends Activity implements LoadListView.OnLoadMoreListener { private List<News> list = new ArrayList<>() ; private loadAdapter mAdapter; private LoadListView mListView; @Override protected void onCreate(Bundle savedInstanceState) { super.onCreate(savedInstanceState); setContentView(R.layout.activity_main); loadMoreData(); mListView =(LoadListView) findViewById(R.id.id_list_view); mAdapter = new loadAdapter(this,list); mListView.setAdapter(mAdapter); mListView.setLoadMoreListener(this); } private void loadMoreData(){ for(int i = 0 ; i <10;i++){ News news = new News(); news.setTitle("許巍"); news.setContent("藍(lán)蓮花"); list.add(news); } } @Override public void loadMore() { new Handler().postDelayed(new Runnable() { @Override public void run() { loadMoreData(); showLoadMore(); } },2000); } private void showLoadMore(){ mAdapter.notifyDataSetChanged(); } }
LoadAdapter.java
public class loadAdapter extends BaseAdapter { private List<News> list; private Context mContext; public loadAdapter(Context context,List<News> list){ this.list = list; this.mContext = context; } @Override public int getCount() { return list.size(); } @Override public Object getItem(int position) { return position; } @Override public long getItemId(int position) { return position; } @Override public View getView(int position, View convertView, ViewGroup parent) { ViewHolder viewHolder; if(convertView==null){ viewHolder = new ViewHolder(); convertView = LayoutInflater.from(mContext).inflate(R.layout.item_news,null); viewHolder.title = (TextView) convertView.findViewById(R.id.id_title); viewHolder.content = (TextView)convertView.findViewById(R.id.id_content); convertView.setTag(viewHolder); }else { viewHolder = (ViewHolder) convertView.getTag(); } viewHolder.title.setText(list.get(position).getTitle()); viewHolder.content.setText(list.get(position).getContent()); return convertView; } public class ViewHolder{ private TextView title; private TextView content; } }
activity_main.xml:
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent"> <view.LoadListView android:layout_width="match_parent" android:layout_height="match_parent" android:id="@+id/id_list_view" /> </LinearLayout>
item_news.xml:
<?xml version="1.0" encoding="utf-8"?> <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android" android:layout_width="match_parent" android:layout_height="match_parent" android:orientation="vertical"> <TextView android:id="@+id/id_title" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="" android:gravity="center" android:padding="5dp"/> <TextView android:id="@+id/id_content" android:layout_width="match_parent" android:layout_height="wrap_content" android:text="" android:gravity="center" android:padding="5dp"/> </LinearLayout>
其實(shí)只要掌握了OnScrollListener的回調(diào),那么就很簡單了。RecyclerView也出現(xiàn)很久了,慢慢的,RecyclerView也會(huì)替代了ListView,所以ListView分頁似乎就過時(shí)了,我們想知道的是RecyclerView怎么實(shí)現(xiàn)分頁。但是我們知道RecyclerView不能實(shí)現(xiàn)頭部和底部的添加,所以我們要自己來實(shí)現(xiàn)一個(gè)能添加頭部和底部的ReyclerView。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
Android模糊處理簡單實(shí)現(xiàn)毛玻璃效果
這篇文章主要介紹了Android模糊處理簡單實(shí)現(xiàn)毛玻璃效果的相關(guān)資料,需要的朋友可以參考下2016-02-02Android 勇闖高階性能優(yōu)化之啟動(dòng)優(yōu)化篇
在移動(dòng)端程序中,用戶希望的是應(yīng)用能夠快速打開。啟動(dòng)時(shí)間過長的應(yīng)用不能滿足這個(gè)期望,并且可能會(huì)令用戶失望。輕則鄙視你,重則直接卸載你的應(yīng)用2021-10-10Android仿微信雷達(dá)掃描效果的實(shí)現(xiàn)方法
最近看了一個(gè)視頻講了一種微信雷達(dá)掃描的實(shí)現(xiàn)方案,借鑒了一下,自己也寫一個(gè)玩玩,所以下面這篇文章主要給大家介紹了利用Android模仿微信雷達(dá)掃描效果的實(shí)現(xiàn)方法,需要的朋友可以參考借鑒,下面來一起看看吧。2017-06-06Android 中ImageView的ScaleType使用方法
這篇文章主要介紹了Android 中ImageView的ScaleType使用方法的相關(guān)資料,希望通過本能幫助到大家,需要的朋友可以參考下2017-09-095種Android數(shù)據(jù)存儲(chǔ)方式匯總
這篇文章主要為大家整理了5種Android數(shù)據(jù)存儲(chǔ)方式,列出了各存儲(chǔ)方式的優(yōu)缺點(diǎn),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-12-12關(guān)于Android 6.0權(quán)限的動(dòng)態(tài)適配詳解
Android 6.0版本(Api 23)推出了很多新的特性, 大幅提升了用戶體驗(yàn), 同時(shí)也為程序員帶來新的負(fù)擔(dān). 動(dòng)態(tài)權(quán)限管理就是這樣, 一方面讓用戶更加容易的控制自己的隱私, 一方面需要重新適配應(yīng)用權(quán)限,本文介紹了關(guān)于Android 6.0權(quán)限動(dòng)態(tài)適配的相關(guān)資料,需要的朋友可以參考下。2017-11-11