SwipeRefreshLayout + RecyclerView 实现 上拉刷新 和 下拉刷新

SwipeRefreshLayout 是谷歌公司推出的用于下拉刷新的控件,support v4源码在SDK\sdk\extras\android\support\v4\src\java\android\support\v4\widget\SwipeRefreshLayout.java


今天说一下最常见的下拉刷新  和 上拉刷新的功能。

 

布局文件:

 

  1. <android.support.v4.widget.SwipeRefreshLayout  
  2.     xmlns:android="http://schemas.android.com/apk/res/android"  
  3.     xmlns:tools="http://schemas.android.com/tools"  
  4.     android:id="@+id/swipe_refresh_widget"  
  5.     android:layout_width="match_parent"  
  6.     android:layout_height="match_parent" >  
  7.   
  8.     <android.support.v7.widget.RecyclerView  
  9.         android:id="@android:id/list"  
  10.         android:layout_width="match_parent"  
  11.         android:layout_height="match_parent"  
  12.         android:cacheColorHint="@null"  
  13.         android:scrollbars="vertical" />  
  14.   
  15. </android.support.v4.widget.SwipeRefreshLayout>  

在Activity中引用这个布局并初始化

 

  1. @Override  
  2.  protected void onCreate(Bundle savedInstanceState) {  
  3.   super.onCreate(savedInstanceState);  
  4.   setContentView(R.layout.activity_main);  
  5.   
  6.   mSwipeRefreshWidget = (SwipeRefreshLayout) findViewById(R.id.swipe_refresh_widget);  
  7.   mRecyclerView = (RecyclerView) findViewById(android.R.id.list);  
  8.   
  9.   mSwipeRefreshWidget.setColorScheme(R.color.color1, R.color.color2,  
  10.     R.color.color3, R.color.color4);  
  11.   mSwipeRefreshWidget.setOnRefreshListener(this);  
  12.   
  13.   // 这句话是为了,第一次进入页面的时候显示加载进度条  
  14.   mSwipeRefreshWidget.setProgressViewOffset(false, 0, (int) TypedValue  
  15.     .applyDimension(TypedValue.COMPLEX_UNIT_DIP, 24, getResources()  
  16.       .getDisplayMetrics()));  
  17.   
  18.   mRecyclerView.setOnScrollListener(new RecyclerView.OnScrollListener() {  
  19.   
  20.    @Override  
  21.    public void onScrollStateChanged(RecyclerView recyclerView,  
  22.      int newState) {  
  23.     super.onScrollStateChanged(recyclerView, newState);  
  24.     if (newState == RecyclerView.SCROLL_STATE_IDLE  
  25.       && lastVisibleItem + 1 == adapter.getItemCount()) {  
  26.      mSwipeRefreshWidget.setRefreshing(true);  
  27.      // 此处在现实项目中,请换成网络请求数据代码,sendRequest .....  
  28.      handler.sendEmptyMessageDelayed(0, 3000);  
  29.     }  
  30.    }  
  31.   
  32.    @Override  
  33.    public void onScrolled(RecyclerView recyclerView, int dx, int dy) {  
  34.     super.onScrolled(recyclerView, dx, dy);  
  35.     lastVisibleItem = mLayoutManager.findLastVisibleItemPosition();  
  36.    }  
  37.   
  38.   });  
  39.   
  40.   mRecyclerView.setHasFixedSize(true);  
  41.   mLayoutManager = new LinearLayoutManager(this);  
  42.   mRecyclerView.setLayoutManager(mLayoutManager);  
  43.   mRecyclerView.setItemAnimator(new DefaultItemAnimator());  
  44.   
  45.   adapter = new SampleAdapter();  
  46.   mRecyclerView.setAdapter(adapter);  
  47.   
  48.   // 此处在现实项目中,请换成网络请求数据代码,sendRequest .....  
  49.   handler.sendEmptyMessageDelayed(0, 3000);  
  50.  }  

SwipeRefreshLayout里面需要注意的Api:
1、setOnRefreshListener(OnRefreshListener listener)  设置下拉监听,当用户下拉的时候会去执行回调
2、setColorSchemeColors(int... colors) 设置 进度条的颜色变化,最多可以设置4种颜色
3、setProgressViewOffset(boolean scale, int start, int end) 调整进度条距离屏幕顶部的距离
4、setRefreshing(boolean refreshing) 设置SwipeRefreshLayout当前是否处于刷新状态,一般是在请求数据的时候设置为true,在数据被加载到View中后,设置为false。


RecyclerView的实现:

