Android完成上拉加载和下拉刷新
2016-03-28 09:31
549 查看
这些天开始跟进项目版本,改了几个UI界面。前两天在上文的基础上研究上拉加载更多和下拉刷新,因为使用的是RecyclerView,然后mRecyclerView.setLayoutManager(new GridLayoutManager(this, 2))这里用的GridLayoutManager显示两列。因为上拉下拉是要判定位置的,下拉有一个系统的SwipeRefreshLayout,在Activity中实现SwipeRefreshLayout.OnRefreshListener这个接口,然后重写onRefresh,这里我在重写的方法里面发送handler,在handler队列进行刷新处理,然后上拉加载的时候遇到一个问题,在百度网上的demo的时候,发现有个findLastVisibleItemPosition这样的方法,但是我的GridLayoutManger里面没有这个方法,这里走了歪路,卡了很久,后面突然看到有一个强转的方法:
int lastVisibleItem = ((LinearLayoutManager) mLayoutManager).findLastVisibleItemPosition();
int totalItemCount = mLayoutManager.getItemCount();
第一个是你页面是最后一个item的position,第二个是所有的item,至于怎么判断:
mSwipeRefreshLayout.setOnRefreshListener(this);
mRecyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {
@Override
public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
super.onScrollStateChanged(recyclerView, newState);
}
@Override
public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
super.onScrolled(recyclerView, dx, dy);
int lastVisibleItem = ((LinearLayoutManager) mLayoutManager).findLastVisibleItemPosition();
int totalItemCount = mLayoutManager.getItemCount();
//lastVisibleItem >= totalItemCount - 1表示剩下1个item自动加载,各位自由选择
// dy>0 表示向下滑动
if (lastVisibleItem >= totalItemCount-1 && dy > 0) {
}
}
});
设置一个监听,然后如上,第一个方法是滑动的时候,第二个是滑动结束。
然后底部加ContentLoadingProgressBar的方法我就直接贴出来吧.(头部是系统的样式)
public int getItemViewType(int position) {
Log.i("-------", position + "-------" + getItemCount());
if (position == getItemCount()-1) {
return TYPE_FOOTER;
} else {
return TYPE_ITEM;
}
}
public static class ViewHolder extends RecyclerView.ViewHolder {
private ImageView imageView;
private View view;
private ContentLoadingProgressBar bar;
public ViewHolder(View v) {
super(v);
view = v;
imageView = (ImageView) v.findViewById(R.id.image_view);
bar = (ContentLoadingProgressBar) v.findViewById(R.id.progressbar);
}
}
public MyAdapter.ViewHolder onCreateViewHolder(ViewGroup parent,
int viewType) {
if (viewType == TYPE_ITEM) {
View v = LayoutInflater.from(parent.getContext())
.inflate(R.layout.imageview, parent, false);
ViewHolder vh = new ViewHolder(v);
return vh;
} else if (viewType == TYPE_FOOTER) {
View footerView = LayoutInflater.from(parent.getContext()).inflate(R.layout.footerview, null);
LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);
footerView.setLayoutParams(lp);
return new ViewHolder(footerView);
}
return null;
}
public void onBindViewHolder(final ViewHolder holder, int position) {
if (holder.imageView != null) {
String url = URLS.get(position);
holder.imageView.setImageResource(R.drawable.ic_launcher);
holder.imageView.setTag(url);
downloadImage(url, url_path, holder.imageView, new DownloadImages() {
@Override
public void onDownloadSucc(Bitmap bitmap, String c_url) {
ImageView imageView = (ImageView) holder.view.findViewWithTag(c_url);
if (imageView != null) {
imageView.setImageBitmap(bitmap);
imageCaches.put(c_url, new SoftReference<Bitmap>(bitmap));
}
}
});
}
}
public int getItemCount() {
return URLS.size()+1;
}
public List<String> getList() {
return URLS;
}
这里基本一些重要的代码都在这里了,具体下载的我就没有贴出来了。
但是我这里有一个问题,因为是两列,所以我加的那个footview总是显示底部的第一列的位置,而第二列的底部是空的,这里有个问题,有知道的朋友麻烦告知下。
加载更多的时候,adapter数据变化的时候:
mSwipeRefreshLayout.setRefreshing(false);
List<String> addlist = addList();
mAdapter.getList().addAll(addlist);
mAdapter.notifyItemRemoved(mAdapter.getItemCount());
这里调用notifyItemRemoved()是下拉刷新显示的时候,刷完删除最后的item,这样就不会一直显示尾部那个刷新的样式。
int lastVisibleItem = ((LinearLayoutManager) mLayoutManager).findLastVisibleItemPosition();
int totalItemCount = mLayoutManager.getItemCount();
第一个是你页面是最后一个item的position,第二个是所有的item,至于怎么判断:
mSwipeRefreshLayout.setOnRefreshListener(this);
mRecyclerView.addOnScrollListener(new RecyclerView.OnScrollListener() {
@Override
public void onScrollStateChanged(RecyclerView recyclerView, int newState) {
super.onScrollStateChanged(recyclerView, newState);
}
@Override
public void onScrolled(RecyclerView recyclerView, int dx, int dy) {
super.onScrolled(recyclerView, dx, dy);
int lastVisibleItem = ((LinearLayoutManager) mLayoutManager).findLastVisibleItemPosition();
int totalItemCount = mLayoutManager.getItemCount();
//lastVisibleItem >= totalItemCount - 1表示剩下1个item自动加载,各位自由选择
// dy>0 表示向下滑动
if (lastVisibleItem >= totalItemCount-1 && dy > 0) {
}
}
});
设置一个监听,然后如上,第一个方法是滑动的时候,第二个是滑动结束。
然后底部加ContentLoadingProgressBar的方法我就直接贴出来吧.(头部是系统的样式)
public int getItemViewType(int position) {
Log.i("-------", position + "-------" + getItemCount());
if (position == getItemCount()-1) {
return TYPE_FOOTER;
} else {
return TYPE_ITEM;
}
}
public static class ViewHolder extends RecyclerView.ViewHolder {
private ImageView imageView;
private View view;
private ContentLoadingProgressBar bar;
public ViewHolder(View v) {
super(v);
view = v;
imageView = (ImageView) v.findViewById(R.id.image_view);
bar = (ContentLoadingProgressBar) v.findViewById(R.id.progressbar);
}
}
public MyAdapter.ViewHolder onCreateViewHolder(ViewGroup parent,
int viewType) {
if (viewType == TYPE_ITEM) {
View v = LayoutInflater.from(parent.getContext())
.inflate(R.layout.imageview, parent, false);
ViewHolder vh = new ViewHolder(v);
return vh;
} else if (viewType == TYPE_FOOTER) {
View footerView = LayoutInflater.from(parent.getContext()).inflate(R.layout.footerview, null);
LinearLayout.LayoutParams lp = new LinearLayout.LayoutParams(ViewGroup.LayoutParams.MATCH_PARENT, ViewGroup.LayoutParams.WRAP_CONTENT);
footerView.setLayoutParams(lp);
return new ViewHolder(footerView);
}
return null;
}
public void onBindViewHolder(final ViewHolder holder, int position) {
if (holder.imageView != null) {
String url = URLS.get(position);
holder.imageView.setImageResource(R.drawable.ic_launcher);
holder.imageView.setTag(url);
downloadImage(url, url_path, holder.imageView, new DownloadImages() {
@Override
public void onDownloadSucc(Bitmap bitmap, String c_url) {
ImageView imageView = (ImageView) holder.view.findViewWithTag(c_url);
if (imageView != null) {
imageView.setImageBitmap(bitmap);
imageCaches.put(c_url, new SoftReference<Bitmap>(bitmap));
}
}
});
}
}
public int getItemCount() {
return URLS.size()+1;
}
public List<String> getList() {
return URLS;
}
这里基本一些重要的代码都在这里了,具体下载的我就没有贴出来了。
但是我这里有一个问题,因为是两列,所以我加的那个footview总是显示底部的第一列的位置,而第二列的底部是空的,这里有个问题,有知道的朋友麻烦告知下。
加载更多的时候,adapter数据变化的时候:
mSwipeRefreshLayout.setRefreshing(false);
List<String> addlist = addList();
mAdapter.getList().addAll(addlist);
mAdapter.notifyItemRemoved(mAdapter.getItemCount());
这里调用notifyItemRemoved()是下拉刷新显示的时候,刷完删除最后的item,这样就不会一直显示尾部那个刷新的样式。
相关文章推荐
- Android Dialog(对话框)增加动画效果
- Android LayoutInflater原理分析,带你一步步深入了解View(一)
- 【Android基础】Activity启动模式以及Intent Flags 与 栈 的全面解析
- Android使用procrank和dumpsysmeminfo分析内存占用情况
- Android 自定义View 三板斧之二——组合现有控件
- 【Android进阶】怎样使用文件来保存程序中的数据
- Android中测量控件的宽和高
- 4.android学习日志
- Android解析——json解析为javabean
- Android Studio发布到Jcenter
- Android系统源码学习参考路线(转载)
- Android开发中从url中加载图片
- android Theme使用三
- android 入门 二
- 对于android源码的忧虑
- 【转载】总结一下Android中主题(Theme)的正确玩法
- Android进阶——Socket长连接通信实例
- 【轉】Android编程之SparseArray<E>详解
- 【轉】Android音频开发(1):基础知识
- 【轉】Android平台一种快速毛玻璃虚化效果实现