背景介绍:
看Android 15版本更新时,"Android 15 deprecates vendor overlay"。 猜想这个vendor overlay是之前用过的settings overlay, 不过具体是怎么回事呢?
目录
Vendor Overlay介绍
Vendor Overlay(供应商覆盖)是一种用于自定义和定制Android系统UI和行为的机制。通过这个机制允许设备厂商(如手机制造商或芯片供应商)在不修改AOSP的源代码的情况下,通过覆盖Android系统的默认资源和配置文件来实现定制化的功能和外观。
Vendor Overlay是Android系统中的一种机制,允许供应商(通常是设备厂商)在系统中覆盖或修改特定的资源和配置文件。例如,可以通过Vendor Overlay来修改系统的主题、布局、图标、行为,甚至是一些系统属性,而无需修改AOSP的源码。
在Android设备的系统镜像中,overlya是一种将特定资源(如图形、颜色、字符串、布局)应用到系统中现有的部分或整个界面的方式。这样,设备厂商就能够根据自己的需求提供定制化的用户体验。
Vendor Overlay工作原理
Overlayer文件夹
供应商可以将定制化的资源放入特定的目录中(如/vendor/overlay/),这些资源会覆盖系统默认的资源。这个机制通常适用于供应商想要修改系统行为或界面的场景。
优先级覆盖
如果供应商放置的资源文件与系统默认资源文件有冲突或相同的路径,系统会优先使用vendor/overlay/中的文件而不是AOSP默认的文件。
应用场景
通常供应商管修改或覆盖以下资源内容:
- 布局文件:调整系统界面的布局,定制启动器界面、设置界面等。
- 主题和样式:提供不同的图标、按钮样式、背景等。
- 字符串资源:修改一些特定的字符串,比如设备名称、操作提示等。
- 图标和图片:改变系统默认图标或其他资源图像。
- 行为和功能:改变系统的某些功能或配置。
Vendor Overlay和其他Overlay的区别
除了Vendor Overlay之外,还有Product Overlay, 它的主要作用是为特定设备(如高端设备或不同产品系列)提供额外的功能或定制。Product Overlay通常用于设备的特定版本,而Vendor Overlay是为设备厂商提供的一种机制能力,用于覆盖默认的系统资源和行为。
Android系统本身也支持一个叫做System Overlay的机制,它是系统在不同的版本或更新中支持的覆盖方式。与Vendor Overlay不同,System Overlay主要由Google提供,用于规范Android系统的某些统一性和向后兼容性。
Vendor Overlay的优点
vendor overlay带来的好处主要是3个:
- 不修改源代码: 供应商可以通过Vendor Overlay来修改Android系统,而无需直接修改AOSP的源代码。这样可以避免每次Android系统更新时都要手动合并代码,提升了定制的维护成本。
- 便于升级和兼容性:因为Vendor Overlay并不修改底层代码,它可以确保设备在Android系统升级时能够更容易地保持与新版本的兼容性。
- 支持快速定制:厂商可以快速定制和修改设备的UI和行为,适应市场需求的变化,而不必等待每个Android版本的发布。
Vendor Overlay使用的例子
- UI定制:例如,Android设备厂商(如三星、华为、小米等)都会提供自己的用户界面(UI)定制,如One UI, EMUI, MIUI等。这些UI通常是通过Vendor Overlay实现的,包括修改系统的颜色方案、图标、按钮样式等。
- 功能定制:一些厂商可能希望添加或修改某些功能,比如系统中的快速设置项、通知栏样式等,这些定制通常也是通过Vendor Overlay来实现的。
那么在实际开发中,通过以下几步来使用Vendor Overlay实现覆盖:
1.创建Overlay目录: 在系统镜像中创建一个vendor/overlay/目录,用于放置定制的资源文件。
2.放置定制资源:在overlay目录中,厂商可以放置定制化的资源文件,这些文件可以是XML布局、图片、样式等,文件路径与AOSP中的路径要一致。
3.应用优先级规则:系统会根据优先级加载这些资源。如果资源与AOSP中的默认资源冲突,系统会优先加载vendor/overlay/中的资源。
Overlay优先级规则
在Android系统中,覆盖优先级规则(Overlay Priority Rules)是一个关键的机制,用于决定在有多个重叠资源时,哪个资源最终会生效。默认情况下,Android的覆盖优先级规则是由系统固定的,但是某些规则是可以被修改的,尤其是在需要定制化Android设备的情况下。建议按照默认的规则来。