【android学习】Jetpack:DataBinding在recycleview中的使用

简介

这文章是结合前面一篇文章写的后续使用,给定的demo包含了上一篇文章的代码,如果有不了解的,可以移步

Jetpack:DataBinding数据绑定

 

直接上代码

public class MyAdapter extends RecyclerView.Adapter<MyAdapter.MyViewHolder> {

    public Context context;
    public List<Item> data;

    public MyAdapter(Context context, List<Item> data) {
        this.context = context;
        this.data = data;
    }

    @NonNull
    @Override
    public MyViewHolder onCreateViewHolder(@NonNull ViewGroup parent, int viewType) {
        ViewDataBinding binding = DataBindingUtil.inflate(LayoutInflater.from(parent.getContext()), R.layout.item, parent, false);
        return new MyViewHolder(binding);
    }

    @Override
    public void onBindViewHolder(@NonNull MyViewHolder holder, int position) {
        Item item = data.get(position);
        if (position%2==0){
            item.setButtonVisiable(false);
        }
        ((MyViewHolder) holder).getBinding().setVariable(BR.item, item);
    }

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


    class MyViewHolder extends RecyclerView.ViewHolder {
        ViewDataBinding binding = null;

        public MyViewHolder(ViewDataBinding itemView) {
            super(itemView.getRoot());
            this.binding = itemView;
        }

        public ViewDataBinding getBinding() {
            return binding;
        }

    }

}

item的代码

public class Item extends BaseObservable {
    private String name;
    private String password;
    private String imageUrl;

    private boolean isButtonVisiable = true;

    public Item(String name, String password, String imageUrl) {
        this.name = name;
        this.password = password;
        this.imageUrl = imageUrl;
    }
    @Bindable
    public boolean isButtonVisiable() {
        return isButtonVisiable;
    }

    public void setButtonVisiable(boolean buttonVisiable) {
        isButtonVisiable = buttonVisiable;
        notifyPropertyChanged(BR.buttonVisiable);
    }

    @Bindable
    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
        notifyPropertyChanged(BR.name);
    }

    @Bindable
    public String getPassword() {
        return password;
    }

    public void setPassword(String password) {
        this.password = password;
        notifyPropertyChanged(BR.password);
    }

    public String getImageUrl() {
        return imageUrl;
    }

    public void setImageUrl(String imageUrl) {
        this.imageUrl = imageUrl;
    }

    //自定义属性:提供一个静态方法来加载image
    @BindingAdapter("bind:imageSrc")
    public static void getImage(ImageView view, String url) {
        Picasso.with(view.getContext()).load(url).into(view);
    }

    public void click(View view) {
        Toast.makeText(view.getContext(), getName(), Toast.LENGTH_SHORT).show();

    }
}

布局文件

<?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>

        <import type="android.view.View"/>
        <variable
            name="item"
            type="com.zkq.myviewmodel.bean.Item" />
    </data>

    <LinearLayout
        android:id="@+id/main"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:orientation="vertical"
        >


        <ImageView
            android:id="@+id/image"
            android:layout_width="100dp"
            android:layout_height="100dp"
            app:imageSrc="@{item.imageUrl}"/>

        <TextView
            android:id="@+id/text1"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@{`name: `+item.name}"
           />


        <TextView
            android:id="@+id/text2"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:text="@{`password: `+item.password}"
            />


        <Button
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:text="点我"
            android:onClick="@{item.click}"
            android:visibility="@{item.buttonVisiable ? View.VISIBLE : View.GONE}"
            />
    </LinearLayout>


</layout>

总结

这里使用了一个表达式

 android:visibility="@{item.buttonVisiable ? View.VISIBLE : View.GONE}"

前面需要引用

<import type="android.view.View"/>

我们在myAdapter中,偶数位设置隐藏

    if (position%2==0){
            item.setButtonVisiable(false);
        }

补充在listview中使用

这里是贴出了主要的getView方法

    public View getView(int position, View convertView, ViewGroup parent) {
        ViewDataBinding dataBinding;
        if(convertView==null){
            dataBinding= DataBindingUtil.inflate(LayoutInflater.from(parent.getContext()),R.layout.item,parent,false);
        }else{
            //就重就之前的
            dataBinding=DataBindingUtil.getBinding(convertView);
        }
        dataBinding.setVariable(BR.item,data.get(position));
        return dataBinding.getRoot().getRootView();
    }

demo下载demo下载地址

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值