google官方的下拉刷新+自定义上拉加载更多

现在很多app都是使用的自定义的下拉刷新上拉加载更多,然而google官方为我们提供了下拉刷新操作,我在之前的博客中有撰文针对google官方为我们提供了下拉刷新,我们自己增加自定义的上拉加载更多,这样相互结合使用,就出现了一款新的下拉刷新和上拉加载更多的组件,非常推荐在app中增加这中效果。
自定义下拉刷新及上拉加载更多

google官方的下拉刷新+自定义上拉加载更多

(1)自定义listView,因为google为我们提供能下拉刷新的组件

android.support.v4.widget.SwipeRefreshLayout  

因此我们只需要为自定的listView添加上拉“ 加载更多 ”的功能。

自定义上拉加载更多的listView代码如下:

package com.example.myfirst.pulltorefreshlist;  

import android.content.Context;  
import android.util.AttributeSet;  
import android.view.View;  
import android.widget.AbsListView;  
import android.widget.ListView;  

/** 
 * 上拉加载更多的listView,配合Google官方的下拉刷新使用 
 * Created by chengguo on 2016/3/21. 
 */  
public class LoadMoreListView extends ListView implements AbsListView.OnScrollListener {  


    private static final String TAG = "RefreshListView";  
    /** 
     * 底部加载更多部分 
     */  
    private boolean isScrollToBottom;//判断是不是滑到了底部  
    private View footerView; //底部的footer   view  
    private int footerViewHeight; //底部view的高度  
    private boolean isLoadingMore = false; //判断是不是"加载更多"  

    /** 
     * listview的接口,监听listview的下来刷新和上拉加载更多 
     */  
    private OnRefreshListener mOnRefreshListener;  


    public LoadMoreListView(Context context) {  
        super(context);  
    }  

    public LoadMoreListView(Context context, AttributeSet attrs) {  
        super(context, attrs);  
        initFooterView();  
        this.setOnScrollListener(this);  
    }  


    /** 
     * 初始化底部view 
     */  
    private void initFooterView() {  
        footerView = View.inflate(getContext(), R.layout.footer_layout, null);  
        //设置(0,0)以便系统测量footerView的宽高  
        footerView.measure(0, 0);  
        footerViewHeight = footerView.getMeasuredHeight();  
        footerView.setPadding(0, -footerViewHeight, 0, 0);  
        this.addFooterView(footerView);  
    }  

    /** 
     * 监听listview滚动的状态变化,如果滑到了底部,就“加载更多..." 
     */  
    @Override  
    public void onScrollStateChanged(AbsListView view, int scrollState) {  

        if (scrollState == SCROLL_STATE_IDLE || scrollState == SCROLL_STATE_FLING) {  
            if (isScrollToBottom && !isLoadingMore) {  
                isLoadingMore = true;  
                footerView.setPadding(0, 0, 0, 0);  
                this.setSelection(this.getCount());  

                if (mOnRefreshListener != null) {  
                    mOnRefreshListener.onLoadingMore();  
                }  
            }  
        }  
    }  

    /** 
     * 监听listview滚动的状态变化,判断当前是不是滑到了底部 
     * 
     * @param view 
     * @param firstVisibleItem 
     * @param visibleItemCount 
     * @param totalItemCount 
     */  
    @Override  
    public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {  
        if (getLastVisiblePosition() == (totalItemCount - 1)) {  
            isScrollToBottom = true;  
        } else {  
            isScrollToBottom = false;  
        }  

    }  

    /** 
     * 设置监听接口,当为 
     * 
     * @param listener 
     */  
    public void setOnRefreshListener(OnRefreshListener listener) {  
        mOnRefreshListener = listener;  
    }  


    /** 
     * 为外界提供的方法,当Activity中的加载更多数据加载完后,就调用这个方法来隐藏底部的footerView 
     */  
    public void loadMoreComplete() {  
        footerView.setPadding(0, -footerViewHeight, 0, 0);  
        isLoadingMore = false;  
    }  

    /** 
     * 设置接口,供外界实现,监听listview的刷新和加载更多的状态 
     */  
    public interface OnRefreshListener {  
        /** 
         * 上拉加载更多 
         */  
        void onLoadingMore();  
    }  
}

(2)activity的layout.xml文件如下:

"1.0" encoding="utf-8"?>  
"http://schemas.android.com/apk/res/android"  
    android:layout_width="match_parent"  
    android:layout_height="match_parent"  
    android:orientation="vertical">  

    .support.v4.widget.SwipeRefreshLayout  
        android:id="@+id/swipe_google_and_loadmore_refresh_layout"  
        android:layout_width="match_parent"  
        android:layout_height="match_parent">  

        <com.example.myfirst.pulltorefreshlist.LoadMoreListView  
            android:id="@+id/google_and_loadmore_refresh_listview"  
            android:layout_width="match_parent"  
            android:layout_height="match_parent">  

        com.example.myfirst.pulltorefreshlist.LoadMoreListView>  

    .support.v4.widget.SwipeRefreshLayout>  
 

