2023年最全 Windows + VSCode 配置 OpenCV C++ 一站式开发调试环境教程

简介: 2023年最全 Windows + VSCode 配置 OpenCV C++ 一站式开发调试环境教程

下载

  1. 首先,打开OpenCV-MinGW-Build,找到对应的Releases版本。这里以OpenCV-4.5.5-x64 | zip | tar.gz为例,我们点击下拉键Configuration:

  1. 下载并解压红色方框除操作系统外对应的两个软件:
  • MinGW-W64 x86_64-posix-seh【下载最新版本即可】
  • Windows-11-64bit-22000.434【Windwos 10也适配】
  • CMake-3.21.3【一定要下载对应的版本,否则大概率会编译失败】

下载时有条件的建议搭梯子,负责下行速度很慢。

  1. 安装 OpenCV-4.5.5-x64 安装包:
  • 点击对应链接下载;

  • 双击解压;
  • 选择解压路径,如C:\opencv

640.png

此处我的安装路径为:

C:\cmake-3.21.3-windows-x86_64

C:\opencv\opencv

C:\mingw64

  1. 设置环境变量
  • 添加环境变量

  • 激活环境变量
  • 进入cmd,输入set path=test;
  • 退出cmd,重新进入
  • 检查是否成功640.png


编译

注意:编译过程有条件的尽量开vpn,否则编译过程中涉及相关软件下载可能会很慢甚至失败。注意:编译过程有条件的尽量开vpn,否则编译过程中涉及相关软件下载可能会很慢甚至失败。

  1. 打开 cmake-gui.exe,文件存放在 C:\cmake-3.21.3-windows-x86_64\cmake-3.21.3-windows-x86_64\bin 目录下;
  2. 输入source code 地址或者点击Browse Source 选项选择对应的 source 路径;
  3. 输入 build 存放地址,可自己建立文件夹存放;

  1. 点击Configure按钮,选择MinGW Makefiles本地编译器:

  1. 指定你的gccg++路径:

不出意外的话,程序会开始自动生成Makefiles等文件配置,需要一段时间请耐心等待。

  1. 再次点击Configure后再点击Generate:

简单总结下:finish->configuring done->configure->generate

  1. 打开cmdcd至刚刚的构建目录下C:/opencv/opencv/build/mingw64-build,输入编译指令minGW32-make -j8,完成后再输入minGW32-make install

640.png

  1. 将编译后的C:\opencv\opencv\build\mingw64-build\bin路径添加到环境变量:

运行

  1. 打开VSCode,在插件管理搜索对应的插件:C/C++:

  1. 到工作目录下的.vscode文件夹下新建三个文件:c_cpp_properties.jsonlaunch.json以及tasks.json:

  1. 编写c_cpp_properties.json文件:
{
  "configurations": [
      {
          "name": "win",
          "includePath": [
              "${workspaceFolder}/**",
              /*此处修改为你对应的路径*/
              "C:/mingw64/include",
              "C:/opencv/opencv/build/mingw64-build/install/include",
              "C:/opencv/opencv/build/mingw64-build/install/include/opencv2"
          ],
          "defines": [
              "_DEBUG",
              "UNICODE",
              "_UNICODE"
          ],
          /*此处修改为本机gcc编译器所在的对应路径*/
          "compilerPath": "C:/mingw64/bin/gcc.exe",
          "cStandard": "c11",
          "cppStandard": "c++17",
          "intelliSenseMode": "clang-x64"
      }
  ],
  "version": 4
}
  1. 编写launch.json文件:
{
    "version": "0.2.0",
    "configurations": [
        {
            "name": "Opencv4.5.5 debug", // 配置名称,将会在启动配置的下拉菜单中显示
            "type": "cppdbg", // 配置类型,这里只能为cppdbg
            "request": "launch", // 请求配置类型,可以为launch(启动)或attach(附加)
            "program": "${fileDirname}/${fileBasenameNoExtension}.exe", // 将要进行调试的程序的路径
            "args": [], // 程序调试时传递给程序的命令行参数,一般设为空即可
            "stopAtEntry": false, // 设为true时程序将暂停在程序入口处,一般设置为false
            "cwd": "${workspaceFolder}", // 调试程序时的工作目录,一般为${workspaceRoot}即代码所在目录,根据自身情况设定为${fileDirname}
            "environment": [],
            "externalConsole": false, // 调试时是否显示控制台窗口,设置为true时会弹出控制台出来,这个随意
            "MIMode": "gdb",
            /*此处修改*/
            "miDebuggerPath": "C:/mingw64/bin/gdb.exe", // miDebugger的路径,注意这里要与MinGw的路径对应
            "setupCommands": [
                {
                    "description": "Enable pretty-printing for gdb",
                    "text": "-enable-pretty-printing",
                    "ignoreFailures": false
                }
            ],
            "preLaunchTask": "Opencv4.5.5 compile task"  // 需要与tasks.json中的`label`字段保持一致
        }
    ]
}
  1. 编写tasks.json文件:
{
    // See https://go.microsoft.com/fwlink/?LinkId=733558
    // for the documentation about the tasks.json format
    "version": "2.0.0",
    "tasks": [
        {
              "type": "shell",
              "label": "Opencv4.5.5 compile task",
                /*修改*/
              "command": "C:/mingw64/bin/g++.exe",
              "args": [
                  "-g",
                  "-std=c++11",
                  "${file}",
                  "-o",
                  "${fileDirname}\\${fileBasenameNoExtension}.exe",
                  /*注意:此处导入的路径为编译后的opencv路径,请勿导入原始的opencv路径*/
                  "-I", "C:/opencv/opencv/build/mingw64-build/install/include/",
                  "-I", "C:/opencv/opencv/build/mingw64-build/install/include/opencv2/",
                  "-L", "C:/opencv/opencv/build/mingw64-build/install/x64/mingw/bin/lib*"
              ],// 编译命令参数
              "options": {
                   /*修改*/
                  "cwd": "C:/mingw64/bin"
              },
              "problemMatcher": [
                  "$gcc"
              ],
              "group": {
                  "kind": "build",
                  "isDefault": true
              },
              "presentation": {
                  "panel": "new", //这里shared表示共享,改成new之后每个进程创建新的端口
              }
        }
    ]
}
  1. 新建main.cpp文件,同时准备一张图片:
