回收瓶中没有连锁效应



我正在使用 RecyclerView显示报价列表 Fragment。我试图在列表项目中使用连锁效果,但它不起作用。我的RecyclerView就像以下

<android.support.v7.widget.RecyclerView
        android:id="@+id/listQuoteView"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="?attr/BackColor"
        android:layout_above="@+id/startAppBanner"
        android:layout_alignParentTop="true"
        android:layout_alignParentLeft="true"
        android:layout_alignParentStart="true" />

和列表项目XML如下

<?xml version="1.0" encoding="utf-8"?>
<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:background="?attr/selectableItemBackground"
    android:clickable="true"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <android.support.v7.widget.CardView
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginBottom="4dp"
        android:layout_marginLeft="8dp"
        android:layout_marginRight="8dp"
        android:layout_marginTop="4dp"
        app:cardCornerRadius="6dp"
        app:cardElevation="4dp">
        <LinearLayout
            android:id="@+id/quoteActionView"
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="?attr/TextColor"
            android:clickable="true"
            android:orientation="horizontal">
            <ImageView
                android:id="@+id/imageAuthorView"
                android:layout_width="@dimen/imageAuthorView"
                android:layout_height="@dimen/imageAuthorView"
                android:visibility="visible" />

            <LinearLayout
                android:layout_width="match_parent"
                android:layout_height="match_parent"
                android:layout_gravity="center"
                android:orientation="vertical">
                <TextView
                    android:id="@+id/textQuote"
                    android:ellipsize="end"
                    android:layout_width="match_parent"
                    android:layout_height="0dp"
                    android:paddingRight="@dimen/list_text_margin"
                    android:paddingLeft="@dimen/list_text_margin"
                    android:gravity="center_vertical"
                    android:layout_weight="2"
                    android:maxLines="2"
                    android:layout_margin="2dp"
                    android:lineSpacingExtra="@dimen/linespace"
                    android:textColor="?attr/MainTextColor"
                    android:text="Hello there two line text for show here which I am typing for a test"
                    android:scrollHorizontally="true"
                    android:textSize="@dimen/textDetailQuote"
                    android:textStyle="bold" />
                <LinearLayout
                    android:layout_width="match_parent"
                    android:layout_height="wrap_content"
                    android:gravity="center"
                    android:background="?attr/dark_color"
                    android:orientation="horizontal">
                    <ImageView
                        android:layout_width="@dimen/likeIcon"
                        android:layout_height="@dimen/likeIcon"
                        android:layout_weight="1"
                        android:tint="?attr/List_Text"
                        android:src="@drawable/time_new_ic" />
                    <TextView
                        android:id="@+id/lblTimeCount"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_weight="2"
                        android:text="00:00"
                        android:textStyle="bold"
                        android:textColor="?attr/List_Text"
                        android:textSize="@dimen/lblTime" />

                    <ImageView
                        android:layout_width="@dimen/likeIcon"
                        android:layout_height="@dimen/likeIcon"
                        android:layout_weight="1"
                        android:tint="?attr/List_Text"
                        android:src="@drawable/fav_new_ic" />
                    <TextView
                        android:id="@+id/lblLikeCount"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_weight="1"
                        android:text="200"
                        android:textStyle="bold"
                        android:textColor="?attr/List_Text"
                        android:textSize="@dimen/lblTime" />
                    <ImageView
                        android:layout_width="@dimen/likeIcon"
                        android:layout_height="@dimen/likeIcon"
                        android:layout_weight="1"
                        android:tint="?attr/List_Text"
                        android:src="@drawable/share_new_ic" />
                    <TextView
                        android:id="@+id/lblShareCount"
                        android:layout_width="wrap_content"
                        android:layout_height="wrap_content"
                        android:layout_weight="1"
                        android:textStyle="bold"
                        android:text="100"
                        android:textColor="?attr/List_Text"
                        android:textSize="@dimen/lblTime" />
                </LinearLayout>
            </LinearLayout>
        </LinearLayout>
    </android.support.v7.widget.CardView>

</RelativeLayout>

我尝试了在Stackoverflow中列出的许多解决方案,但没有起作用。如果我从列表项目中删除CardView。...Ripple效果在LinearLayout后面显示出来,但我也想使用CardView让我知道是否有人可以帮助我解决此问题。谢谢。

注意:我已经使用此解决方案解决了它。谢谢

将波纹设置为前景 可在CardView上绘制:

android:foreground="?attr/selectableItemBackground"

这将允许纹波显示上面的 CardView中的内容,这通常是您想要的CardView

创建Ripple drawable ,并将其设置为前景的布局

ripple.xml

<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:tools="http://schemas.android.com/tools"
    android:color="@color/your_color"
    tools:targetApi="lollipop">
    <item android:id="@android:id/mask">
        <shape android:shape="rectangle">
            <solid android:color="@color/your_color" />
        </shape>
    </item>
</ripple>

这样更改您的代码:

<RelativeLayout
    xmlns:android="http://schemas.android.com/apk/res/android"
    xmlns:app="http://schemas.android.com/apk/res-auto"
    android:layout_width="match_parent"
    android:layout_height="wrap_content">

    <android.support.v7.widget.CardView
        android:clickable="true"
        android:foreground="@drawable/ripple"
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:layout_marginBottom="4dp"
        android:layout_marginLeft="8dp"
        android:layout_marginRight="8dp"
        android:layout_marginTop="4dp"
        app:cardCornerRadius="6dp"
        app:cardElevation="4dp">

使用android:background="?android:attr/selectableItemBackground"

相关内容

  • 没有找到相关文章

最新更新