C/C++开发,linux下OpenCV+gcc+cmake编译环境搭建

Posted py_free-物联智能

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了C/C++开发,linux下OpenCV+gcc+cmake编译环境搭建相关的知识,希望对你有一定的参考价值。

目录

一、源码下载

二、源码编译

        2.1 OpenCV源码下载

        2.2 cmake安装(非必要)

        2.3 opencv安装依赖及支持模块查看

        2.4 安装pkgconfig包

        2.5 安装opencv依赖包

        2.6 真正安装opencv包开始

        2.7 opencv环境路径配置

三、案例测试

        3.1 案例设计

        3.2 编译测试


一、源码下载

        opencv可以在官网(Courses - OpenCV)、github、gitee下载源码编译自己所需要的特定功能的库,也可以在SourceForge获得已经编译好的库直接应用。

        gitee镜像:opencv: Open Source Computer Vision Library

        建议用国内镜像:git clone git@gitee.com:mirrors/opencv.git

        cmake下载:Index of /files,自行下载需要的版本,不同的opencv版本编译需要不同的cmake版本要求,建议2.8.12以上,这是opecv42的版本。

二、源码编译

        2.1 OpenCV源码下载

        本文采用的是vmware15安装了centos7的Linux系统,预先安装好了git工具。进入系统内,打开命令工具,下载源码:

git clone git@gitee.com:mirrors/opencv.git
git clone git@gitee.com:cubone/opencv_contrib.git

        源码下载完成后,进入opencv目录,打开CmakeLists.txt,可以看到不同opencv版本所需要的cmake版本要求:

#
# Configure CMake policies
#
if(POLICY CMP0026)
  cmake_policy(SET CMP0026 NEW)
endif()

if(POLICY CMP0042)
  cmake_policy(SET CMP0042 NEW)  # CMake 3.0+ (2.8.12): MacOS "@rpath" in target's install name
endif()

if(POLICY CMP0046)
  cmake_policy(SET CMP0046 NEW)  # warn about non-existed dependencies
endif()

if(POLICY CMP0051)
  cmake_policy(SET CMP0051 NEW)
endif()

if(POLICY CMP0054)  # CMake 3.1: Only interpret if() arguments as variables or keywords when unquoted.
  cmake_policy(SET CMP0054 NEW)
endif()

if(POLICY CMP0056)
  cmake_policy(SET CMP0056 NEW)  # try_compile(): link flags
endif()

if(POLICY CMP0066)
  cmake_policy(SET CMP0066 NEW)  # CMake 3.7: try_compile(): use per-config flags, like CMAKE_CXX_FLAGS_RELEASE
endif()

if(POLICY CMP0067)
  cmake_policy(SET CMP0067 NEW)  # CMake 3.8: try_compile(): honor language standard variables (like C++11)
endif()

if(POLICY CMP0068)
  cmake_policy(SET CMP0068 NEW)  # CMake 3.9+: `RPATH` settings on macOS do not affect `install_name`.
endif()

if(POLICY CMP0075)
  cmake_policy(SET CMP0075 NEW)  # CMake 3.12+: Include file check macros honor `CMAKE_REQUIRED_LIBRARIES`
endif()

if(POLICY CMP0077)
  cmake_policy(SET CMP0077 NEW)  # CMake 3.13+: option() honors normal variables.
endif()

        因此如果需要某个opencv版本,需要自行下载相关版本支持。

        2.2 cmake安装(非必要)

        本文安装的是cmake-3.25.3版本:

wget https://cmake.org/files/v3.25/cmake-3.25.3.tar.gz --no-check-certificate
//root
//可以先删除旧版本(非必要):yum remove -y cmake
cp cmake-3.25.3.tar.gz /usr/local/
tar zxvf cmake-3.25.3.tar.gz 
mv cmake-3.25.3 cmake
cd cmake/
./configure 
make && make install

        然后修改profile,设置cmake路径

gedit /etc/profile
//修改,例如在文末加入:
export PATH=$PATH:/usr/local/cmake/bin
//使其生效
source /etc/profile
//测试
cmake --version
//完成后删除安装包
rm -f /usr/local/cmake-3.25.3.tar.gz 

        2.3 opencv安装依赖及支持模块查看

        创建编译输出目录,然后通过cmake命令创建Makefile文件

