使用@hide 的api,可以通过反射,但反射速度慢,且使用不方便。
@hide的api,在编译的时候有问题,如果能编译成功,是可以调用的。那么问题来了,如何编译成功?
可以修改android源码,去掉@hide,编译生成该模块的framework.jar。Eclipse中直接引入该jar包在android.jar前即可。AndroidStudio就比较麻烦,需要做两步。
1.引入jar包,这个网上有无数方法,不表。注意设置compile->provide,gradle文件如下:
Shell
provided files('lib/android_packageManager.jar')
1
providedfiles('lib/android_packageManager.jar')
原因就是我们只需要编译成功,不需要把这个包打到系统。
这时候在系统自动生成的iml文件中,可以看到一排orderEntry标签 ,也就是我们引用的所有jar包信息,把framework的jar包放到orderEntry的第一位,也就是
Shell
<orderEntry type="jdk" jdkName="Android API 22 Platform" jdkType="Android SDK" />
1
<orderEntrytype="jdk"jdkName="Android API 22 Platform"jdkType="Android SDK"/>
前面,这时候IDE就不报错了。
不过只是表象,方便我们写代码自动补全而已。而且iml文件是自动生成的,每次重启IDE都要重新改一下。
2.真正的编译需要在工程的gradle中增加编译选项
找到
Shell
allprojects {
repositories {
jcenter()
}
}
1
2
3
4
5
6
7
allprojects{
repositories{
jcenter()
}
}
在repositores同级增加
Shell
gradle.projectsEvaluated {
tasks.withType(JavaCompile) {
options.compilerArgs.add('-Xbootclasspath/p:/lib/android_packageManager.jar')
}
}
1
2
3
4
5
gradle.projectsEvaluated{
tasks.withType(JavaCompile){
options.compilerArgs.add('-Xbootclasspath/p:/lib/android_packageManager.jar')
}
}
Xbootclasspath/p:是Java编译的寻址优先设置,先找缺省路径还是全路径
Shell
Xbootclasspath/p:
1
Xbootclasspath/p:
不确定路径怎么填的,可以使用绝对路径,如
Shell
Xbootclasspath/p:D://mProject/app/lib/android_packageManager.jar')
1
Xbootclasspath/p:D://mProject/app/lib/android_packageManager.jar')
编译通过
Tips:
1.有时候@hide的api编译过了,其他地方又报错。查看一下报错的api,看看是不是对android版本有要求,framework.jar编译最好用较新的编译环境。
2.不要做过多的其他尝试,这两步绝对可以解决问题。