使用RecyclerView实现瀑布流

准备工作

  • 添加网络权限,在此项目中用于获取网络图片
  • 添加Glide依赖,用于加载图片
  • 启用dataBinding,也可不用dataBinding,这里主要是练习一下

添加网络权限
implementation ‘com.github.bumptech.glide:glide:4.11.0’//图片加载

添加依赖/启用dataBinding

布局

这里用了dataBinding的布局,在最外层是layout,好处是不用一个个findview控件了,data中为空,表示我们这里不需要数据

activity_main.xml
<?xml version="1.0" encoding="utf-8"?>
<layout 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">
    <data>

    </data>
    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="match_parent"
        android:orientation="vertical"
        tools:context=".MainActivity">

        <androidx.recyclerview.widget.RecyclerView
            android:id="@+id/rv"
            android:layout_width="match_parent"
            android:layout_height="match_parent" />
    </LinearLayout>
</layout>
rv_item.xml

variable中的type,RVBean是我们自定义的一个Javabean
也就是get/set那个,懂我意思吧

Textview中的android:text="@{item.text}" ,item是我们在variable中name的值,由我们自己指定,text就是RVBean中自己定的String类型的值

而ImageView中的app:url="@{item.url}",url是在RVBean中使用的BindingAdapter进行自定的属性,用于指定图片的url

指定了variable和上面的属性,我们连id都可以不用加了,后面直接setItem()就行了【PS:因为我们这里的name是item,所以就是setItem().如果是data,后面就要用setData()

<?xml version="1.0" encoding="utf-8"?>
<layout xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto">

    <data>

        <variable
            name="item"
            type="com.cq.recyclerbinding.RVBean" />
    </data>

    <LinearLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content">

        <androidx.cardview.widget.CardView
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:layout_margin="8dp"
            app:cardCornerRadius="8dp"
            app:cardElevation="4dp">

            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="wrap_content"
                android:orientation="vertical">

                <ImageView
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:adjustViewBounds="true"
                    android:scaleType="fitXY"
                    app:url="@{item.url}" />

                <TextView
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:textAlignment="center"
                    android:layout_margin="4dp"
                    android:text="@{item.text}" />
            </LinearLayout>
        </androidx.cardview.widget.CardView>
    </LinearLayout>
</layout>

代码

终于要到主角了,先创建RVBean

RVBean.class

可以看到 @BindingAdapter(“url”) ,下面的loadImg就是使用Glide加载的图片,这个方法一定要是静态(static)的

public class RVBean {
    private String url;
    private String text;

    @BindingAdapter("url")
    public static void loadImg(ImageView imageView, String url) {
        Glide.with(imageView).load(url).into(imageView);
    }

    public String getUrl() {
        return url;
    }

    public void setUrl(String url) {
        this.url = url;
    }

    public String getText() {
        return text;
    }

    public void setText(String text) {
        this.text = text;
    }

    public RVBean(String url, String text) {
        this.url = url;
        this.text = text;
    }
}

RVAdapter.class

RecyclerView的适配器,在布局中加入了dataBinding的layout标签,就会自动生成binding类,比如我们之前的 rv_item.xml就会生成一个RvItemBinding,我们直接获取这个binding就可以操作视图了

获取到了RvItemBinding,可以直接setItem(RVBean),这个item也就是我们在布局中命的名字,如果你命的是data,那就是setData(),同理如果你命的是rvbean,那就是setRvbean()

public class RVAdapter extends RecyclerView.Adapter<RVAdapter.VH> {
    private Context context;
    private List<RVBean> rvBeans;

    public RVAdapter(Context context, List<RVBean> rvBeans) {
        this.context = context;
        this.rvBeans = rvBeans;
    }

    @NonNull
    @Override
    public VH onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        return new VH(DataBindingUtil.inflate(
                LayoutInflater.from(context), R.layout.rv_item, parent, false).getRoot());
    }

    @Override
    public void onBindViewHolder(@NonNull VH holder, int position) {
        RvItemBinding binding = DataBindingUtil.bind(holder.itemView);
        binding.setItem(rvBeans.get(position));
    }

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

    public class VH extends RecyclerView.ViewHolder {
        public VH(@NonNull View itemView) {
            super(itemView);
        }
    }
}

MainActivity.class

因为我们之前的activity_main.xml也用了layout标签,所以我们直接获取ActivityMainBinding来操作

public class MainActivity extends AppCompatActivity {
    private ActivityMainBinding binding;
    private List<RVBean> rvBeanList = new ArrayList<>();
    private RVAdapter adapter;

    @Override
    protected void onCreate(Bundle savedInstanceState) {
        super.onCreate(savedInstanceState);
        binding = DataBindingUtil.inflate(LayoutInflater.from(this), R.layout.activity_main, null, false);
        setContentView(binding.getRoot());
        initData();
    }

    private void initData() {
        for (int i = 0; i < 20; i++) {
            rvBeanList.add(new RVBean("", "text" + i));
            rvBeanList.add(new RVBean("https://ss3.bdstatic.com/70cFv8Sh_Q1YnxGkpoWK1HF6hhy/it/u=3656208536,1275700259&fm=26&gp=0.jpg", "text" + i));
            rvBeanList.add(new RVBean("https://ss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=342143065,3756070031&fm=26&gp=0.jpg", "text" + i));
        }
        adapter = new RVAdapter(this, rvBeanList);
        //主要就是这个LayoutManager,就是用这个来实现瀑布流的,3表示有3列(垂直)或3行(水平),我们这里用的垂直VERTICAL
        binding.rv.setLayoutManager(new StaggeredGridLayoutManager(3, StaggeredGridLayoutManager.VERTICAL));
        binding.rv.setAdapter(adapter);
    }
}

最后/效果

我也不怎么会写教程,就只是贴代码,上面也是全部的代码,直接copy下来就能用😂最后就来看看效果图
横屏
竖屏

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值