//opencv所在父目录
mkdir build_opencv
cd  build_opencv
//按需要添加模块支持
cmake -DOPENCV_EXTRA_MODULES_PATH=../opencv_contrib/modules ../opencv
//输出Makefile文件
//make help命令可以查看支持哪些模块
例如:
The following are some of the valid targets for this Makefile:
... all (the default if no target is provided)
... clean
... depend
... edit_cache
... install
... install/local
... install/strip
... list_install_components
... package
... package_source
... rebuild_cache
... test
......

        安装时前仔细阅读cmake命令的输出信息,查看是否由缺失的包没有支持到,例如:

        在cmake命令输出结论,仔细斟酌那些我们需要的功能及依赖是否支持到,例如图形窗口方面需要gtk、vtk等支持的,又例如视频需要FFMPEG支持,等等。相比起windows,opencv在linux下安装主要就是明确需要哪些opencv模块,这些模块需要安装哪些依赖包

        2.4 安装pkgconfig包

        前往Index of /releases去下载pkg-config包:

//指令安装,本文安装方式
yum -y install pkgconfig
//安装完后,路径/usr/lib64/pkgconfig,/usr/share/pkgconfig

//如果版本不合适,手动下载安装
wget https://pkgconfig.freedesktop.org/releases/pkg-config-0.29.2.tar.gz --no-check-certificate
//解压
tar -zxvf pkg-config-0.29.2.tar.gz 
//配置
cd pkg-config-0.29.2/
./configure --prefix=/usr/local/pkg-config --with-internal-glib 
//编译
make
//root 用于
make install
//安装路径在/usr/local/pkg-config
whereis pkgconfig

        2.5 安装opencv依赖包

        安装GTK等,centos7支持yum命令直接安装

yum -y install epel-release
yum -y install gtk2 gtk2-devel gtk2-devel-docs
yum -y install libpng-devel
yum -y install jasper-devel
yum -y install openexr-devel
yum -y install libwebp-devel
yum -y install libjpeg-turbo-devel 
yum -y install libtiff-devel 
yum -y install tbb-devel eigen3-devel
yum -y install boost boost-thread boost-devel
yum -y install libgnomeui-devel
yum -y install libv4l-devel
yum -y install libdc1394-devel
yum -y install gstreamer-plugins-base-devel
yum -y install python-devel numpy
yum -y install gnome-devel gnome-devel-docs

#yum localinstall –nogpgcheck https://download1.rpmfusion.org/free/el/rpmfusion-free-release-7.noarch.rpm
#yum localinstall –nogpgcheck https://download1.rpmfusion.org/nonfree/el/rpmfusion-nonfree-release-7.noarch.rpm
#rpm -Uvh http://li.nux.ro/download/nux/dextop/el7/x86_64/nux-dextop-release-0-1.el7.nux.noarch.rpm
#yum -y install ffmpeg ffmpeg-devel

        安装好一些依赖包后,重新cmake一下,查看这些包是否被找到,下列cmake指令仅参考,请按自行系统环境及所需配置,相关宏请查看源码的CMakeLists.txt文件确认:

cmake \\
-D CMAKE_BUILD_TYPE=RELEASE \\
-D CMAKE_INSTALL_PREFIX=/usr/local \\
-D WITH_TBB=OFF \\
-D BUILD_NEW_PYTHON_SUPPORT=ON \\
-D WITH_V4L=ON \\
-D WITH_QT=ON \\
-D WITH_OPENGL=ON \\
-D OPENCV_EXTRA_MODULES_PATH=../opencv_contrib/modules/ \\
-D WITH_GTK=ON \\
-D ENABLE_CXX11=ON \\
-D OPENCV_GENERATE_PKGCONFIG=ON \\
-D WITH_CUDA=OFF \\
-D BUILD_opencv_cudacodec=OFF \\
-D INSTALL_C_EXAMPLES=OFF \\
-D INSTALL_PYTHON_EXAMPLES=OFF \\
-D BUILD_EXAMPLES=OFF \\
-D WITH_EIGEN=OFF \\
-D WITH_VTK=OFF \\
-D BUILD_TESTS=OFF \\
-D BUILD_PERF_TESTS=OFF \\
-D BUILD_opencv_python2=OFF \\
../opencv

        2.6 真正安装opencv包开始

        编译整个opencv是一个费时间的事,如果开发者只想使用某个模块,可以按需编译,例如:

