我无法从https://github.com/yixia/VitamioBundle运行vitamio-sample。

我正在使用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项目拉到一个libraries文件夹中,并像这样引用它:
     compile(project(':libraries:vitamio'))

该示例项目保持原样。

最佳答案

我不确定较新版本的Vitamino(或gradle)是否有更清洁的方法。但是,这就是我如何使其与gradle构建工具0.6一起使用的方式。

  • 将一个项目添加到我的/ libraries目录中,并添加了Vitamino source / sdk。它具有一个/ libs / armeabi / libs / armeabi-v7a,其中包含libvinit.so。
  • 在我的主项目的build.gradle中,像这样引用库项目:
    dependencies {
    
        // other dependencies
    
        compile(project(':libraries:vitamio'))
    
    }
    
  • 将以下内容添加到我的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')
    }
    

  • 然后,当我运行干净并重建时,它将把本机libs复制到适当的位置,并将其包括在构建中。

    关于java - Vitamio示例错误-java.lang.UnsatisfiedLinkError:无法加载vinit findLibrary返回null,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/21289930/

    10-09 20:01