需求
前段时间在做挖孔屏适配,中间就不要有刘海,需求就是把这个刘海去掉。
调研
官方关于刘海屏有介绍,其中有两个属性比较关键:
值 | 说明 |
---|---|
config_mainBuiltInDisplayCutout |
用于定义刘海屏形状的路径。这是一个可由 android.util.PathParser 解析的字符串,并且是告知系统刘海屏大小和形状的方式。可在路径中指定 @dp 以便模拟针对不同设备的形状。由于实际的刘海屏具有精确的像素尺寸,因此在定义硬件刘海屏的路径时,请勿使用 @dp 指定符。 |
config_fillMainBuiltinDisplayCutout |
一个确定是否在软件中绘制刘海屏路径(在上文中进行了定义)的布尔值。可用于模拟刘海屏,或填充实际刘海屏,以实现抗锯齿。如果为 true,则系统会以黑色填充config_mainBuiltInDisplayCutout 。 |
看原生 frameworks/base/core/res/res/values/config.xml 这两个属性:
<string translatable="false" name="config_mainBuiltInDisplayCutout"></string>
<bool name="config_fillMainBuiltInDisplayCutout">false</bool>
说明原生是没有适配刘海,而现在手机却看到了刘海,肯定是哪里有定制,找了下,果然,有定制资源 apk A 将 config_fillMainBuiltInDisplayCutout 打开了,并配了 config_mainBuiltInDisplayCutout。
需求是去刘海,我只要再定制个资源,设置 config_fillMainBuiltInDisplayCutout 为 false 即可。
解决
一通复制粘贴,我的定制资源 apk B 完成了,等编译验证,结果刘海还在,WTF,不应该啊,难道是我的定制资源 apk 没有覆盖成功?
一般要想覆盖,可以使用 LOCAL_OVERRIDES_PACKAGES,可是并没有看到 apk A 有这样的写法,为什么他优先使用了 apk A 资源配置,我定制资源 apk B 没有生效,是不是还要哪里配置?一开始自然怀疑自己是不是哪里写错了,一行行检查代码,问之前做过这块的同事,确认我写的代码没问题!协调资源问 OS 组, ROM 组,并没有得到更多的支持。
以为这个问题没法解了,处在放弃边缘,有人提到了 priority, apk A 和 apk B 等级是一样,自然不能生效,AndroidManifest.xml 有这段:
<overlay
android:targetPackage="com.android.settings"
android:isStatic="true"
android:priority="1" />
Android overlay 机制允许在不修改 packages 中 apk 的情况下,来自定义 framework 和 package 中的资源文件,实现资源的定制。其中 priority 决定优先级,必须是整数,默认是 0,范围是[−1000, 1000]。
握草,我再怎么也想不到是 android:priority 起作用了。
最后
处理问题要积极推动,直到有定论,没有什么问题是解不掉的,嗯,是这样的!