[***@pyfree build_opencv]$ make -j2 opencv_core
[ 14%] Built target ittnotify
[100%] Built target opencv_core
[***@pyfree build_opencv]$ 

        由于cmake时没有指定编译静态库,因此默认编译的是动态库。编译完成后,就可以切换到root用户下进行安装:

//默认编译
make
//安装
su root
//密码
make install

        PS,如果没有相关依赖包,很多模块opencv在cmake配置时就取消掉了,因此编译出来的包有限,如果没有您想要的包或库,可能需要反复cmake和make、make install直接重复,因此这个编译包最好不要再安装完成后进删除,需要等待版本安装稳定后再说。

        2.7 opencv环境路径配置

        由于cmake时指定/usr/local安装路径,因此采用的默认安装路径 :

OpenCV 默认安装路径是/usr/local目录下, 相关文件部署情况:
    /usr/local/bin - executable files
    /usr/local/lib - libraries (.so)
    /usr/local/cmake/opencv4 - cmake package
    /usr/local/include/opencv4 - headers
    /usr/local/share/opencv4 - other files

//由于cmake配置时,没有做安装目录指定,采用默认路径,也没有指定编译静态库,默认的是动态库编译

         对于opencv,我们开发者最主要的就是头文件及库路径需要关注,本文的存放路径及相关内容信息如下:

//头文件所在位置
[root@pyfree ***]# ls /usr/local/include/opencv4/opencv2/
calib3d      features2d      highgui.hpp    objdetect           stitching.hpp
calib3d.hpp  features2d.hpp  imgcodecs      objdetect.hpp       video
core         flann           imgcodecs.hpp  opencv.hpp          video.hpp
core.hpp     flann.hpp       imgproc        opencv_modules.hpp  videoio
cvconfig.h   gapi            imgproc.hpp    photo               videoio.hpp
dnn          gapi.hpp        ml             photo.hpp
dnn.hpp      highgui         ml.hpp         stitching
[root@pyfree ***]# 
//动态库文件位置
[root@pyfree ***]# ls /usr/local/lib64 | grep libopencv
libopencv_calib3d.so
libopencv_calib3d.so.407
libopencv_calib3d.so.4.7.0
libopencv_core.so
libopencv_core.so.407
libopencv_core.so.4.7.0
libopencv_dnn.so
libopencv_dnn.so.407
libopencv_dnn.so.4.7.0
libopencv_features2d.so
libopencv_features2d.so.407
libopencv_features2d.so.4.7.0
libopencv_flann.so
libopencv_flann.so.407
libopencv_flann.so.4.7.0
libopencv_gapi.so
libopencv_gapi.so.407
libopencv_gapi.so.4.7.0
libopencv_highgui.so
libopencv_highgui.so.407
libopencv_highgui.so.4.7.0
libopencv_imgcodecs.so
libopencv_imgcodecs.so.407
libopencv_imgcodecs.so.4.7.0
libopencv_imgproc.so
libopencv_imgproc.so.407
libopencv_imgproc.so.4.7.0
libopencv_ml.so
libopencv_ml.so.407
libopencv_ml.so.4.7.0
libopencv_objdetect.so
libopencv_objdetect.so.407
libopencv_objdetect.so.4.7.0
libopencv_photo.so
libopencv_photo.so.407
libopencv_photo.so.4.7.0
libopencv_stitching.so
libopencv_stitching.so.407
libopencv_stitching.so.4.7.0
libopencv_videoio.so
libopencv_videoio.so.407
libopencv_videoio.so.4.7.0
libopencv_video.so
libopencv_video.so.407
libopencv_video.so.4.7.0
[root@pyfree ***]# 

        将动态库加入库路径:

//下面指令需要安装pkgconfig包,以及opencv开启-D OPENCV_GENERATE_PKGCONFIG=ON 支持
ln -sf /usr/local/lib64/pkgconfig/opencv4.pc /usr/share/pkgconfig/
ldconfig
//--1--,root
gedit /etc/profile
//修改PKG_CONFIG_PATH,需要已经安装pkgconfig包
export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/lib64/pkgconfig:/usr/share/pkgconfig
//修改LD_LIBRARY_PATH,将opencv库路径加入,例如文末加入
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib64:/usr/lib64:/lib64
//修改保存,关闭文件,运行以下命令生效
 source /etc/profile
