Android Studio引用framework.jar
前言
做系統開發感覺還是用eclipse比較好,另外compile-sdk-version最好提前設置好,不要設置的太高,因為我在開始做項目的時候沒有告知Android版本,設置的比較高,導致項目中有的api不能用,所以要重新寫功能。
如果做系統應用開發,可以將應用源碼在Android源碼里編譯,但是因為兩點我推薦使用預置apk的方式:
1. 因為我的項目是Android studio項目,也就是說用gradle構建的,項目中也是用了很多gradle配置,如果要將應用源碼導入Android源碼中編譯,我不得不先將項目遷移到eclipse,并且配置編譯環境
2. 如果是內置源碼,就需要維護兩份代碼,而且如果應用做了修改,就要就要先在eclipse上調試成功,再在編譯過Android之后,再次調試。
3. 如果修改了framework層的代碼,驗證起來也是比較麻煩。
步驟
-
編譯classes.jar。
- 修改完framework源碼,使用make -j5 framework編譯framework模塊。
- 對于user版本和dubug版本,生成的路徑分別是out/target/product/$(DEVICE)/system/framework/framework.jar和out/target/common/obj/JAVA_LIBRARY/framework_interminate/classes.jar。將這個jar包拷貝到項目libs目錄下。注意,1我這里只試過JAVA_LIBRARY目錄下的classes.jar。2在Android4.4上使用的時候發現framework的代碼其實被編譯為兩部分,framework.jar和framework2.jar。其中framework.jar對應framework/base/core/java/android/也就是我們日常用的api,framework2.jar對應framework/base/core/java/com和/javax,這里主要是一些Android內部的api和類文件,一般都有點問題沒有被公開,但是正好我項目里就用到了TAT,這里要說的是framework.jar和framework2.jar對應out/target/common/obj/JAVA_LIBRARY/framework_intermediates和out/target/common/obj/JAVA_LIBRARY/framework2_intermediates中的classes.jar文件。如果你要用framework2.jar中的api,做法是跟framework.jar的方式是一樣的。
目前在mtk平臺上,通過make framework最終生成的jar文件在sys_dir/out/target/product/xxx/obj/JAVA_LIBRARY/framework_intermediates/javalib.jar
-
項目中引用framework.jar并配置。
1. 在Android studio項目里剛才復制的jar文件上右鍵add as library,此時會在mudule的build.gradle文件中的dependencies中自動生成compile files('libs/frameworks.jar') 2. 將這行代碼放在dependencies的開頭,并將compile改為provided。這里是設置生成apk時不將這個jar編譯進去。 3. 在project的build.gradle中的allprojects下添加 gradle.projectsEvaluated { tasks.withType(JavaCompile) { // options.compilerArgs.add('-Xbootclasspath/p:app\\libs\\frameworks.jar') options.compilerArgs << '-Xbootclasspath/p:app/libs/frameworks.jar' } }
編譯運行。這里在Android studio中修改過的api還是會想顯示紅色,但是可以編譯運行。