Android O 引入了名为「自适应图标」(adaptive icon)的全新应用图标格式,旨在使一部设备上的所有图标风格更为连贯。本文将会探讨如何为你的应用创建自适应图标。由于短时间内,大多数应用不会将 minSdkVersion 设为 26,本文也将探讨如何高效地添加这种新的图标格式。

值得说明的一点是,Android Studio 3.0 引入了

如果你想知道自适应图标的来龙去脉,或者想了解如何设计自适应图标,请访问这两篇文章:《理解 Android 的「自适应图标」》和《设计自适应图标》。

基本知识

自适应图标是一个新的 drawable 类型,名为 。你不需要直接操作这个类,只需在 XML 中定义,并在清单文件(manifest)中指向即可。可以遵循如下格式:

Drawable 元素大小应为 108dp * 108dp,背景 drawable 元素不透明度应为 100%,前景元素则可以设置其他不透明度。

minSDK 应为 26

自适应图标只能用于 API 26 及之后版本,所以你可以利用一些现有的特性,特别是对于 VectorDrawable 不错的支持。然而,你不能使用自定义方式扩展(inflate)drawable 元素;由于你的应用图标可能会被其他应用的进程加载,你必须使用系统提供的 drawable 类型。

使用矢量图将会是不错的选择:一方面,你可以用体积很小的文件格式,一次性设置好 drawable 元素,另一方面,图像可以在任何像素密度下都十分锐利,不会因为迁就像素密度,使用太多位图而增加 APK 文件体积。

有一点需要指出,很多开发者似乎还没有充分利用 VectorDrawable 中对渐变的支持。就这一话题,我推荐大家阅读

Ian 在文章中提到了如何使用简单的线性渐变,但 VectorDrawable 的功能可远不止于此。下面这段示例代码,就是用包括多个色标的径向渐变实现「长阴影」效果的部分代码。我还使用了 内连资源句法(inline resource syntax) ,可以将原本的多个文件嵌入一个文件(通过 AAPT 实现,通常与 AnimatedVectorDrawable 一同使用):

android:pathData="...">

android:type="radial"

android:centerX="54"

android:centerY="54"

android:gradientRadius="76.37">

...

使用径向渐变实现的投影

大多数应用图标都会(遵照 Material Design设计指南 的要求)设计投影元素,然而,这些设计往往不受 VectorDrawable 支持。而如果采用自适应图标,矢量图往往更能派上用场,原因有二:

现在,为图标加遮罩和生成投影,都由启动器负责,不需要将阴影写死在图标中;

由于图标是由前景和背景构成的,如果其中一层不包含/需要阴影效果,便可以使用矢量图来实现。

渐变确实可以用来模拟一些简单的阴影效果,但更为复杂的阴影效果则难以通过渐变实现。

可用栅格最小化

如果你的设计不能用矢量图实现,那当然也可以用 PNG 格式的图像。启动器图标(桌面图标)至关重要,当然值得多花一点空间打磨,以求效果完美。

要使用有透明区域的素材,倒是有一个不错的技巧,常用于制作自适应图标的前景。包含透明区域的素材虽然在构建时压缩效果不错,但在运行时,每个像素无论不透明度,都会占用 8 位内存。因此,为最小化内存占用,你可以将 PNG 图像周围的透明区域裁去,再使用 再使用 InsetDrawable1  扩展(wrap) ,并填充为 108dp * 108dp 大小的素材。但是,使用 InsetDrawable 就无法缩放(即如果顶部插入(top inset)设为 16dp,那么无论 drawable 如何缩放,顶部插入也不会按比例变换,仍会保持 16dp)。因此,在 API 26 中,添加了比例插入(fractional inset)来解决这个问题。如此便可以将插入设定为 drawable 整体的一个百分比,实现正确的缩放。

例如,有一前景素材,大小为 54dp * 54dp,与其放置在 108dp * 108dp 的素材上,并套上透明部分,不如按如下代码设置:

android:drawable="@mipmap/ic_fg_trimmed"

android:insetLeft="25%"

android:insetTop="25%"

android:insetRight="25%"

android:insetBottom="25%" />

下面这个 例子 也使用了这个技巧:无需绘制/加载透明像素

注意:你仍然需要为不同像素密度提供不同的栅格图像素材,但起码可以降低每张素材占用的空间和内存。

制作快捷方式

自适应图标不但可以用于应用图标,还能用于 应用快捷方式 。应用快捷方式可以固定在主屏幕,因此也需要与其他应用图标保持风格一致。Android O 之前的 设计规范 中,要求快捷方式功能图标必须放置于灰色圆形背景之上。而 Android O 中,图标背景应当填满整个自适应图标遮罩。如果没有升级为自适应图标,快捷方式图标将会被缩小,并放置在白色背景上。Plaid 的搜索快捷方式,左图为使用自适应图标前,右图为使用后

为了让我自己的应用 Plaid 用上新的快捷方式样式,我起初在 API 26 的配置文件中 添加了新的图标(新图标是把旧图标按照自适应图标的网格和 参考线(keyline) 重绘得到的)。但我不喜欢这种解决方案,因为新图标实际上是把 API 25 的旧图标缩放得到的,这就意味着我现在得管理两套图标。最后 我决定把 API 25 使用的图标拆分成前景(即搜索图标)和背景(即灰色圆形),再用 LayerDrawable 合并:

这样一来,前景素材也能用于自适应图标了。在 API 25 中,应用快捷方式图标大小为 24dp * 24dp,前景素材总大小为 48 dp * 48 dp;而在 API 26 中,应用快捷方式图标大小则为 44dp * 44dp,前景素材总大小为 108 dp * 108 dp:API 25 和 API 26 中,应用快捷方式所需前景素材的对比

