RecyclerView onBindviewholder Dialog clicklistner动画

时间:2017-09-05 06:20:48

标签: android android-layout android-fragments android-recyclerview

我已经创建了一个recyclerView,其中有一个recycleview onBindView Holder方法,我希望在每个recyclerview行中设置一个对话框(自定义对话框)一个图像,当我点击recyclerview的图像时,一个对话框将从底部出现相同的图像,当我点击任何地方时,对话框应该关闭。

注意:recylerview中的数据来自凌空库

1 个答案:

答案 0 :(得分:1)

首先,您必须创建一个自定义对话框。

<强> dialog_image.xml

    <?xml version="1.0" encoding="utf-8"?>
    <LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
    android:orientation="vertical"
    android:background="@color/white"
    android:layout_width="260dp"
    android:layout_height="270dp">

    <ImageView
        android:id="@+id/dialog_iv"
        android:layout_width="260dp"
        android:layout_height="260dp"
        />

</LinearLayout>

适配器类的OnbindViewHolder()

 holder.medPic.setOnClickListener(new View.OnClickListener() {
            @Override
            public void onClick(View view) {

                final Dialog dialogi = new Dialog(context);
                dialogi.requestWindowFeature(Window.FEATURE_NO_TITLE);
                dialogi.setCancelable(true);
                dialogi.setContentView(R.layout.dialog_image);
               // dialog.getWindow().setBackgroundDrawable(new ColorDrawable(android.graphics.Color.TRANSPARENT));


                ImageView dialogIv = (ImageView)dialogi.findViewById(R.id.dialog_iv);


                Picasso.with(context)
                        .load(data.get(position).getMedicine_img_url().replace(" ","%20").trim())
                        .into(dialogIv);
                dialogi.getWindow().getAttributes().windowAnimations = R.style.DialogAnimation_2; //style id
                dialogi.show(); 

                dialogIv.setOnClickListener(new View.OnClickListener() {
                    @Override
                    public void onClick(View view) {
                        dialogi.dismiss();
                    }
                });


            }
        });
    }

Style.xml 中输入此代码:

 <style name="DialogAnimation_2">
    <item name="android:windowEnterAnimation">@anim/slide_up_dialog</item>
    <item name="android:windowExitAnimation">@anim/slide_out_down</item>
</style>

res 内创建一个文件夹 anim ,并在 anim 文件夹中放置两个动画res文件:

slide_up_dialog:

<set xmlns:android="http://schemas.android.com/apk/res/android">
<translate
    android:duration="@android:integer/config_mediumAnimTime"
    android:fromYDelta="100%"
    android:interpolator="@android:anim/accelerate_interpolator"
    android:toXDelta="0">
</translate>

slide_out_down:

<set xmlns:android="http://schemas.android.com/apk/res/android">
<translate
    android:duration="@android:integer/config_mediumAnimTime"
    android:fromYDelta="0%p"
    android:interpolator="@android:anim/accelerate_interpolator"
    android:toYDelta="100%p">
</translate>