安卓14上蓝牙调用SystemProperties.set(),解决找不到SystemProperties.set()的问题

近期遇到一个需求,要在安卓14的蓝牙模块中调用SystemProperties.set()。

安卓14中的蓝牙,和安卓12的版本有较大的不同。它在packages/modules目录下,而安卓12是分散在packages/apps和frameworks/base等目录下;安卓14的蓝牙打包产物为apex,安卓12则是apk等。

接口的校验也更加严格,安卓12上SystemProperties.set()可以正常编译,安卓14上则会编译报错

这个报错比较特别,它找不到的不是SystemProperties这个类,而是set这个方法。实际上,AdapterState这个类里面还有SystemProperties.getInt()。这个get方法就是可以正常编译的。

进一步尝试,发现packages/modules目录下其它模块,SystemProperties.set()也编译不过,但get方法就可以。

于是看看frameworks/base/core/java/android/os/SystemProperties.java这个类

可以看到set方法和getInt方法都是有的,只是注解不同。再进行尝试,发现同样注解了UnsupportedAppUsage的reportSyspropChanged()方法也编译不过,看来问题就在于这个注解了。

找到这个类/tools/platform-compat/java/android/compat/annotation/UnsupportedAppUsage.java,从注释上看,它会根据sdk版本限制访问。

考虑到这次是要修改原生蓝牙,不方便对配置做太多改动。实际上在Android.bp里尝试注释掉min_sdk_version和sdk_version也不行,会报错。

于是采用的方案是,做一个jar,其中包裹SystemProperties.set()。如下图

这样可以通过MySystemProperties.set()调用SystemProperties.set()。也避免了SystemProperties.set()的注解的影响。

打包jar很简单,Android Studio中File->New->New Module->Java or Kotlin Library,完成代码后Build->Make Project。创建的module的目录下build/libs里就是生成的jar包。

这个jar包要放在加到对应模块的Android.bp中。关键代码

java_import {

name: "mypropertylib",

sdk_version: "system_current",

min_sdk_version: "Tiramisu",

jars: [

"lib/mypropertylib.jar",

],

installable: false,

apex_available: [

"com.android.xxxxxxx",

],

}

static_libs: [

........

"mypropertylib",

],

注意这个库要加在static_libs中,因为是作为静态库加入。

如果加在libs中,编译时会当作动态库。虽然编译能通过,但是运行时,会因为在系统库找不到对应的类而报错。

这样在蓝牙的代码中使用MySystemProperties.set(),就可以正常编译了,验证功能也OK。

相关推荐
贺biubiu2 小时前
2025 年终总结|总有那么一个人,会让你千里奔赴...
android·程序员·年终总结
xuekai200809013 小时前
mysql-组复制 -8.4.7 主从搭建
android·adb
nono牛4 小时前
ps -A|grep gate
android
未知名Android用户5 小时前
Android动态变化渐变背景
android
nono牛6 小时前
Gatekeeper 的精确定义
android
stevenzqzq7 小时前
android启动初始化和注入理解3
android
城东米粉儿9 小时前
compose 状态提升 笔记
android
粤M温同学9 小时前
Android 实现沉浸式状态栏
android
ljt272496066110 小时前
Compose笔记(六十八)--MutableStateFlow
android·笔记·android jetpack