android之刷新框架

下拉框架集合:https://www.cnblogs.com/foxy/p/7825073.html

综合带侧滑,移动的刷新框架:SwipeRecyclerView----https://github.com/yanzhenjie/SwipeRecyclerView

===============Android官方刷新组件 SwipeRefreshLayout ============

参考:https://www.jianshu.com/p/d23b42b6360b

使用SwipeRefreshLayout可以实现下拉刷新,前提是布局里需要包裹一个可以滑动的子控件,并且只能有一个子控件。然后在代码里设置OnRefreshListener设置监听,最后在监听里设置刷新时的数据获取就可以了

<?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.wofu.dataget.MainActivity">

    <!--使用谷歌官方的下拉刷新组件,只有下拉刷新功能-->
    <!--
        <android.support.v4.widget.SwipeRefreshLayout
            android:id="@+id/srl"
            android:layout_width="match_parent"
            android:layout_height="match_parent">

            <ListView
                android:id="@+id/lv"
                android:layout_width="match_parent"
                android:layout_height="match_parent"/>

        </android.support.v4.widget.SwipeRefreshLayout>
    -->


    <!--自定义View实现SwipeRefreshLayout,添加上拉加载更多的功能-->
    <com.example.wofu.dataget.SwipeRefreshView
        android:id="@+id/srl"
        android:layout_width="match_parent"
        android:layout_height="match_parent">

        <ListView
            android:id="@+id/lv"
            android:layout_width="match_parent"
            android:layout_height="match_parent"/>

    </com.example.wofu.dataget.SwipeRefreshView>
</RelativeLayout>
<?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="match_parent">

    <RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="48dp">

        <ProgressBar
            android:id="@+id/load_progress"
            android:layout_width="24dp"
            android:layout_height="24dp"
            android:layout_centerVertical="true"
            android:layout_marginLeft="30dp"/>

        <TextView
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerInParent="true"
            android:text="正在努力加载中..."
            android:textColor="@android:color/black"
            android:textSize="16sp"/>

    </RelativeLayout>

</RelativeLayout>

/**
 * 使用谷歌提供的SwipeRefreshLayout下拉控件进行下拉刷新
 */
public class MainActivity extends AppCompatActivity {
    private List<String> mList;
    private StringAdapter mAdapter;
    private SwipeRefreshView mSwipeRefreshView;

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

        mSwipeRefreshView = (SwipeRefreshView) findViewById(R.id.srl);
        ListView listView = (ListView) findViewById(R.id.lv);

        mList = new ArrayList<>();
        mAdapter = new StringAdapter();
        listView.setAdapter(mAdapter);


        // 不能在onCreate中设置,这个表示当前是刷新状态,如果一进来就是刷新状态,SwipeRefreshLayout会屏蔽掉下拉事件
        //swipeRefreshLayout.setRefreshing(true);

        // 设置颜色属性的时候一定要注意是引用了资源文件还是直接设置16进制的颜色,因为都是int值容易搞混
        // 设置下拉进度的背景颜色,默认就是白色的
        mSwipeRefreshView.setProgressBackgroundColorSchemeResource(android.R.color.white);
        // 设置下拉进度的主题颜色
        mSwipeRefreshView.setColorSchemeResources(R.color.colorAccent,
                android.R.color.holo_blue_bright, R.color.colorPrimaryDark,
                android.R.color.holo_orange_dark, android.R.color.holo_red_dark, android.R.color.holo_purple);

        mSwipeRefreshView.setItemCount(20);

        // 手动调用,通知系统去测量
        mSwipeRefreshView.measure(0, 0);
        mSwipeRefreshView.setRefreshing(true);

