Android cmake toolchain file is included into OpenCV
This commit is contained in:
parent
ce2edd137d
commit
727fbd5376
@ -446,6 +446,7 @@ if(UNIX)
|
|||||||
set(HAVE_XINE FALSE)
|
set(HAVE_XINE FALSE)
|
||||||
endif()
|
endif()
|
||||||
if(WITH_V4L)
|
if(WITH_V4L)
|
||||||
|
|
||||||
CHECK_MODULE(libv4l1 HAVE_LIBV4L)
|
CHECK_MODULE(libv4l1 HAVE_LIBV4L)
|
||||||
CHECK_INCLUDE_FILE(linux/videodev.h HAVE_CAMV4L)
|
CHECK_INCLUDE_FILE(linux/videodev.h HAVE_CAMV4L)
|
||||||
CHECK_INCLUDE_FILE(linux/videodev2.h HAVE_CAMV4L2)
|
CHECK_INCLUDE_FILE(linux/videodev2.h HAVE_CAMV4L2)
|
||||||
|
@ -57,7 +57,7 @@ if(NOT ANDROID)
|
|||||||
set(OPENCV_LIB_COMPONENTS opencv_core opencv_imgproc opencv_features2d opencv_gpu opencv_calib3d opencv_objdetect opencv_video opencv_highgui opencv_ml opencv_legacy opencv_contrib opencv_flann)
|
set(OPENCV_LIB_COMPONENTS opencv_core opencv_imgproc opencv_features2d opencv_gpu opencv_calib3d opencv_objdetect opencv_video opencv_highgui opencv_ml opencv_legacy opencv_contrib opencv_flann)
|
||||||
else()
|
else()
|
||||||
#libraries order is very important because linker from Android NDK is one-pass linker
|
#libraries order is very important because linker from Android NDK is one-pass linker
|
||||||
set(OPENCV_LIB_COMPONENTS opencv_calib3d opencv_objdetect opencv_features2d opencv_imgproc opencv_video opencv_highgui opencv_ml opencv_legacy opencv_flann opencv_core )
|
set(OPENCV_LIB_COMPONENTS opencv_contrib opencv_calib3d opencv_objdetect opencv_features2d opencv_imgproc opencv_video opencv_highgui opencv_ml opencv_legacy opencv_flann opencv_core )
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
SET(OpenCV_LIBS "")
|
SET(OpenCV_LIBS "")
|
||||||
|
@ -22,6 +22,9 @@ macro(define_opencv_module name)
|
|||||||
|
|
||||||
file(GLOB lib_srcs "src/*.cpp")
|
file(GLOB lib_srcs "src/*.cpp")
|
||||||
file(GLOB lib_int_hdrs "src/*.h*")
|
file(GLOB lib_int_hdrs "src/*.h*")
|
||||||
|
if(COMMAND get_module_external_sources)
|
||||||
|
get_module_external_sources(${name})
|
||||||
|
endif()
|
||||||
source_group("Src" FILES ${lib_srcs} ${lib_int_hdrs})
|
source_group("Src" FILES ${lib_srcs} ${lib_int_hdrs})
|
||||||
|
|
||||||
file(GLOB lib_hdrs "include/opencv2/${name}/*.h*")
|
file(GLOB lib_hdrs "include/opencv2/${name}/*.h*")
|
||||||
|
@ -89,19 +89,19 @@ set(WITH_V4L OFF CACHE BOOL "" )
|
|||||||
set(WITH_XINE OFF CACHE BOOL "" )
|
set(WITH_XINE OFF CACHE BOOL "" )
|
||||||
|
|
||||||
#Enable SSE instructions
|
#Enable SSE instructions
|
||||||
SET( ENABLE_SSE OFF CACHE BOOL "" )
|
SET( ENABLE_SSE OFF CACHE INTERNAL "" FORCE )
|
||||||
|
|
||||||
#Enable SSE2 instructions
|
#Enable SSE2 instructions
|
||||||
SET( ENABLE_SSE2 OFF CACHE BOOL "" )
|
SET( ENABLE_SSE2 OFF CACHE INTERNAL "" FORCE )
|
||||||
|
|
||||||
#Enable SSE3 instructions
|
#Enable SSE3 instructions
|
||||||
SET( ENABLE_SSE3 OFF CACHE BOOL "" )
|
SET( ENABLE_SSE3 OFF CACHE INTERNAL "" FORCE )
|
||||||
|
|
||||||
#Enable SSE4.1 instructions
|
#Enable SSE4.1 instructions
|
||||||
SET( ENABLE_SSE41 OFF CACHE BOOL "" )
|
SET( ENABLE_SSE41 OFF CACHE INTERNAL "" FORCE )
|
||||||
|
|
||||||
#Enable SSE4.2 instructions
|
#Enable SSE4.2 instructions
|
||||||
SET( ENABLE_SSE42 OFF CACHE BOOL "" )
|
SET( ENABLE_SSE42 OFF CACHE INTERNAL "" FORCE )
|
||||||
|
|
||||||
#Enable SSSE3 instructions
|
#Enable SSSE3 instructions
|
||||||
SET( ENABLE_SSSE3 OFF CACHE BOOL "" )
|
SET( ENABLE_SSSE3 OFF CACHE INTERNAL "" FORCE )
|
||||||
|
353
android/android.toolchain.cmake
Normal file
353
android/android.toolchain.cmake
Normal file
@ -0,0 +1,353 @@
|
|||||||
|
# ----------------------------------------------------------------------------
|
||||||
|
# Android CMake toolchain file, for use with the ndk r5
|
||||||
|
# See home page: http://code.google.com/p/android-cmake/
|
||||||
|
#
|
||||||
|
# Usage Linux:
|
||||||
|
# $ export ANDROID_NDK=/<absolute path to NDK>
|
||||||
|
# $ cmake -DCMAKE_TOOLCHAIN_FILE=<path to this file>/android.toolchain.cmake ..
|
||||||
|
# $ make
|
||||||
|
#
|
||||||
|
# Usage Linux (using standalone toolchain):
|
||||||
|
# $ export ANDROID_NDK_TOOLCHAIN_ROOT=/<absolute path to standalone toolchain>
|
||||||
|
# $ cmake -DCMAKE_TOOLCHAIN_FILE=<path to this file>/android.toolchain.cmake ..
|
||||||
|
# $ make
|
||||||
|
#
|
||||||
|
# Usage Windows:
|
||||||
|
# You need native port of make to build your project.
|
||||||
|
# For example this one: http://gnuwin32.sourceforge.net/packages/make.htm
|
||||||
|
#
|
||||||
|
# $ SET ANDROID_NDK=C:\<absolute path to NDK>\android-ndk-r5b
|
||||||
|
# $ cmake.exe -G"Unix Makefiles" -DCMAKE_TOOLCHAIN_FILE=<path to this file>\android.toolchain.cmake -DCMAKE_MAKE_PROGRAM=C:\<absolute path to make>\make.exe ..
|
||||||
|
# $ C:\<absolute path to make>\make.exe
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# Toolchain options (can be set as cmake parameters: -D<option_name>=<value>):
|
||||||
|
# ANDROID_NDK=/opt/android-ndk-r5b - path to NDK root.
|
||||||
|
# Can be set as environment variable.
|
||||||
|
#
|
||||||
|
# ANDROID_NDK_TOOLCHAIN_ROOT=/opt/android-toolchain - path to standalone toolchain.
|
||||||
|
# Option is not used if full NDK is found. Can be set as environment variable.
|
||||||
|
#
|
||||||
|
# ANDROID_API_LEVEL=android-8 - level of android API to use.
|
||||||
|
# Option is ignored when build uses stanalone toolchain.
|
||||||
|
#
|
||||||
|
# ARM_TARGET=armeabi-v7a - type of floating point support.
|
||||||
|
# Other possible values are: "armeabi", "armeabi-v7a with NEON", "armeabi-v7a with VFPV3"
|
||||||
|
#
|
||||||
|
# FORCE_ARM=false - set true to generate 32-bit ARM instructions instead of Thumb-1.
|
||||||
|
#
|
||||||
|
# NO_UNDEFINED=true - set true to show all undefined symbols will as linker errors even if they are not used.
|
||||||
|
#
|
||||||
|
# NO_SWIG=false - set true to disable SWIG package
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# Toolcahin will search for NDK/toolchain in following order:
|
||||||
|
# ANDROID_NDK - cmake parameter
|
||||||
|
# ANDROID_NDK - environment variable
|
||||||
|
# ANDROID_NDK - default location
|
||||||
|
# ANDROID_NDK_TOOLCHAIN_ROOT - cmake parameter
|
||||||
|
# ANDROID_NDK_TOOLCHAIN_ROOT - environment variable
|
||||||
|
# ANDROID_NDK_TOOLCHAIN_ROOT - default location
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# What?:
|
||||||
|
# Make sure to do the following in your scripts:
|
||||||
|
# SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} ${my_cxx_flags}")
|
||||||
|
# SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} ${my_cxx_flags}")
|
||||||
|
# The flags will be prepopulated with critical flags, so don't loose them.
|
||||||
|
#
|
||||||
|
# ANDROID and BUILD_ANDROID will be set to true, you may test these
|
||||||
|
# variables to make necessary changes.
|
||||||
|
#
|
||||||
|
# Also ARMEABI and ARMEABI_V7A will be set true, mutually exclusive. V7A is
|
||||||
|
# for floating point. NEON option will be set true if fpu is set to neon.
|
||||||
|
#
|
||||||
|
# LIBRARY_OUTPUT_PATH_ROOT should be set in cache to determine where android
|
||||||
|
# libraries will be installed.
|
||||||
|
# default is ${CMAKE_SOURCE_DIR} , and the android libs will always be
|
||||||
|
# under ${LIBRARY_OUTPUT_PATH_ROOT}/libs/armeabi* depending on target.
|
||||||
|
# this will be convenient for android linking
|
||||||
|
#
|
||||||
|
# Base system is Linux, but you may need to change things
|
||||||
|
# for android compatibility.
|
||||||
|
#
|
||||||
|
#
|
||||||
|
# - initial version December 2010 Ethan Rublee ethan.ruble@gmail.com
|
||||||
|
# - modified April 2011 Andrey Kamaev andrey.kamaev@itseez.com
|
||||||
|
# [+] added possibility to build with NDK (without standalone toolchain)
|
||||||
|
# [+] support croos compilation on Windows (native, no cygwin support)
|
||||||
|
# [+] added compiler option to force "char" type to be signed
|
||||||
|
# [+] added toolchain option to compile to 32-bit ARM instructions
|
||||||
|
# [+] added toolchain option to disable SWIG search
|
||||||
|
# [+] added platform "armeabi-v7a with VFPV3"
|
||||||
|
# [~] ARM_TARGETS renamed to ARM_TARGET
|
||||||
|
# - modified April 2011 Andrey Kamaev andrey.kamaev@itseez.com
|
||||||
|
# [+] EXECUTABLE_OUTPUT_PATH is set by toolchain (required on Windows)
|
||||||
|
# [~] Fixed bug with ANDROID_API_LEVEL variable
|
||||||
|
# [~] turn off SWIG search if it is not found first time
|
||||||
|
# - modified May 2011 Andrey Kamaev andrey.kamaev@itseez.com
|
||||||
|
# [~] ANDROID_LEVEL is renamed to ANDROID_API_LEVEL
|
||||||
|
# [+] ANDROID_API_LEVEL is detected by toolchain if not specified
|
||||||
|
# [~] added guard to prevent changing of output directories on first cmake pass
|
||||||
|
# [~] toolchain exits with error if ARM_TARGET is not recognized
|
||||||
|
# ----------------------------------------------------------------------------
|
||||||
|
|
||||||
|
# this one is important
|
||||||
|
set( CMAKE_SYSTEM_NAME Linux )
|
||||||
|
#this one not so much
|
||||||
|
set( CMAKE_SYSTEM_VERSION 1 )
|
||||||
|
|
||||||
|
set( ANDROID_NDK_DEFAULT_SEARCH_PATH /opt/android-ndk-r5b )
|
||||||
|
set( ANDROID_NDK_TOOLCHAIN_DEFAULT_SEARCH_PATH /opt/android-toolchain )
|
||||||
|
set( TOOL_OS_SUFFIX "" )
|
||||||
|
|
||||||
|
macro( __TOOLCHAIN_DETECT_API_LEVEL _path _expected)
|
||||||
|
if( NOT EXISTS ${_path} )
|
||||||
|
message( FATAL_ERROR "Could not verify Android API level. Probably you have specified invalid level value, or your copy of NDK/toolchain is broken." )
|
||||||
|
endif()
|
||||||
|
SET( API_LEVEL_REGEX "^[\t ]*#define[\t ]+__ANDROID_API__[\t ]+([0-9]+)[\t ]*$" )
|
||||||
|
FILE( STRINGS ${_path} API_FILE_CONTENT REGEX "${API_LEVEL_REGEX}")
|
||||||
|
if( NOT API_FILE_CONTENT )
|
||||||
|
message( FATAL_ERROR "Could not verify Android API level. Probably you have specified invalid level value, or your copy of NDK/toolchain is broken." )
|
||||||
|
endif()
|
||||||
|
string( REGEX REPLACE "${API_LEVEL_REGEX}" "\\1" ANDROID_LEVEL_FOUND "${API_FILE_CONTENT}" )
|
||||||
|
if( NOT "${_expected}" STREQUAL "" )
|
||||||
|
if( NOT ${ANDROID_LEVEL_FOUND} EQUAL ${_expected} )
|
||||||
|
message( FATAL_ERROR "Specified Android API level does not match level found. Probably your copy of NDK/toolchain is broken." )
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
set( ANDROID_API_LEVEL ${ANDROID_LEVEL_FOUND} CACHE STRING "android API level" FORCE )
|
||||||
|
endmacro()
|
||||||
|
|
||||||
|
#set path for android NDK -- look
|
||||||
|
if( NOT DEFINED ANDROID_NDK )
|
||||||
|
set( ANDROID_NDK $ENV{ANDROID_NDK} )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if( NOT EXISTS ${ANDROID_NDK} )
|
||||||
|
if( EXISTS ${ANDROID_NDK_DEFAULT_SEARCH_PATH} )
|
||||||
|
set ( ANDROID_NDK ${ANDROID_NDK_DEFAULT_SEARCH_PATH} )
|
||||||
|
message( STATUS "Using default path for android NDK ${ANDROID_NDK}" )
|
||||||
|
message( STATUS "If you prefer to use a different location, please define the environment variable: ANDROID_NDK" )
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if( EXISTS ${ANDROID_NDK} )
|
||||||
|
set( ANDROID_NDK ${ANDROID_NDK} CACHE PATH "root of the android ndk" FORCE )
|
||||||
|
|
||||||
|
if( APPLE )
|
||||||
|
set( NDKSYSTEM "darwin-x86" )
|
||||||
|
elseif( WIN32 )
|
||||||
|
set( NDKSYSTEM "windows" )
|
||||||
|
set( TOOL_OS_SUFFIX ".exe" )
|
||||||
|
elseif( UNIX )
|
||||||
|
set( NDKSYSTEM "linux-x86" )
|
||||||
|
else()
|
||||||
|
message( FATAL_ERROR "Your platform is not supported" )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set( ANDROID_API_LEVEL $ENV{ANDROID_API_LEVEL} )
|
||||||
|
string( REGEX REPLACE "android-([0-9]+)" "\\1" ANDROID_API_LEVEL "${ANDROID_API_LEVEL}" )
|
||||||
|
|
||||||
|
set( PossibleAndroidLevels "3;4;5;8;9" )
|
||||||
|
set( ANDROID_API_LEVEL ${ANDROID_API_LEVEL} CACHE STRING "android API level" )
|
||||||
|
set_property( CACHE ANDROID_API_LEVEL PROPERTY STRINGS ${PossibleAndroidLevels} )
|
||||||
|
|
||||||
|
if( NOT ANDROID_API_LEVEL GREATER 2 )
|
||||||
|
set( ANDROID_API_LEVEL 8 )
|
||||||
|
message( STATUS "Using default android API level android-${ANDROID_API_LEVEL}" )
|
||||||
|
message( STATUS "If you prefer to use a different API level, please define the environment variable: ANDROID_API_LEVEL" )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set( ANDROID_NDK_TOOLCHAIN_ROOT "${ANDROID_NDK}/toolchains/arm-linux-androideabi-4.4.3/prebuilt/${NDKSYSTEM}" )
|
||||||
|
set( ANDROID_NDK_SYSROOT "${ANDROID_NDK}/platforms/android-${ANDROID_API_LEVEL}/arch-arm/" )
|
||||||
|
|
||||||
|
__TOOLCHAIN_DETECT_API_LEVEL( "${ANDROID_NDK_SYSROOT}/usr/include/android/api-level.h" ${ANDROID_API_LEVEL} )
|
||||||
|
|
||||||
|
#message( STATUS "Using android NDK from ${ANDROID_NDK}" )
|
||||||
|
set( BUILD_WITH_ANDROID_NDK True )
|
||||||
|
else()
|
||||||
|
#try to find toolchain
|
||||||
|
if( NOT DEFINED ANDROID_NDK_TOOLCHAIN_ROOT )
|
||||||
|
set( ANDROID_NDK_TOOLCHAIN_ROOT $ENV{ANDROID_NDK_TOOLCHAIN_ROOT} )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if( NOT EXISTS ${ANDROID_NDK_TOOLCHAIN_ROOT} )
|
||||||
|
set( ANDROID_NDK_TOOLCHAIN_ROOT ${ANDROID_NDK_TOOLCHAIN_DEFAULT_SEARCH_PATH} )
|
||||||
|
message( STATUS "Using default path for toolchain ${ANDROID_NDK_TOOLCHAIN_ROOT}" )
|
||||||
|
message( STATUS "If you prefer to use a different location, please define the environment variable: ANDROID_NDK_TOOLCHAIN_ROOT" )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set( ANDROID_NDK_TOOLCHAIN_ROOT ${ANDROID_NDK_TOOLCHAIN_ROOT} CACHE PATH "root of the Android NDK standalone toolchain" FORCE )
|
||||||
|
|
||||||
|
if( NOT EXISTS ${ANDROID_NDK_TOOLCHAIN_ROOT} )
|
||||||
|
message( FATAL_ERROR "neither ${ANDROID_NDK} nor ${ANDROID_NDK_TOOLCHAIN_ROOT} does not exist!
|
||||||
|
You should either set an environment variable:
|
||||||
|
export ANDROID_NDK=~/my-android-ndk
|
||||||
|
or
|
||||||
|
export ANDROID_NDK_TOOLCHAIN_ROOT=~/my-android-toolchain
|
||||||
|
or put the toolchain or NDK in the default path:
|
||||||
|
sudo ln -s ~/my-android-ndk ${ANDROID_NDK_DEFAULT_SEARCH_PATH}
|
||||||
|
sudo ln -s ~/my-android-toolchain ${ANDROID_NDK_TOOLCHAIN_DEFAULT_SEARCH_PATH}" )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
__TOOLCHAIN_DETECT_API_LEVEL( "${ANDROID_NDK_TOOLCHAIN_ROOT}/include/android/api-level.h" )
|
||||||
|
|
||||||
|
#message( STATUS "Using android NDK standalone toolchain from ${ANDROID_NDK_TOOLCHAIN_ROOT}" )
|
||||||
|
set( BUILD_WITH_ANDROID_NDK_TOOLCHAIN True )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# specify the cross compiler
|
||||||
|
set( CMAKE_C_COMPILER ${ANDROID_NDK_TOOLCHAIN_ROOT}/bin/arm-linux-androideabi-gcc${TOOL_OS_SUFFIX} CACHE PATH "gcc" FORCE )
|
||||||
|
set( CMAKE_CXX_COMPILER ${ANDROID_NDK_TOOLCHAIN_ROOT}/bin/arm-linux-androideabi-g++${TOOL_OS_SUFFIX} CACHE PATH "g++" FORCE )
|
||||||
|
#there may be a way to make cmake deduce these TODO deduce the rest of the tools
|
||||||
|
set( CMAKE_AR ${ANDROID_NDK_TOOLCHAIN_ROOT}/bin/arm-linux-androideabi-ar${TOOL_OS_SUFFIX} CACHE PATH "archive" FORCE )
|
||||||
|
set( CMAKE_LINKER ${ANDROID_NDK_TOOLCHAIN_ROOT}/bin/arm-linux-androideabi-ld${TOOL_OS_SUFFIX} CACHE PATH "linker" FORCE )
|
||||||
|
set( CMAKE_NM ${ANDROID_NDK_TOOLCHAIN_ROOT}/bin/arm-linux-androideabi-nm${TOOL_OS_SUFFIX} CACHE PATH "nm" FORCE )
|
||||||
|
set( CMAKE_OBJCOPY ${ANDROID_NDK_TOOLCHAIN_ROOT}/bin/arm-linux-androideabi-objcopy${TOOL_OS_SUFFIX} CACHE PATH "objcopy" FORCE )
|
||||||
|
set( CMAKE_OBJDUMP ${ANDROID_NDK_TOOLCHAIN_ROOT}/bin/arm-linux-androideabi-objdump${TOOL_OS_SUFFIX} CACHE PATH "objdump" FORCE )
|
||||||
|
set( CMAKE_STRIP ${ANDROID_NDK_TOOLCHAIN_ROOT}/bin/arm-linux-androideabi-strip${TOOL_OS_SUFFIX} CACHE PATH "strip" FORCE )
|
||||||
|
set( CMAKE_RANLIB ${ANDROID_NDK_TOOLCHAIN_ROOT}/bin/arm-linux-androideabi-ranlib${TOOL_OS_SUFFIX} CACHE PATH "ranlib" FORCE )
|
||||||
|
|
||||||
|
#setup build targets, mutually exclusive
|
||||||
|
set( PossibleArmTargets "armeabi;armeabi-v7a;armeabi-v7a with NEON;armeabi-v7a with VFPV3" )
|
||||||
|
set( ARM_TARGET "armeabi-v7a" CACHE STRING "the arm target for android, recommend armeabi-v7a for floating point support and NEON." )
|
||||||
|
set_property( CACHE ARM_TARGET PROPERTY STRINGS ${PossibleArmTargets} )
|
||||||
|
|
||||||
|
#compatibility junk for previous version of toolchain
|
||||||
|
if( DEFINED ARM_TARGETS AND NOT DEFINED ARM_TARGET )
|
||||||
|
SET( ARM_TARGET "${ARM_TARGETS}" )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
#set these flags for client use
|
||||||
|
if( ARM_TARGET STREQUAL "armeabi" )
|
||||||
|
set( ARMEABI true )
|
||||||
|
set( ARMEABI_NDK_NAME "armeabi" )
|
||||||
|
set( NEON false )
|
||||||
|
else()
|
||||||
|
if( ARM_TARGET STREQUAL "armeabi-v7a with NEON" )
|
||||||
|
set( NEON true )
|
||||||
|
set( VFPV3 true )
|
||||||
|
elseif( ARM_TARGET STREQUAL "armeabi-v7a with VFPV3" )
|
||||||
|
set( VFPV3 true )
|
||||||
|
elseif( NOT ARM_TARGET STREQUAL "armeabi-v7a")
|
||||||
|
message( FATAL_ERROR "Unsupported ARM_TARGET=${ARM_TARGET} is specified.
|
||||||
|
Supported values are: \"armeabi\", \"armeabi-v7a\", \"armeabi-v7a with NEON\", \"armeabi-v7a with VFPV3\"
|
||||||
|
" )
|
||||||
|
endif()
|
||||||
|
set( ARMEABI_V7A true )
|
||||||
|
set( ARMEABI_NDK_NAME "armeabi-v7a" )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
#setup output directories
|
||||||
|
set( LIBRARY_OUTPUT_PATH_ROOT ${CMAKE_SOURCE_DIR} CACHE PATH "root for library output, set this to change where android libs are installed to" )
|
||||||
|
|
||||||
|
SET( DO_NOT_CHANGE_OUTPUT_PATHS_ON_FIRST_PASS OFF CACHE BOOL "")
|
||||||
|
if( DO_NOT_CHANGE_OUTPUT_PATHS_ON_FIRST_PASS )
|
||||||
|
#some cmake standard modules work incorrectly if output paths are changed
|
||||||
|
set( LIBRARY_OUTPUT_PATH ${LIBRARY_OUTPUT_PATH_ROOT}/libs/${ARMEABI_NDK_NAME} CACHE PATH "path for android libs" FORCE )
|
||||||
|
set( EXECUTABLE_OUTPUT_PATH ${LIBRARY_OUTPUT_PATH_ROOT}/bin/${ARMEABI_NDK_NAME} CACHE PATH "Output directory for applications" FORCE)
|
||||||
|
set( CMAKE_INSTALL_PREFIX ${ANDROID_NDK_TOOLCHAIN_ROOT}/user/${ARMEABI_NDK_NAME} CACHE STRING "path for installing" FORCE )
|
||||||
|
endif()
|
||||||
|
SET( DO_NOT_CHANGE_OUTPUT_PATHS_ON_FIRST_PASS ON CACHE INTERNAL "" FORCE)
|
||||||
|
|
||||||
|
# where is the target environment
|
||||||
|
if( BUILD_WITH_ANDROID_NDK )
|
||||||
|
set( STL_LIBRARIES_PATH "${ANDROID_NDK}/sources/cxx-stl/gnu-libstdc++/libs/${ARMEABI_NDK_NAME}" )
|
||||||
|
set( CMAKE_FIND_ROOT_PATH ${ANDROID_NDK_TOOLCHAIN_ROOT}/bin ${ANDROID_NDK_TOOLCHAIN_ROOT}/arm-linux-androideabi ${ANDROID_NDK_SYSROOT} )
|
||||||
|
include_directories( ${ANDROID_NDK}/sources/cxx-stl/gnu-libstdc++/include ${ANDROID_NDK}/sources/cxx-stl/gnu-libstdc++/libs/${ARMEABI_NDK_NAME}/include )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if( BUILD_WITH_ANDROID_NDK_TOOLCHAIN )
|
||||||
|
set( STL_LIBRARIES_PATH "${CMAKE_INSTALL_PREFIX}/lib" )
|
||||||
|
set( CMAKE_FIND_ROOT_PATH ${ANDROID_NDK_TOOLCHAIN_ROOT}/bin ${ANDROID_NDK_TOOLCHAIN_ROOT}/arm-linux-androideabi ${ANDROID_NDK_TOOLCHAIN_ROOT}/sysroot ${CMAKE_INSTALL_PREFIX} ${CMAKE_INSTALL_PREFIX}/share )
|
||||||
|
#for some reason this is needed? TODO figure out why...
|
||||||
|
include_directories( ${ANDROID_NDK_TOOLCHAIN_ROOT}/arm-linux-androideabi/include/c++/4.4.3/arm-linux-androideabi )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
# allow programs like swig to be found -- but can be deceiving for
|
||||||
|
# system tool dependencies.
|
||||||
|
set( CMAKE_FIND_ROOT_PATH_MODE_PROGRAM ONLY )
|
||||||
|
# only search for libraries and includes in the ndk toolchain
|
||||||
|
set( CMAKE_FIND_ROOT_PATH_MODE_LIBRARY ONLY )
|
||||||
|
set( CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY )
|
||||||
|
|
||||||
|
set( CMAKE_CXX_FLAGS "-fPIC -DANDROID -Wno-psabi -fsigned-char" )
|
||||||
|
set( CMAKE_C_FLAGS "-fPIC -DANDROID -Wno-psabi -fsigned-char" )
|
||||||
|
|
||||||
|
set( FORCE_ARM OFF CACHE BOOL "Use 32-bit ARM instructions instead of Thumb-1" )
|
||||||
|
if( NOT FORCE_ARM )
|
||||||
|
#It is recommended to use the -mthumb compiler flag to force the generation
|
||||||
|
#of 16-bit Thumb-1 instructions (the default being 32-bit ARM ones).
|
||||||
|
set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mthumb" )
|
||||||
|
set( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -mthumb" )
|
||||||
|
else()
|
||||||
|
set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -marm" )
|
||||||
|
set( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -marm" )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if( BUILD_WITH_ANDROID_NDK )
|
||||||
|
set( CMAKE_CXX_FLAGS "--sysroot=${ANDROID_NDK_SYSROOT} ${CMAKE_CXX_FLAGS}" )
|
||||||
|
set( CMAKE_C_FLAGS "--sysroot=${ANDROID_NDK_SYSROOT} ${CMAKE_C_FLAGS}" )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
if( ARMEABI_V7A )
|
||||||
|
#these are required flags for android armv7-a
|
||||||
|
set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -march=armv7-a -mfloat-abi=softfp" )
|
||||||
|
set( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -march=armv7-a -mfloat-abi=softfp" )
|
||||||
|
if( NEON )
|
||||||
|
set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mfpu=neon" )
|
||||||
|
set( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -mfpu=neon" )
|
||||||
|
elseif( VFPV3 )
|
||||||
|
set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -mfpu=vfpv3" )
|
||||||
|
set( CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -mfpu=vfpv3" )
|
||||||
|
endif()
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set( CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS}" CACHE STRING "c++ flags" )
|
||||||
|
set( CMAKE_C_FLAGS "${CMAKE_C_FLAGS}" CACHE STRING "c flags" )
|
||||||
|
|
||||||
|
#-Wl,-L${LIBCPP_LINK_DIR},-lstdc++,-lsupc++
|
||||||
|
#-L${LIBCPP_LINK_DIR} -lstdc++ -lsupc++
|
||||||
|
#Also, this is *required* to use the following linker flags that routes around
|
||||||
|
#a CPU bug in some Cortex-A8 implementations:
|
||||||
|
set( LINKER_FLAGS "-Wl,--fix-cortex-a8 -L${STL_LIBRARIES_PATH} -lstdc++ -lsupc++ " )
|
||||||
|
|
||||||
|
set( NO_UNDEFINED ON CACHE BOOL "Don't all undefined symbols" )
|
||||||
|
if( NO_UNDEFINED )
|
||||||
|
set( LINKER_FLAGS "-Wl,--no-undefined ${LINKER_FLAGS}" )
|
||||||
|
endif()
|
||||||
|
|
||||||
|
set( CMAKE_SHARED_LINKER_FLAGS "${LINKER_FLAGS}" CACHE STRING "linker flags" FORCE )
|
||||||
|
set( CMAKE_MODULE_LINKER_FLAGS "${LINKER_FLAGS}" CACHE STRING "linker flags" FORCE )
|
||||||
|
set( CMAKE_EXE_LINKER_FLAGS "${LINKER_FLAGS}" CACHE STRING "linker flags" FORCE )
|
||||||
|
|
||||||
|
#set these global flags for cmake client scripts to change behavior
|
||||||
|
set( ANDROID True )
|
||||||
|
set( BUILD_ANDROID True )
|
||||||
|
|
||||||
|
#SWIG junk...
|
||||||
|
set( NO_SWIG OFF CACHE BOOL "Don't search for SWIG" )
|
||||||
|
if( NOT NO_SWIG )
|
||||||
|
#need to search in the host for swig to be found
|
||||||
|
set( CMAKE_FIND_ROOT_PATH_MODE_PROGRAM BOTH )
|
||||||
|
set( CMAKE_FIND_ROOT_PATH_MODE_INCLUDE BOTH )
|
||||||
|
find_package( SWIG QUIET )
|
||||||
|
set( CMAKE_FIND_ROOT_PATH_MODE_PROGRAM ONLY )
|
||||||
|
set( CMAKE_FIND_ROOT_PATH_MODE_INCLUDE ONLY )
|
||||||
|
|
||||||
|
if( SWIG_FOUND )
|
||||||
|
set( SWIG_USE_FILE ${CMAKE_ROOT}/Modules/UseSWIG.cmake CACHE PATH "Use Swig cmake module" )
|
||||||
|
set( SWIG_OUTPUT_ROOT ${LIBRARY_OUTPUT_PATH_ROOT}/src CACHE PATH "Where swig generated files will be placed relative to, <SWIG_OUTPUT_ROOT>/com/mylib/foo/jni ..." FORCE )
|
||||||
|
|
||||||
|
#convenience macro for swig java packages
|
||||||
|
macro( SET_SWIG_JAVA_PACKAGE package_name )
|
||||||
|
string( REGEX REPLACE "[.]" "/" package_name_output ${package_name} )
|
||||||
|
set( CMAKE_SWIG_OUTDIR ${SWIG_OUTPUT_ROOT}/${package_name_output} )
|
||||||
|
set( CMAKE_SWIG_FLAGS "-package" "'${package_name}'" )
|
||||||
|
endmacro()
|
||||||
|
else()
|
||||||
|
message( STATUS "SWIG is not found" )
|
||||||
|
set( NO_SWIG ON CACHE BOOL "Don't search for SWIG" FORCE )
|
||||||
|
endif()
|
||||||
|
endif()
|
@ -1,4 +0,0 @@
|
|||||||
mkdir build
|
|
||||||
cd build
|
|
||||||
cmake -C ../CMakeCache.android.initial.cmake -DCMAKE_TOOLCHAIN_FILE=$ANDTOOLCHAIN ../..
|
|
||||||
|
|
@ -1,4 +0,0 @@
|
|||||||
mkdir build_armeabi
|
|
||||||
cd build_armeabi
|
|
||||||
cmake -C ../CMakeCache.android.initial.cmake -DARM_TARGETS=armeabi -DCMAKE_TOOLCHAIN_FILE=$ANDTOOLCHAIN ../..
|
|
||||||
|
|
@ -1,4 +0,0 @@
|
|||||||
mkdir build_neon
|
|
||||||
cd build_neon
|
|
||||||
cmake -C ../CMakeCache.android.initial.cmake -DARM_TARGETS="armeabi-v7a with NEON" -DCMAKE_TOOLCHAIN_FILE=$ANDTOOLCHAIN ../..
|
|
||||||
|
|
11
android/scripts/cmake_android.cmd
Normal file
11
android/scripts/cmake_android.cmd
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
cd %~dp0\..
|
||||||
|
|
||||||
|
::rmdir /S /Q build
|
||||||
|
mkdir build 2>null
|
||||||
|
|
||||||
|
SET ANDROID_NDK=C:\apps\android-ndk-r5b
|
||||||
|
SET CMAKE_EXE=C:\apps\cmake\bin\cmake.exe
|
||||||
|
SET MAKE_EXE=C:\apps\gnuport\make.exe
|
||||||
|
|
||||||
|
cd build
|
||||||
|
%CMAKE_EXE% -G"Unix Makefiles" -DCMAKE_TOOLCHAIN_FILE=..\android.toolchain.cmake -DCMAKE_MAKE_PROGRAM=%MAKE_EXE% ..\..
|
8
android/scripts/cmake_android.sh
Normal file
8
android/scripts/cmake_android.sh
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
cd `dirname $0`/..
|
||||||
|
|
||||||
|
mkdir -p build
|
||||||
|
cd build
|
||||||
|
|
||||||
|
cmake -C ../CMakeCache.android.initial.cmake -DCMAKE_TOOLCHAIN_FILE=../android.toolchain.cmake ../..
|
||||||
|
|
11
android/scripts/cmake_android_armeabi.cmd
Normal file
11
android/scripts/cmake_android_armeabi.cmd
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
cd %~dp0\..
|
||||||
|
|
||||||
|
::rmdir /S /Q build
|
||||||
|
mkdir build 2>null
|
||||||
|
|
||||||
|
SET ANDROID_NDK=C:\apps\android-ndk-r5b
|
||||||
|
SET CMAKE_EXE=C:\apps\cmake\bin\cmake.exe
|
||||||
|
SET MAKE_EXE=C:\apps\gnuport\make.exe
|
||||||
|
|
||||||
|
cd build
|
||||||
|
%CMAKE_EXE% -G"Unix Makefiles" -DARM_TARGET=armeabi -DCMAKE_TOOLCHAIN_FILE=..\android.toolchain.cmake -DCMAKE_MAKE_PROGRAM=%MAKE_EXE% ..\..
|
8
android/scripts/cmake_android_armeabi.sh
Normal file
8
android/scripts/cmake_android_armeabi.sh
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
cd `dirname $0`/..
|
||||||
|
|
||||||
|
mkdir -p build_armeabi
|
||||||
|
cd build_armeabi
|
||||||
|
|
||||||
|
cmake -C ../CMakeCache.android.initial.cmake -DARM_TARGET=armeabi -DCMAKE_TOOLCHAIN_FILE=../android.toolchain.cmake ../..
|
||||||
|
|
11
android/scripts/cmake_android_neon.cmd
Normal file
11
android/scripts/cmake_android_neon.cmd
Normal file
@ -0,0 +1,11 @@
|
|||||||
|
cd %~dp0\..
|
||||||
|
|
||||||
|
::rmdir /S /Q build
|
||||||
|
mkdir build 2>null
|
||||||
|
|
||||||
|
SET ANDROID_NDK=C:\apps\android-ndk-r5b
|
||||||
|
SET CMAKE_EXE=C:\apps\cmake\bin\cmake.exe
|
||||||
|
SET MAKE_EXE=C:\apps\gnuport\make.exe
|
||||||
|
|
||||||
|
cd build
|
||||||
|
%CMAKE_EXE% -G"Unix Makefiles" -DARM_TARGET="armeabi-v7a with NEON" -DCMAKE_TOOLCHAIN_FILE=..\android.toolchain.cmake -DCMAKE_MAKE_PROGRAM=%MAKE_EXE% ..\..
|
8
android/scripts/cmake_android_neon.sh
Normal file
8
android/scripts/cmake_android_neon.sh
Normal file
@ -0,0 +1,8 @@
|
|||||||
|
#!/bin/sh
|
||||||
|
cd `dirname $0`/..
|
||||||
|
|
||||||
|
mkdir -p build_neon
|
||||||
|
cd build_neon
|
||||||
|
|
||||||
|
cmake -C ../CMakeCache.android.initial.cmake -DARM_TARGET="armeabi-v7a with NEON" -DCMAKE_TOOLCHAIN_FILE=../android.toolchain.cmake ../..
|
||||||
|
|
@ -1,6 +1,8 @@
|
|||||||
if (ANDROID)
|
if(ANDROID)
|
||||||
ADD_DEFINITIONS(-DGTEST_HAS_STD_WSTRING=0)
|
ADD_DEFINITIONS(-DGTEST_HAS_STD_WSTRING=0)
|
||||||
ADD_DEFINITIONS(-DGTEST_HAS_CLONE=0)
|
if(ANDROID_API_LEVEL LESS 8)
|
||||||
|
ADD_DEFINITIONS(-DGTEST_HAS_CLONE=0)
|
||||||
|
endif()
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
add_subdirectory(calib3d)
|
add_subdirectory(calib3d)
|
||||||
|
@ -119,6 +119,13 @@ CV_INLINE IppiSize ippiSize(int width, int height)
|
|||||||
#define CV_SSE3 0
|
#define CV_SSE3 0
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
#if defined ANDROID && defined __ARM_NEON__
|
||||||
|
#include "arm_neon.h"
|
||||||
|
#define CV_NEON 1
|
||||||
|
#else
|
||||||
|
#define CV_NEON 0
|
||||||
|
#endif
|
||||||
|
|
||||||
#ifndef IPPI_CALL
|
#ifndef IPPI_CALL
|
||||||
#define IPPI_CALL(func) CV_Assert((func) >= 0)
|
#define IPPI_CALL(func) CV_Assert((func) >= 0)
|
||||||
#endif
|
#endif
|
||||||
|
@ -216,6 +216,14 @@ if(HAVE_ANDROID_NATIVE_CAMERA)
|
|||||||
add_definitions(-DHAVE_ANDROID_NATIVE_CAMERA)
|
add_definitions(-DHAVE_ANDROID_NATIVE_CAMERA)
|
||||||
endif()
|
endif()
|
||||||
|
|
||||||
|
if(COMMAND get_module_external_sources)
|
||||||
|
set( lib_srcs "${highgui_srcs}" )
|
||||||
|
set( lib_int_hdrs "${highgui_hdrs}" )
|
||||||
|
get_module_external_sources(highgui)
|
||||||
|
set( highgui_srcs "${lib_srcs}" )
|
||||||
|
set( highgui_hdrs "${lib_int_hdrs}" )
|
||||||
|
endif()
|
||||||
|
|
||||||
source_group("Src" FILES ${highgui_srcs} ${highgui_hdrs})
|
source_group("Src" FILES ${highgui_srcs} ${highgui_hdrs})
|
||||||
source_group("Include" FILES ${highgui_ext_hdrs})
|
source_group("Include" FILES ${highgui_ext_hdrs})
|
||||||
|
|
||||||
|
Loading…
Reference in New Issue
Block a user