我正在使用Windows 7,jdk 1.8.0(64位),jre 8(64位),Unity Pro 4.3.4f1和Android SDK 22.6.1
所有都是更新的软件。 一切正常,但当我使用 StartApp sdk时,会出现此错误。没有使用额外的插件,只有StartApp广告提供的SDK。
Error building Player: CommandInvokationFailure: Unable to convert classes into dex format. See the Console for details.
C:\Program Files\Java\jdk1.8.0\bin\java.exe -Xmx1024M -Dcom.android.sdkmanager.toolsdir="D:/android-sdks\tools" -Dfile.encoding=UTF8 -jar "C:/Program Files (x86)/Unity/Editor/Data/BuildTargetTools/AndroidPlayer\sdktools.jar" -
stderr[
UNEXPECTED TOP-LEVEL EXCEPTION:
java.lang.IllegalArgumentException: already added: Lcom/unity3d/player/a$1;
at com.android.dx.dex.file.ClassDefsSection.add(ClassDefsSection.java:122)
at com.android.dx.dex.file.DexFile.add(DexFile.java:161)
at com.android.dx.command.dexer.Main.processClass(Main.java:685)
at com.android.dx.command.dexer.Main.processFileBytes(Main.java:634)
at com.android.dx.command.dexer.Main.access$600(Main.java:78)
at com.android.dx.command.dexer.Main$1.processFileBytes(Main.java:572)
at com.android.dx.cf.direct.ClassPathOpener.processArchive(ClassPathOpener.java:284)
at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:166)
at com.android.dx.cf.direct.ClassPathOpener.processDirectory(ClassPathOpener.java:229)
at com.android.dx.cf.direct.ClassPathOpener.processOne(ClassPathOpener.java:158)
at com.android.dx.cf.direct.ClassPathOpener.process(ClassPathOpener.java:144)
at com.android.dx.command.dexer.Main.processOne(Main.java:596)
at com.android.dx.command.dexer.Main.processAllFiles(Main.java:498)
at com.android.dx.command.dexer.Main.runMonoDex(Main.java:264)
at com.android.dx.command.dexer.Main.run(Main.java:230)
at com.android.dx.command.dexer.Main.main(Main.java:199)
at com.android.dx.command.Main.main(Main.java:103)
at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62)
at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43)
at java.lang.reflect.Method.invoke(Method.java:483)
at SDKMain.main(SDKMain.java:129)
1 error; aborting
]
我已经尝试过JAVA_OPT和JAVA_HOME解决方案。但仍然无法解决
答案 0 :(得分:2)
我使用IntelliJ 13.1.4,JDK 1.6遇到了这个,但我猜这是由任何其他IDE上的相同内容引起的 - > classes.jar被多次引用/包含。
检查并确保您添加到项目中的classes.jar(来自Unity \ Editor \ Data \ PlaybackEngines \ androidplayer \ bin \ classes.jar)未被多次引用/包含。如果你进入File->项目结构: 应该只有一个"类"在图书馆下。 应该没有对Artifacts下的类的引用(Artifacts用于创建插件.jar文件。)
查看此相关答案 - > https://stackoverflow.com/a/8437996/3464367
答案 1 :(得分:0)
今天我解决了错误构建播放器的类似问题:CommandInvokationFailure:无法将类转换为dex格式。有关详细信息,请参阅控制台。将.jar文件添加到Plugins \ Android \
中我遇到了不同的错误:
我的结果工作解决方案类似于this:
代码住在这里:
verysimple\src\ht\stringing\test.java
我做:
> javac -classpath "c:\Android\sdk\platforms\android-15" ht\stringing\test.java
> jar cvf ..\dist\verysimple.jar ht\stringing\test.class
> copy ..\dist\verysimple.jar c:\ExUnityApp\Assets\Plugins\Android
不要忘记比较您的最低Api级别'在玩家设置中。对我来说,这是 Android 4.0.3 ...(15)