第一种,下拉刷新和上拉刷新都用SwipeRefreshLayout 自带的进度条
  1. mRecyclerView = (RecyclerView) findViewById(android.R.id.list);  
  2. mRecyclerView.setOnScrollListener(new RecyclerView.OnScrollListener() {  
  3.   
  4.    @Override  
  5.    public void onScrollStateChanged(RecyclerView recyclerView,  
  6.      int newState) {  
  7.     super.onScrollStateChanged(recyclerView, newState);  
  8.     if (newState == RecyclerView.SCROLL_STATE_IDLE  
  9.       && lastVisibleItem + 1 == adapter.getItemCount()) {  
  10.      mSwipeRefreshWidget.setRefreshing(true);  
  11.      // 此处在现实项目中,请换成网络请求数据代码,sendRequest .....  
  12.      handler.sendEmptyMessageDelayed(0, 3000);  
  13.     }  
  14.    }  
  15.   
  16.    @Override  
  17.    public void onScrolled(RecyclerView recyclerView, int dx, int dy) {  
  18.     super.onScrolled(recyclerView, dx, dy);  
  19.     lastVisibleItem = mLayoutManager.findLastVisibleItemPosition();  
  20.    }  
  21.   });  
  22.   
  23.   mRecyclerView.setHasFixedSize(true);  
  24.   mLayoutManager = new LinearLayoutManager(this);  
  25.   mRecyclerView.setLayoutManager(mLayoutManager);  
  26.   mRecyclerView.setItemAnimator(new DefaultItemAnimator());  
  27.   
  28.   adapter = new SampleAdapter();  
  29.   mRecyclerView.setAdapter(adapter);  

第二种实现下拉刷新用SwipeRefreshLayout 自带的进度条, 上拉刷新用类似ListView的刷新 提示“加载中”等信息。
class SampleAdapter extends RecyclerView.Adapter<ViewHolder> {  
  •  private List<Integer> list;  
  •   
  •  private static final int TYPE_ITEM = 0;  
  •  private static final int TYPE_FOOTER = 1;  
  •   
  •  public List<Integer> getList() {  
  •   return list;  
  •  }  
  •   
  •  public SampleAdapter() {  
  •   list = new ArrayList<Integer>();  
  •  }  
  •   
  •  // RecyclerView的count设置为数据总条数+ 1(footerView)  
  •  @Override  
  •  public int getItemCount() {  
  •   return list.size() + 1;  
  •  }  
  •   
  •  @Override  
  •  public int getItemViewType(int position) {  
  •   // 最后一个item设置为footerView  
  •   if (position + 1 == getItemCount()) {  
  •    return TYPE_FOOTER;  
  •   } else {  
  •    return TYPE_ITEM;  
  •   }  
  •  }  
  •   
  •  @Override  
  •  public void onBindViewHolder(ViewHolder holder, final int position) {  
  •   if (holder instanceof ItemViewHolder) {  
  •    ((ItemViewHolder) holder).textView.setText(String.valueOf(list  
  •      .get(position)));  
  •   }  
  •  }  
  •   
  •  @Override  
  •  public ViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {  
  •   if (viewType == TYPE_ITEM) {  
  •    View view = LayoutInflater.from(parent.getContext()).inflate(  
  •      R.layout.list_item_text, null);  
  •    view.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT,  
  •      LayoutParams.WRAP_CONTENT));  
  •    return new ItemViewHolder(view);  
  •   }  
  •   // type == TYPE_FOOTER 返回footerView  
  •   else if (viewType == TYPE_FOOTER) {  
  •    View view = LayoutInflater.from(parent.getContext()).inflate(  
  •      R.layout.footerview, null);  
  •    view.setLayoutParams(new LayoutParams(LayoutParams.MATCH_PARENT,  
  •      LayoutParams.WRAP_CONTENT));  
  •    return new FooterViewHolder(view);  
  •   }  
  •   
  •   return null;  
  •  }  
  •   
  •  class FooterViewHolder extends ViewHolder {  
  •   
  •   public FooterViewHolder(View view) {  
  •    super(view);  
  •   }  
  •   
  •  }  
  •   
  •  class ItemViewHolder extends ViewHolder {  
  •   TextView textView;  
  •   
  •   public ItemViewHolder(View view) {  
  •    super(view);  
  •    textView = (TextView) view.findViewById(R.id.text);  
  •   }  
  •  }  
  • }  

这样我们就可以针对footerview的布局做一些处理了,比如提示“加载中,”,“已经全部加载”等信息。更加灵活一点
posted @ 2016-11-11 21:50  天涯海角路  阅读(91)  评论(0)    收藏  举报