(二)OpenCV的链接(MinGW-w64)

OpenCV的链接(MinGW-w64)

上一篇blog讲了如何编译OpenCV,这一篇blog将使用g++编译一个OpenCV程序。

第一步,写一个读图的源码。

main.cpp

#include
#include
using namespace std;
using namespace cv;
int main(int argc,const char** argv)
    {
            cout << "Load image from E:\\BFV.jpg" << endl;
            Mat src = imread("E:\\BFV.jpg");
            imshow("BFV",src);
            waitKey(0);
            return 0;
    }
  • 保存文件名为main.cpp。在开始编译之前,还得做点准备工作。打开install目录(可以把build目录下的install子目录单独复制出来,方便以后操作。),找到下面的x64/mingw/bin子目录,可以将bin子目录加到环境变量中,也可以选择将bin下面的libopencv_img_hash345.dlllibopencv_world345.dllopencv_ffmpeg345_64.dll复制到C:\Windows\System32目录下(可能需要管理员权限,这样的话即使OpenCV被删除了,也可以运行已经编译好了的OpenCV的程序——谁没事会去动System32下面的dll文件呢?)

  • 这里说明一下install下的目录结构:

    bin:可执行程序目录。
    etc:一些配置文件目录。
    include:OpenCV头文件目录。
    x64:64位系统对应的OpenCV库。
    x64子目录1mingw
    mingw子目录1 bin:用于存放可执行程序和.dll动态链接库文件。
    mingw子目录2 lib: .a文件,LINUX系统中的静态链接库文件。一些.cmake文件。

第二步,编译。

  • 进入终端(cmd/powershell),cdmain.cpp所在的目录。
    (二)OpenCV的链接(MinGW-w64)_第1张图片
    终端1
  • 终端键入g++ .\main.cpp -o main.exe -I F:\CV\build\install\include -L F:\CV\build\install\x64\mingw\lib -l opencv_img_hash345 -l opencv_world345
  • 终端没有报错(Error),没有警告(Warning)。程序编译完成。键入.\main.exe尝试运行,输出正确的图片,编译完成。

CV2.png


编译说明

  • MinGW-w64本质上就是GNU编译器套件的Windows版,所以使用的命令和Linux终端下的也一样。上述命令中使用g++以编译.cpp的文件。具体编译指令可以问度娘或者谷歌或者CSDN或者Stack Overflow。这里解释一下上述编译指令:

    g++ 源文件名称(.cpp) -o 生成可执行文件名称(.exe)
    -I注意是大写的“I”,表示include目录,这项后面填入OpenCV头文件目录。
    -L大写的“L”,表示lib目录,这后面填mingw下的lib目录。
    -l注意此处是小写的“l”,表示需要链接的静态库文件,这后面填入运行所必须的两个静态库opencv_img_hash345opencv_world345
编译第一个OpenCV程序到此完成了,可是总是输这么长串的命令会让人头痛,偶尔因为一个单词或者一个地方没打对就要重新来过。所以我们就可以依赖IDE了,下一篇文章将着重于使用Visual Studio Code来配置OpenCV开发环境,使得编译调试一键运行。

你可能感兴趣的:((二)OpenCV的链接(MinGW-w64))