http://www.cocoachina.com/bbs/read.php?tid=215700
錯誤如下。。。但是使用eclipse生成apk包時不收影響。。
-dex:
[dex] input: E:\cocos\Mine\frameworks\runtime-src\proj.android\bin\classes
[dex] input: E:\cocos\Mine\frameworks\js-bindings\cocos2d-x\cocos\platform\android\java\bin\classes.jar
[dex] Pre-Dexing E:\cocos\Mine\frameworks\js-bindings\cocos2d-x\cocos\platform\android\java\bin\classes.jar -> classes-022efb48739f8be18b60e7464733537d.jar
[dex] Converting compiled files and external libraries into E:\cocos\Mine\frameworks\runtime-src\proj.android\bin\classes.dex...
[dx]
[dx] UNEXPECTED TOP-LEVEL EXCEPTION:
[dx]
com.android.dx.util.DexException: Multiple dex files define Lorg/cocos2dx/lib/Cocos2dxAccelerometer;
[dx] at com.android.dx.merge.DexMerger.readSortableTypes(DexMerger.java:592)
[dx] at com.android.dx.merge.DexMerger.getSortedTypes(DexMerger.java:550)
[dx] at com.android.dx.merge.DexMerger.mergeClassDefs(DexMerger.java:531)
[dx] at com.android.dx.merge.DexMerger.mergeDexBuffers(DexMerger.java:168)
[dx] at com.android.dx.merge.DexMerger.merge(DexMerger.java:186)
[dx] at com.android.dx.command.dexer.Main.mergeLibraryDexBuffers(Main.java:300)
[dx] at com.android.dx.command.dexer.Main.run(Main.java:232)
[dx] at com.android.dx.command.dexer.Main.main(Main.java:174)
[dx] at com.android.dx.command.Main.main(Main.java:91)
[dx]
BUILD FAILED
E:\BST\adt-bundle-windows-x86-20130917\sdk\tools\ant\build.xml:892: The following error occurred while executing this line:
E:\BST\adt-bundle-windows-x86-20130917\sdk\tools\ant\build.xml:894: The following error occurred while executing this line:
E:\BST\adt-bundle-windows-x86-20130917\sdk\tools\ant\build.xml:906: The following error occurred while executing this line:
E:\BST\adt-bundle-windows-x86-20130917\sdk\tools\ant\build.xml:284: null returned: 2
---------------------------
查資料發現,發現:
cocos compile 的腳本里會自動把“frameworks\js-bindings\cocos2d-x\cocos\platform\android\java\bin\classes.jar”(2dx的java代碼)添加到classes.dex中。
而當用eclipse打開android項目時,默認是沒有引入2dx的java類的,此時如果想正常運行android項目,需要引入2dx的jar包,或者引入2dx的java源碼。
如 果引入java的源碼,當再次執行“cocos compile”時,2dx的java源碼生成的class文件,會跟默認引入的“frameworks\js-bindings\cocos2d-x \cocos\platform\android\java\bin\classes.jar”發生沖突,會報 “com.android.dx.util.DexException: Multiple dex files define ……”的錯誤;
如 果不引入java源碼,而是直接在“Build path”中引入了jar包(位于引擎的:frameworks\js-bindings\cocos2d-x\cocos\platform \android\java\bin\下的classes.jar),此時android的項目不報錯了,但是直接使用eclipse生成apk包時會發 現安裝到手機上無法運行,這是因為項目需要的2dx文件沒有被打入到apk中。此時,可以將對應的jar包放到android項目的libs目錄里 (frameworks\runtime-src\proj.android\libs\),這樣生成的apk包就可以正常運行了。
但是,如果這樣做了,再次執行“cocos compile”時,發現還會報如上的錯誤,這是因為腳本里會默認將libs目錄里的文件添加到classes.dex中。
綜上所述:
出現如上錯誤的原因是在使用“cocos compile”腳本時,2dx文件被重復添加了。
不過,如果像我這樣操作,使用“cocos compile”編譯腳本(主要是因為該腳本會將js文件和資源拷貝的android項目里),使用eclipse將android項目打包成apk,可以忽略如上問題的;感覺很不爽。。。。
-------------解決方法
注釋掉project.properties文件中的#android.library.reference.1=../cocos2d/cocos/platform/android/java就可以啦!!!