        initEvent();
        initData();
    }

    private void initEvent() {

        // 下拉时触发SwipeRefreshLayout的下拉动画,动画完毕之后就会回调这个方法
        mSwipeRefreshView.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
            @Override
            public void onRefresh() {
                initData();
            }
        });


        // 设置下拉加载更多------实现接口,在接口就实现方法,在方法中加载更多的数据
        mSwipeRefreshView.setOnLoadMoreListener(new SwipeRefreshView.OnLoadMoreListener() {
            @Override
            public void onLoadMore() {
                loadMoreData();
            }
        });
    }

    //加载更多数据
    private void loadMoreData() {
        new Handler().postDelayed(new Runnable() {
            @Override
            public void run() {

                mList.clear();
                mList.addAll(DataResource.getMoreData());
                Toast.makeText(MainActivity.this, "加载了" + 20 + "条数据", Toast.LENGTH_SHORT).show();
                mAdapter.notifyDataSetChanged();//通知适配器刷新数据
                // 加载完数据设置为不加载状态,将加载进度收起来
                mSwipeRefreshView.setLoading(false);
            }
        }, 2000);
    }


    private void initData() {
        new Handler().postDelayed(new Runnable() {
            @Override
            public void run() {
                mList.clear();
                mList.addAll(DataResource.getData());
                mAdapter.notifyDataSetChanged();//通知适配器刷新数据

                Toast.makeText(MainActivity.this, "刷新了20条数据", Toast.LENGTH_SHORT).show();

                // 加载完数据设置为不刷新状态,将下拉进度收起来
                if (mSwipeRefreshView.isRefreshing()) {
                    mSwipeRefreshView.setRefreshing(false);
                }
            }
        }, 2000);
    }


    /**
     * listview的适配器
     */
    private class StringAdapter extends BaseAdapter {

        @Override
        public int getCount() {
            return mList.size();
        }

        @Override
        public Object getItem(int position) {
            return mList.get(position);
        }

        @Override
        public long getItemId(int position) {
            return position;
        }

        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            if (convertView == null) {
                convertView = View.inflate(MainActivity.this, android.R.layout.simple_list_item_1, null);
            }

            TextView tv = (TextView) convertView;
            tv.setGravity(Gravity.CENTER);
            tv.setPadding(0, 20, 0, 20);
            tv.setText(mList.get(position));

            return convertView;
        }
    }


    //数据源
    public static class DataResource {
        private static List<String> datas = new ArrayList<>();
        private static int page = 0;
//初始化的数据
        public static List<String> getData() {
            page = 0;
            datas.clear();
            for (int i = 0; i < 15; i++) {
                datas.add("我是天才" + i + "号");
            }

            return datas;
        }
//加载更多数据
        public static List<String> getMoreData() {
            page = page + 1;
            for (int i = 20 * page; i < 20 * (page + 1); i++) {
                datas.add("我是天才" + i + "号");
            }

            return datas;
        }
    }
}

/**
 * 自定义View继承SwipeRefreshLayout,添加上拉加载更多的布局属性,添加对RecyclerView的支持
 * Created by Pinger on 2016/9/26.
 */

public class SwipeRefreshView extends SwipeRefreshLayout {

    private static final String TAG = SwipeRefreshView.class.getSimpleName();
    private final int mScaledTouchSlop;
    private final View mFooterView;
    private ListView mListView;
    private OnLoadMoreListener mListener;

    /**
     * 正在加载状态
     */
    private boolean isLoading;
    private RecyclerView mRecyclerView;
    private int mItemCount;

    public SwipeRefreshView(Context context, AttributeSet attrs) {
        super(context, attrs);
        // 填充底部加载布局
        mFooterView = View.inflate(context, R.layout.view_footer, null);

        // 表示控件移动的最小距离,手移动的距离大于这个距离才能拖动控件
        mScaledTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();
    }