(3)主activity的代码如下,也有非常详细的代码注释,非常简单,这样一款google下拉刷新+自定义上拉加载更多就诞生了。

package com.example.myfirst.pulltorefreshlist;  

import android.app.Activity;  
import android.os.Bundle;  
import android.os.Handler;  
import android.support.v4.widget.SwipeRefreshLayout;  

import java.util.ArrayList;  

/** 
 * google下拉刷新和自定义上拉加载更多的activity 
 * Created by chengguo on 2016/3/21. 
 */  
public class GoogleAndLoadMoreActivity extends Activity implements SwipeRefreshLayout.OnRefreshListener, LoadMoreListView.OnRefreshListener {  
    private SwipeRefreshLayout swipeRefreshLayout;  
    private LoadMoreListView loadMoreListView;  
    //对象数据集合  
    private ArrayList items;  
    //listview的数据加载器adapter  
    private RefreshListAdapter adapter;  

    @Override  
    protected void onCreate(Bundle savedInstanceState) {  
        super.onCreate(savedInstanceState);  
        setContentView(R.layout.google_and_loadmor_refreshing_aty);  

        initView();  
        initEvent();  
        initData();  
    }  

    /** 
     * 初始化列表数据 
     */  
    private void initData() {  
        items = new ArrayList();  

        //这里只是模拟10个列表项数据,在现实开发中,listview中的数据都是从服务器获取的。  
        for (int i = 0; i < 10; i++) {  
            ListViewItem item = new ListViewItem();  
            item.setUserImg(R.mipmap.ic_launcher);  
            item.setUserName("seven" + i);  
            item.setUserComment("这是google官方一个下拉刷新ListView+自定义ListView上拉加载跟多");  
            items.add(item);  
        }  

        //为listview配置adapter  
        adapter = new RefreshListAdapter(GoogleAndLoadMoreActivity.this, items);  
        loadMoreListView.setAdapter(adapter);  
    }  

    /** 
     * 给控件添加事件 
     */  
    private void initEvent() {  
        swipeRefreshLayout.setOnRefreshListener(this);  

        //设置圆圈进度条的背景颜色  
//        swipeRefreshLayout.setProgressBackgroundColorSchemeColor(  
//                getResources().getColor(R.color.colorPrimary));  

        //设置进度条变化的颜色  
        swipeRefreshLayout.setColorSchemeResources(  
                R.color.firstColor,  
                R.color.secondColor,  
                R.color.thirdColor,  
                R.color.forthColor);  
    }  

    /** 
     * 初始化界面控件 
     */  
    private void initView() {  
        swipeRefreshLayout = (SwipeRefreshLayout) findViewById(R.id.swipe_google_and_loadmore_refresh_layout);  
        loadMoreListView = (LoadMoreListView) findViewById(R.id.google_and_loadmore_refresh_listview);  
        loadMoreListView.setOnRefreshListener(this);  
    }  

    /** 
     * 触发了下拉刷新事件,就会执行onRefresh()方法,这样就能在这个 
     * 方法中去执行网络获取最新的数据,然后再刷新到listview上面 
     */  
    @Override  
    public void onRefresh() {  
        //因为本例中没有从网络获取数据,因此这里使用Handler演示4秒延迟来从服务器获取数据的延迟现象,以便于大家  
        // 能够看到listView正在刷新的状态。大家在现实使用时只需要使用run(){}方法中的代码就行了。  
        Handler handler = new Handler();  
        handler.postDelayed(new Runnable() {  
            @Override  
            public void run() {  
                //获取最新的list数据  
                setRefreshData();  
                //通知界面显示,  
                adapter.notifyDataSetChanged();  
                // 通知listview刷新数据完毕,让listview停止刷新  
                swipeRefreshLayout.setRefreshing(false);  
            }  
        }, 6000);  
    }  

    /** 
     * 模拟加载刷新数据 
     */  
    private void setRefreshData() {  
        //这里只是模拟3个列表项数据,在现实开发中,listview中的数据都是从服务器获取的。  
        for (int i = 0; i < 3; i++) {  
            ListViewItem item = new ListViewItem();  
            item.setUserImg(R.mipmap.ic_launcher);  
            item.setUserName("seven" + i);  
            item.setUserComment("这是一个下拉刷新,上拉加载更多的ListView");  
            items.add(item);  
        }  
    }  

    /** 
     * ”加载更多“ 的回调接口方法 
     */  
    @Override  
    public void onLoadingMore() {  

        //因为本例中没有从网络获取数据,因此这里使用Handler演示4秒延迟来从服务器获取数据的延迟现象,以便于大家  
        // 能够看到listView正在刷新的状态。大家在现实使用时只需要使用run(){}方法中的代码就行了。  
        Handler handler = new Handler();  
        handler.postDelayed(new Runnable() {  
            @Override  
            public void run() {  
                //获取最新的list数据  
                setRefreshData();  
                //通知界面显示,  
                adapter.notifyDataSetChanged();  
                // 通知listview刷新数据完毕,让listview停止刷新,取消加载跟多  
                loadMoreListView.loadMoreComplete();  
            }  
        }, 6000);  
    }  
}  

你可能感兴趣的:(android)