2014-01-22 3 views
3

У меня возникла проблема с запуском витамина-образца от https://github.com/yixia/VitamioBundle.Ошибка образца Vitamio - java.lang.UnsatisfiedLinkError: Не удалось загрузить vinit findLibrary возвращается null

Я строю его с Android Studio и отлично компилируется и работает, но когда дело доходит до этой строки:

if (!io.vov.vitamio.LibsChecker.checkVitamioLibs(this)) 
    return; 

Он бросает исключение, когда я запустить его на моем Nexus 5 (а также на Galaxy S4):

01-22 11:58:40.759 12323-12323/? E/AndroidRuntime﹕ FATAL EXCEPTION: main 
Process: io.vov.vitamio.demo, PID: 12323 
java.lang.UnsatisfiedLinkError: Couldn't load vinit from loader dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/io.vov.vitamio.demo-1.apk"],nativeLibraryDirectories=[/data/app-lib/io.vov.vitamio.demo-1, /vendor/lib, /system/lib]]]: findLibrary returned null 
     at java.lang.Runtime.loadLibrary(Runtime.java:358) 
     at java.lang.System.loadLibrary(System.java:526) 
     at io.vov.vitamio.Vitamio.<clinit>(Vitamio.java:258) 
     at io.vov.vitamio.LibsChecker.checkVitamioLibs(LibsChecker.java:40) 
     at io.vov.vitamio.demo.VitamioListActivity.onCreate(VitamioListActivity.java:40) 
     at android.app.Activity.performCreate(Activity.java:5231) 
     at android.app.Instrumentation.callActivityOnCreate(Instrumentation.java:1087) 
     at android.app.ActivityThread.performLaunchActivity(ActivityThread.java:2159) 
     at android.app.ActivityThread.handleLaunchActivity(ActivityThread.java:2245) 
     at android.app.ActivityThread.access$800(ActivityThread.java:135) 
     at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1196) 
     at android.os.Handler.dispatchMessage(Handler.java:102) 
     at android.os.Looper.loop(Looper.java:136) 
     at android.app.ActivityThread.main(ActivityThread.java:5017) 
     at java.lang.reflect.Method.invokeNative(Native Method) 
     at java.lang.reflect.Method.invoke(Method.java:515) 
     at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:779) 
     at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:595) 
     at dalvik.system.NativeStart.main(Native Method) 

Исключение также случается, когда я запускаю дерево v4.2.0 в своем приложении.

Любая идея, что мне не хватает? В моем собственном приложении я вытащил vitamio проект в папку библиотеки, и я ссылаться на него, как это:

 compile(project(':libraries:vitamio')) 

Проект образец оставляют как есть.

+0

Проверьте это http://stackoverflow.com/questions/20117884/android-studio-app-with-library-project-fails-to-build –

+0

удалить (из проекта компиляции линии компиляции (': libraries: vitamio') Убедитесь, что вы очистили свой проект Build-> clean project или ./gradlew clean –

+0

Он правильно строится, он просто не похож на то, что он копирует файлы, находящиеся в нужном месте. – Paul

ответ

1

Я не уверен, есть ли более чистый способ в новой версии Vitamino (или градации). Но вот как я получил его для работы с инструментами построения градации 0.6.

  1. Добавлен проект в каталог моих/библиотек с источником vitamino/sdk. У этого есть/libs/armeabi/libs/armeabi-v7a с libvinit.so внутри.

  2. В моей build.gradle для моего основного проекта, ссылаться на проект библиотеки, как:

    dependencies { 
    
        // other dependencies 
    
        compile(project(':libraries:vitamio')) 
    
    } 
    
  3. Добавьте следующие строки в нижней части моего build.gradle

    task copyNativeLibs(type: Copy) { 
        from(new File(project(':libraries:vitamio').getProjectDir(), 'libs')) { include '**/*.so' } 
    into new File(buildDir, 'native-libs') 
    } 
    
    tasks.withType(JavaCompile) { compileTask -> compileTask.dependsOn copyNativeLibs } 
    
    clean.dependsOn 'cleanCopyNativeLibs' 
    
    tasks.withType(com.android.build.gradle.tasks.PackageApplication) { pkgTask -> 
        pkgTask.jniDir new File(buildDir, 'native-libs') 
    } 
    

Затем, когда я запускаю чистую и перестраиваю, он скопирует родные библиотеки в нужное место и включит их в сборку.

+0

Могу ли я передать vedio с помощью библиотеки Vitamio на Android-эмулятор Intel x86? –