#include <iostream>
#include <opencv2/opencv.hpp>
using namespace cv;
using namespace std;
int main(void)
{
    cv::Mat img = cv::imread("D:/Projects/CODE_CPP/OpenCV/Projects/demo/lena.jpg");
    cv::imshow("img", img);
    cv::waitKey(0);
    return 0;
}
  1. 运行 一切准备就绪后,直接按F5即可,显示结果如下:

完结。

目录
相关文章
|
5月前
|
Ubuntu 编译器 计算机视觉
Ubuntu 20.04环境下无法找到#include<opencv/cv.h>文件 - 解决方案。
希望这些信息能帮助你解决遇到的问题。
351 10
|
5月前
|
并行计算 算法 数据可视化
基于OpenCV C++实现的光流法目标检测
基于OpenCV C++实现的光流法目标检测
|
编译器 C语言 C++
配置C++的学习环境
【10月更文挑战第18天】如果想要学习C++语言,那就需要配置必要的环境和相关的软件,才可以帮助自己更好的掌握语法知识。 一、本地环境设置 如果您想要设置 C++ 语言环境,您需要确保电脑上有以下两款可用的软件,文本编辑器和 C++ 编译器。 二、文本编辑器 通过编辑器创建的文件通常称为源文件,源文件包含程序源代码。 C++ 程序的源文件通常使用扩展名 .cpp、.cp 或 .c。 在开始编程之前,请确保您有一个文本编辑器,且有足够的经验来编写一个计算机程序,然后把它保存在一个文件中,编译并执行它。 Visual Studio Code:虽然它是一个通用的文本编辑器,但它有很多插
582 6
|
Ubuntu Linux 编译器
Linux/Ubuntu下使用VS Code配置C/C++项目环境调用OpenCV
通过以上步骤,您已经成功在Ubuntu系统下的VS Code中配置了C/C++项目环境,并能够调用OpenCV库进行开发。请确保每一步都按照您的系统实际情况进行适当调整。
2858 3
|
Ubuntu Linux Python
如何利用wsl-Ubuntu里conda用来给Windows的PyCharm开发
如何在WSL(Windows Subsystem for Linux)的Ubuntu环境中使用conda虚拟环境来为Windows上的PyCharm开发设置Python解释器。
2403 1
|
监控 关系型数据库 MySQL
PowerShell 脚本编写 :自动化Windows 开发工作流程
PowerShell 脚本编写 :自动化Windows 开发工作流程
677 0
|
NoSQL 编译器 C语言
VSCode配置配置C++环境
VSCode配置配置C++环境
540 1
|
存储 安全 程序员
Windows任务管理器开发原理与实现
Windows任务管理器开发原理与实现
|
开发者 C# Windows
WPF与游戏开发:当桌面应用遇见游戏梦想——利用Windows Presentation Foundation打造属于你的2D游戏世界,从环境搭建到代码实践全面解析新兴开发路径
【8月更文挑战第31天】随着游戏开发技术的进步,WPF作为.NET Framework的一部分,凭借其图形渲染能力和灵活的UI设计,成为桌面游戏开发的新选择。本文通过技术综述和示例代码,介绍如何利用WPF进行游戏开发。首先确保安装最新版Visual Studio并创建WPF项目。接着,通过XAML设计游戏界面,并在C#中实现游戏逻辑,如玩家控制和障碍物碰撞检测。示例展示了创建基本2D游戏的过程,包括角色移动和碰撞处理。通过本文,WPF开发者可更好地理解并应用游戏开发技术,创造吸引人的桌面游戏。
969 0
|
开发者 iOS开发 C#
Uno Platform 入门超详细指南:从零开始教你打造兼容 Web、Windows、iOS 和 Android 的跨平台应用,轻松掌握 XAML 与 C# 开发技巧,快速上手示例代码助你迈出第一步
【8月更文挑战第31天】Uno Platform 是一个基于 Microsoft .NET 的开源框架,支持使用 C# 和 XAML 构建跨平台应用,适用于 Web(WebAssembly)、Windows、Linux、macOS、iOS 和 Android。它允许开发者共享几乎全部的业务逻辑和 UI 代码,同时保持原生性能。选择 Uno Platform 可以统一开发体验,减少代码重复,降低开发成本。安装时需先配置好 Visual Studio 或 Visual Studio for Mac,并通过 NuGet 或官网下载工具包。
1847 0