意想不到的 priority

意想不到的 priority,第1张

概述需求前段时间在做挖孔屏适配,中间就不要有刘海,需求就是把这个刘海去掉。调研官方关于刘海屏有介绍,其中有两个属性比较关键:值说明config_mainBuiltInDisplayCutout用于定义刘海屏形状的路径。这是一个可由 android.util.PathParser 解析的字符串,并且是告知系统刘海屏大小和形状的方 需求

前段时间在做挖孔屏适配,中间就不要有刘海,需求就是把这个刘海去掉。

调研

官方关于刘海屏有介绍,其中有两个属性比较关键:

说明
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 起作用了。

最后

处理问题要积极推动,直到有定论,没有什么问题是解不掉的,嗯,是这样的!

总结

以上是内存溢出为你收集整理的意想不到的 priority全部内容,希望文章能够帮你解决意想不到的 priority所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/web/1006971.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-22
下一篇 2022-05-22

发表评论

登录后才能评论

评论列表(0条)

保存