【JavaSE(四)】Java面向对象(中)

项目中遇到一个问题,Android 8.0 系统上 APP 的 icon 显示的是默认的机器人的 icon,这是什么回事?原来 Android 8.0(API 级别 26)引入了自适应启动器图标,可以在不同设备模型中显示各种形状。下面看下官方酷炫动态图:

图1. 自适应图标支持各种设备之间不同的掩码。

可以通过定义 2 层来控制自适应启动器图标的外观,包括背景和前景。您必须提供图标图层作为可绘图,图标轮廓周围不能有蒙版或背景阴影。

图2. 自适应图标使用 2 个图层和 1 个蒙版进行定义。

在 Android 7.1(API级别25)及更早版本中,启动器图标大小为 48 x 48 dp。必须使用以下准则来调整图标图层的大小:

  • 两层的尺寸必须为 108 x 108 dp。
  • 图标的内部 72 x 72 dp 出现在蒙版视口内。
  • 系统会在四面各留出 18 dp,以产生有趣的视觉效果,如视差或脉冲。

我验证了,不是这些尺寸也是可以的,但我们还是严格按照这个准则来吧。

图3. 自适应图标支持各种视觉效果。

注意: 如果您没有使用必要的图层更新启动器图标,则该图标与系统 UI 显示的其他图标看起来不一致,并且不支持视觉效果。

用 XML 创建自适应图标

我们首先创建一个 Sample 项目,如图:

比以往多一个 res/mipmap-anydpi-v26 文件,打开,有背景和前景。

ic_launcher_background.xml

12345678910111213141516

<?xml version="1.0" encoding="utf-8"?><vector xmlns:android="http://schemas.android.com/apk/res/android" android:width="108dp" android:height="108dp" android:viewportHeight="108" android:viewportWidth="108"> <path android:fillColor="#26A69A" android:pathData="M0,0h108v108h-108z" /> <path android:fillColor="#00000000" android:pathData="M9,0L9,108" android:strokeColor="#33FFFFFF" android:strokeWidth="0.8" /> <!--省略部分代码--></vector>

ic_launcher_foreground.xml

1234567891011121314151617181920212223242526272829

<vector xmlns:android="http://schemas.android.com/apk/res/android" xmlns:aapt="http://schemas.android.com/aapt" android:width="108dp" android:height="108dp" android:viewportHeight="108" android:viewportWidth="108"> <path android:fillType="evenOdd" android:pathData="M32,64C32,64 38.39,52.99 44.13,50.95C51.37,48.37 70.14,49.57 70.14,49.57L108.26,87.69L108,109.01L75.97,107.97L32,64Z" android:strokeColor="#00000000" android:strokeWidth="1"> <aapt:attr name="android:fillColor"> <gradient android:endX="78.5885" android:endY="90.9159" android:startX="48.7653" android:startY="61.0927" android:type="linear"> <item android:color="#44000000" android:offset="0.0" /> <item android:color="#00000000" android:offset="1.0" /> </gradient> </aapt:attr> </path> <!--省略部分代码--></vector>

它们都是 vector,<foreground><background> 是支持android:drawable属性,我直接换成 ic_launcher_background.png 和 ic_launcher_foreground.png,<foreground><background>也支持@color/资源名

123456

<?xml version="1.0" encoding="utf-8"?><adaptive-icon xmlns:android="http://schemas.android.com/apk/res/android"> <!--<background android:drawable="@color/colorAccent" />--> <background android:drawable="@drawable/ic_launcher_background" /> <foreground android:drawable="@drawable/ic_launcher_foreground" /></adaptive-icon>

然后清单使用android:icon 属性以指定可绘制资源,还可以使用该android:roundIcon 属性定义图标可绘制资源。

123456

<application … android:icon="@mipmap/ic_launcher" android:roundIcon="@mipmap/ic_launcher_round" …></application>

如果要将常规自适应启动器图标应用于快捷方式的相同蒙版和视觉效果,使用以下:

  • 对于静态快捷方式,请使用该<adaptive-icon>元素。
  • 对于动态快捷方式,请在createWithAdaptiveBitmap() 创建方法时调用该 方法。

大功告成,Android 8.0 上能自适应,以下是默认的图标。

注意:Android Studio 3.0 以下的编译器无法找到 adaptive-icon 标签,这点未验证。

源码

公众号「吴小龙同学」回复:AdaptiveIconsSample,获得完整 Sample 代码。

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏Java帮帮-微信公众号-技术文章全总结

Web前端工程师2016必学的四大核心技能

1.HTML5(结构层) HTML超文本标记语言是结构层,是为“网页创建和其他可在网页浏览器中看到的信息”设计的语言。它是学习前端开发的基础语言,要重点学习H5...

2773
来自专栏张善友的专栏

HTML5 canvas图形库RGraph

在新的HTML5标准中,新增了一个非常重要的元素—canvas元素。使用该元素,可以在页面中直接进行各种复杂图形的制作。因此,如果使用该元素绘制统计图,比之前使...

1928
来自专栏walterlv - 吕毅的博客

WPF 使用 WindowChrome,在自定义窗口标题栏的同时最大程度保留原生窗口样式(类似 UWP/Chrome)

发布于 2018-07-12 07:57 更新于 2018-09...

1392
来自专栏娱乐心理测试

Ios常用第三方框架(二)

1366
来自专栏黑泽君的专栏

注册页面案例_表单标签

833
来自专栏微信终端开发团队的专栏

微信iOS多设备多字体适配方案总结

一、背景 2014下半年,微信iOS版先后适配iPad, iPhone6/6plus。随着这些大屏设备的登场,部分用户觉得微信的字体太小,但...

4465
来自专栏Guangdong Qi

iOS开发常用之UI下拉刷新

951
来自专栏葡萄城控件技术团队

用css3制作旋转加载动画的几种方法

以WebKit为核心的浏览器,例如Safari和Chrome,对html5有着很好的支持,在移动平台中这两个浏览器对应的就是IOS和Android。最近在开发一...

2226
来自专栏向治洪

ConstraintLayout约束控件详解

简介 在Google IO大会中不仅仅带来了Android Studio 2.2预览版,同时带给我们一个依赖约束控件–ConstraintLayout。一种构建...

2805
来自专栏斜述视角

0基础学习网页制作-Css

文章来自:4月14日早,在贵州大学北校区10栋715寝室,对物理学院同学培训的内容。

671

扫码关注云+社区