下拉框架集合: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控件======================