Я пытаюсь открыть исходный код a library, который я создал, но столкнулся с проблемами с созданным AAR и NoClassDefFoundError
с, когда я пытаюсь использовать библиотеку под APC с поддержкой Gradle. Примечательно, что если я конвертирую AAR в более старый, неофициальный и теперь устаревший формат apklib
(и использовать под созданным APK android-maven-plugin
), библиотека работает без проблем.Android AAR NoClassDefFoundError
С этими доказательствами я, вероятно, вижу дефицит андроида-градиента-плагина. Из попытки всех documentedroots, в том числе полагаться на локальное репозитирование maven, включая AAR, и импортировать AAR с использованием механизма импорта модуля Studio, ошибка остается.
Более глубокое расследование указывает на то, что не все классы библиотеки подвергаются проблеме, отмеченной ниже. В частности, есть проблемы с теми классами, которые сами полагаются на Службы Google Play или на библиотеку поддержки Android. Аналогичная проблема (вероятно, точно такая же, по сути) была отмечена here еще в феврале.
Исключение, которое я вижу ниже;
04-21 00:02:25.863 21336-21336/com.oceanlife E/AndroidRuntime﹕ FATAL EXCEPTION: main
Process: com.oceanlife, PID: 21336
java.lang.NoClassDefFoundError: com.brantapps.polaris.google.GoogleMapWrapper
at com.brantapps.polaris.PolarisModule.provideMappable(PolarisModule.java:46)
at com.brantapps.polaris.PolarisModule$$ModuleAdapter$ProvideMappableProvidesAdapter.get(PolarisModule$$ModuleAdapter.java:57)
at com.brantapps.polaris.PolarisModule$$ModuleAdapter$ProvideMappableProvidesAdapter.get(PolarisModule$$ModuleAdapter.java:41)
at com.oceanlife.fragment.addspot.AddSpotMapFragment.onCreate(AddSpotMapFragment.java:171)
at android.support.v4.app.Fragment.performCreate(Fragment.java:1763)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:915)
at android.support.v4.app.FragmentManagerImpl.moveToState(FragmentManager.java:1136)
at android.support.v4.app.BackStackRecord.run(BackStackRecord.java:739)
at android.support.v4.app.FragmentManagerImpl.execPendingActions(FragmentManager.java:1499)
at android.support.v4.app.FragmentActivity.onStart(FragmentActivity.java:548)
at android.app.Instrumentation.callActivityOnStart(Instrumentation.java:1220)
at android.app.Activity.performStart(Activity.java:5949)
at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2261)
at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2360)
at android.app.ActivityThread.access$800(ActivityThread.java:144)
at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1278)
at android.os.Handler.dispatchMessage(Handler.java:102)
at android.os.Looper.loop(Looper.java:135)
at android.app.ActivityThread.main(ActivityThread.java:5221)
at java.lang.reflect.Method.invoke(Native Method)
at java.lang.reflect.Method.invoke(Method.java:372)
at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:899)
at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:694)
конфигурации проекта можно рассматривать под GitHub repo here но вот зависимостей сборки у меня есть для ясности;
dependencies {
compile 'com.android.support:support-v4:22.0.0'
compile 'com.google.guava:guava:18.0'
compile 'com.squareup.dagger:dagger:1.2.1'
googleCompile 'com.google.android.gms:play-services:7.0.0'
kindleCompile 'org.osmdroid:osmdroid-android:4.1'
kindleCompile 'org.osmdroid:osmbonuspack:4.4'
kindleCompile 'org.slf4j:slf4j-android:1.7.7'
provided 'com.squareup.dagger:dagger-compiler:1.2.+'
}
Любое понимание/обходные пути к этой проблеме любезно приняты.
Я работал вокруг этого путем размещения кода AAR под привкусом. Повторите попытку со следующей версией инструмента сборки. – OceanLife
Все еще не работает, как я, кажется, ожидаю ... – OceanLife