//--2--,root
cd /etc/ld.so.conf.d/
vi opencv.conf
//或:gedit /etc/ld.so.conf.d/opencv.conf
//添加opencv动态库路径在文件中,如/usr/local/lib64
//配置生效,运行以下命令
ldconfig    

        有些版本安装了gtk等包后,会产生依赖错误,造成启动时logout错误界面,这是需要ctrl+alt+F2 进入命令模式,然后输入root 账号和密码。

root
#输入密码
yum update
#...等待
输入 y

        更新后重启,可能会产生一个新版本内核,启动时,最好选择原来的内核版本来登录(就是我们原来安装了一系列opencv相关软件包的版本)。

三、案例测试

        3.1 案例设计

        工程目录如下:

#一个读取图片的测试项目
test 
    bin
        1.png        #png图片
        2.bmp        #bmp图片
    src
        main.cpp
    Makefile_linux

        main.cpp

#include <opencv2/core.hpp>
#include <opencv2/imgcodecs.hpp>
#include <opencv2/highgui.hpp>
#include <iostream>
using namespace cv;
using namespace std;
int main( int argc, char** argv )

    if( argc != 2)
    
     cout <<" Usage: " << argv[0] << " ImageToLoadAndDisplay" << endl;
     return -1;
    
    Mat image;
    image = imread(argv[1], IMREAD_COLOR); // Read the file
    if( image.empty() ) // Check for invalid input
    
        cout << "Could not open or find the image" << std::endl ;
        return -1;
    
    namedWindow( "Display window", WINDOW_AUTOSIZE ); // Create a window for display.
    imshow( "Display window", image ); // Show our image inside it.
    waitKey(0); // Wait for a keystroke in the window
    return 0;

        Makefile_linux工程配置信息如下:

#/bin/sh
CX= g++

