Android ListView分頁簡單實現(xiàn)
Android ListView分頁簡單實現(xiàn)
分頁,開發(fā)應(yīng)用中必不可少。那么,現(xiàn)在就來實現(xiàn)分頁功能。
首先來想想實現(xiàn)它要有哪些步驟,
1, 實現(xiàn)的組件,
2、初始化第一頁數(shù)據(jù),
3,底部布局 ,
4,加載數(shù)據(jù)的條件
5、獲取下一頁的數(shù)據(jù)。
有了思路,我們一步步來實現(xiàn)就行了。先來想想我們用什么組件實現(xiàn),我們知道列表UI我們常用ListView或者RecyclerView,初始化數(shù)據(jù),我們就在通過一個for循環(huán)來準備數(shù)據(jù),底部布局我們直接使ProgressBar控件和一個TextView來顯示就可以了。至于,加載的數(shù)據(jù),我們就使用OnScrollListener來監(jiān)聽滑動事件,然后在滿足加載條件時,我們就可以加載下一頁的數(shù)據(jù)了。
先來看看ListView實現(xiàn):
自定義ListView (LoadListView.Java):
public class LoadListView extends ListView implements AbsListView.OnScrollListener{
private LayoutInflater mInflater;
//判斷是否滾動最后一行
private boolean isLastRow = false;
//底部View布局
private View mFooter;
//實現(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) {
//正在滾動時回調(diào),回調(diào)2-3次,手指沒拋則回調(diào)2次。scrollState = 2的這次不回調(diào)
//回調(diào)順序如下
//第1次:scrollState = SCROLL_STATE_TOUCH_SCROLL(1) 正在滾動
//第2次:scrollState = SCROLL_STATE_FLING(2) 手指做了拋的動作(手指離開屏幕前,用力滑了一下)
//第3次:scrollState = SCROLL_STATE_IDLE(0) 停止?jié)L動
//當(dāng)屏幕停止?jié)L動時為0;當(dāng)屏幕滾動且用戶使用的觸碰或手指還在屏幕上時為1;
//由于用戶的操作,屏幕產(chǎn)生慣性滑動時為2
//當(dāng)滾到最后一行且停止?jié)L動時,執(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) {
//滾動時一直回調(diào),直到停止?jié)L動時才停止回調(diào)。單擊時回調(diào)一次。
//firstVisibleItem:當(dāng)前能看見的第一個列表項ID(從0開始)
//visibleItemCount:當(dāng)前能看見的列表項個數(shù)(小半個也算)
//totalItemCount:列表項共數(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("藍蓮花");
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>
其實只要掌握了OnScrollListener的回調(diào),那么就很簡單了。RecyclerView也出現(xiàn)很久了,慢慢的,RecyclerView也會替代了ListView,所以ListView分頁似乎就過時了,我們想知道的是RecyclerView怎么實現(xiàn)分頁。但是我們知道RecyclerView不能實現(xiàn)頭部和底部的添加,所以我們要自己來實現(xiàn)一個能添加頭部和底部的ReyclerView。
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
相關(guān)文章
Android 勇闖高階性能優(yōu)化之啟動優(yōu)化篇
在移動端程序中,用戶希望的是應(yīng)用能夠快速打開。啟動時間過長的應(yīng)用不能滿足這個期望,并且可能會令用戶失望。輕則鄙視你,重則直接卸載你的應(yīng)用2021-10-10
Android 中ImageView的ScaleType使用方法
這篇文章主要介紹了Android 中ImageView的ScaleType使用方法的相關(guān)資料,希望通過本能幫助到大家,需要的朋友可以參考下2017-09-09
關(guān)于Android 6.0權(quán)限的動態(tài)適配詳解
Android 6.0版本(Api 23)推出了很多新的特性, 大幅提升了用戶體驗, 同時也為程序員帶來新的負擔(dān). 動態(tài)權(quán)限管理就是這樣, 一方面讓用戶更加容易的控制自己的隱私, 一方面需要重新適配應(yīng)用權(quán)限,本文介紹了關(guān)于Android 6.0權(quán)限動態(tài)適配的相關(guān)資料,需要的朋友可以參考下。2017-11-11

