现象
在mtk平台修改SystemUI的时候,出现了修改资源文件不生效的情况,但代码修改是生效的,很确定指向的资源文件是对的,之前在amlogic平台修改fragment资源内容并未碰到过这种情况,查阅资料后才知道mtk平台的客制化内容对部分资源文件进行了覆盖重写。
资源替换机制overlay
覆盖重写的资源文件在overlay文件夹下,可以通过grep命令在device目录下查找,因为可能不止一套overlay文件,真正使用的资源文件有可能在对应芯片型号的文件夹,也可能在google文件夹下,与lunch也有关系,根据实际情况修改生效的资源文件就好(注意:代码中使用到的资源ID,要么保留,要么在代码中去除)
这种属于静态的overlay方式,本质上是通过AAPT打包成APK时,通过-S命令多增加了一个资源目录,编译时将overlay下的同名资源文件替换
还有一种动态的overlay方式,本质上是动态资源查找机制,用在定制替换非系统app资源
总结
Android 的overlay机制为平台客制化提供了很大的便利,本文章只描述了如何找到mtk平台的overlay文件,想了解更详细的overlay机制描述还请查阅资料,目前工作与平台客制化相关,可以在公司框架中通过此方式,为不同的客户定制不同的系统UI,而不需要编译多套代码以及分支控制,十分便利,值得学习掌握