Android Fragment + RecyclerView瀑布流布局

本文介绍了如何在Android中利用RecyclerView实现瀑布流布局。详细讲解了RecyclerView的基本用法,包括Adapter的实现,如onCreateViewHolder、onBindViewHolder和getItemCount方法。此外,还提供了Adapter代码示例、Fragment或Activity的相关代码片段,以及主布局和item子布局的设计。
摘要由CSDN通过智能技术生成

瀑布流效果图

使用RecyclerView实现瀑布流布局

在这里插入图片描述

RecyclerView的用法

RecyclerView与ListView 类似,都使用Adapter(适配器)来生成列表项,不同的是RecyclerView 使用的是改进的RecyclerView.Adapter,RecyclerView.Adapter需要实现三种方法。

onCreteViewHolder(ViewGroup viewGroup,int i);
此方法用于创建列表项组件。

onBindViewHolder(ViewHolder viewHolder,int i);
此方法用于负责为列表项组件绑定数据,每次组件重新显示出来都会重新执行该方法。

getItemCount();
该方法的返回值决定包含多少个列表项。

Adapter代码示例

public class StaggeredGridAdater extends RecyclerView.Adapter<StaggeredGridAdater.HomeViewHolder> {
   

    private Context mContext;
    private List<Home> homeList = new ArrayList<>();

    public StaggeredGridAdater(Context context,List<Home> homeList){
   
        this.mContext = context;
        this.homeList = homeList;
    }

    //创建列表组件
    @NonNull
    @Override
    public StaggeredGridAdater.HomeViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
   
        View view = LayoutInflater.from(parent.getContext()).inflate(R.layout.home_item,null);
        return new StaggeredGridAdater.HomeViewHolder(view,this);
    }

    //绑定数据
    @Override
    public void onBindViewHolder(@NonNull HomeViewHolder holder, int position) {
   
        holder.imageIdIv.setImageResource(homeList.get(position).getImageId());
        holder.nameTv.setText(homeList.get(position).getName());
    }

    //返回列表数据总数
    @Override
    public int getItemCount() {
   
评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值