Unity-Android _ CommandInvokationFailure: невозможно преобразовать классы в формат dex
Я использую Windows 7, JDK 1.8.0 (64-разрядная версия), JRE 8 (64-разрядная версия), Unity Pro 4.3.4f1 и Android SDK 22.6.1.
Все обновленные программные продукты. Все работает нормально, но когда я использую StartApp SDK, эта ошибка приходит. Дополнительный плагин не используется, только SDK, предоставленный рекламой StartApp.
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. Но до сих пор не удалось решить
3 ответа
Я столкнулся с этим, используя IntelliJ 13.1.4, JDK 1.6, но я предполагаю, что это вызвано тем же самым в любой другой среде IDE -> classes.jar упоминается / включается более одного раза.
Проверьте и убедитесь, что на файл classes.jar, который вы добавили в проект (из Unity\Editor\Data\PlaybackEngines\androidplayer\bin\classes.jar), нет ссылок / включенных более одного раза. Если вы зайдете в File->Project Structure: в библиотеках должен быть только один "класс". Не должно быть НИКАКОЙ ссылки на классы в Артефактах (Артефакты используются для создания файла плагина.jar.)
Проверьте этот связанный ответ -> /questions/27351068/oshibka-sborki-android-javalangillegalargumentexception-uzhe-dobavleno-lcomgoogleapiclientescapecharescapers/27351090#27351090
Моя проблема была связана с наличием дубликатов файлов. Ну, не совсем дубликаты, но у меня было 2 пакета adMob sdk (разные версии), которые вступали в конфликт. После удаления старого все было исправлено. Используете ли вы какие-либо сторонние SDK или что-то подобное, если это так, попробуйте удалить их, если это возможно, и посмотрите, сохраняется ли проблема. Попробуйте выяснить, какая часть кода вызывает это. В конечном итоге вы можете попытаться скомпилировать пустой проект только для тестирования.
Сегодня я решил аналогичную проблему создания ошибки Player: CommandInvokationFailure: невозможно преобразовать классы в формат dex. Смотрите Консоль для деталей. с добавлением файла.jar в плагины \Android\
Я получил разные виды ошибок:
- Вызывается: com.android.dx.cf.iface.ParseException: неверная магия файла класса (cafebabe) или версия (0034.0000 ...
- Вызывается: 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)