效果图:(本地图片就不放上来了,大家随意使用自己喜欢的图片即可)
先导入依赖
compile 'com.android.support:recyclerview-v7:25.3.1'
activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:app="http://schemas.android.com/apk/res-auto"
xmlns:tools="http://schemas.android.com/tools"
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"/>
</LinearLayout>
recyclerview子条目的布局 recycler_item_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="wrap_content">
<ImageView
android:scaleType="fitXY"
android:src="@drawable/a"
android:id="@+id/imageview"
android:gravity="center"
android:layout_margin="3dp"
android:layout_width="match_parent"
android:layout_height="200dp" />
</LinearLayout>
MainActivity
import android.support.v7.app.AppCompatActivity;
import android.os.Bundle;
import android.support.v7.widget.DefaultItemAnimator;
import android.support.v7.widget.RecyclerView;
import android.support.v7.widget.StaggeredGridLayoutManager;
import java.util.ArrayList;
import java.util.List;
public class MainActivity extends AppCompatActivity {
/**
* 复用视图的控件
*/
private RecyclerView recyclerView;
/**
* 显示的数据
*/
private List<Integer> mDatas;
/**
* RecyclerView的适配器
*/
private MyRecyclerViewAdapter adapter;
@Override
protected void onCreate(Bundle savedInstanceState) {
super.onCreate(savedInstanceState);
setContentView(R.layout.activity_main);
//1.找到控件
recyclerView = (RecyclerView) findViewById(R.id.recyclerview);
//2.声名为瀑布流的布局方式: 2列,垂直方向
StaggeredGridLayoutManager staggeredGridLayoutManager = new StaggeredGridLayoutManager(2,StaggeredGridLayoutManager.VERTICAL);
//3.为recyclerView设置布局管理器
recyclerView.setLayoutManager(staggeredGridLayoutManager);
initData();//初始化数据
//3.创建适配器
adapter = new MyRecyclerViewAdapter(this, mDatas);
//设置添加,移除item的动画,DefaultItemAnimator为默认的
recyclerView.setItemAnimator(new DefaultItemAnimator());
//4.设置适配器
recyclerView.setAdapter(adapter);
}
//初始化数据
protected void initData(){
mDatas = new ArrayList();
mDatas.add(R.drawable.u);
mDatas.add(R.drawable.v);
mDatas.add(R.drawable.w);
mDatas.add(R.drawable.x);
mDatas.add(R.drawable.y);
mDatas.add(R.drawable.z);
mDatas.add(R.drawable.a);
mDatas.add(R.drawable.b);
mDatas.add(R.drawable.c);
mDatas.add(R.drawable.d);
mDatas.add(R.drawable.e);
mDatas.add(R.drawable.f);
mDatas.add(R.drawable.g);
mDatas.add(R.drawable.h);
mDatas.add(R.drawable.i);
mDatas.add(R.drawable.j);
mDatas.add(R.drawable.k);
mDatas.add(R.drawable.l);
mDatas.add(R.drawable.m);
mDatas.add(R.drawable.n);
mDatas.add(R.drawable.o);
mDatas.add(R.drawable.p);
mDatas.add(R.drawable.q);
mDatas.add(R.drawable.r);
mDatas.add(R.drawable.s);
mDatas.add(R.drawable.t);
mDatas.add(R.drawable.u);
mDatas.add(R.drawable.v);
mDatas.add(R.drawable.w);
mDatas.add(R.drawable.x);
mDatas.add(R.drawable.y);
mDatas.add(R.drawable.z);
}
}
适配器MyRecyclerViewAdapter
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.ImageView;
import java.util.ArrayList;
import java.util.List;
import java.util.Random;
public class MyRecyclerViewAdapter extends RecyclerView.Adapter<MyRecyclerViewAdapter.MyViewHolder> {
private Context context;
private List<Integer> list;//数据
private List<Integer> heightList;//装产出的随机数
public MyRecyclerViewAdapter(Context context, List<Integer> list) {
this.context = context;
this.list = list;
//记录为每个控件产生的随机高度,避免滑回到顶部出现空白
heightList = new ArrayList<>();
for (int i = 0; i < list.size(); i++) {
int height = new Random().nextInt(300) + 500;//[100,300)的随机数
heightList.add(height);
}
}
@Override
public MyViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
//找到item的布局
View view= LayoutInflater.from(context).inflate(R.layout.recycler_item_layout,parent,false);
return new MyViewHolder(view);//将布局设置给holder
}
@Override
public int getItemCount() {
return list.size();
}
/**
* 绑定视图到holder,就如同ListView的getView(),但是这里已经把复用实现了,我们只需要填充数据就行.
* 由于在复用的时候都是调用该方法填充数据,但是上滑的时候,又会随机产生高度设置到控件上,这样当滑
* 到顶部可能就会看到一片空白,因为后面随机产生的高度和之前的高度不一样,就不能填充屏幕了,所以
* 需要记录每个控件产生的随机高度,然后在复用的时候再设置上去
*/
@Override
public void onBindViewHolder(final MyViewHolder holder, final int position) {
//填充数据
holder.imageView.setImageResource(list.get(position));
//由于需要实现瀑布流的效果,所以就需要动态的改变控件的高度了
ViewGroup.LayoutParams params = holder.imageView.getLayoutParams();
params.height=heightList.get(position);
holder.imageView.setLayoutParams(params);
}
class MyViewHolder extends RecyclerView.ViewHolder{
ImageView imageView;
public MyViewHolder(View itemView) {
super(itemView);
imageView = (ImageView) itemView.findViewById(R.id.imageview);
}
}
}