3

我正在使用 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 解决方案。但是还是解决不了

4

3 回答 3

2

我使用 IntelliJ 13.1.4、JDK 1.6 遇到了这个问题,但我猜这是由任何其他 IDE 上的相同事情引起的 -> classes.jar 被多次引用/包含。

检查并确保您添加到项目中的 classes.jar(来自 Unity\Editor\Data\PlaybackEngines\androidplayer\bin\classes.jar)没有被多次引用/包含。如果您进入文件-> 项目结构:库下应该只有一个“类”。Artifacts 下不应有对类的引用(Artifacts 用于创建插件 .jar 文件。)

查看此相关答案-> https://stackoverflow.com/a/8437996/3464367

于 2014-08-08T13:50:56.950 回答
0

我的问题实际上与重复文件有关。好吧,并不是真的重复,但我有 2 个 adMob sdk 包(不同版本),它们正在发生冲突。删除旧的后,一切都已修复。您是否使用任何 3rd 方 SDK 或类似的东西,如果是,请尝试删除它们(如果可能)并查看问题是否仍然存在。尝试找出导致这种情况发生的代码部分。您最终可以尝试编译一个空项目来进行测试。

于 2016-04-11T07:44:07.950 回答
0

今天解决了Error building Player: CommandInvokationFailure: Unable to convert classes into dex format的类似问题。有关详细信息,请参阅控制台。将 .jar 文件添加到 Plugins\Android\

我遇到了不同类型的错误:

  1. 引起:com.android.dx.cf.iface.ParseException: bad class file magic (cafebabe) or version (0034.0000 ...
  2. 引起:com.android.dx.cf.iface.ParseException:类名(ht/stringing/test)不匹配路径(src/ht/stringing/test.class)

我的结果工作解决方案与类似:

代码在这里:

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)

于 2016-05-07T16:29:02.773 回答