编译opencv2.1静态库

环境: VS2008 + WIN7 + opencv2.1 + cmake2.8  

    背景:自己编写的一个工具类,用到了opencv库,需要编译成静态库以便于其他应用程序链接。 网上有的教程中写的在vs2010下安装opencv2.1时用到了TBB库,而我在编译链接自己的程序后需要用到tbb.dll,我的目的是做一个独立的应用程序,不需要携带其他第三方库,经过自己的摸索,终于找到了编译opencv2.1静态库的方法。

需要的环境在开始已经说明了,下面开始。

    首先将OpenCV-2.1.0-win.zip解压到一个目录,我的是E:/opencv21(可以自己改名),然后在opencv21目录下创建vc2008目录,再打开安装好的cmake2.8,填入源代码目录(E:/opencv21)和生成目录(E:/opencv21/vc2008),然后点击configure,弹出对话框如下图:


 

    选择visual studio 9 2008,然后确定,出现很多红色的选项,因为主要是生成opencv的库,所以将无关的选项都去掉,去掉BUILD_NEW_PYTHON_SUPPORT,BUILD_SHARED_LIBS, BUILD_TESTS, 勾选OPENCV_BUILD_3RDPARTY_LIBS,  WITH_TBB,WITH_JASPER,  WITH_JPEG,  WITH_PNG,  WITH_TIFF选项,然后点击configure,如下图:

 

 

    提示TBB_INCLUDE_DIR找不到,因为不需要TBB库,所以忽略,直接点击configure,好了,配置完成,点击generate,完成后关闭cmake。

    进入E:/opencv21/vc2008目录,使用vs2008打开opencv.sln文件,打开项目管理器,如下图:


    这时我们右键点击cv项目,选择属性,可以在配置属性下的常规项目中看到,配置类型为 静态库(lib)。下面按住ctrl键,选中除过ALL_BUILD, INSTALL, ZERO_CHECK, uninstall四个项目的其他所有项目,在菜单中选择项目->属性,打开配置属性->c/c++->代码生成选项,在右侧窗口中的运行时库中选择  多线程调试(/MTd),然后确认。顺便说一句,这里有四个选项(/MT, /MTd, /MD, /MDd),前两个一组,为静态链接运行时库,运行时不需要运行时库的支持,代码直接插入到程序中去;后两个一组,为动态链接运行时库,运行时需要msvcr90.dll或msvcp90.dll支持。

    我们先编译debug版的opencv静态库,在解决方案"opencv"(22个项目)上单击右键,选择重新生成,此时便开始编译opencv库了,等编译结束会提示完成16个,失败4个,这四个项目生成的是exe程序,不需要管他。

    然后我们用相同的方式生成release版的库, 这时的选项选择 多线程/MT,再进行编译。编译时警告很多,我的有120多个。

    待完成后我们打开E:/opencv21/vc2008/lib 和 E:/opencv21/vc2008/3rdparty/lib 两个目录,我们编译好的库就在这两个文件夹下。

    好了,我们的库编译完成了,现在要做的就是编写好自己的类,然后链接到下面这些库,下次就可以直接和自己写的库进行链接,而不再依赖opencv库了。要链接的库包括:cv210d.lib cxcore210d.lib highgui210d.lib zlibd.lib flannd.lib libjasperd.lib libjpegd.lib libpngd.lib libtiffd.lib opencv_lapackd.lib vfw32.lib videoinput.lib。

  • 0
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 6
    评论
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})`链接静态库。需要注意的是,交叉编译时需要指定正确的库路径和头文件路径。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值