android使用dragonSDK初始化连接报错

标签 android

我无法弄清楚这段代码出了什么问题。我正在为基于 ASR 的 Android 应用程序使用 Nuance 的 DragonSDK。我认为加载 lib 文件和初始化与服务器的连接存在一些问题。我检查了 libs 目录中存在的依赖项 (.jar) 文件。还检查了 lib 文件的 gradle 条目。

   06-29 10:33:35.326  31216-31216/com.ashwin.speechtotext E/IMGSRV﹕ :0: PVRDRMOpen: TP3, ret = 46
    06-29 10:33:35.336  31216-31216/com.ashwin.speechtotext E/IMGSRV﹕ :0: PVRDRMOpen: TP3, ret = 49
    06-29 10:33:35.336  31216-31216/com.ashwin.speechtotext E/IMGSRV﹕ :0: PVRDRMOpen: TP3, ret = 50
    06-29 10:33:35.336  31216-31216/com.ashwin.speechtotext E/IMGSRV﹕ :0: PVRDRMOpen: TP3, ret = 50
    06-29 10:33:35.336  31216-31216/com.ashwin.speechtotext E/IMGSRV﹕ :0: PVRDRMOpen: TP3, ret = 50
    06-29 10:33:35.346  31216-31216/com.ashwin.speechtotext E/IMGSRV﹕ :0: PVRDRMOpen: TP3, ret = 52
    06-29 10:33:41.136  31216-31502/com.ashwin.speechtotext E/NMSP﹕ [b] ANDROID_CONTEXT parameter is not passed in!!!
    06-29 10:33:41.146  31216-31502/com.ashwin.speechtotext E/NMSP﹕ [b] ANDROID_CONTEXT parameter is not passed in!!!
    06-29 10:33:44.426  31216-31502/com.ashwin.speechtotext E/NMSP﹕ [b] ANDROID_CONTEXT parameter is not passed in!!!
    06-29 10:33:44.426  31216-31502/com.ashwin.speechtotext E/NMSP﹕ [b] ANDROID_CONTEXT parameter is not passed in!!!
    06-29 10:33:44.436  31216-31500/com.ashwin.speechtotext E/SpeechKit﹕ Error creating recorder
        java.lang.UnsatisfiedLinkError: Couldn't load nmsp_sk_speex from loader dalvik.system.PathClassLoader[DexPathList[[zip file "/mnt/asec/com.ashwin.speechtotext-2/pkg.apk"],nativeLibraryDirectories=[/mnt/asec/com.ashwin.speechtotext-2/lib, /vendor/lib, /system/lib, /system/lib/arm]]]: findLibrary returned null
                at java.lang.Runtime.loadLibrary(Runtime.java:358)
                at java.lang.System.loadLibrary(System.java:526)
                at com.nuance.nmsp.client.sdk.oem.AudioSystemOEM.<clinit>(Unknown Source)
                at com.nuance.nmdp.speechkit.ce.<init>(Unknown Source)
                at com.nuance.nmdp.speechkit.bc.<init>(Unknown Source)
                at com.nuance.nmdp.speechkit.ah.n(Unknown Source)
                at com.nuance.nmdp.speechkit.aj.a(Unknown Source)
                at com.nuance.nmdp.speechkit.r.a(Unknown Source)
                at com.nuance.nmdp.speechkit.af.c(Unknown Source)
                at com.nuance.nmdp.speechkit.r.a(Unknown Source)
                at com.nuance.nmdp.speechkit.b.start(Unknown Source)
                at com.nuance.nmdp.speechkit.c$5.run(Unknown Source)
                at com.nuance.nmdp.speechkit.av$2.run(Unknown Source)
                at android.os.Handler.handleCallback(Handler.java:733)
                at android.os.Handler.dispatchMessage(Handler.java:95)
                at android.os.Looper.loop(Looper.java:149)
                at com.nuance.nmdp.speechkit.k.run(Unknown Source)
    06-29 10:33:44.436  31216-31500/com.ashwin.speechtotext E/SpeechKit﹕ Recorder error
    06-29 10:33:44.436  31216-31500/com.ashwin.speechtotext E/SpeechKit﹕ Can't stop recorder because it wasn't started
    06-29 10:33:44.446  31216-31500/com.ashwin.speechtotext E/SpeechKit﹕ Exception in application callback
        android.view.ViewRootImpl$CalledFromWrongThreadException: Only the original thread that created a view hierarchy can touch its views.
                at android.view.ViewRootImpl.checkThread(ViewRootImpl.java:6187)
                at android.view.ViewRootImpl.invalidateChildInParent(ViewRootImpl.java:877)
                at android.view.ViewGroup.invalidateChild(ViewGroup.java:4334)
                at android.view.View.invalidate(View.java:11192)
                at android.view.View.invalidate(View.java:11147)
                at android.widget.TextView.checkForRelayout(TextView.java:6688)
                at android.widget.TextView.setText(TextView.java:3908)
                at android.widget.TextView.setText(TextView.java:3766)
                at android.widget.TextView.setText(TextView.java:3741)
                at com.ashwin.speechtotext.Dictation$2.onError(Dictation.java:81)
                at com.nuance.nmdp.speechkit.c$3$1.run(Unknown Source)
                at com.nuance.nmdp.speechkit.i.a(Unknown Source)
                at com.nuance.nmdp.speechkit.c.a(Unknown Source)
                at com.nuance.nmdp.speechkit.c$3.onError(Unknown Source)
                at com.nuance.nmdp.speechkit.b$1.a(Unknown Source)
                at com.nuance.nmdp.speechkit.u$1.a(Unknown Source)
                at com.nuance.nmdp.speechkit.o.a(Unknown Source)
                at com.nuance.nmdp.speechkit.aa.a(Unknown Source)
                at com.nuance.nmdp.speechkit.r.a(Unknown Source)
                at com.nuance.nmdp.speechkit.ai.a(Unknown Source)
                at com.nuance.nmdp.speechkit.q.a(Unknown Source)
                at com.nuance.nmdp.speechkit.aj.g(Unknown Source)
                at com.nuance.nmdp.speechkit.ah$1$2.run(Unknown Source)
                at com.nuance.nmdp.speechkit.av$2.run(Unknown Source)
                at android.os.Handler.handleCallback(Handler.java:733)
                at android.os.Handler.dispatchMessage(Handler.java:95)
                at android.os.Looper.loop(Looper.java:149)
                at com.nuance.nmdp.speechkit.k.run(Unknown Source)
    06-29 10:33:44.446  31216-31500/com.ashwin.speechtotext E/SpeechKit﹕ Recorder error
    06-29 10:34:34.436  31216-31502/com.ashwin.speechtotext E/NMSP﹕ [bw] Session Idle for too long, longer than [50] ()
    06-29 10:34:34.436  31216-31503/com.ashwin.speechtotext E/NMSP﹕ [g] Socket Read/Available Expception - [java.net.SocketException] Message - [Socket closed]
    06-29 10:36:17.426  31216-31216/com.ashwin.speechtotext E/AndroidRuntime﹕ FATAL EXCEPTION: main
        Process: com.ashwin.speechtotext, PID: 31216
        java.lang.RuntimeException: Unable to destroy activity {com.ashwin.speechtotext/com.ashwin.speechtotext.Dictation}: java.lang.NullPointerException
                at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:3664)
                at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:3682)
                at android.app.ActivityThread.access$1400(ActivityThread.java:139)
                at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1346)
                at android.os.Handler.dispatchMessage(Handler.java:102)
                at android.os.Looper.loop(Looper.java:149)
                at android.app.ActivityThread.main(ActivityThread.java:5257)
                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:793)
                at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:609)
                at dalvik.system.NativeStart.main(Native Method)
         Caused by: java.lang.NullPointerException
                at com.ashwin.speechtotext.Dictation.onDestroy(Dictation.java:61)
                at android.app.Activity.performDestroy(Activity.java:5583)
                at android.app.Instrumentation.callActivityOnDestroy(Instrumentation.java:1117)
                at android.app.ActivityThread.performDestroyActivity(ActivityThread.java:3651)
                at android.app.ActivityThread.handleDestroyActivity(ActivityThread.java:3682)
                at android.app.ActivityThread.access$1400(ActivityThread.java:139)
                at android.app.ActivityThread$H.handleMessage(ActivityThread.java:1346)
                at android.os.Handler.dispatchMessage(Handler.java:102)
                at android.os.Looper.loop(Looper.java:149)
                at android.app.ActivityThread.main(ActivityThread.java:5257)
                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:793)
                at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:609)
                at dalvik.system.NativeStart.main(Native Method)
    device not found
        --------- beginning of /dev/log/system
    06-29 10:55:11.786    9101-9145/com.ashwin.speechtotext E/NMSP﹕ [b] ANDROID_CONTEXT parameter is not passed in!!!
    06-29 10:55:11.796    9101-9145/com.ashwin.speechtotext E/NMSP﹕ [b] ANDROID_CONTEXT parameter is not passed in!!!
    06-29 10:55:14.116    9101-9145/com.ashwin.speechtotext E/NMSP﹕ [b] ANDROID_CONTEXT parameter is not passed in!!!
    06-29 10:55:14.116    9101-9145/com.ashwin.speechtotext E/NMSP﹕ [b] ANDROID_CONTEXT parameter is not passed in!!!
    06-29 10:55:14.126    9101-9143/com.ashwin.speechtotext E/SpeechKit﹕ Error creating recorder
        java.lang.UnsatisfiedLinkError: Couldn't load nmsp_sk_speex from loader dalvik.system.PathClassLoader[DexPathList[[zip file "/mnt/asec/com.ashwin.speechtotext-1/pkg.apk"],nativeLibraryDirectories=[/mnt/asec/com.ashwin.speechtotext-1/lib, /vendor/lib, /system/lib, /system/lib/arm]]]: findLibrary returned null
                at java.lang.Runtime.loadLibrary(Runtime.java:358)
                at java.lang.System.loadLibrary(System.java:526)
                at com.nuance.nmsp.client.sdk.oem.AudioSystemOEM.<clinit>(Unknown Source)
                at com.nuance.nmdp.speechkit.ce.<init>(Unknown Source)
                at com.nuance.nmdp.speechkit.bc.<init>(Unknown Source)
                at com.nuance.nmdp.speechkit.ah.n(Unknown Source)
                at com.nuance.nmdp.speechkit.aj.a(Unknown Source)
                at com.nuance.nmdp.speechkit.r.a(Unknown Source)
                at com.nuance.nmdp.speechkit.af.c(Unknown Source)
                at com.nuance.nmdp.speechkit.r.a(Unknown Source)
                at com.nuance.nmdp.speechkit.b.start(Unknown Source)
                at com.nuance.nmdp.speechkit.c$5.run(Unknown Source)
                at com.nuance.nmdp.speechkit.av$2.run(Unknown Source)
                at android.os.Handler.handleCallback(Handler.java:733)
                at android.os.Handler.dispatchMessage(Handler.java:95)
                at android.os.Looper.loop(Looper.java:149)
                at com.nuance.nmdp.speechkit.k.run(Unknown Source)
    06-29 10:55:14.126    9101-9143/com.ashwin.speechtotext E/SpeechKit﹕ Recorder error
    06-29 10:55:14.126    9101-9143/com.ashwin.speechtotext E/SpeechKit﹕ Can't stop recorder because it wasn't started
    06-29 10:55:14.136    9101-9143/com.ashwin.speechtotext E/SpeechKit﹕ Exception in application callback
        android.view.ViewRootImpl$CalledFromWrongThreadException: Only the original thread that created a view hierarchy can touch its views.
                at android.view.ViewRootImpl.checkThread(ViewRootImpl.java:6187)
                at android.view.ViewRootImpl.invalidateChildInParent(ViewRootImpl.java:877)
                at android.view.ViewGroup.invalidateChild(ViewGroup.java:4334)
                at android.view.View.invalidate(View.java:11192)
                at android.view.View.invalidate(View.java:11147)
                at android.widget.TextView.checkForRelayout(TextView.java:6688)
                at android.widget.TextView.setText(TextView.java:3908)
                at android.widget.TextView.setText(TextView.java:3766)
                at android.widget.TextView.setText(TextView.java:3741)
                at com.ashwin.speechtotext.Dictation$2.onError(Dictation.java:81)
                at com.nuance.nmdp.speechkit.c$3$1.run(Unknown Source)
                at com.nuance.nmdp.speechkit.i.a(Unknown Source)
                at com.nuance.nmdp.speechkit.c.a(Unknown Source)
                at com.nuance.nmdp.speechkit.c$3.onError(Unknown Source)
                at com.nuance.nmdp.speechkit.b$1.a(Unknown Source)
                at com.nuance.nmdp.speechkit.u$1.a(Unknown Source)
                at com.nuance.nmdp.speechkit.o.a(Unknown Source)
                at com.nuance.nmdp.speechkit.aa.a(Unknown Source)
                at com.nuance.nmdp.speechkit.r.a(Unknown Source)
                at com.nuance.nmdp.speechkit.ai.a(Unknown Source)
                at com.nuance.nmdp.speechkit.q.a(Unknown Source)
                at com.nuance.nmdp.speechkit.aj.g(Unknown Source)
                at com.nuance.nmdp.speechkit.ah$1$2.run(Unknown Source)
                at com.nuance.nmdp.speechkit.av$2.run(Unknown Source)
                at android.os.Handler.handleCallback(Handler.java:733)
                at android.os.Handler.dispatchMessage(Handler.java:95)
                at android.os.Looper.loop(Looper.java:149)
                at com.nuance.nmdp.speechkit.k.run(Unknown Source)
    06-29 10:55:14.136    9101-9143/com.ashwin.speechtotext E/SpeechKit﹕ Recorder error

