Android RecyclerView的使用及下拉刷新

原创 2018年04月17日 14:45:01

一. 简介

       RecyclerView 是android5.0提出的代替ListView的新控件,还可以实现GridView的效果,自带分割线,也可以自定义分割线,增加List显示的美观性,而新增的LayoutManager可用来确定item的排列方式,可以通过LayoutManager来设置list要展示的是垂直还是水平,还添加了默认的增加和删除item动画。

二. 配置

在model下添加:

    compile 'com.android.support:recyclerview-v7:21.0.0'

三. RecyclerView的使用和下拉刷新

(1)简单布局

activity_layout.xml布局:

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:layout_width="match_parent"
    android:layout_height="match_parent"
    android:orientation="vertical">

    <android.support.v4.widget.SwipeRefreshLayout
        android:id="@+id/swipe"
        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" />
    </android.support.v4.widget.SwipeRefreshLayout>

</LinearLayout>

注:在布局中SwipeRefreshLayout是下拉加载的控件

list_layout.xml布局:

<?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="40dp"
    android:orientation="vertical">

    <TextView
        android:id="@+id/tv_recycler"
        android:layout_width="match_parent"
        android:layout_height="40dp" />

</LinearLayout>

注:列表布局我只显示了一个TextView,简单明了。需要注意的是父控件的高度跟list的item的高度相关。

(2)RecyclerView适配器

都知道写ListView展示数据都需要适配器,RecyclerView也不例外

RecyclerViewAdapter.java : 

import android.content.Context;
import android.support.v7.widget.RecyclerView;
import android.view.LayoutInflater;
import android.view.View;
import android.view.ViewGroup;
import android.widget.TextView;

import java.util.List;

public class RecyclerViewAdapter extends RecyclerView.Adapter<RecyclerViewAdapter.MyHolder> {

    List<String> list;    //数据集合
    Context context;

    public RecyclerViewAdapter(List<String> list, Context context){
        this.list = list;
        this.context = context;
    }
    
    //初始化item布局
    @Override
    public MyHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        View view =  LayoutInflater.from(context).inflate(R.layout.recycler_layout, parent, false);
        MyHolder holder = new MyHolder(view);
        return holder;
    }

    //想要怎么处理item,等同于BaseAdapter的getView
    @Override
    public void onBindViewHolder(MyHolder holder, int position) {
        holder.textView.setText(list.get(position));
    }

    //展示的数量
    @Override
    public int getItemCount() {
        return list.size();
    }

    //自动的HolderView优化,初始化item控件
    public class MyHolder extends RecyclerView.ViewHolder {
        TextView textView;

        public MyHolder(View itemView) {
            super(itemView);
            textView = itemView.findViewById(R.id.tv_recycler);
        }
    }

}

注:RecyclerView的适配器跟ListView略不同,但可以看出解耦性很高。

(3)MainActivity.java 

import android.graphics.Color;
import android.support.v4.widget.SwipeRefreshLayout;
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.DefaultItemAnimator;
import android.support.v7.widget.LinearLayoutManager;
import android.support.v7.widget.RecyclerView;

import java.util.ArrayList;
import java.util.List;

public class MainActivity extends AppCompatActivity {

    private RecyclerView recyclerView;
    private SwipeRefreshLayout swipe;
    private List<String> list;

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

    //添加演示数据
    private void initData() {
        list = new ArrayList<>();
        for (int i = 1; i < 21; i++)
            list.add("item " + i);
    }