为使用 48dp * 48dp 的素材,需要设置插入,以确保素材缩放(矢量图万岁!)为 108dp * 108dp 后,图标大小正确;背景则是使用 ColorDrawable 实现。示例代码如下:

android:drawable="@drawable/ic_shortcut_search_foreground"

android:inset="9.26%" />

AdaptiveIconDrawable 会将提供的素材缩放至 108dp * 108dp,故要计算插入量,应先将旧素材整体缩放至图标大小为 44dp:48dp / 24dp * 44dp = 88dp(即应缩放至 88dp),可见,每边插入量应为 10dp:10dp / 108dp * 100% = 9.26%。

要使用位图制作快捷方式图标,参见 此链接 。

多多试验

如果你正在制作自适应图标,可以使用 Adaptive Icon Playground 应用,来预览自适应图标的显示效果,尝试使用不同遮罩和不同动效。

你可以 在此下载 APK 文件(设备必须运行 Android O),或 在此下载源码 。

勇敢「适应」吧!

希望这些建议可以帮你设计出优秀的自适应图标,让你的应用在用户的设备上体验更上一层楼。如果你有任何意见或者建议,请移步 原文 发表评论。

android自适应图标如何制作,实现自适应图标相关推荐

  1. favicon.ico介绍,网页图标的制作动态网页图标

    1.直接上成功的代码,关键代码: <!DOCTYPE html> <html><head><title>网页图标</title><li ...

  2. android图标的制作

    android的adt提供了android图标的制作:Android icon set. 通过这个可以新建一个图标. 1.首先,在Eclipse中某个android项目上右击打开 New - Othe ...

  3. Android之制作App的图标

    在过去,Android应用程序的图标都是应该放到相应的分辨率的mipmap目录下,不过从Android8.0开始,Google已经不再建议使用单一的一张图片来作为应用程序的图标,而是应该使用前景和背景 ...

  4. Android动态图标包制作教程,安卓手机ico图标制作美化图文教程

    如何让手机更加与众不同?今天我们就来学习如何利用出色的ico图标制作软件--Axialis IconWorkshop制作出美化手机屏幕的个性图标! 如今,每个人都有属于自己的手机,每天使用手机聊QQ. ...

  5. android 按钮带图标 阴影_android中带图标的按钮(ImageButton)怎么用

    展开全部 除了Android系统自带的Button按钮以外,还提供了带图标的按钮ImageButton 要制作带图标的按钮,首先要在布局62616964757a686964616fe58685e5ae ...

  6. 在Ubuntu下为应用程序制作自定义桌面图标

    操作系统:Ubuntu 18.04 在这个案例中,我使用的是"Joplin"这款笔记程序.这是一款全平台的笔记应用程序,通吃Windows.Linux.MacOS.Android和 ...

  7. Image2icon for Mac(icns图标转换制作工具)

    你是否想设置一款独特的图标呢?Image2icon Mac版是一款icns图标转换制作工具.用户可以随心制作属于自己的个性图标,还能对文件以及文件夹进行自定义的个性设置.Image2icon下载使用设 ...

  8. 在iOS应用中使用字体图标及制作字体库

    做iOS开发的都知道,因为屏幕分辨率的问题,在iOS app 中都得放两套切图来支持retina屏和非retina屏幕,但是文字就不需要考虑分辨率的问题,所以可不可以将一些图片用文字来代替呢,省时省力 ...

  9. android开发之Launcher icon(启动图标)的设计

    不同厂商的不同型号的android设备的分辨率是不一样的,而不同分辨率的所使用的icon的图片的大小要求也是不一样的.为了让用户能在不同的android设备上面有统一的视觉体验,作为  Launche ...

最新文章

  1. 棋盘型动态规划 之 CODE[VS] 1169 传纸条 2008年NOIP全国联赛提高组
  2. 乘法器之五(混和式乘法器(Hybrid multiplication))
  3. 先来先服务算法的特点
  4. maven中文乱码问题——编译错误
  5. Android内核开发:如何统计系统的启动时间
  6. matlab在图片上画框
  7. spring3.1 profile 配置不同的环境
  8. 【Android】【移动应用开发】基础知识
  9. 挂服务器刷屏微信,谁知道微信群刷屏代码啊,跪求
  10. ICA算法的数学原理
  11. 怎么做应力应变曲线_如何用Origin画应力应变曲线
  12. Wox插件之程序员不安装会死系列
  13. 天行健,君子以自强不息;地势坤,君子以厚德载物 释意
  14. linux shell sed快速开始-(添加文本到文件的第一行和最后一行、文本的行尾添加字符)
  15. java八皇后答案_java八皇后问题详解
  16. 菜鸟教程css事件,【推荐】DIV+CSS入门菜鸟教程
  17. 洛谷 - P1008 [NOIP1998 普及组] 三连击 [Java版]
  18. f烽火ExMobi,移动应用平台的互联网思维
  19. 如何学西方经济学?(起源与发展、主流观点概括)
  20. 数据可视化BI平台选型调研报告 Superset VS Redash VS Metabase

热门文章

  1. 常用颜色的十六进制和rgb格式
  2. 寒假每日一题——两句话中的不常见单词
  3. 文科生能学好数据分析吗
  4. initial、inherit、unset、revert和all的区别
  5. 瑞丰银行近日IPO过会,3年前曾被证监会取消审核
  6. 天工开物 #5 我的 Linux 开发机
  7. 支持html5的页面刷新,qik的方法
  8. 关于微信公众号调起支付
  9. 智能手术机器人技术与原理(二)
  10. Android客户端学习-jdk安装