    @Override
    protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
        super.onLayout(changed, left, top, right, bottom);
        // 获取ListView,设置ListView的布局位置
        if (mListView == null || mRecyclerView == null) {
            // 判断容器有多少个孩子
            if (getChildCount() > 0) {
                // 判断第一个孩子是不是ListView
                if (getChildAt(0) instanceof ListView) {
                    // 创建ListView对象
                    mListView = (ListView) getChildAt(0);

                    // 设置ListView的滑动监听
                    setListViewOnScroll();
                } else if (getChildAt(0) instanceof RecyclerView) {
                    // 创建ListView对象
                    mRecyclerView = (RecyclerView) getChildAt(0);

                    // 设置RecyclerView的滑动监听
                    setRecyclerViewOnScroll();
                }
            }
        }
    }


    /**
     * 在分发事件的时候处理子控件的触摸事件
     */
    private float mDownY, mUpY;

    @Override
    public boolean dispatchTouchEvent(MotionEvent ev) {

        switch (ev.getAction()) {
            case MotionEvent.ACTION_DOWN:
                // 移动的起点
                mDownY = ev.getY();
                break;
            case MotionEvent.ACTION_MOVE:
                // 移动过程中判断时候能下拉加载更多
                if (canLoadMore()) {
                    // 加载数据
                    loadData();
                }

                break;
            case MotionEvent.ACTION_UP:
                // 移动的终点
                mUpY = getY();
                break;
        }
        return super.dispatchTouchEvent(ev);
    }

    /**
     * 判断是否满足加载更多条件
     */
    private boolean canLoadMore() {
        // 1. 是上拉状态
        boolean condition1 = (mDownY - mUpY) >= mScaledTouchSlop;
        if (condition1) {
            Log.d(TAG, "------->  是上拉状态");
        }

        // 2. 当前页面可见的item是最后一个条目,一般最后一个条目位置需要大于第一页的数据长度
        boolean condition2 = false;
        if (mListView != null && mListView.getAdapter() != null) {

            if (mItemCount > 0) {
                if (mListView.getAdapter().getCount() < mItemCount) {
                    // 第一页未满,禁止下拉
                    condition2 = false;
                }else {
                    condition2 = mListView.getLastVisiblePosition() == (mListView.getAdapter().getCount() - 1);
                }
            } else {
                // 未设置数据长度,则默认第一页数据不满时也可以上拉
                condition2 = mListView.getLastVisiblePosition() == (mListView.getAdapter().getCount() - 1);
            }

        }

        if (condition2) {
            Log.d(TAG, "------->  是最后一个条目");
        }
        // 3. 正在加载状态
        boolean condition3 = !isLoading;
        if (condition3) {
            Log.d(TAG, "------->  不是正在加载状态");
        }
        return condition1 && condition2 && condition3;
    }

    public void setItemCount(int itemCount) {
        this.mItemCount = itemCount;
    }

    /**
     * 处理加载数据的逻辑
     */
    private void loadData() {
        System.out.println("加载数据...");
        if (mListener != null) {
            // 设置加载状态,让布局显示出来
            setLoading(true);
            mListener.onLoadMore();
        }

    }

    /**
     * 设置加载状态,是否加载传入boolean值进行判断
     *
     * @param loading
     */
    public void setLoading(boolean loading) {
        // 修改当前的状态
        isLoading = loading;
        if (isLoading) {
            // 显示布局
            mListView.addFooterView(mFooterView);
        } else {
            // 隐藏布局
            mListView.removeFooterView(mFooterView);

            // 重置滑动的坐标
            mDownY = 0;
            mUpY = 0;
        }
    }


    /**
     * 设置ListView的滑动监听
     */
    private void setListViewOnScroll() {

        mListView.setOnScrollListener(new AbsListView.OnScrollListener() {
            @Override
            public void onScrollStateChanged(AbsListView view, int scrollState) {
                // 移动过程中判断时候能下拉加载更多
                if (canLoadMore()) {
                    // 加载数据
                    loadData();
                }
            }

            @Override
            public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {

            }
        });
    }


    /**
     * 设置RecyclerView的滑动监听
     */
    private void setRecyclerViewOnScroll() {
        mRecyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {
            @Override
            public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
                super.onScrollStateChanged(recyclerView, newState);
                // 移动过程中判断时候能下拉加载更多
                if (canLoadMore()) {
                    // 加载数据
                    loadData();
                }
            }

            @Override
            public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
                super.onScrolled(recyclerView, dx, dy);
            }
        });
    }


    /**
     * 上拉加载的接口回调
     */

    public interface OnLoadMoreListener {
        void onLoadMore();
    }
//在MainActivity 中调用,设置上拉刷新
    public void setOnLoadMoreListener(OnLoadMoreListener listener) {
        this.mListener = listener;
    }

}



*****************上拉刷新***********

上啦是根据手指在屏幕的上接触的起始点和结束点来判断的;用户是上拉操作 :dispatchTouchEvent(MotionEvent ev)中处理分发事件,可由此获得相应手指触摸与抬起的对应坐标,当然在MotionEvent.ACTION_MOVE状态下还应判断是否为上拉加载更多的状态;

参考:https://www.jianshu.com/p/4e914258c73d

SwipeRefreshLoadLayout

*******https://github.com/kafukwen/SwipeRefreshLoadLayout
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    tools:context="com.example.wofu.dataget.MainActivity"
    android:orientation="vertical">

    <com.example.wofu.dataget.SwipeRefreshLoadLayout
        android:id="@+id/srll"
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        >

        <!--<ListView-->
        <!--android:id="@+id/listView"-->
        <!--android:layout_width="match_parent"-->
        <!--android:layout_height="match_parent" />-->

        <android.support.v7.widget.RecyclerView
            android:id="@+id/recyclerView"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    </com.example.wofu.dataget.SwipeRefreshLoadLayout>

