【问题标题】:No Ripple Effect in RecyclerViewRecyclerView 中没有涟漪效应
【发布时间】:2018-02-23 17:47:17
【问题描述】:

我正在使用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" />

List Item 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.... 涟漪效应显示在 LinearLayout 后面,但我也想使用 CardView 如果有人可以帮助我解决此问题,请告诉我.谢谢。

注意:我已经使用this solution 解决了这个问题。谢谢

【问题讨论】:

  • 让您的卡片视图可点击,并赋予它forgroundColor

标签: java android rippledrawable


【解决方案1】:

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

android:foreground="?attr/selectableItemBackground"

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

【讨论】:

  • 你是应用在 CardView 上还是在 RelativeLayout 上?它只适用于 CardView。
【解决方案2】:

创建波纹 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">

【讨论】:

  • 作为前台试试。我尝试将相同的代码设置为对我有用的前台代码。
  • 查看我的更新答案。将波纹设置为 cardview 不适用于相对布局@Priya
【解决方案3】:

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

【讨论】:

    猜你喜欢
    • 2015-11-07
    • 1970-01-01
    • 2018-01-07
    • 2016-04-25
    • 1970-01-01
    • 2015-08-12
    • 1970-01-01
    • 2018-05-10
    • 2018-11-13
    相关资源
    最近更新 更多