前段时间在做挖孔屏适配,中间就不要有刘海,需求就是把这个刘海去掉。
调研官方关于刘海屏有介绍,其中有两个属性比较关键:
值 | 说明 |
---|---|
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所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)