-
Notifications
You must be signed in to change notification settings - Fork 72
Expand file tree
/
Copy pathCMakeLists.txt
More file actions
69 lines (51 loc) · 2.49 KB
/
Copy pathCMakeLists.txt
File metadata and controls
69 lines (51 loc) · 2.49 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
# For more information about using CMake with Android Studio, read the
# documentation: https://d.android.com/studio/projects/add-native-code.html
# Sets the minimum version of CMake required to build the native library.
cmake_minimum_required(VERSION 3.18.1)
project("native-lib")
# Use OpenCV_DIR passed from gradle (via arguments in build.gradle)
# This eliminates the need for hardcoded paths and uses the opencvsdk gradle property
if(NOT DEFINED OpenCV_DIR)
message(FATAL_ERROR "OpenCV_DIR not set. Make sure it's passed from gradle build.gradle")
endif()
# Include OpenCV headers
include_directories(${OpenCV_DIR}/include)
# Add prebuilt OpenCV library
add_library(opencv_java4 SHARED IMPORTED)
set_target_properties(opencv_java4 PROPERTIES
IMPORTED_LOCATION ${OpenCV_DIR}/../libs/${ANDROID_ABI}/libopencv_java4.so)
# Creates and names a library, sets it as either STATIC
# or SHARED, and provides the relative paths to its source code.
# You can define multiple libraries, and CMake builds them for you.
# Gradle automatically packages shared libraries with your APK.
add_library( # Sets the name of the library.
native-lib
# Sets the library as a shared library.
SHARED
# Provides a relative path to your source file(s).
native-lib.cpp )
# Configure 16 KB page size compatibility
# Add linker flags for proper alignment to support 16 KB page sizes
set_target_properties(native-lib PROPERTIES
LINK_FLAGS "-Wl,-z,max-page-size=16384"
)
# Searches for a specified prebuilt library and stores the path as a
# variable. Because CMake includes system libraries in the search path by
# default, you only need to specify the name of the public NDK library
# you want to add. CMake verifies that the library exists before
# completing its build.
find_library( # Sets the name of the path variable.
log-lib
# Specifies the name of the NDK library that
# you want CMake to locate.
log )
# Specifies libraries CMake should link to your target library. You
# can link multiple libraries, such as libraries you define in this
# build script, prebuilt third-party libraries, or system libraries.
target_link_libraries( # Specifies the target library.
native-lib
# OpenCV
opencv_java4
# Links the target library to the log library
# included in the NDK.
${log-lib} )