info library for OpenCV added.
This commit is contained in:
parent
b5ecb1d32d
commit
fc085d9dbd
@ -467,6 +467,10 @@ if(BUILD_ANDROID_PACKAGE)
|
|||||||
add_subdirectory(android/package)
|
add_subdirectory(android/package)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if (ANDROID AND NOT BUILD_ANDROID_SERVICE AND NOT BUILD_ANDROID_PACKAGE AND NOT BUILD_CAMERA_WRAPER)
|
||||||
|
add_subdirectory(android/libinfo)
|
||||||
|
endif()
|
||||||
|
|
||||||
# ----------------------------------------------------------------------------
|
# ----------------------------------------------------------------------------
|
||||||
# Finalization: generate configuration-based files
|
# Finalization: generate configuration-based files
|
||||||
# ----------------------------------------------------------------------------
|
# ----------------------------------------------------------------------------
|
||||||
|
39
android/libinfo/CMakeLists.txt
Normal file
39
android/libinfo/CMakeLists.txt
Normal file
@ -0,0 +1,39 @@
|
|||||||
|
project(libopencv_info)
|
||||||
|
if(NOT ANDROID_PACKAGE_RELEASE)
|
||||||
|
set(ANDROID_PACKAGE_RELEASE 1)
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if(NOT ANDROID_PACKAGE_PLATFORM)
|
||||||
|
if(ARMEABI_V7A)
|
||||||
|
if(NEON)
|
||||||
|
set(ANDROID_PACKAGE_PLATFORM armv7a_neon)
|
||||||
|
else()
|
||||||
|
set(ANDROID_PACKAGE_PLATFORM armv7a)
|
||||||
|
endif()
|
||||||
|
elseif(ARMEABI_V6)
|
||||||
|
set(ANDROID_PACKAGE_PLATFORM armv6)
|
||||||
|
elseif(ARMEABI)
|
||||||
|
set(ANDROID_PACKAGE_PLATFORM armv5)
|
||||||
|
elseif(X86)
|
||||||
|
set(ANDROID_PACKAGE_PLATFORM x86)
|
||||||
|
elseif(MIPS)
|
||||||
|
set(ANDROID_PACKAGE_PLATFORM mips)
|
||||||
|
else()
|
||||||
|
message(ERROR "Can not automatically determine the value for ANDROID_PACKAGE_PLATFORM")
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
add_definitions(-DANDROID_PACKAGE_RELEASE=${ANDROID_PACKAGE_RELEASE} -DANDROID_PACKAGE_PLATFORM="${ANDROID_PACKAGE_PLATFORM}")
|
||||||
|
|
||||||
|
include_directories(jni/BinderComponent jni/include "${OpenCV_SOURCE_DIR}/modules/core/include")
|
||||||
|
|
||||||
|
add_library(opencv_info SHARED info.c)
|
||||||
|
|
||||||
|
set_target_properties(${the_module} PROPERTIES
|
||||||
|
ARCHIVE_OUTPUT_DIRECTORY ${LIBRARY_OUTPUT_PATH}
|
||||||
|
RUNTIME_OUTPUT_DIRECTORY ${EXECUTABLE_OUTPUT_PATH}
|
||||||
|
INSTALL_NAME_DIR lib
|
||||||
|
)
|
||||||
|
|
||||||
|
get_filename_component(lib_name "opencv_info" NAME)
|
||||||
|
install(FILES "${LIBRARY_OUTPUT_PATH}/${lib_name}" DESTINATION ${OPENCV_LIB_INSTALL_PATH} COMPONENT main)
|
31
android/libinfo/info.c
Normal file
31
android/libinfo/info.c
Normal file
@ -0,0 +1,31 @@
|
|||||||
|
#include "opencv2/core/version.hpp"
|
||||||
|
#include <jni.h>
|
||||||
|
|
||||||
|
const char* GetPackageName(void);
|
||||||
|
const char* GetRevision(void);
|
||||||
|
const char* GetLibraryList(void);
|
||||||
|
JNIEXPORT jstring JNICALL Java_org_opencv_android_StaticHelper_getLibraryList(JNIEnv *, jclass);
|
||||||
|
|
||||||
|
#define PACKAGE_NAME "org.opencv.lib_v" CVAUX_STR(CV_MAJOR_VERSION) CVAUX_STR(CV_MINOR_VERSION) "_" ANDROID_PACKAGE_PLATFORM
|
||||||
|
#define PACKAGE_REVISION CVAUX_STR(CV_SUBMINOR_VERSION) CVAUX_STR(ANDROID_PACKAGE_RELEASE)
|
||||||
|
|
||||||
|
const char* GetPackageName(void)
|
||||||
|
{
|
||||||
|
return PACKAGE_NAME;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char* GetRevision(void)
|
||||||
|
{
|
||||||
|
return PACKAGE_REVISION;
|
||||||
|
}
|
||||||
|
|
||||||
|
const char* GetLibraryList(void)
|
||||||
|
{
|
||||||
|
return "";
|
||||||
|
}
|
||||||
|
|
||||||
|
JNIEXPORT jstring JNICALL Java_org_opencv_android_StaticHelper_getLibraryList(JNIEnv * env, jclass clazz)
|
||||||
|
{
|
||||||
|
(void)clazz;
|
||||||
|
return (*env)->NewStringUTF(env, GetLibraryList());
|
||||||
|
}
|
@ -130,7 +130,7 @@ android::String16 OpenCVEngine::GetLibraryList(android::String16 version)
|
|||||||
LOGD("Trying to load info library \"%s\"", tmp.c_str());
|
LOGD("Trying to load info library \"%s\"", tmp.c_str());
|
||||||
|
|
||||||
void* handle;
|
void* handle;
|
||||||
char* (*info_func)();
|
const char* (*info_func)();
|
||||||
|
|
||||||
handle = dlopen(tmp.c_str(), RTLD_LAZY);
|
handle = dlopen(tmp.c_str(), RTLD_LAZY);
|
||||||
if (handle)
|
if (handle)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user