</LinearLayout>
<?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="wrap_content"
    android:orientation="vertical">

    <TextView
        android:id="@+id/text"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:text="我是会更加厉害的%s号!"
        android:textSize="30dp"/>
</LinearLayout>

<?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="40dp">

    <LinearLayout
        android:layout_width="wrap_content"
        android:layout_height="wrap_content"
        android:layout_centerInParent="true"
        android:gravity="center">

        <ProgressBar
            android:layout_width="25dp"
            android:layout_height="25dp" />

        <TextView
            android:id="@+id/loading_text"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_marginLeft="40dp"
            android:text="正在怒力加载中..." />
    </LinearLayout>

</RelativeLayout>
public class MainActivity extends AppCompatActivity {

    private SwipeRefreshLoadLayout swipeRefreshLoadLayout;

    //    private ListView listView;//***********************
    private ArrayList<Integer> data = new ArrayList<>();

    private RecyclerView recyclerView;
    private MyAdapter mAdapter;
    private RecyclerViewAdapter mRecyclerViewAdapter;



    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.activity_main);
        swipeRefreshLoadLayout = (SwipeRefreshLoadLayout) findViewById(R.id.srll);
//        listView = (ListView) findViewById(R.id.listView);
        recyclerView = (RecyclerView) findViewById(R.id.recyclerView);
        for (int i = 0; i < 10; i++) {
            data.add(i);
        }

        //***************这是用listview实现**************************
//        mAdapter = new MyAdapter(this, data);
//        listView.setAdapter(mAdapter);

        //这是用RecyclerView实现
        mRecyclerViewAdapter = new RecyclerViewAdapter(this, data);
        recyclerView.setLayoutManager(new LinearLayoutManager(this));
        recyclerView.setAdapter(mRecyclerViewAdapter);
        //下拉刷新
        swipeRefreshLoadLayout.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() {
            @Override
            public void onRefresh() {
                //mAdapter.loadMore(5);//lsitview实现*************************

                mRecyclerViewAdapter.loadMore(5);
                swipeRefreshLoadLayout.setRefreshing(false);
                Toast.makeText(MainActivity.this, "had loaded 5 more items.", Toast.LENGTH_SHORT).show();
            }
        });

