上周Android发布了Android M的Preview版本.但想必Android5.0很多炫酷效果,多数开发者还没有使用过,那更不要说广大用户了.

本文介绍的是Android5.0中其中一个炫酷的效果,点击水波纹扩散效果(Ripple Effect).

以下介绍的实现方式都是调用Android5.0的新API,并非自定义实现,所以支持在Android5.0的设备.

而大家想兼容低系统版本的话,就需要新建v21(即Android5.0)的Resource Directory.

圆角背景的水波纹效果(如上图)

1. 定义一个普通圆角背景的xml;

rounded_corners.xml

<?xml version="1.0" encoding="utf-8"?>
<shape xmlns:android="http://schemas.android.com/apk/res/android"
android:shape="rectangle">
<solid android:color="#FFFFFF" />
<corners android:radius="4dp" />
</shape>

2. 这里是重点,<ripple>是API21才有的新Tag,正是实现水波纹效果的;

其中<ripple android:color="#FF21272B" .... />这个是指定水波纹的颜色.

而<item />里面的东西,我们都很熟悉,就是普通的定义一个带圆角的背景.

ripple_bg.xml:

<?xml version="1.0" encoding="utf-8"?>
<ripple xmlns:android="http://schemas.android.com/apk/res/android"
android:color="#FF21272B">
<item>
<shape android:shape="rectangle">
<solid android:color="#FFFFFF" />
<corners android:radius="4dp" />
</shape>
</item>
<item android:drawable="@drawable/rounded_corners" />
</ripple>

3. 这是Activity的布局xml;

<Button android:background="@drawable/ripple_bg"... />直接使用ripple_bg作为背景.

activity_main.xml

<LinearLayout xmlns:android="http://schemas.android.com/apk/res/android"
xmlns:tools="http://schemas.android.com/tools"
android:layout_width="match_parent"
android:layout_height="match_parent"
android:gravity="center"
android:orientation="vertical"
android:paddingBottom="@dimen/activity_vertical_margin"
android:paddingLeft="@dimen/activity_horizontal_margin"
android:paddingRight="@dimen/activity_horizontal_margin"
android:paddingTop="@dimen/activity_vertical_margin"
tools:context=".MainActivity"> <TextView
android:layout_width="wrap_content"
android:layout_height="wrap_content"
android:text="@string/hello_world" /> <Button
android:layout_width="match_parent"
android:layout_height="wrap_content"
android:background="@drawable/ripple_bg"
android:text="@string/hello_world" />
</LinearLayout>

参考文章: Android Ripples With Rounded Corners

最新文章

  1. c#资料
  2. js多文件上传
  3. jmap命令详解(转)
  4. 详解Paint的setPathEffect(PathEffect effect)
  5. JAVA设计模式--strategy(策略者模式)
  6. (转)Linux下Oracle启动、建立表空间、用户、授权、数据库导入导出
  7. 【面试题012】打印1到最大的n位数
  8. cf 283A
  9. 基于Noootes/Dooomino的文档工作流系统(转)
  10. MySQL 常用字段类型,介绍及其建表使用方法经验分享
  11. update值与原值相同时,SQL Server会真的去update还是忽略呢?
  12. 20155304田宜楠2006-2007-2 《Java程序设计》第一周学习总结
  13. C++为什么要设计友元函数和友元类
  14. Bootstrap优秀模板-ColorAdmin.4.3.0
  15. Angular4.x学习日志
  16. P2947 [USACO09MAR]向右看齐Look Up--单调栈
  17. 接口测试 - ti
  18. hashlib 模块用来进行hash
  19. python爬虫出现的状态码
  20. HDU - 4389 X mod f(x)(数位dp)

热门文章

  1. Spring SimpleJdbcOperations 批量更新
  2. 【转载】CPU阿甘
  3. Drupal8 Console 命令行工具
  4. jenkins+jacoco+ant自动化代码和应用服务代码分离场景获取远程服务的覆盖率
  5. SQL基本的45题
  6. Hexo+gitment
  7. python终端计算器,还有没其他方法?
  8. 合并SQL 调优
  9. 网络安全攻防----html基础
  10. 清空git缓存