无法加载库libopencv_java.so

时间:2014-03-19 02:34:40

标签: android eclipse opencv android-ndk java-native-interface

我目前正面临某个原生编译问题。为了清楚起见,我已经完成了opencv-ndk配置而没有错误。事实上,我已经从源代码编译并执行了一些示例和教程。但是,当我尝试编译它时,它给出了一个错误,表明我在我的库中丢失了一些东西。以下是eclipse的日志文件。请注意,在eclipse项目中,我在obj-> local-> armeabi-v7a> objs目录下有libopencv_java.so。

03-19 10:14:11.142: D/dalvikvm(6360): Trying to load lib /data/app-lib/com.example.detectimage-2/libnative_sample.so 0x4141bc60
03-19 10:14:11.152: E/dalvikvm(6360): dlopen("/data/app-lib/com.example.detectimage-2/libnative_sample.so") failed: Cannot load library: soinfo_link_image(linker.cpp:1635): could not load library "libopencv_java.so" needed by "libnative_sample.so"; caused by load_library(linker.cpp:745): library "libopencv_java.so" not found
03-19 10:14:11.152: E/JNI(6360): WARNING: Could not load libmysharedlibrary.so
03-19 10:14:11.152: I/Sample::Activity(6360): Instantiated new class com.example.detectimage.DetectImageActivity
03-19 10:14:11.162: I/Sample::Activity(6360): onCreate
03-19 10:14:11.162: D/dalvikvm(6360): Trying to load lib /data/app-lib/com.example.detectimage-2/libnative_sample.so 0x4141bc60
03-19 10:14:11.162: E/dalvikvm(6360): dlopen("/data/app-lib/com.example.detectimage-2/libnative_sample.so") failed: Cannot load library: find_library(linker.cpp:889): "/data/app-lib/com.example.detectimage-2/libnative_sample.so" failed to load previously
03-19 10:14:11.162: W/dalvikvm(6360): Exception Ljava/lang/UnsatisfiedLinkError; thrown while initializing Lcom/example/detectimage/CameraPreview;
03-19 10:14:11.172: D/AndroidRuntime(6360): Shutting down VM
03-19 10:14:11.172: W/dalvikvm(6360): threadid=1: thread exiting with uncaught exception (group=0x40f06ae0)
03-19 10:14:11.182: E/AndroidRuntime(6360): FATAL EXCEPTION: main

如果您还需要我的Android.mk文件

LOCAL_PATH:= $(call my-dir)
include $(CLEAR_VARS)
OPENCV_INSTALL_MODULES:=on
OPENCV_CAMERA_MODULES:=off
include D:\Development\OpenCV-2.4.8-android-sdk\sdk\native\jni\OpenCV.mk

LOCAL_C_INCLUDES:= D:\Development\OpenCV-2.4.8-android-sdk\sdk\native\jni\include
LOCAL_MODULE    := native_sample
LOCAL_CFLAGS    := -Werror -O3 -ffast-math
LOCAL_LDLIBS    += -llog


LOCAL_SRC_FILES := jni_part.cpp
include $(BUILD_SHARED_LIBRARY)
坦率地说,我搜索了整个资源,并尝试了很多资源,但它无法运作。也许我是这个话题的新手,我无法遵循某些先进的解决方案。我希望我能在这里得到更好的理解。非常感谢你的帮助。

1 个答案:

答案 0 :(得分:0)

看起来这是一个运行时错误,并且您可以毫无问题地构建本机代码。 为了在.apk中包含任何必要的.so文件,您需要在要部署的项目的lib /子目录中使它们可用。

这可以像手动复制它们一样简单,但是ant应该足够聪明,可以为你复制它。如果它没有这样做,可能还有其他事情发生。

另一种方法是静态链接到OpenCV。 你可以在你自己的Android.mk中包含OpenCV.mk之前添加这一行:

OPENCV_LIB_TYPE :=STATIC

当然,这只是有意义的,如果您的OpenCV构建带有静态库(lib * .a)。 您会注意到,通过静态链接到OpenCV,您的.so文件的文件大小会略有增加,但不再需要打包libopencv_java.so。你的.so拥有OpenCV所需的一切。

总而言之,如果您的项目使用任何.so文件,请在.apk打包时将它们放在/ lib下,以便您的应用程序可以在启动/运行时找到它们。