RecyclerView 的使用

本文详细介绍了如何在Android中实现瀑布流布局。首先,通过XML创建了一个包含RecyclerView的LinearLayout。接着,在Activity中设置了StaggeredGridLayoutManager以达到瀑布流效果,并创建了RecyclerView的Adapter来填充数据。最后,Adapter中的onBindViewHolder方法用于定制每个条目的高度,例如在特定位置增大高度以模拟瀑布效果。

这里只是简单记录一下怎么使用

 

第一步:Layout文件

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

    <androidx.recyclerview.widget.RecyclerView
        android:id="@+id/RecyclerViewId"
        android:layout_width="match_parent"
        android:layout_height="match_parent"/>
</LinearLayout>

 第2步:Activity
这里是实现的瀑布视图


public class RecyclerViewActivity extends Activity {
    private RecyclerView mRecyclerView;
    @Override
    protected void onCreate(@Nullable Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        setContentView(R.layout.recycler_view_demo);
        mRecyclerView = findViewById(R.id.RecyclerViewId);

        List<String> dataList = new ArrayList<>();
        for(int i=0;i<30;i++){
            dataList.add(new String("数据" + (i+1)));
        }
        RecycleViewAdapter recycleAdapter = new RecycleViewAdapter(this,dataList);
//截图2的效果
         /*GridLayoutManager manager = new GridLayoutManager(this,4);
        manager.setSpanSizeLookup(new GridLayoutManager.SpanSizeLookup(){

            @Override
            public int getSpanSize(int position) {
                if(position == 4) return  3;
                if(position == 8) return  2;
                return 1;
            }
        });*/
//截图1的效果
        StaggeredGridLayoutManager manager=new StaggeredGridLayoutManager(4, OrientationHelper.VERTICAL);
        mRecyclerView.setLayoutManager(manager);
        mRecyclerView.setAdapter(recycleAdapter);
    }
}

第3步:实现Adapter


public class RecycleViewAdapter extends RecyclerView.Adapter<RecycleViewAdapter.MyViewHolder>{
    private View mItemView;
    private Context mContext;
    private List<String> mList;

    public RecycleViewAdapter(Context context, List<String> list) {
        this.mContext = context;
        mList = list;
    }

    @NonNull
    @Override
    public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        mItemView = LayoutInflater.from(mContext).inflate(R.layout.item_text,parent,false);
        MyViewHolder holder = new MyViewHolder(mItemView);
        return holder;
    }

    @Override
    public void onBindViewHolder(@NonNull MyViewHolder holder, int position) {
        if(position == 4){
            ViewGroup.LayoutParams params = holder.rootView.getLayoutParams();
            params.height = 150 * 3 *2;//holder.rootView.getMeasuredHeight() *2;
            holder.rootView.setLayoutParams(params);
        }
        holder.textView.setText(mList.get(position));
    }

    @Override
    public int getItemCount() {
        return mList.size();
    }

    class MyViewHolder extends RecyclerView.ViewHolder{
        TextView textView;
        ViewGroup rootView ;
        public MyViewHolder(View itemView) {
            super(itemView);
            rootView= (ViewGroup)itemView;
            textView = (TextView) itemView.findViewById(R.id.textView);
        }
    }
}

其他:导入support 包

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值