前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Android 水波纹效果的探究

Android 水波纹效果的探究

作者头像
Jingbin
发布2018-09-10 17:23:50
2.2K0
发布2018-09-10 17:23:50
举报
文章被收录于专栏:Android 技术栈Android 技术栈

长按水波纹扩展效果

前言

水波纹效果从Android5.0就已经出来了,基本的使用相信大家都知道了,这里多谈一些相对深层次的使用:

  • 1、基本使用
  • 2、水波纹效果与布局绘制之间的问题
  • 3、长按水波纹扩散效果
  • 4、Button点击的水波纹效果

基本使用

系统自带水波纹实现方式

有界水波纹
代码语言:javascript
复制
android:background="?android:attr/selectableItemBackground"
无界水波纹

以控件宽高中最大的数值作为水波纹效果所在正方形的边界进行绘制

代码语言:javascript
复制
android:background="?android:attr/selectableItemBackgroundBorderless"

自定义水波纹实现方式

无界水波纹
代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"?>  
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="@color/colorAccent"> 
</ripple> 
有界水波纹
代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="@color/itemBackground">
    <item >
        <color android:color="@android:color/white" />
    </item>
</ripple>

水波纹效果与布局绘制之间的问题

在使用了以上的自定义有界水波纹点击效果后,使用[开发者选项 - 调试GPU过渡绘制]得到下面的视图

自定义有界水波纹

对比后,发现绿色的文字部分经过了二重绘制,因为布局的白色背景和文字自身颜色的原因。如果布局背景能去掉还能实现水波纹的效果就好了,这样就只有文字一层的颜色。

有两种方案可以达到想要的这种效果:

1、使用系统自带有界水波纹实现方式,因为系统本身的默认背景是透明色的。

代码语言:javascript
复制
android:background="?android:attr/selectableItemBackground"

系统的默认水波纹颜色是灰色,如果需要使用对应的高亮色来作为ripple的背景色,我们可以在styles-v21系统主题里加入这个:<item name = "android:colorControlHighlight">@color/colorAccent</item>

2、使用自定义有界水波纹效果,使其默认背景色为透明色。 写法:

代码语言:javascript
复制
<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
    android:color="@color/itemBackground">
    <item android:id="@android:id/mask">
        <color android:color="@android:color/white" />
    </item>
</ripple>

添item时,如果指定id为@android:id/mask,那么不点击时不会显示出该item指定的color。 可以设置指定子层item的android:id="@android:id/mask"来设定当前Ripple的Mask。 Mask的内容并不会被绘制到屏幕上,它的作用是限定Ripple效果的绘制区域。

最后可以得到我们想要的效果:

image.png

长按水波纹扩散效果

长按水波纹扩展效果

在使用小红书时,我们可以看到关于“笔记”的item长按会展示扩散的效果,其实原理也很简单。无边界的水波纹可以达到长按扩散的效果,只是它会超出边界,那我们就在对应的父布局加一层有边界的水波纹背景即可。就像这样:

代码语言:javascript
复制
<RelativeLayout
        android:layout_width="match_parent"
        android:layout_height="wrap_content"
        android:background="?attr/selectableItemBackground">

        <RelativeLayout
            android:layout_width="match_parent"
            android:layout_height="wrap_content"
            android:background="?attr/selectableItemBackgroundBorderless"
            android:onClick="@{()->adapter.openDetail(bean)}"
            android:padding="8dp">
        </RelativeLayout>
</RelativeLayout>

Button点击的水波纹效果

button阴影与点击效果

代码语言:javascript
复制
<Button
    style="@style/Widget.AppCompat.Button.Colored"
    android:layout_width="0dp"
    android:layout_height="wrap_content"
    android:layout_marginLeft="20dp"
    android:layout_weight="1"
    android:onClick="login"
    android:text="登陆"
    android:textColor="@android:color/white"
    android:textStyle="bold" />

The Widget.AppCompat.Button.Colored 继承了 Widget.AppCompat.Button style并且根据你选择的主题应用最接近的颜色。

参考资料

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2018.05.27 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 前言
  • 基本使用
    • 系统自带水波纹实现方式
      • 有界水波纹
      • 无界水波纹
    • 自定义水波纹实现方式
      • 无界水波纹
      • 有界水波纹
  • 水波纹效果与布局绘制之间的问题
    • 有两种方案可以达到想要的这种效果:
    • 长按水波纹扩散效果
    • Button点击的水波纹效果
    • 参考资料
    领券
    问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档