应用Material Design Touch Ripple到ImageButton?

san*_*nic 81 xml android imagebutton material-design android-5.0-lollipop

我有一个图像按钮,点击它时没有响应触摸动画,因为它是一个静态图像,而不像棒棒糖上的常规按钮带有内置的连锁效果.我想将材料设计波纹触摸效果添加到图像中,但似乎无法找到实现它的方法.我可以在图像上设置一个滤色器,但这不是涟漪效应.我正在尝试做的一个例子就是当你在Google Play音乐中保存一个专辑封面图像并且阴影波纹在图像上移动时.

i.s*_*rin 225

为了更好的结果:

<ImageButton
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:src="@android:drawable/ic_button"
    android:background="?attr/selectableItemBackgroundBorderless"
/>
Run Code Online (Sandbox Code Playgroud)

  • 相反背景使用前景为所有视图它工作正常. (10认同)
  • 这是更好的答案 - 给出圆形的感觉以及涟漪效果,谢谢. (6认同)
  • 这是否也适用于彩色抽屉?对我来说,尽管应用背景,但没有触摸效果.我的主题是从Theme.AppCompat.Light.DarkActionBar扩展,这可能是个问题吗? (3认同)
  • 有没有人找到一种方法来做到这一点并改变背景颜色?更改 BackgroundTint 不起作用并将 Foreground 设置为“?attr/selectableItemBackgroundBorderless”会在按钮上产生令人讨厌的填充。 (2认同)
  • 我一定很喜欢我浏览了大量的谷歌文档却从未见过这个……风格信息是如此令人难以置信地难以发现。 (2认同)

Nic*_*las 25

您可以像这样向ImageButton添加背景:

<ImageButton
    android:layout_width="wrap_content"
    android:layout_height="wrap_content"
    android:src="@android:drawable/btn_dialog"
    android:background="?android:attr/selectableItemBackground" />
Run Code Online (Sandbox Code Playgroud)

  • 如果我已经有一个drawable作为背景怎么办? (3认同)
  • 使用android:foreground =“?attr / selectableItemBackgroundBorderless” (2认同)

Sab*_*viş 7

如果你已经有一个背景并且不想改变它,使用前景;

<ImageButton
    android:layout_width="60dp"
    android:layout_height="match_parent"
    android:background="@drawable/preview_in_4k_background"
    android:src="@drawable/ic_full_screen_24px"
    android:layout_marginLeft="5dp"
    android:foreground="?attr/selectableItemBackgroundBorderless"
    android:layout_column="2"/>
Run Code Online (Sandbox Code Playgroud)

  • 不错的解决方案,但如果你有圆角背景,那么波纹将超出它。 (2认同)

Fil*_*ito 5

我从i.shadrin(在这里)和Nicolars(在这里)得到了很好的答案。

他们的答案之间的区别是?attr/selectableItemBackgroundBorderless可以给您一个android.view.InflateException,因此?android:attr/selectableItemBackground解决方案是。

FWIW,我不知道为什么会发生异常,因为第一个答案在我所有的旧项目中都很好,但是在我最近的项目中却不行(也许是因为应用主题= android:Theme.Material?)。

发生的奇怪事情是,尽管显示了波纹效果,但它超出了ImageButton的范围,因此解决方案是:

  • 使用android:foreground="?android:attr/selectableItemBackgroundBorderless"代替android:background="?android:attr/selectableItemBackgroundBorderless"

希望对您有帮助。