Android 使用系统JAR包
项目开发过程中,经常有需要到系统jar包,导入系统jar包后,发现无法正常编译通过,针对此问题,下文简述下如何导入framework.jar ,并正常使用
1、导入framework.jar ,使用compileOnly
依赖
compileOnly files('libs/framework.jar')
正常情况下 已经可以使用framework.jar 中相关api,但是存在使用的API可能在系统源码中已有,所以在编译时,无法获取到framework.jar中的api,默认用的是系统api,原因如下:
可以发现在项目.idea/module_name/module_name.iml (module_name 替换成自己的)文件中 找到orderEntry 代表该模块的库依赖顺序,通过调整依赖顺序可以解决项目引用库编译默认报红问题,调整后 顺序如下
调整好依赖顺序之后,只要sync 项目 会导致orderEntry 顺序重新回到默认顺序,默认依赖系统api 而非引入framework.jar,所以不建议sync
修改好上述顺序后,AndroidStudio 不会爆红,方法与类也都可以跟进到framework源码中,但是编译时还是会报错,找不到对应的类和方法,需要在项目的build.gradle 下加入以下配置
#引入jar包路径
def externalFramework = file('../download_upgrade/provider/framework8.0.jar')
gradle.projectsEvaluated {
# 执行JavaCompile时,添加此依赖
tasks.withType(JavaCompile) {
options.compilerArgs.add("-Xbootclasspath/p:$externalFramework")
}
}
通过以上方式可以确保编译不会报错
以上即为引入系统jar包 相关问题
系统jar包api爆红问题
上面虽然解决了使用系统jar包的问题,但是调用系统jar里的api会爆红,要解决这个问题则:
在module的build.gradle中添加以下代码,此段代码的目的是为了编译时动态的修改iml文件,将androidSutdio默认的Android SDK优先级调整到最后,以使我们自己的frameworks.jar的优先级提高,这样在代码加载时则会根据优先级进行加载,可以解决代码报红的问题
apply plugin: 'com.android.application'
// place in first line of gradle.
import groovy.xml.XmlUtil
// not contained in any attribute, put it in the outermost layer
// make SDK directory's android.jar set in libs behind
preBuild {
doLast {
def imlFile = file("../.idea/modules/${project.name}/TSmartLink.LinkPermissionProxy.iml //这里是此module的iml文件路径,一定要写对
println 'Change ' + imlFile.name + ' order'
try {
def parseXml = new XmlParser().parse(imlFile)
def jdkNode = parseXml.component[1].orderEntry.find { it.'@type' == 'jdk' }
parseXml.component[1].remove(jdkNode)
def sdkString = "Android API " + android.compileSdkVersion.substring("android-".length()) + " Platform"
println 'sdkString ' + sdkString + ' '
new Node(parseXml.component[1], 'orderEntry', ['type': 'jdk', 'jdkName': sdkString, 'jdkType': 'Android SDK'])
XmlUtil.serialize(parseXml, new FileOutputStream(imlFile))
} catch (FileNotFoundException e) {
//nop, iml not found.
println e.printStackTrace()
}
}
}
android {
...
...
}
dependencies {
...
...
}