【问题标题】:Unsatisfied Link Error when initializing Myo hub on Android在 Android 上初始化 Myo 集线器时出现不满意的链接错误
【发布时间】:2016-01-06 23:11:27
【问题描述】:

我正在开发一个使用Myo armband 的Android 应用程序。我想将其实现为可访问性服务,以便臂章检测到的手势可以,例如导航回家等。

我正在尝试初始化集线器,但应用因以下错误堆栈而停止:

01-06 23:42:41.222 11979-11979/eu.miko.myoid E/AndroidRuntime: FATAL EXCEPTION: main
                                                           Process: eu.miko.myoid, PID: 11979
                                                           java.lang.UnsatisfiedLinkError: dalvik.system.PathClassLoader[DexPathList[[zip file "/data/app/eu.miko.myoid-1/base.apk"],nativeLibraryDirectories=[/data/app/eu.miko.myoid-1/lib/arm, /vendor/lib, /system/lib]]] couldn't find "libgesture-classifier.so"
                                                               at java.lang.Runtime.loadLibrary(Runtime.java:367)
                                                               at java.lang.System.loadLibrary(System.java:1076)
                                                               at com.thalmic.myo.scanner.Scanner.<clinit>(Scanner.java:31)
                                                               at com.thalmic.myo.Hub.init(Hub.java:201)
                                                               at eu.miko.myoid.MyoidAccessibilityService.onCreate(MyoidAccessibilityService.java:21)
                                                               at android.app.ActivityThread.handleCreateService(ActivityThread.java:2877)
                                                               at android.app.ActivityThread.-wrap4(ActivityThread.java)
                                                               at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1427)
                                                               at android.os.Handler.dispatchMessage(Handler.java:102)
                                                               at android.os.Looper.loop(Looper.java:148)
                                                               at android.app.ActivityThread.main(ActivityThread.java:5417)
                                                               at java.lang.reflect.Method.invoke(Native Method)
                                                               at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:726)
                                                               at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:616)

根据 Myo 文档,这是我用于集线器初始化的代码。我已经尝试将它放在无障碍服务的 onCreate 和 onServiceConnected 方法中,无论如何都会出现错误。

    Hub hub = Hub.getInstance();
    if (hub.init(this, getPackageName())) {
        Intent intent = new Intent(this, ScanActivity.class);
        startActivity(intent);

        hub.setLockingPolicy(Hub.LockingPolicy.NONE);

        hub.addListener(mListener);
    }
    else {
        Log.e(TAG, "Could not initialize the Hub.");
    }

我正在使用最新的 Myo Android SDK。使用最新固件在 Nexus 5 上进行测试。

对我来说,这似乎是 SDK 内部的一个错误,但也许与我的配置有关?任何帮助将不胜感激。

SDK 中给出的示例似乎没有遇到同样的问题。

理论上是添加libgesture-classifier.so文件,通过以下方式:

  1. 我通过 build.gradle 文件将 Myo SDK 包含在项目中:

    dependencies {
        ...    
        repositories {
            maven {
                // this must point to the myorepository distributed with the Myo SDK
                url '../myorepository'
            }
        }
    compile('com.thalmic:myosdk:0.10.+@aar')
    }
    
  2. myorepository 包含 myosdk-0.10.0.aar。

  3. 当我将其作为 zip 检查时,其中包含 libs/native-libs.jar

  4. 当作为 zip 检查时,它又包含,每个都包含单个文件 libgesture-classifier.so

【问题讨论】:

  • 您是否将libgesture-classifier.so 文件添加到您的应用中?
  • 是的,请参阅问题中的编辑 :)
  • @user2363767:你找到合适的解决方案了吗?我手动将 .so 文件复制到 src/main/jniLibs 文件夹作为解决方法。
  • 不,我没有...但是解决方法确实有效,非常感谢! :)

标签: java android dalvik unsatisfiedlinkerror myo


【解决方案1】:

我可以通过切换回适用于 Android 的 gradle 插件的早期版本来解决此问题。 myosdk 中的本机库似乎有问题,它们没有被正确复制。

只需编辑项目中的 build.gradle 文件。 1.3.0 版对我有用。

// Top-level build file where you can add configuration options common to all sub-projects/modules.
buildscript {
    repositories {
        mavenCentral()
    }
    dependencies {
        **classpath 'com.android.tools.build:gradle:1.3.0'**
    }
}

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2015-03-07
    • 2011-12-29
    • 2016-04-26
    • 2014-03-26
    • 1970-01-01
    • 2019-12-22
    • 1970-01-01
    • 2012-04-22
    相关资源
    最近更新 更多