Opencv Android: java.lang.UnsatisfiedLinkError: dlopen failed: could not load library "libopencv_java.so"

fat

UPDATES AT THE BOTTOM OF THE POST

I am trying to use OpenCV face recognizers on android and while i was able to wrap the c++ code i couldn't make it work on a Intel Atom avd. I'm not 100% sure but i think the cause of the error in the title is that i miss the libopencv_java.so in the /lib/x86 project directory.

Any thoughts why the lib is missing and how to get it work properly?

libopencv_java.so for x86 is missing

My Android.mk looks like:

LOCAL_PATH := $(call my-dir)

include $(CLEAR_VARS)
OPENCV_LIB_TYPE:=SHARED
include /home/fat/Scaricati/OpenCV-2.4.9-android-sdk/sdk/native/jni/OpenCV.mk

LOCAL_MODULE    := FaceDetectionPerformances
LOCAL_SRC_FILES := FaceDetectionPerformances.cpp
FILE_LIST_CPP := $(wildcard $(LOCAL_PATH)/*.cpp) # finds all cpp files
OPENCV_INSTALL_MODULES:=on


include $(BUILD_SHARED_LIBRARY)

While my Application.mk is

APP_STL := gnustl_static
APP_CPPFLAGS := -frtti -fexceptions
APP_ABI := x86 armeabi armeabi-v7a
APP_PLATFORM := android-8

The ndk-build log is

    18:32:16 **** Auto Build of configuration Default for project FaceDetectionPerformances ****
/home/fat/android-ndk-r9d/ndk-build NDK_DEBUG=1 all 
Android NDK: WARNING:jni/Android.mk:FaceDetectionPerformances: non-system libraries in linker flags: -lopencv_java    
Android NDK:     This is likely to result in incorrect builds. Try using LOCAL_STATIC_LIBRARIES    
Android NDK:     or LOCAL_SHARED_LIBRARIES instead to list the library dependencies of the    
Android NDK:     current module    
[x86] Gdbserver      : [x86-4.6] libs/x86/gdbserver
[x86] Gdbsetup       : libs/x86/gdb.setup
[armeabi] Gdbserver      : [arm-linux-androideabi-4.6] libs/armeabi/gdbserver
[armeabi] Gdbsetup       : libs/armeabi/gdb.setup
[armeabi-v7a] Gdbserver      : [arm-linux-androideabi-4.6] libs/armeabi-v7a/gdbserver
[armeabi-v7a] Gdbsetup       : libs/armeabi-v7a/gdb.setup
[x86] Compile++      : FaceDetectionPerformances <= FaceDetectionPerformances.cpp
[x86] SharedLibrary  : libFaceDetectionPerformances.so
[x86] Install        : libFaceDetectionPerformances.so => libs/x86/libFaceDetectionPerformances.so
[armeabi] Compile++ thumb: FaceDetectionPerformances <= FaceDetectionPerformances.cpp
[armeabi] SharedLibrary  : libFaceDetectionPerformances.so
[armeabi] Install        : libFaceDetectionPerformances.so => libs/armeabi/libFaceDetectionPerformances.so
[armeabi] Install        : libopencv_java.so => libs/armeabi/libopencv_java.so
[armeabi-v7a] Compile++ thumb: FaceDetectionPerformances <= FaceDetectionPerformances.cpp
[armeabi-v7a] SharedLibrary  : libFaceDetectionPerformances.so
/home/fat/android-ndk-r9d/toolchains/arm-linux-androideabi-4.6/prebuilt/linux-x86_64/bin/../lib/gcc/arm-linux-androideabi/4.6/../../../../arm-linux-androideabi/bin/ld: warning: hidden symbol '__aeabi_atexit' in /home/fat/android-ndk-r9d/sources/cxx-stl/gnu-libstdc++/4.6/libs/armeabi-v7a/libgnustl_static.a(atexit_arm.o) is referenced by DSO ./obj/local/armeabi-v7a/libopencv_java.so
[armeabi-v7a] Install        : libFaceDetectionPerformances.so => libs/armeabi-v7a/libFaceDetectionPerformances.so
[armeabi-v7a] Install        : libopencv_java.so => libs/armeabi-v7a/libopencv_java.so

1

8:32:37 Build Finished (took 20s.952ms)

UPDATE 1 The opencvAndroidSdk package provides the shared library libopencv_java for the x86 arch, but ndk will not move it to the libs/x86 directory at build time, while it does for armeabi arch. I also tried to move it manually from /OpenCV-2.4.9-android-sdk/sdk/native/libs/x86/libopencv_java.so to the /libs/x86 project subdirectory, but when i build the project, ndk deletes the file.

fat

After some research, i managed to solve my problem. Apparently the APP_PLATFORM android-8 is not compatible with x86 android-opencv libs. So i just targeted android-9 and it worked.

Collected from the Internet

Please contact [email protected] to delete if infringement.

edited at
0

Comments

0 comments
Login to comment

Related

From Dev

Opencv Android: java.lang.UnsatisfiedLinkError: dlopen failed: could not load library "libopencv_java.so"

From Dev

Android M crash java.lang.UnsatisfiedLinkError: dlopen failed:

From Dev

java.lang.UnsatisfiedLinkError: Cannot load library

From Dev

java.lang.UnsatisfiedLinkError: Cannot load library

From Dev

Android NDK : Getting java.lang.UnsatisfiedLinkError: dlopen failed: cannot locate symbol "signal" referenced by "libffmpeg.so"

From Dev

Android ReactNative java.lang.UnsatisfiedLinkError:could find DSO to load: libreactnativejni.so

From Dev

OpenCV java.lang.UnsatisfiedLinkError

From Dev

FATAL EXCEPTION: main java.lang.UnsatisfiedLinkError in Android Studio library

From Dev

java.lang.UnsatisfiedLinkError when loading native library in Android 5.0

From Dev

Android NDK UnsatisfiedLinkError: "dlopen failed: empty/missing DT_HASH"

From Dev

Google OR-Tools: Could not run the java example, java.lang.UnsatisfiedLinkError: no jniortools in java.library.path

From Dev

Android - dlopen failed: file offset for the library

From Dev

java.lang.UnsatisfiedLinkError: no opencv_java2411 in java.library.path

From Dev

java.lang.UnsatisfiedLinkError: no opencv_java300 in java.library.path only while testing

From Dev

"Java.lang.UnsatisfiedLinkError: no opencv_java320 in java.library.path"

From Dev

Exception in thread "main" java.lang.UnsatisfiedLinkError: no opencv_java2410 in java.library.path

From Dev

java.lang.UnsatisfiedLinkError: no opencv_java300 in java.library.path only while testing

From Dev

Android ndk and dynamic load library with dlopen

From Dev

Android ndk and dynamic load library with dlopen

From Dev

Tess4j : java.lang.UnsatisfiedLinkError: Unable to load library

From Dev

Tess4j : java.lang.UnsatisfiedLinkError: Unable to load library

From Dev

QT Android UnsatisfiedLinkError Cannot load library

From Dev

OCR implementation error-java.lang.UnsatisfiedLinkError: dlopen failed: cannot locate symbol "png_set_longjmp_fn" referenced by "liblept.so"

From Dev

Android - Scandit - java.lang.UnsatisfiedLinkError

From Dev

java.lang.UnsatisfiedLinkError error in android

From Dev

java.lang.UnsatisfiedLinkError error in android

From Dev

java.lang.UnsatisfiedLinkError: The specified module could not be found

From Dev

Getting 'java.lang.UnsatisfiedLinkError': no lwjgl in java.library.path

From Dev

java.lang.UnsatisfiedLinkError: no JCfiLib in java.library.path

Related Related

  1. 1

    Opencv Android: java.lang.UnsatisfiedLinkError: dlopen failed: could not load library "libopencv_java.so"

  2. 2

    Android M crash java.lang.UnsatisfiedLinkError: dlopen failed:

  3. 3

    java.lang.UnsatisfiedLinkError: Cannot load library

  4. 4

    java.lang.UnsatisfiedLinkError: Cannot load library

  5. 5

    Android NDK : Getting java.lang.UnsatisfiedLinkError: dlopen failed: cannot locate symbol "signal" referenced by "libffmpeg.so"

  6. 6

    Android ReactNative java.lang.UnsatisfiedLinkError:could find DSO to load: libreactnativejni.so

  7. 7

    OpenCV java.lang.UnsatisfiedLinkError

  8. 8

    FATAL EXCEPTION: main java.lang.UnsatisfiedLinkError in Android Studio library

  9. 9

    java.lang.UnsatisfiedLinkError when loading native library in Android 5.0

  10. 10

    Android NDK UnsatisfiedLinkError: "dlopen failed: empty/missing DT_HASH"

  11. 11

    Google OR-Tools: Could not run the java example, java.lang.UnsatisfiedLinkError: no jniortools in java.library.path

  12. 12

    Android - dlopen failed: file offset for the library

  13. 13

    java.lang.UnsatisfiedLinkError: no opencv_java2411 in java.library.path

  14. 14

    java.lang.UnsatisfiedLinkError: no opencv_java300 in java.library.path only while testing

  15. 15

    "Java.lang.UnsatisfiedLinkError: no opencv_java320 in java.library.path"

  16. 16

    Exception in thread "main" java.lang.UnsatisfiedLinkError: no opencv_java2410 in java.library.path

  17. 17

    java.lang.UnsatisfiedLinkError: no opencv_java300 in java.library.path only while testing

  18. 18

    Android ndk and dynamic load library with dlopen

  19. 19

    Android ndk and dynamic load library with dlopen

  20. 20

    Tess4j : java.lang.UnsatisfiedLinkError: Unable to load library

  21. 21

    Tess4j : java.lang.UnsatisfiedLinkError: Unable to load library

  22. 22

    QT Android UnsatisfiedLinkError Cannot load library

  23. 23

    OCR implementation error-java.lang.UnsatisfiedLinkError: dlopen failed: cannot locate symbol "png_set_longjmp_fn" referenced by "liblept.so"

  24. 24

    Android - Scandit - java.lang.UnsatisfiedLinkError

  25. 25

    java.lang.UnsatisfiedLinkError error in android

  26. 26

    java.lang.UnsatisfiedLinkError error in android

  27. 27

    java.lang.UnsatisfiedLinkError: The specified module could not be found

  28. 28

    Getting 'java.lang.UnsatisfiedLinkError': no lwjgl in java.library.path

  29. 29

    java.lang.UnsatisfiedLinkError: no JCfiLib in java.library.path

HotTag

Archive