前言
?? 本文包括VScode安装、C++环境配置以及OpenCV配置全过程。VS Studio配置OpenCV比较简单,可以直接使用OpenCV官网已有的用VS Studio编译器编译好的OpenCV库。但VS Code不能直接利用VS Studio编译好的OpenCV库,因此需要借助MinGW-64和CMake工具对OpenCV源码重新进行编译(编译前提是C:\Users目录下不能包含中文,否则无法成功编译)。
一、资源下载
1、VS Code
?百度网盘是我自己下载的版本,与官网最新版本不一定一致。 ?? 1)百度网盘下载:VSCodeSetup-x64-1.66.2.exe (提取码:ggec) ?? 2)官网下载:Visual Studio Code(官网下载速度很慢,可以安装IDM,使用方法可参考下载外网资源加速) data:image/s3,"s3://crabby-images/8f2a3/8f2a3bf381d118015aceed328652fe2c73dab59e" alt="在这里插入图片描述"
2、MinGW-w64
?? 1)百度网盘下载:x86_64-8.1.0-release-posix-seh-rt_v6-rev0.7z (提取码:2dis) ?? 2)官网下载:MinGW-w64离线包下载地址(一定要是"seh"后缀的,千万别错了!!!) data:image/s3,"s3://crabby-images/b2f92/b2f9291ed995ae37f3bd2aa5244e278fa985c561" alt="在这里插入图片描述"
3、CMake
?? 1)百度网盘下载:cmake-3.9.0-rc3-win64-x64 .zip (提取码:zgqi) ?? 2)官网下载:CMake(要选择二进制文件,即Binary distributions栏目) data:image/s3,"s3://crabby-images/35fb8/35fb8b4619b620357f14353e456b5a10ec9f7181" alt="在这里插入图片描述"
4、OpenCV
?? 1)百度网盘下载:opencv-4.5.5-vc14_vc15.exe (提取码:0hf7) ?? 2)官网下载:OpenCV data:image/s3,"s3://crabby-images/c3e03/c3e03033a2da2c041b833a73fc4c816fc849fa22" alt="在这里插入图片描述"
二、环境配置
1、VS Code安装
??双击.exe文件开始安装,同意此协议,点击下一步: data:image/s3,"s3://crabby-images/5b2bf/5b2bfdb82f3c2c5227fd71c9d03d8b1c238345e4" alt="在这里插入图片描述" ??选择安装路径,点击下一步: data:image/s3,"s3://crabby-images/1443c/1443ce34d67df1e6be5f1806156d685292b1c8ac" alt="在这里插入图片描述" ??点击下一步: data:image/s3,"s3://crabby-images/0f84f/0f84f32b3b8bf8d1f5e0245613ce86197de352bc" alt="在这里插入图片描述" ??根据图中提示勾选,点击下一步: data:image/s3,"s3://crabby-images/e81e9/e81e97429b26f07a7833e4eeba377a68c378468d" alt="在这里插入图片描述" ??点击安装: data:image/s3,"s3://crabby-images/7c47e/7c47ee3edf9f165a5c4f748f93699d661c65d135" alt="在这里插入图片描述"
2、VS Code的C++配置
??选择喜欢的界面形式,点击Mark Done: data:image/s3,"s3://crabby-images/0e184/0e1842ec14fd17bf48fbff311985047e03bc130d" alt="在这里插入图片描述" ??按图中所示步骤安装C/C++、C/C++ Extension Pack、C/C++ Intellisense、Code Runner插件: data:image/s3,"s3://crabby-images/9d926/9d9265048d579ac3bf93dac8435461100d28997d" alt="在这里插入图片描述" ??桌面新建一个test文件夹,再在VS Code界面点击Open Folder打开文件夹,进行简单测试: data:image/s3,"s3://crabby-images/e522e/e522e1ed33806a81c5e532d6665064aac8230afe" alt="在这里插入图片描述" ??选择trust: data:image/s3,"s3://crabby-images/8c513/8c51347f114fcebabce9b0a5fdbabe974a7496d9" alt="在这里插入图片描述" ??点击左上角File --> New File --> 按ctrl+s保存文件名为hello.cpp,写一个测试代码:
#include<iostream>
using namespace std;
int main(){
cout<<"Hello,VScode!"<<endl;
return 0;
}
??点击右上角三角形进行编译: data:image/s3,"s3://crabby-images/7e1b9/7e1b9c3101b037bd57fae618ce521dcca9c0c63b" alt="在这里插入图片描述" ??这个地方报错,是因为VS Code只是一个编辑器,如果想正常运行C++程序还需要安装编译器。
3、MinGW-w64安装
??解压MinGW-w64压缩包,存在下图文件夹: data:image/s3,"s3://crabby-images/c18bf/c18bf057282e3e416794def69b86e9cddaab8ce9" alt="在这里插入图片描述" ??将该文件夹的bin路径添加到环境变量中: ??检查MinGW-w64是否安装成功,若成功则如下图所示: data:image/s3,"s3://crabby-images/48ef8/48ef8240d6cbbd3cf6515846da7eac9db7f7d1ee" alt="在这里插入图片描述" ??重启VS Code,再次运行程序成功: data:image/s3,"s3://crabby-images/e1852/e185294941157fdb40e342d50892bb7b8f3ebea6" alt="在这里插入图片描述"
4、OpenCV配置
??将opencv-4.5.5-vc14_vc15.exe解压到除C盘外的其他盘内(若是C盘,cmake 时很可能报错) data:image/s3,"s3://crabby-images/58ba6/58ba67a1f347e7a53c7d315b1e64bec944ca7199" alt="在这里插入图片描述" ??在 opencv\build\x64 路径下新建一个文件夹(可自起,这里是 MinGW ) data:image/s3,"s3://crabby-images/f8e44/f8e4423f92577c3eba0498f2eb318ab44b4cc5f6" alt="在这里插入图片描述"
5、CMake安装
??将cmake-3.9.0-rc3-win64-x64解压,文件夹如图所示: data:image/s3,"s3://crabby-images/efae8/efae8dbb7f03d17e531203a5a5185c0603463bf9" alt="在这里插入图片描述" ??将该文件夹下的bin文件路径添加到环境变量: data:image/s3,"s3://crabby-images/68908/689080550114e514235b9fc451d33e8d4d9c4e37" alt="在这里插入图片描述" ??检查cmake是否安装成功: data:image/s3,"s3://crabby-images/02536/02536868f926632bc54f70df994370d9f7b67d26" alt="在这里插入图片描述"
6、生成MakeFiles
??进入D:\cmake-3.9.0-rc3-win64-x64\bin,先不要进行任何操作: data:image/s3,"s3://crabby-images/ab295/ab29530c599be4c55f135d9fc97b48b106b12012" alt="在这里插入图片描述" ??在操作cmake-gui之前,如果没有翻过墙的话,先用记事本方式打开C:\Windows\System32\drivers\etc\hosts,在文件的末尾加上151.101.72.133 raw.githubusercontent.com(因为cmake-gui会下载一些文件, 这些文件都在raw.githubusercontent.com上, 如果不修改一下hosts,许多文件很可能会下载失败)。(如果hosts文件修改后无法保存,则是因为电脑默认hosts权限为只读,在属性里修改hosts文件为可写即可成功保存,记得环境配置好之后把hosts属性改回去,以保护电脑安全性)。 data:image/s3,"s3://crabby-images/6e9dc/6e9dcfd9419fa71d519ecb83c501fa20419d9e89" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/36cb6/36cb6b3753cf44b2d7344047580cb6863a585bdf" alt="在这里插入图片描述" ??打开cmake-gui,选择OpenCV的源文件路径和MakeFiles保存路径(即之前新建的MinGW): data:image/s3,"s3://crabby-images/ba135/ba135c723b96a14511dbfca5a7132ee31e3167e4" alt="在这里插入图片描述" ??点击Configure,弹窗配置如下,点击Next: data:image/s3,"s3://crabby-images/3fd12/3fd123b7d6177fea480bac95ed87942208193a3a" alt="在这里插入图片描述" ??选择前面安装的D:/mingw64/bin文件夹下的gcc.exe和g++.exe,点击Finsh data:image/s3,"s3://crabby-images/b4ff2/b4ff2b4ff9c01dc2b06267c579d7e68079bf760c" alt="在这里插入图片描述" ??执行过程中消息框会出现一堆红色信息,最后显示Configure done,是正常的。显示Configure done后,勾选BUILD_ opencv_world、WITH_ OPENGL和BUILD EXAMPLES,不勾选WITH_IPP、WITH_MSMF和ENABLE_PRECOMPILED_HEADERS (如果有的话),CPU_ DISPATCH选空。再次点击Configure,这时会发现没有红色错误信息了。显示Configure done之后再点击Generate,会显示Generate Done: data:image/s3,"s3://crabby-images/43238/4323824eb4152b66d2b4a8b60ebff34055b33da3" alt="在这里插入图片描述"
7、编译OpenCV
??cmd到MakeFiles所在文件夹,执行如下命令:
minGW32-make -j 8
data:image/s3,"s3://crabby-images/6415d/6415dcfc947b99fc7de5ba944d7fa895baf45e7c" alt="在这里插入图片描述" ??如果报错可查阅编译报错解答,如果编译成功则执行如下命令完成装载:
mingw32-make install
data:image/s3,"s3://crabby-images/0f532/0f53210894df3ef27727478a29dae7606ae6ff3f" alt="在这里插入图片描述" ??将D:\opencv\build\x64\MinGW\bin加入环境变量: data:image/s3,"s3://crabby-images/1c244/1c244d8f81283ed5b488b2aacc8b8dece9d81dd2" alt="在这里插入图片描述"
8、VS Code配置
(1)launch.json配置
data:image/s3,"s3://crabby-images/9d0a0/9d0a04b247e7762ed887eeacd536af1499920ccb" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/5a438/5a4384f76b03824a1d963045f9ff0e6666c2a7ae" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/205c3/205c3c4d60a7dd0735e802845bcdd49f95497b59" alt="在这里插入图片描述" ??在生成的launch.json文件中复制一下代码(需要配置miDebuggerPath项,注意修改name、preLaunchTask的 opencv版本号):
{
"version": "0.2.0",
"configurations": [
{
"name": "opencv4.5.5 debuge",
"type": "cppdbg",
"request": "launch",
"program": "${workspaceFolder}\\${fileBasenameNoExtension}.exe",
"args": [],
"stopAtEntry": true,
"cwd": "${workspaceFolder}",
"environment": [],
"externalConsole": true,
"MIMode": "gdb",
"miDebuggerPath": "D:/mingw64/bin/gdb.exe",
"setupCommands": [
{
"description": "为 gdb 启用整齐打印",
"text": "-enable-pretty-printing",
"ignoreFailures": false
}
],
"preLaunchTask": "opencv4.5.5 compile task"
}
]
}
(2)c_cpp_properties.json配置
??按快捷键crtl+shift+p,出现如下弹窗: ??点击C/C++:Edit Confighrations(UI)进行如下配置: data:image/s3,"s3://crabby-images/82062/82062e47e69fc135762f7379e483e5ff52d76b97" alt="在这里插入图片描述"
data:image/s3,"s3://crabby-images/ae5cc/ae5cc4e5d7f1a38fb5169981ba8139bb579eec17" alt="在这里插入图片描述" data:image/s3,"s3://crabby-images/23dab/23dab3b9b82b7069946437394decf4e21a604324" alt="在这里插入图片描述" ??配置完成会自动生成c_cpp_properties.json文件: data:image/s3,"s3://crabby-images/38aef/38aef2c4c8f44284dbb48266361b2c724a567036" alt="在这里插入图片描述"
(3)task.json配置
??点击Terminal的Configure Tasks: data:image/s3,"s3://crabby-images/b2cb3/b2cb3ad9e0db80f97a4b119c34a8acc0acdf5b20" alt="在这里插入图片描述" ??出现如下弹窗,选择C/C++:g++.exe生成活动文件 data:image/s3,"s3://crabby-images/62094/620945ccb10163e29d1dc6893b63349120f9041a" alt="在这里插入图片描述" ??生成task.json文件: data:image/s3,"s3://crabby-images/fb640/fb640f1197ac865a264550c0c45f4373d958a5e6" alt="在这里插入图片描述"
(4)settings.json配置
??按ctrl+, 出现如下弹窗,输入code-runner:Executor Map,点击下方的 Edit in settings.json data:image/s3,"s3://crabby-images/91902/919029cc306989828809b2461ed5ef5f39f9f0b5" alt="" 点击 Edit in settings.json之后会生成settigs.json(该文件地址是:C:\Users\WCJ\AppData\Roaming\Code\User\settings.json),在生成的settings.json中复制如下代码:
{
"workbench.colorTheme": "Default Light+",
"editor.suggest.snippetsPreventQuickSuggestions": false,
"code-runner.runInTerminal": true,
"files.autoSave": "afterDelay",
"code-runner.executorMap": {
"javascript": "node",
"java": "cd $dir && javac $fileName && java $fileNameWithoutExt",
"c": "cd $dir && gcc $fileName -o $fileNameWithoutExt && $dir$fileNameWithoutExt",
"cpp":"cd $dir && g++ $fileName -o $fileNameWithoutExt -I D:/opencv/build/include -L D:/opencv/build/x64/MinGW/bin -l libopencv_world455 -l opencv_videoio_ffmpeg455_64 && $dir$fileNameWithoutExt",
"objective-c": "cd $dir && gcc -framework Cocoa $fileName -o $fileNameWithoutExt && $dir$fileNameWithoutExt",
"php": "php",
"python": "python -u",
"perl": "perl",
"perl6": "perl6",
"ruby": "ruby",
"go": "go run",
"lua": "lua",
"groovy": "groovy",
"powershell": "powershell -ExecutionPolicy ByPass -File",
"bat": "cmd /c",
"shellscript": "bash",
"fsharp": "fsi",
"csharp": "scriptcs",
"vbscript": "cscript //Nologo",
"typescript": "ts-node",
"coffeescript": "coffee",
"scala": "scala",
"swift": "swift",
"julia": "julia",
"crystal": "crystal",
"ocaml": "ocaml",
"r": "Rscript",
"applescript": "osascript",
"clojure": "lein exec",
"haxe": "haxe --cwd $dirWithoutTrailingSlash --run $fileNameWithoutExt",
"rust": "cd $dir && rustc $fileName && $dir$fileNameWithoutExt",
"racket": "racket",
"scheme": "csi -script",
"ahk": "autohotkey",
"autoit": "autoit3",
"dart": "dart",
"pascal": "cd $dir && fpc $fileName && $dir$fileNameWithoutExt",
"d": "cd $dir && dmd $fileName && $dir$fileNameWithoutExt",
"haskell": "runhaskell",
"nim": "nim compile --verbosity:0 --hints:off --run",
"lisp": "sbcl --script",
"kit": "kitc --run",
"v": "v run",
"sass": "sass --style expanded",
"scss": "scss --style expanded",
"less": "cd $dir && lessc $fileName $fileNameWithoutExt.css",
"FortranFreeForm": "cd $dir && gfortran $fileName -o $fileNameWithoutExt && $dir$fileNameWithoutExt",
"fortran-modern": "cd $dir && gfortran $fileName -o $fileNameWithoutExt && $dir$fileNameWithoutExt",
"fortran_fixed-form": "cd $dir && gfortran $fileName -o $fileNameWithoutExt && $dir$fileNameWithoutExt",
"fortran": "cd $dir && gfortran $fileName -o $fileNameWithoutExt && $dir$fileNameWithoutExt"
},
"window.zoomLevel": 1,
"files.associations": {
"iostream": "cpp",
"ostream": "cpp"
}
}
三、测试案例
1、测试代码
#include <iostream>
#include <opencv2\highgui\highgui.hpp>
#include <opencv2\opencv.hpp>
using namespace std;
using namespace cv;
int main()
{
string path = "C:/Users/WCJ/Desktop/0402/01/0.bmp";
cv::Mat img = imread(path);
imshow("img",img);
waitKey(0);
return 0;
}
2、测试结果
data:image/s3,"s3://crabby-images/f7192/f7192008dbd5ca96d2138a0028661c00e818eaea" alt="在这里插入图片描述"
|