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が複数回参照/含まれています。

プロジェクトに (Unity\Editor\Data\PlaybackEngines\androidplayer\bin\classes.jar から) 追加した classes.jar が複数回参照/インクルードされていないことを確認してください。File->Project Structure に移動すると、ライブラリの下に「クラス」が1つだけあるはずです。Artifacts の下のクラスへの参照はありません (Artifacts はプラグイン .jar ファイルの作成に使用されます)。

この関連する回答を確認してください - > https://stackoverflow.com/a/8437996/3464367

于 2014-08-08T13:50:56.950 に答える
0

私の問題は、実際にはファイルが重複していることに関連していました。実際には重複していませんが、2 つの adMob SDK パッケージ (異なるバージョン) が競合していました。古いものを削除した後、すべてが修正されました。サードパーティの SDK または類似のものを使用していますか。使用している場合は、可能であればそれらを削除して、問題が解決しないかどうかを確認してください。コードのどの部分がこれを引き起こしているかを調べてみてください。最終的には、テストのためだけに空のプロジェクトをコンパイルすることができます。

于 2016-04-11T07:44:07.950 に答える