opencv交叉编译arm环境库,静态,动态库和可执行程序

在工作中遇到把基于opencv的代码移植到板子上运行,在网上查看了很多资料,尝试了两种方案,都是可行的

1.把opencv代码用ndk的方式编译成可执行文件,直接放到板子上运行,这种方式是最便捷的不用考虑板子上其他程序的干扰

附上ndk编译代码,准备好下面两个文件后,就可以编译出一个native的可执行文件,直接放到机器上运行,就可以得到opencv计算的结果了

android.mk 


LOCAL_PATH := $(call my-dir) 
include $(CLEAR_VARS)
OPENCV_LIB_TYPE:=STATIC
OPENCV_INSTALL_MODULES:=on
OPENCV_CAMERA_MODULES:=off
ifeq ("$(wildcard $(OPENCV_MK_PATH))","")
#try to load OpenCV.mk from default install location
include /home/zoone/OpenCV-android-sdk/sdk/native/jni/OpenCV.mk 
else
include $(OPENCV_MK_PATH)
endif
LOCAL_MODULE    := native
LOCAL_SRC_FILES := native.cpp


LOCAL_LDLIBS +=  -llog -ldl
include $(BUILD_EXECUTABLE)

application.mk

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

2.把opencv的源码交叉编译arm的so库文件

编译arm平台的so库时,最好基于cmake来配置,因为opencv下载下来的源码自带了各个模块的cmake文件,直接配置cmake来编译非常方便

配置编译环境按照下面的三张图顺序进行就可以了


选择opencv源代码根目录



选择编译平台



选择编译工具,分别是gcc 和 g++  Operation system任意写一个好识别的名字,如arm-linux ,因为系统识别不到,后面会报system的错误,这个错误忽略不管


按上面的配置完成之后,点击Configue,为了方便找到编译出来opencv的so库的位置,对CMAKE_INSTALL_PREFIX 设置一下,指向到你想存放so库 的路径

完成上诉后,点击Generate,配置编译文件,编译过程中会报很多错误,包括pthread,ltr,ldl等 ,发现报这些错误后

很简单,找到你定义的编译路径build下面的CMakeCache.txt,修改CMAKE_EXE_LINKER_FLAGS:STRING = -lpthread -lrt ldl

修改了上面配置后,重新点击Generate,OK,静静等待编译通过就可以了


在反复尝试上面两种方式运行opencv代码时,还尝试过编译静态库,编译静态很简单,只要把camke配置上shared_lib勾去掉就可以,但静态库编译出来很麻烦,需要链接其他对应的20多个其他库,解决起来很头疼,所以建议不用静态库,用动态库 


1. 安装交叉编译工具链 首先需要安装交叉编译工具链,可以根据目标平台的架构选择相应的工具链。以ARM架构为例,可以使用ARM的官方工具链或者使用Ubuntu提供的工具链: ```bash sudo apt-get install gcc-arm-linux-gnueabihf g++-arm-linux-gnueabihf ``` 2. 下载并编译opencv 下载opencv源码,解压后进入源码目录,执行以下命令: ```bash mkdir build cd build cmake -DCMAKE_TOOLCHAIN_FILE=../platforms/linux/arm-gnueabi.toolchain.cmake -DOPENCV_EXTRA_MODULES_PATH=../opencv_contrib/modules -DBUILD_SHARED_LIBS=OFF -DBUILD_TESTS=OFF -DBUILD_PERF_TESTS=OFF -DBUILD_EXAMPLES=OFF -DCMAKE_BUILD_TYPE=RELEASE -DCMAKE_INSTALL_PREFIX=/usr/arm-linux-gnueabihf .. make -j4 ``` 其中,`-DCMAKE_TOOLCHAIN_FILE`指定了交叉编译工具链,`-DOPENCV_EXTRA_MODULES_PATH`指定了opencv_contrib的路径,`-DBUILD_SHARED_LIBS=OFF`表示编译静态,`-DBUILD_TESTS=OFF`、`-DBUILD_PERF_TESTS=OFF`、`-DBUILD_EXAMPLES=OFF`表示不编译测试和示例程序,`-DCMAKE_BUILD_TYPE=RELEASE`表示编译优化,`-DCMAKE_INSTALL_PREFIX`指定了安装目录。 编译完成后,执行以下命令安装opencv: ```bash sudo make install ``` 3. 链接静态 在编译自己的程序时,需要链接opencv静态。以CMake为例,可以在`CMakeLists.txt`中添加以下代码: ```cmake set(OpenCV_STATIC ON) find_package(OpenCV REQUIRED) target_link_libraries(your_target ${OpenCV_LIBS}) ``` 其中,`set(OpenCV_STATIC ON)`指定链接静态,`find_package(OpenCV REQUIRED)`查找opencv,`target_link_libraries(your_target ${OpenCV_LIBS})`链接静态。需要注意的是,交叉编译时需要指定正确的路径和头文件路径。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值