提前致谢。

最佳答案

看起来触发其他错误的是“未传入 ANDROID_CONTEXT 参数!!!”检查你的 SpeechKit.initialize 应该看起来像
SpeechKit.initialize(上下文, speechKitAppId, speechKit服务器, 语音套件端口, speechKitSSL, speechKitCert总结, speechKitCertData, speechKitApplicationKey);

http://dragonmobile.nuancemobiledeveloper.com/public/Help/DragonMobileSDKReference_Android/SpeechKit_Guide/ServerConnection.html

同时检查您是否拥有正确的权限:

 <uses-permission android:name="android.permission.WRITE_EXTERNAL_STORAGE" />
<uses-permission android:name="android.permission.RECORD_AUDIO" />
<uses-permission android:name="android.permission.INTERNET"/>
<uses-permission android:name="android.permission.ACCESS_NETWORK_STATE"/>
<uses-permission android:name="android.permission.READ_PHONE_STATE"/>

最后,检查库 libnmsp_sk_speex.so 是否添加到您的项目中

关于android使用dragonSDK初始化连接报错,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/31108445/

相关文章:

android - ListView 中的删除线文本?

javascript - 在物理 Android 设备上运行 Meteor 移动应用

java - 如何控制 okHttpClient 的连接大小?

java - 无法关闭间隔服务

android - Google Play 游戏,0x​​104567910 已弃用?

java - 我试图在屏幕上显示 CountDownTimer,但在 logcat 中得到 "Only one looper can be created per thread"

安卓 : Tab like toggling button selector instead of spinner

android - 铃声首选项未触发 onSharedPreferenceChanged

android - 使用 AccountManager 的 Gmail Imap 身份验证

java - 需要帮助获取安装在 Android 手机上的所有应用程序的列表