Android数据绑定添加小部件作为绑定适配器的参数

Android数据绑定添加小部件作为绑定适配器的参数,android,data-binding,android-recyclerview,android-databinding,Android,Data Binding,Android Recyclerview,Android Databinding,我想在progressbar中运行可见的,直到图像加载到imageview中。我想通过绑定适配器实现它。我有一个CustomBinder类,它的bindingadpter为imageUrl。这是我的定制活页夹- public class CustomBinders { static ImageLoader imageLoader; public static DisplayImageOptions options; private static final String

我想在progressbar中运行可见的,直到图像加载到imageview中。我想通过绑定适配器实现它。我有一个CustomBinder类,它的bindingadpter为imageUrl。这是我的定制活页夹-

public class CustomBinders {

    static ImageLoader imageLoader;
    public static DisplayImageOptions options;
    private static final String TAG = "CustomBinders";

    @BindingAdapter({"imageUrl"})
    public static void loadImage(ImageView view, String imageUrl){
        imageLoader= ImageLoader.getInstance();
        options = StaticMethods.setUIL();
        Log.d(TAG, "loadImage: ");
        imageLoader.displayImage(imageUrl, view, options, new SimpleImageLoadingListener() {
            @Override
            public void onLoadingStarted(String imageUri, View view) {

            }

            @Override
            public void onLoadingFailed(String imageUri, View view, FailReason failReason) {
                String message = null;
                switch (failReason.getType()) {
                    case IO_ERROR:
                        message = "Input/Output error";
                        break;
                    case DECODING_ERROR:
                        message = "Image can't be decoded";
                        break;
                    case NETWORK_DENIED:
                        message = "Downloads are denied";
                        break;
                    case OUT_OF_MEMORY:
                        message = "Out Of Memory error";
                        break;
                    case UNKNOWN:
                        message = "Unknown error";
                        break;
                }
                view.setBackgroundResource(R.drawable.blank);

            }

            @Override
            public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {

            }
        });
    }
}
在我的xml中,它们是一个progressbar,我想看到progressbar,直到图像加载完成。这是我的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"
    >
    <data class="ArtListCreatedByBind">
        <variable
            name="artlist"
            type="com.twebexponent.artwork.data.ArtListCreatedBy"/>
    </data>

    <FrameLayout
        android:id="@+id/myContainer"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:visibility="visible"
        android:background="@drawable/manageartwork_border">

        <ProgressBar
            android:id="@+id/progressBar"
            style="?android:attr/progressBarStyleSmall"
            android:layout_width="wrap_content"
            android:layout_height="wrap_content"
            android:layout_centerHorizontal="true"
            android:layout_centerVertical="true"
            android:layout_gravity="center"
            android:layout_marginBottom="20dp"
            android:layout_marginTop="20dp"
            android:visibility="gone" />

        <ImageView
            android:id="@+id/art_img"
            android:layout_width="match_parent"
            android:layout_height="100dp"
            android:scaleType="centerCrop"
            android:adjustViewBounds="true"
            app:imageUrl="@{artlist.image}"
            />
    </FrameLayout>



</layout>
现在,在上面的代码中,我第一次看到progressbar,然后当图像加载完成时,我只需打开progressbar。现在,我将如何使用@BindingAdapter({“imageUrl”})实现这一点

这就是recylerview的适配器的外观-

public class ArtistCreatedByAdapter extends RecyclerView.Adapter<ArtistCreatedByAdapter.CustomViewHolder> {


    ArrayList<ArtListCreatedBy> createdByArtList;
    Activity activity;
    LayoutInflater inflater;
    ImageLoader imageLoader;
    public DisplayImageOptions options;
    ArtListCreatedByBind viewDataBinding;

    public class CustomViewHolder extends RecyclerView.ViewHolder {

        private ArtListCreatedByBind mViewDataBinding;

        public CustomViewHolder( View v) {
            super(v);

            mViewDataBinding = DataBindingUtil.bind(v);
            mViewDataBinding.executePendingBindings();

        }

        public ArtListCreatedByBind getViewDataBinding() {
            return mViewDataBinding;
        }
    }

    public ArtistCreatedByAdapter(Activity activity, ArrayList<ArtListCreatedBy> createdByArtList) {
        this.activity = activity;
        imageLoader= ImageLoader.getInstance();
        this.createdByArtList = createdByArtList;
    }

    @Override
    public CustomViewHolder onCreateViewHolder(ViewGroup parent, int viewType) {
        inflater = (LayoutInflater) activity.getSystemService(Context.LAYOUT_INFLATER_SERVICE);
        View itemView = inflater.inflate(R.layout.singlerow_art_list_created_by, parent, false);

        return new CustomViewHolder(itemView);
    }

    @Override
    public void onBindViewHolder(CustomViewHolder holder, final int position) {
        ArtListCreatedBy artListModel= createdByArtList.get(position);
        viewDataBinding = holder.getViewDataBinding();

        viewDataBinding.setArtlist(artListModel);


    }

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


}
公共类ArtistCreatedByAdapter扩展了RecyclerView.Adapter{
ArrayList创建的DbYartList;
活动;
充气机;
图像加载器;
公共显示图像选项;
ArtListCreatedByBind视图数据绑定;
公共类CustomViewHolder扩展了RecyclerView.ViewHolder{
私有ArtListCreatedByBind mViewDataBinding;
公共CustomViewHolder(视图v){
超级(五);
mViewDataBinding=DataBindingUtil.bind(v);
mViewDataBinding.executePendingBindings();
}
public ArtListCreatedByBind getViewDataBinding(){
返回mViewDataBinding;
}
}
公共ArtistCreatedByAdapter(活动活动,ArrayList CreatedByAdapter){
这个。活动=活动;
imageLoader=imageLoader.getInstance();
this.createdByArtList=createdByArtList;
}
@凌驾
公共CustomViewHolder onCreateViewHolder(视图组父级,int-viewType){
充气器=(LayoutInflater)activity.getSystemService(Context.LAYOUT\u充气器\u SERVICE);
视图项视图=充气机。充气(R.layout.singlerow\u art\u list\u created\u by,parent,false);
返回新的CustomViewHolder(itemView);
}
@凌驾
公共无效onBindViewHolder(CustomViewHolder,最终int位置){
ArtListCreatedBy artListModel=createdByArtList.get(位置);
viewDataBinding=holder.getViewDataBinding();
viewDataBinding.setArtlist(artListModel);
}
@凌驾
public int getItemCount(){
返回createdByArtList.size();
}
}

使用
BindingAdapter
方法绑定另一个参数

@BindingAdapter({"imageUrl","progressbar"})
public static void loadImage(ImageView view, String imageUrl, ProgressBar progressBar){
    ...
    ...
    @Override
    public void onLoadingComplete(String imageUri, View view, Bitmap loadedImage) {
        progressBar.setVisibility(View.GONE);
    }
}
现在,按如下方式从xml传递progressBar:

<ImageView
        android:id="@+id/art_img"
        android:layout_width="match_parent"
        android:layout_height="100dp"
        android:scaleType="centerCrop"
        android:adjustViewBounds="true"
        app:imageUrl="@{artlist.image}"
        app:progressbar="@{progressBar}"/>


注意:这里是您的
progressBar的id

好的,谢谢您的回答,我正在尝试并在5分钟内回复您。很高兴为您提供帮助,享受编码:)不,真的很感谢你,因为在谷歌搜索了这么多东西后,我没有找到正确的答案,但我找到了一些与你的答案相似的答案,但我没能正确地实现它。。。只是为了进一步澄清…此行中的progressBar应用程序:progressBar=“@{progressBar}是progressBar的idid。@KetanAhir yes,这将是progressBar的id
<ImageView
        android:id="@+id/art_img"
        android:layout_width="match_parent"
        android:layout_height="100dp"
        android:scaleType="centerCrop"
        android:adjustViewBounds="true"
        app:imageUrl="@{artlist.image}"
        app:progressbar="@{progressBar}"/>