将 Material Design Touch Ripple 应用于 ImageButton?

Posted

技术标签:

【中文标题】将 Material Design Touch Ripple 应用于 ImageButton?【英文标题】:Apply Material Design Touch Ripple to ImageButton? 【发布时间】:2015-09-06 16:53:39 【问题描述】:

我有一个图像按钮,当它被点击时,它不会响应触摸动画,因为它是一个静态图像,不像棒棒糖上的常规按钮,它带有内置的波纹效果。我想为图像添加材料设计波纹触摸效果,但似乎找不到实现它的方法。我可以在图像上设置一个滤色器,但这不是涟漪效应。我正在尝试做的一个示例是,当您在 Google Play 音乐中拿着专辑封面图片时,阴影波纹在图片上移动。

【问题讨论】:

【参考方案1】:

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

<ImageButton
    android:layout_
    android:layout_
    android:src="@android:drawable/btn_dialog"
    android:background="?android:attr/selectableItemBackground" />

【讨论】:

使用 android:foreground="?attr/selectableItemBackgroundBorderless" @MFQ 与 ?android:attr/selectableItemBackground 有何不同 @killer selectableItemBackgroundBorderless = 给出一个没有边界的圆形波纹,就像您单击工具栏中的图标一样,但是 selectableItemBackground 给出矩形波纹,如果您长时间单击实现的图标,您会看到差异这个画带【参考方案2】:

为了更好的结果:

<ImageButton
    android:layout_
    android:layout_
    android:src="@android:drawable/ic_button"
    android:background="?attr/selectableItemBackgroundBorderless"
/>

【讨论】:

这是更好的答案 - 提供圆形感觉以及涟漪效应,谢谢。 这也适用于彩色绘图吗?对我来说,尽管应用了背景,但没有可见的触摸效果。我的主题是从 Theme.AppCompat.Light.DarkActionBar 扩展而来的,这可能是个问题吗? 而不是背景使用它的前景,它工作正常的所有视图。 有没有人找到办法做到这一点并改变背景颜色?更改 BackgroundTint 不起作用并将 Foreground 设置为“?attr/selectableItemBackgroundBorderless”会在按钮上产生令人讨厌的填充。 一定很喜欢我翻阅了大量 Google 文档但从未见过的方式...风格信息令人难以置信地难以发现。【参考方案3】:

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

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

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

发生的奇怪事情是,虽然显示了涟漪效果,但它超出了 ImageButton 的范围,因此解决方案是:

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

如果您面临同样的问题,希望对您有所帮助。

【讨论】:

【参考方案4】:

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

<ImageButton
    android:layout_
    android:layout_
    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"/>

【讨论】:

不错的解决方案,但如果你有圆角背景,那么波纹会超出它。【参考方案5】:

您可以使用具有此属性的 MaterialButton (com.google.android.material.button.MaterialButton) 代替 ImageButton。 如果您使用材料组件。

 <style name="IconOnlyButton">
    <item name="iconPadding">0dp</item>
    <item name="iconGravity">textStart</item>
 </style>

<com.google.android.material.button.MaterialButton
    style="@style/IconOnlyButton"
    app:icon="@drawable/ic_refresh"/>

【讨论】:

以上是关于将 Material Design Touch Ripple 应用于 ImageButton?的主要内容,如果未能解决你的问题,请参考以下文章

Material Design控件使用

使用 Material Design 组件实现 Material 动效

如何将符合 Material Design 标准的填充应用到我的 Flutter Scaffold?

将 Material Design Lite 与 Angular2 集成

Android Material Design-Creating Apps with Material Design(用 Material Design设计App)-(零)

如何在本地将 Material Design Iconic Font 托管到 vue 应用中