//在这个方法内部实现接口,实现接口中的onload方法
        swipeRefreshLoadLayout.setOnLoadListener(new SwipeRefreshLoadLayout.OnLoadListener() {
            @Override
            public void onLoad() {
                new Handler().postDelayed(new Runnable() {
                    @Override
                    public void run() {
                        //mAdapter.loadMore(5);//lsitview实现***********************

                        mRecyclerViewAdapter.loadMore(5);//加载数据

                        Toast.makeText(MainActivity.this, "had loaded 5 more items.", Toast.LENGTH_SHORT).show();

                        swipeRefreshLoadLayout.setLoading(false);//设置是否转圈
                    }
                }, 1500);
            }
        });
    }

    //listview的适配器**********************
    class MyAdapter extends BaseAdapter {

        LayoutInflater inflater;

        ArrayList<Integer> listData;

        public MyAdapter(Context context, ArrayList<Integer> listData) {
            inflater = LayoutInflater.from(context);
            this.listData = listData;
        }

        public void loadMore(int addNum) {
            int fromIndex = listData.size();
            System.out.println("fromIndex: " + fromIndex);
            for (int i = fromIndex; i < fromIndex + addNum; i++)
                listData.add(i);
            notifyDataSetChanged();
        }

        @Override
        public int getCount() {
            return listData.size();
        }

        @Override
        public Object getItem(int position) {
            return listData.get(position);
        }

        @Override
        public long getItemId(int position) {
            return position;
        }

        @Override
        public View getView(int position, View convertView, ViewGroup parent) {
            ViewHolder holder;
            String text;
            if (convertView == null) {
                convertView = inflater.inflate(R.layout.item_ls, parent, false);
                holder = new ViewHolder(convertView);
//                text = String.format(holder.textView.getText().toString(), listData.get(position).toString());
//                holder.textView.setTag(text);
                convertView.setTag(holder);
            } else {
                holder = (ViewHolder) convertView.getTag();
            }
            text = String.format("我是会更加厉害的%s号!", listData.get(position).toString());
            holder.textView.setText(text);
            return convertView;
        }
    }

    private static class ViewHolder {
        TextView textView;

        public ViewHolder(View layout) {
            textView = (TextView) layout.findViewById(R.id.text);
        }
    }
}

 public class RecyclerViewAdapter extends RecyclerView.Adapter {

        private static final int TYPE_ITEM = 0;
        private static final int TYPE_FOOTER = 1;

        private int mSwitch = 0;

        private final LayoutInflater mLayoutInflater;
        private final Context mContext;
        private ArrayList<Integer> mData;

        public RecyclerViewAdapter(Context context, ArrayList<Integer> data) {
            mContext = context;
            mLayoutInflater = LayoutInflater.from(mContext);
            mData = data;
        }

        public void setFooterOn() {
            mSwitch = 1;
            notifyDataSetChanged();
        }

        public void setFooterOff() {
            mSwitch = 0;
            notifyDataSetChanged();
        }

    //加载更多数据
        public void loadMore(int addNum) {
            int fromIndex = mData.size();
            for (int i = fromIndex; i < fromIndex + addNum; i++)
                mData.add(i);
            notifyDataSetChanged();//更新适配器数据
        }

        @Override
        public int getItemViewType(int position) {
            if (position == getItemCount() - 1 && mSwitch == 1) {
                return TYPE_FOOTER;
            } else {
                return TYPE_ITEM;
            }
        }

        @Override
        public RecyclerView.ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
            View itemView = null;
            if (viewType == TYPE_ITEM) {
                itemView = mLayoutInflater.inflate(R.layout.item_ls, parent, false);
                ItemViewHolder viewHolder = new ItemViewHolder(itemView);
                return viewHolder;
            } else if (viewType == TYPE_FOOTER) {
                itemView = mLayoutInflater.inflate(R.layout.view_footer, parent, false);
                FooterViewHolder viewHolder = new FooterViewHolder(itemView);
                return viewHolder;
            }
            return null;
        }

        @Override
        public void onBindViewHolder(RecyclerView.ViewHolder holder, int position) {
            if (holder instanceof ItemViewHolder) {
                String text = String.format("我是%s号!!!", mData.get(position).toString());
                ((ItemViewHolder) holder).itemText.setText(text);
            } else if (holder instanceof FooterViewHolder) {
                // you can do somethings here in your footer
            }
        }

        @Override
        public int getItemCount() {
            // 若footer显示则应为item count 增加一项
            return mData.size() + mSwitch;
        }

        public static class ItemViewHolder extends RecyclerView.ViewHolder {

            public TextView itemText;

            public ItemViewHolder(View itemView) {
                super(itemView);
                itemText = (TextView) itemView.findViewById(R.id.text);

            }
        }

        public static class FooterViewHolder extends RecyclerView.ViewHolder {

            public TextView loadingText;

            public FooterViewHolder(View itemView) {
                super(itemView);
                loadingText = (TextView) itemView.findViewById(R.id.loading_text);
            }
        }
    }


 public class SwipeRefreshLoadLayout extends SwipeRefreshLayout {

        private final int mScaledTouchSlop;
        private final View mFooterView;

        private int CHILD_TYPE = 0; // 0:ListView 1:RecyclerView
        private ListView mListView;
        private RecyclerView mRecyclerView;

        private float mDownY, mUpY;
        private boolean mIsLoading;

        private OnLoadListener mOnLoadListener;//接口

        public SwipeRefreshLoadLayout(Context context) {
            super(context);

            // 控件移动的最小距离,手移动的距离大于此才能移动控件
            mScaledTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();

            mFooterView = View.inflate(context,R.layout.view_footer , null);
        }
//构造方法
        public SwipeRefreshLoadLayout(Context context, AttributeSet attrs) {
            super(context, attrs);

            // 控件移动的最小距离,手移动的距离大于此才能移动控件
            mScaledTouchSlop = ViewConfiguration.get(context).getScaledTouchSlop();

            mFooterView = View.inflate(context, R.layout.view_footer, null);

//            TypedArray a = context.obtainStyledAttributes(attrs,
//                    R.styleable.SwipeRefreshLoadLayout);
//            CHILD_TYPE = a.getInteger(R.styleable.SwipeRefreshLoadLayout_type, 0);
//            a.recycle();

        }

        //布局完成-----获取滚动的控件listview或者RecyclerView
        @Override
        protected void onLayout(boolean changed, int left, int top, int right, int bottom) {
            super.onLayout(changed, left, top, right, bottom);
            if (mRecyclerView == null) {
                if (getChildCount() > 1) {//使用listview实现*************
                    if (getChildAt(0) instanceof ListView) {
                        mListView = (ListView) getChildAt(0);
                        CHILD_TYPE = 0;
                    } //使用RecyclerView实现***************
                    else if (getChildAt(1) instanceof RecyclerView) {
                        mRecyclerView = (RecyclerView) getChildAt(1);
                        CHILD_TYPE = 1;
                    }
                    setChildViewOnScroll();//设置下拉滚动监听
                }
            }
        }

        //手势事件,用来判断是否触发滚动监听
        @Override
        public boolean dispatchTouchEvent(MotionEvent ev) {
            switch (ev.getAction()) {
                case MotionEvent.ACTION_DOWN:
                    mDownY = ev.getY();
                    break;
                case MotionEvent.ACTION_MOVE:
                    if (canLoadMore(mDownY - ev.getY())) {
                        loadData();
                    } else {
                        // 此处应重置,避免setChildViewOnScroll监听滑动时仍符合条件进入加载
                        mDownY = 0;
                        mUpY = 0;
                    }
                    break;
                case MotionEvent.ACTION_UP:
                    mUpY = ev.getY();
            }
            return super.dispatchTouchEvent(ev);
        }

        //是否加载小圈
        public void setLoading(boolean loading) {
            mIsLoading = loading;
            if (mIsLoading) {//转圈
                if (CHILD_TYPE == 0) {//listview实现
                    mListView.addFooterView(mFooterView);
                } else {
                    ((RecyclerViewAdapter) mRecyclerView.getAdapter()).setFooterOn();
                }
            } else {//不转圈
                if (CHILD_TYPE == 0) {//listview实现
                    mListView.removeFooterView(mFooterView);
                } else {
                    ((RecyclerViewAdapter) mRecyclerView.getAdapter()).setFooterOff();
                }
                mDownY = 0;
                mUpY = 0;
            }
        }
//这个使用来加载更多数据的,在MainActivity中调用,实现具体的接口中加载数据,设置是否转圈
        public void setOnLoadListener(OnLoadListener listener) {
            mOnLoadListener = listener;
        }

        //设置下拉滚动监听
        private void setChildViewOnScroll() {
            if (CHILD_TYPE == 0) {//listview实现**********
                mListView.setOnScrollListener(new AbsListView.OnScrollListener() {
                    @Override
                    public void onScrollStateChanged(AbsListView view, int scrollState) {
                        if (canLoadMore(mDownY - mUpY))
                            loadData();
                    }

                    @Override
                    public void onScroll(AbsListView view, int firstVisibleItem, int visibleItemCount, int totalItemCount) {

                    }
                });
            } else {//使用RecyclerView实现
                mRecyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {
                    @Override
                    public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
                        super.onScrollStateChanged(recyclerView, newState);
                        if (canLoadMore(mDownY - mUpY))
                            loadData();
                    }

                    @Override
                    public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
                        super.onScrolled(recyclerView, dx, dy);
                    }
                });
            }
        }

        private boolean canLoadMore(float touchSlop) {
            boolean isUp = touchSlop >= mScaledTouchSlop;
            if (isUp) {
                System.out.println("moving up...");
            } else {
                System.out.println("moving down...");
            }

            boolean isLastItem = false;
            if (CHILD_TYPE == 0) {
                if (mListView != null && mListView.getAdapter() != null)//判断是否是最后一个,listview实现
                    isLastItem = mListView.getLastVisiblePosition() == (mListView.getAdapter().getCount() - 1);
            } else {//
                if (mRecyclerView != null && mRecyclerView.getAdapter() != null) {
                    LinearLayoutManager manager = (LinearLayoutManager) mRecyclerView.getLayoutManager();
                    if (manager != null)
                        isLastItem = manager.findLastCompletelyVisibleItemPosition() == manager.getItemCount() - 1;
                }
            }
            if (isLastItem) {
                System.out.println("is last item");
            }

            if (!mIsLoading)
                System.out.println("not loading.");

            return isUp && isLastItem && !mIsLoading && !isRefreshing();
        }

        private void loadData() {
            System.out.println("loading data...");
            if (mOnLoadListener != null) {
                setLoading(true);//加载
                mOnLoadListener.onLoad();//调用接口中的方法
            }
        }

        //定义一个接口
        public interface OnLoadListener {
            void onLoad();
        }

    }



===============recyclerview控件======================

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值