工欲善其事,必先利其器!
成都創(chuàng)新互聯(lián)是一家專注于網(wǎng)站制作、成都網(wǎng)站建設(shè)與策劃設(shè)計(jì),潁泉網(wǎng)站建設(shè)哪家好?成都創(chuàng)新互聯(lián)做網(wǎng)站,專注于網(wǎng)站建設(shè)十多年,網(wǎng)設(shè)計(jì)領(lǐng)域的專業(yè)建站公司;建站業(yè)務(wù)涵蓋:潁泉等地區(qū)。潁泉做網(wǎng)站價(jià)格咨詢:18980820575
Android Apk 的推薦開(kāi)發(fā)環(huán)境是Eclipse + ADT,它的調(diào)試、代碼檢查、分析、重構(gòu)等功能為應(yīng)用程序的開(kāi)發(fā)提供了極大的方便。但對(duì)于象瀏覽器這樣的內(nèi)置應(yīng)用,由于使用了一些Framework層的隱藏API,在Import到Eclipse工程時(shí)會(huì)報(bào)告很多錯(cuò)誤。本文分析和解決了使用Eclipse建立瀏覽器Apk的開(kāi)發(fā)環(huán)境的一系列問(wèn)題。
問(wèn)題:為什么使用Eclipse Import 瀏覽器目錄建立的工程有很多錯(cuò)誤
分析:查看這些錯(cuò)誤,大部分都是類或者方法無(wú)法找到。這是因?yàn)闉g覽器作為內(nèi)置應(yīng)用,它使用了Framework里的一些隱藏API,這些API在代碼中使用@hide標(biāo)記,ADT 使用的Android.jar文件中沒(méi)有包含這些隱藏API,導(dǎo)致在Eclipse工程中報(bào)告錯(cuò)誤。
問(wèn)題:這些隱藏的API可以使用嗎?
分析:當(dāng)然,既然瀏覽器可以在手機(jī)上運(yùn)行,說(shuō)明它使用的這些隱藏的API在運(yùn)行環(huán)境是可用的。事實(shí)上,這些隱藏API都是被編譯進(jìn)入Framework的運(yùn)行庫(kù)的。為什么將它們@hide掉而且從android.jar中去除呢?這是個(gè)接口與實(shí)現(xiàn)的問(wèn)題,APK應(yīng)該依賴于Framework的接口,而不是實(shí)現(xiàn),但作為內(nèi)置應(yīng)用,它是可以依賴實(shí)現(xiàn)的。
問(wèn)題:如何在Eclipse工程中使用這些隱藏API?
分析:其實(shí)就像普通的Java工程一樣,你想在工程中使用這些API,那就將它們的Jar包添加到你的工程Build Path中去即可。所以這里需要做的就是找到包含我們需要的API的Jar包。
問(wèn)題:如何找到我們需要的Jar包?
分析:使用Android 源代碼工程,可以在編譯的中間文件中查找你需要的Jar包;或者可以在手機(jī)的/system/framework/下pull出來(lái)你需要的Jar文件,不過(guò)這個(gè)Jar文件是dex格式的,可以使用dex2jar工具轉(zhuǎn)換為jar文件,不過(guò),在手機(jī)上找這些Jar文件不太好判斷是哪個(gè)文件,我曾經(jīng)在4.2和4.3上比較容易地找到,不過(guò)在4.4上找了半天也沒(méi)有找到common和google-common,如果你使用4.4,建議在Android源代碼工程的編譯中間文件夾中查找。
具體步驟:
首先說(shuō)明,這里使用的是Android 4.4 版本。
第一步,Import Browser 代碼,建立Eclipse 工程
使用Eclipse的Import Existing Android Code Into WorkSpace將/packages/apps/Browser目錄Import到Eclipse中,建立工程。(代碼里還有一個(gè)Test工程,這里沒(méi)有使用)
這個(gè)時(shí)候打開(kāi)工程,看到當(dāng)前有619個(gè)錯(cuò)誤:
隨便打開(kāi)一個(gè)源文件,比如com.android.browser.AddBookmarkPage.java,里面的錯(cuò)誤如:
The import … cannot be resolved, … cannotbe resolved to a variable等都是文件或者方法找不到的錯(cuò)誤。
第二步,根據(jù)錯(cuò)誤提示,在工程的編譯中間文件夾中查找我們需要的Jar包
注意這些目錄下由于都是臨時(shí)文件夾,Jar文件需要將它們重命名到恰當(dāng)?shù)拿帧?/p>
比如在BrowserActivity文件中提示找不到這個(gè)文件:
com.google.common.annotations.VisibleForTesting
于是我們到編譯的out/target中去find這個(gè)類,找到它的目錄:
將這個(gè)class-jarjar.jar文件重命名為googlecommon.jar。
第三步,將前面找到的Jar文件都添加到工程的Java Build Path,注意,需要設(shè)置這些類的順序在Android.jar(Android 4.4 dependency)之前,否則優(yōu)先使用Android.jar中的類,導(dǎo)致某些方法找不到。
第四步:添加Android-support v13.jar到 Java Build Path.
從錯(cuò)誤提示中可以看到需要support v13,這個(gè)jar包可以在SDK的sdk\extras\android\support\v13目錄中找到。
第五步,修改AndroidManifest.xml,添加SDK Version
有一些錯(cuò)誤檢查是由于SDK版本,修改AndroidManifest.xml,添加SDK版本聲明:
第六步:修改LogTag.java
將這個(gè)類的三個(gè)方法的內(nèi)容刪掉,我們不需要它們。
另外,有一些注解類也可以不要,比如在view.ScrollerView 中的錯(cuò)誤:The annotation @ViewDebug.ExportedProperty must define the attributeflagMapping,將出錯(cuò)的這一句@ViewDebug.ExportedProperty(category= "layout")刪掉即可。
OK,太棒了,所有的錯(cuò)誤都消失了,現(xiàn)在我們有了一個(gè)沒(méi)有編譯錯(cuò)誤的Android Apk工程了!