BIN 		:= ./bin
TARGET      := testlinux.exe
FLAGS		:= -std=c++11
SRCDIR 		:= ./src
INCLUDEDIR 	:= -I"/usr/local/include/opencv4" 
DLLDIR		:= "/usr/local/lib64"
LIBDIR		:= -L $(DLLDIR) -lopencv_core -lopencv_highgui -lopencv_imgcodecs
#LIBDIR		:= $(DLLDIR)/libopencv_core.so $(DLLDIR)/libopencv_highgui.so $(DLLDIR)/libopencv_imgcodecs.so
source		:= $(wildcard $(SRCDIR)/*.cpp) 

$(TARGET) :
	$(CX) $(FLAGS) $(INCLUDEDIR) $(source) $(LIBDIR) -o $(BIN)/$(TARGET) 

clean:
	rm  $(BIN)/$(TARGET)

        3.2 编译测试

        运行makfe -f Makefile_linux命令进行编译

[***@pyfree test]$ make -f Makefile_linux 
g++  -std=c++11 -I"/usr/local/include/opencv4"  ./src/main.cpp  -L "/usr/local/lib64" -lopencv_core -lopencv_highgui -lopencv_imgcodecs -o ./bin/testlinux.exe 
[***@pyfree test]$ 

        编译完成后会在bin目录下输出程序,运行该程序:
 

    cd bin
    ./testlinux.exe 1.png

        ./testlinux.exe 2.bmp

Linux下C/C++编程开发GCC

文章目录

前言

下面的所有操作的的操作都是基于:

  • 操作系统:Ubuntu20.04.3-desktop
  • GCC-Version:gcc (Ubuntu 9.4.0-1ubuntu1~20.04.1) 9.4.0
  • G+±Version:g++ (Ubuntu 9.4.0-1ubuntu1~20.04.1) 9.4.0

一、GCC

GCC 原名为 GNU C 语言编译器(GNU C Compiler)是由 GNU 开发的编程语言译器。GNU 编译器套件包括 CC++Objective-CJavaAdaGo 语言前端,也包括了这些语言的库(如 libstdc++libgcj 等)

二、 安装GCC、G++

在终端中输入sudo apt install gcc g++ 即可完成安装,然后通过gcc --versiong++ --version 就可以查看当前安装的版本,如下:

mangata@mangata:~$ g++ --version
g++ (Ubuntu 9.4.0-1ubuntu1~20.04.1) 9.4.0
Copyright (C) 2019 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.  There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

mangata@mangata:~$ gcc --version
gcc (Ubuntu 9.4.0-1ubuntu1~20.04.1) 9.4.0
Copyright (C) 2019 Free Software Foundation, Inc.
This is free software; see the source for copying conditions.  There is NO
warranty; not even for MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.

三、GCC的工作流程


我们在编译代码的时候的流程基本就是上面的步骤:预编译->编译->汇编->链接

假设我们有一个代码test.c

#include <stdio.h>

#define MAX_SIZE 5

int main()
   
    int res = MAX_SIZE;    
    int len = MAX_SIZE;
    for(int i = 0;i < len; ++i) 
        printf("Hello world %d\\n",i);
    return 0;

3.1 预编译

在终端中输入:

gcc -E test.c -o test.i

然后就会生成一个test.i 文件,这个其实就是预编译处理后的源代码

我们可以看到main 函数中的MAX_SIZE已经被替换了

3.2 编译

在终端输入:

gcc -S test.i -o test.s

此时就会生成一个 test.s 的汇编代码

3.3 编译

在终端输入:

gcc -c test.s -o test.o

此时就会生成一个 test.o 的二进制代码

3.4 链接

在终端输入:

gcc -o test test.o

此时就会生成一个 test 的可执行程序,此时我们就可以通过./test 运行我们的程序了~

3.5 一步到位

当然我们也可以一步到位,直接从 .c 文件生成 可执行文件:

gcc -o test test.c

四、GCC、G++常用编译选项

gcc编译选项说明
-E预处理指定的源文件,不进行编译
-S编译指定的源文件,但是不进行汇编
-c编译、汇编指定的源文件,但是不进行链接
-o [file1] [file2] 或者 [file2] -o [file1] 将文件 file2 编译成可执行文件 file1
-Idirectory 指定 include 包含文件的搜索目录
-g在编译的时候,生成调试信息,该程序可以被调试器调试
-D在程序编译的时候,指定一个宏
-w不生成任何警告信息
-Wall生成所有警告信息
-On n n n 的取值范围: [ 0 , 3 ] [0,3] [0,3] 编译器的优化选项的 4 4 4 个级别,-O0表示没有优化,-O1 为缺省值,-O3 优化级别最高
-l在程序编译的时候,指定使用的库
-L指定编译的时候,搜索的库的路径。
-fPIC/fpic生成与位置无关的代码
-shared生成共享目标文件,通常用在建立共享库时
-std指定C方言,如:-std=c99gcc默认的方言是GNU C

五、GCC和G++区别

  • 编译阶段,g++ 会调用 gcc ,对于 C++ 代码,两者是等价的,但是 因为 gcc 命令不能自动和 C++ 程序使用的库联接,所以通常用 g++ 来完成链接,为了统一起见,干脆编译/链接统统用 g++ ,这就给人一种错觉,好像 c++ 程序只能用 g++ 似的,所以对于不需要链接的 C++ 程序而言我们仍然可以使用 gcc 编译

  • 如果源代码文件后缀为 .c ,并且采用 gcc 编译器那么 __cplusplus 宏是未定义的,否则是定义的

例如我们有如下代码 a.cc

#include <stdio.h>

int main()
   
    #ifdef __cplusplus
    printf("__cplusplus is define!\\n");
    #endif
    return 0;

然后编译生成可执行文件a : gcc -o a a.cc
我们执行这个程序的时候会发现,终端输出了__cplusplus is define! 也表示__cplusplus宏是定义的,即便是用gcc 编译

  • 编译可以用gcc/g++,而链接可以用g++或者gcc -lstdc++
  • gcc命令不能自动和C++程序使用的库联接.所以通常使用g++来完成联接。但在编译阶段, gcc会自动调用g++,二者等价

以上是关于C/C++开发,linux下OpenCV+gcc+cmake编译环境搭建的主要内容,如果未能解决你的问题,请参考以下文章

Linux下C/C++编程开发GCC

Linux下C/C++编程开发GCC

在Linux下如何开发C程序?

windows下c/c++构建总结

Linux C编程之一:Linux下c语言的开发环境

gcc 和VC++有啥区别呢,VC++编译时用的编译器 相当于gcc的是啥东西