    private void initView() {
        recyclerView = (RecyclerView) findViewById(R.id.recyclerView);
        RecyclerViewAdapter adapter = new RecyclerViewAdapter(list, this);
        LinearLayoutManager manager = new LinearLayoutManager(this);
        manager.setOrientation(OrientationHelper.VERTICAL);             //设置布局管理器,可设置水平或垂直
//        recyclerView.setLayoutManager(new LinearLayoutManager(this));   //设置布局管理器,默认是垂直(VERTICAL)
        recyclerView.setLayoutManager(manager);                         //设置布局管理器
        recyclerView.setAdapter(adapter);                               //设置适配器
        recyclerView.setItemAnimator(new DefaultItemAnimator());        //设置item默认动画
        //下拉刷新
        swipe = (SwipeRefreshLayout) findViewById(R.id.swipe);
        swipe.setColorSchemeColors(Color.RED);          //设置下拉刷新的动画颜色
        swipe.setOnRefreshListener(new SwipeRefreshLayout.OnRefreshListener() { //下拉刷新的处理事件
            @Override
            public void onRefresh() {
                swipe.setRefreshing(false);     //关闭下拉刷新,此处做下拉刷新的结果处理

            }
        });
}}注:注释应该很明了了。

四. 效果图






android 打造真正的下拉刷新上拉加载recyclerview(一):使用

WZMRecyclerview 是一个集成了 下拉刷新、上拉加载、滑到底部自动加载、添加删除头尾部 四个主要功能的recyclerview,当然,还支持 自定义的刷新头部和加载底部、EmptyView...
  • anyfive
  • anyfive
  • 2016-11-03 12:29:19
  • 6527

关于RecyclerView的下拉刷新,自定义帧动画,第三方框架PtrFrameLayout使用手册

首先放上一张gif图片 本身使用的是一个网上很出名的开源框架,地址是https://github.com/liaohuqiu/android-Ultra-Pull-To-Refresh,在此声明,我...
  • android_mylife
  • android_mylife
  • 2017-02-09 09:58:46
  • 1777

采用SwipeFreshLayout+Recyclerview实现下拉刷新和上拉加载更多以及CoordinatorLayout的引入

使用谷歌自己的控件swipefreshlayout+recyclerview实现下来刷新和上拉加载。。。
  • tiandiwuya
  • tiandiwuya
  • 2017-04-25 18:57:16
  • 2158

使用SwipeRefreshLayout和RecyclerView实现下拉刷新上拉加载更多

效果图: 文件目录 布局文件
  • zhe_ge_sha_shou
  • zhe_ge_sha_shou
  • 2017-03-28 19:42:49
  • 886

SwipeRefreshLayout+RecyclerView实现下拉刷新上拉自动加载

在实际开发中,为了节省开发周期,下拉刷新上拉加载通常都会采取使用一些第三方库,典型的就是用PullToRefresh,XListView等等,还有就是谷歌推荐的SwipeRefreshLayout,可...
  • AndroidStudioo
  • AndroidStudioo
  • 2016-07-09 19:48:10
  • 5832

Android RecyclerView嵌套RecyclerView并使用SwipeRefreshLayout导致未到顶部就触发下拉刷新

RecyclerView嵌套RecyclerView,外层再加下拉刷新,刷新时出现item中的recyclerView 下拉时触发刷新,感觉是滑动冲突引发的内层recyclerView把到达顶部给了s...
  • hjw45611
  • hjw45611
  • 2017-05-25 11:43:44
  • 750

Android RecyclerView实现了下拉刷新和上拉加载

  • 2016年04月27日 16:52
  • 3MB
  • 下载

【Android】给RecyclerView添加下拉刷新和加载更多(二)

大家都知道由于ListView的紧耦合问题,谷歌的改进就是RecyclerView本身不参与任何视图相关的问题。它不关心如何将子View放在合适的位置,也不关心如何分割这些子View,更不关心每个子V...
  • xiaoping0915
  • xiaoping0915
  • 2016-07-19 16:40:33
  • 3978

recyclerview 下拉刷新

  • 2017年12月03日 18:24
  • 20.95MB
  • 下载

RecyclerView下拉刷新上拉加载

作为ListView和GridView的替代者, RecyclerView以它的灵活性著称,而且有着更好更完善的缓存处理机制。但是在使用RecyclerVew的过程中有个很明显的问题:Recycler...
  • huyongl1989
  • huyongl1989
  • 2016-06-30 11:36:13
  • 3695
收藏助手
不良信息举报
您举报文章:Android RecyclerView的使用及下拉刷新
举报原因:
原因补充:

(最多只允许输入30个字)