我有一个带有本机代码的Android应用程序,我使用openCV库。在手机中运行应用程序时一切正常,但是当我尝试在平板电脑上运行它时(联想yoga 2 pro)我遇到了这个错误:
01-03 11:53:13.007: E/AndroidRuntime(25632): FATAL EXCEPTION: main
01-03 11:53:13.007: E/AndroidRuntime(25632): Process: <appname>, PID: 25632
01-03 11:53:13.007: E/AndroidRuntime(25632): java.lang.UnsatisfiedLinkError: dlopen failed: "/data/app-lib/<appname>/libnative_module.so" has unexpected e_machine: 40
01-03 11:53:13.007: E/AndroidRuntime(25632): at java.lang.Runtime.loadLibrary(Runtime.java:364)
01-03 11:53:13.007: E/AndroidRuntime(25632): at java.lang.System.loadLibrary(System.java:526)
01-03 11:53:13.007: E/AndroidRuntime(25632): at <appname>.SplashActivity$1.onManagerConnected(SplashActivity.java:35)
01-03 11:53:13.007: E/AndroidRuntime(25632): at org.opencv.android.AsyncServiceHelper$1.onServiceConnected(AsyncServiceHelper.java:318)
01-03 11:53:13.007: E/AndroidRuntime(25632): at android.app.LoadedApk$ServiceDispatcher.doConnected(LoadedApk.java:1127)
01-03 11:53:13.007: E/AndroidRuntime(25632): at android.app.LoadedApk$ServiceDispatcher$RunConnection.run(LoadedApk.java:1144)
01-03 11:53:13.007: E/AndroidRuntime(25632): at android.os.Handler.handleCallback(Handler.java:733)
01-03 11:53:13.007: E/AndroidRuntime(25632): at android.os.Handler.dispatchMessage(Handler.java:95)
01-03 11:53:13.007: E/AndroidRuntime(25632): at android.os.Looper.loop(Looper.java:149)
01-03 11:53:13.007: E/AndroidRuntime(25632): at android.app.ActivityThread.main(ActivityThread.java:5283)
01-03 11:53:13.007: E/AndroidRuntime(25632): at java.lang.reflect.Method.invokeNative(Native Method)
01-03 11:53:13.007: E/AndroidRuntime(25632): at java.lang.reflect.Method.invoke(Method.java:515)
01-03 11:53:13.007: E/AndroidRuntime(25632): at com.android.internal.os.ZygoteInit$MethodAndArgsCaller.run(ZygoteInit.java:825)
01-03 11:53:13.007: E/AndroidRuntime(25632): at com.android.internal.os.ZygoteInit.main(ZygoteInit.java:641)
01-03 11:53:13.007: E/AndroidRuntime(25632): at dalvik.system.NativeStart.main(Native Method)
这是在SplashActivity的第45行:
System.loadLibrary("native_module");
有人可以帮我解决这个错误吗?或者我做错了什么?
答案 0 :(得分:4)
您的平板电脑基于Intel Atom CPU。您必须为APP_ABI=x86
构建 native_module 。请注意,您还需要兼容版本的OpenCV。
更新:在这种特殊情况下,该应用程序是为x86和ARM构建的。但是应用程序安装程序选择了错误的子文件夹,可能是因为libs/x86
和libs/armeabi
did not exactly match 中列出了文件名。对于具有非平凡本机组件的应用程序,可靠且有效的方法是upload separate APKs to PlayStore。
答案 1 :(得分:0)
我有一个华硕Zenfone 5(使用x86 ABI),我遇到了同样的问题。 显然问题出在 OpenCV 2.x 版本上。 开始使用OpenCV 3.x版本,问题将得到解决。
OpenCV 3.x 版本有更多 ABI 选项,例如:
arm64v8a
arm
armv7a
mips
mips64
x86
x86-64
您可以找到 3.x 版本here。
希望它有所帮助!