Visual Studio 2022新建 cmake 工程测试 opencv helloworld

1. 参考博客:

        1.1. https://blog.csdn.net/yangSHU21/article/details/130237669( 利用OpenCV把一幅彩色图像转换成灰度图 )( vs2022_cmake_test.cpp 中的代码用的此博客的,就改了下图片文件路径而已 )

2. 检查 Visual Studio 2022是否支持 cmake:

        打开 Visual Studio installer:

已安装--》修改:

 工作负荷--》使用C++的桌面开发--》可选--》如果 "用于 windows的 C++ cmake工具" 勾选了,即表示你的 Visual Studio 2022 支持 cmake:

3. 操作步骤:

        打开 Visual Studio 2022 --》创建新项目--》搜索 cmake--》选择 "cmake 项目( 生成不依赖于 .sln 或 .vcxproj 文件的新式跨平台 C++ 应用。 )"--》点击下一步--》 设置项目名称、位置--》点击创建,默认生成的 vs2022_cmake_test_02.cpp 文件内容如下:

#include "vs2022_cmake_test_02.h"
using namespace std;int main()
{cout << "Hello CMake." << endl;return 0;
}

默认生成的 CMakeLists.txt内容如下:        

cmake_minimum_required (VERSION 3.8)# 如果支持,请为 MSVC 编译器启用热重载。
if (POLICY CMP0141)cmake_policy(SET CMP0141 NEW)set(CMAKE_MSVC_DEBUG_INFORMATION_FORMAT "$<IF:$<AND:$<C_COMPILER_ID:MSVC>,$<CXX_COMPILER_ID:MSVC>>,$<$<CONFIG:Debug,RelWithDebInfo>:EditAndContinue>,$<$<CONFIG:Debug,RelWithDebInfo>:ProgramDatabase>>")
endif()project ("vs2022_cmake_test_02")# 将源代码添加到此项目的可执行文件。
add_executable (vs2022_cmake_test_02 "vs2022_cmake_test_02.cpp" "vs2022_cmake_test_02.h")if (CMAKE_VERSION VERSION_GREATER 3.12)set_property(TARGET vs2022_cmake_test_02 PROPERTY CXX_STANDARD 20)
endif()

将 vs2022_cmake_test.cpp 的内容修改为如下所示:

#include "vs2022_cmake_test_02.h"
#include <opencv2\opencv.hpp>using namespace cv;
using namespace std;void opencv_test();
void ConvertRGB2GRAY(const Mat& image, Mat& imageGray);void opencv_test() {Mat src = imread("D:/素材/图片/壁纸/0001.jpg");Mat src0 = imread("D:/素材/图片/壁纸/0001.jpg", 0);Mat grayImage;Mat cvt_gray_image;//读入的彩色图namedWindow("origin_image", WINDOW_NORMAL);imshow("origin_image", src);//opencv使用imread函数读入彩色图,设置第二个参数为0得到的灰度图namedWindow("opencv_image", WINDOW_NORMAL);imshow("opencv_image", src0);//使用公式GRAY=0.299*R+0.587*G+0.114*BConvertRGB2GRAY(src, grayImage);namedWindow("my_gray_image", WINDOW_NORMAL);imshow("my_gray_image", grayImage);//先读入彩色图,然后使用cvtColor函数进行灰度转化cvtColor(src, cvt_gray_image, COLOR_BGR2GRAY);namedWindow("cvt_gray_image", WINDOW_NORMAL);imshow("cvt_gray_image", cvt_gray_image);waitKey(0);
}void ConvertRGB2GRAY(const Mat& image, Mat& imageGray)
{if (!image.data || image.channels() != 3){return;}//创建一张单通道的灰度图像imageGray = Mat::zeros(image.size(), CV_8UC1);//取出存储图像像素的数组的指针uchar* pointImage = image.data;uchar* pointImageGray = imageGray.data;//取出图像每行所占的字节数size_t stepImage = image.step;size_t stepImageGray = imageGray.step;for (int i = 0; i < imageGray.rows; i++){for (int j = 0; j < imageGray.cols; j++){//opencv的通道顺序是BGR,而不是我们常说的RGB顺序pointImageGray[i * stepImageGray + j] =(uchar)(0.114 * pointImage[i * stepImage + 3 * j] +0.587 * pointImage[i * stepImage + 3 * j + 1] +0.299 * pointImage[i * stepImage + 3 * j + 2]);}}
}int main()
{cout << "Hello CMake." << endl;opencv_test();return 0;
}

此时 vs2022 报错 "找不到opencv 的头文件":

 找到 opencv2 的位置如下所示:

可以直接将 "D:\install\opencv\opencv\build\include" 加入进来,即在 CMakeLists.txt 中加入 如下指令:

include_directories( "D:/install/opencv/opencv/build/include" ) 

但是这样不太优雅,优雅的做法是加入如下指令:

 find_package(OpenCV REQUIRED) 

其作用是查找 OpenCV 包,找到以后就可以直接使用内置变量 OpenCV_INCLUDE_DIRS 和 OpenCV_LIBS 了( 分别表示 opencv 的 头文件的目录位置和 链接库的目录位置 ),但是 cmake 是从哪里去找 opencv 呢?可能它内置的有一些策略吧,不放心的话或者电脑装了多个版本的 opencv,其实可以手动指定查找位置,即使用如下指令:

set(OpenCV_DIR "D:/install/opencv/opencv/build")

这里指定 "D:/install/opencv/opencv/build" 的依据是什么呢?到底是 opencv 的根目录还是头文件目录还是链接库目录呢?其实应该写 opencv 编译目录中 

OpenCVConfig.cmake

文件所在的目录,例如我电脑中 OpenCVConfig.cmake  所在位置如下所示:

所以我指定的是  D:/install/opencv/opencv/build( ps:windows中 CMakeLists.txt 中的路径最好写正斜线,不能写反斜线!!!不知道双反斜线可不可以?没试过 )

修改后的最终完整的 CMakeLists.txt 如下所示:

cmake_minimum_required (VERSION 3.8)# 如果支持,请为 MSVC 编译器启用热重载。
if (POLICY CMP0141)cmake_policy(SET CMP0141 NEW)set(CMAKE_MSVC_DEBUG_INFORMATION_FORMAT "$<IF:$<AND:$<C_COMPILER_ID:MSVC>,$<CXX_COMPILER_ID:MSVC>>,$<$<CONFIG:Debug,RelWithDebInfo>:EditAndContinue>,$<$<CONFIG:Debug,RelWithDebInfo>:ProgramDatabase>>")
endif()project ("vs2022_cmake_test_02")set(OpenCV_DIR "D:/install/opencv/opencv/build")
# 查找OpenCV包
find_package(OpenCV REQUIRED)# include_directories( "D:/install/opencv/opencv/build/include" )
# set(CMAKE_LIBRARY_PATH "D:/install/opencv/opencv/build/x64/vc16/bin"  "D:/install/opencv/opencv/build/x64/vc16/lib" )# 如果OpenCV被找到,包含其头文件目录和库
message( "--------------------------------------------------" )
message( "--------------------------------------------------" )
message( "--------------------------------------------------" )
message( "OpenCV_INCLUDE_DIRS = ${OpenCV_INCLUDE_DIRS}"  )
message( "OpenCV_LIBS = ${OpenCV_LIBS}" )
message( "OpenCV_FOUND = ${OpenCV_FOUND}" )if(OpenCV_FOUND)message( "OpenCV founded" )include_directories(${OpenCV_INCLUDE_DIRS})
endif()# 将源代码添加到此项目的可执行文件。
add_executable (vs2022_cmake_test_02 "vs2022_cmake_test_02.cpp" "vs2022_cmake_test_02.h")if(OpenCV_FOUND)message( "OpenCV founded" )target_link_libraries(vs2022_cmake_test_02 ${OpenCV_LIBS})
endif()message( "------------------------------------------------" )
message( "-----------------------------------------------" )
message( "--------------------------------------------------" )if (CMAKE_VERSION VERSION_GREATER 3.12)set_property(TARGET vs2022_cmake_test_02 PROPERTY CXX_STANDARD 20)
endif()

这时候编译就成功了,部分输出信息如下:

1> 工作目录: D:/code/c_code/cpp_study_demo/vs2022/vs2022_cmake_test_02/out/build/x64-debug
1> [CMake] -- OpenCV ARCH: x64
1> [CMake] -- OpenCV RUNTIME: vc16
1> [CMake] -- OpenCV STATIC: OFF
1> [CMake] -- Found OpenCV 4.10.0 in D:/install/opencv/opencv/build/x64/vc16/lib
1> [CMake] -- You might need to add D:\install\opencv\opencv\build\x64\vc16\bin to your PATH to be able to run your applications.
1> [CMake] --------------------------------------------------
1> [CMake] --------------------------------------------------
1> [CMake] --------------------------------------------------
1> [CMake] OpenCV_INCLUDE_DIRS = D:/install/opencv/opencv/build/include
1> [CMake] OpenCV_LIBS = opencv_calib3d;opencv_core;opencv_dnn;opencv_features2d;opencv_flann;opencv_gapi;opencv_highgui;opencv_imgcodecs;opencv_imgproc;opencv_ml;opencv_objdetect;opencv_photo;opencv_stitching;opencv_video;opencv_videoio;opencv_world
1> [CMake] OpenCV_FOUND = 1
1> [CMake] OpenCV founded
1> [CMake] OpenCV founded
1> [CMake] ------------------------------------------------
1> [CMake] -----------------------------------------------
1> [CMake] --------------------------------------------------
1> [CMake] -- Configuring done (0.0s)
1> [CMake] -- Generating done (0.0s)
1> [CMake] -- Build files have been written to: D:/code/c_code/cpp_study_demo/vs2022/vs2022_cmake_test_02/out/build/x64-debug
1> 已提取 CMake 变量。
1> 已提取源文件和标头。
1> 已提取代码模型。
1> 已提取工具链配置。
1> 已提取包含路径。
1> CMake 生成完毕。

可以看到 :

OpenCV_INCLUDE_DIRS = D:/install/opencv/opencv/build/include
OpenCV_LIBS = opencv_calib3d;opencv_core;opencv_dnn;opencv_features2d;opencv_flann;opencv_gapi;opencv_highgui;opencv_imgcodecs;opencv_imgproc;opencv_ml;opencv_objdetect;opencv_photo;opencv_stitching;opencv_video;opencv_videoio;opencv_world

这时候运行 vs2022_cmake_test_02.exe报错:

使用 Everything 搜索下 opencv_world4100.dll:

应该把 D:\install\opencv\opencv\build\x64\vc16\bin 加入环境变量,其实刚才 cmake 的输入信息中已经建议这样做了:

1> [CMake] -- Found OpenCV 4.10.0 in D:/install/opencv/opencv/build/x64/vc16/lib
1> [CMake] -- You might need to add D:\install\opencv\opencv\build\x64\vc16\bin to your PATH to be able to run your applications.
1> [CMake] --------------------------------------------------
1> [CMake] --------------------------------------------

加入环境变量:

 这时候就运行成功了:

 记得打开新的 cmd 测试,如果是在 vs2022中测试也需要关闭工程重新打开进行测试。

4. CMakeLists.txt 中直接使用的变量 OpenCV_INCLUDE_DIRS、OpenCV_LIBS、OpenCV_FOUND 是在哪里定义的?

打开 D:\install\opencv\opencv\build 下面的 OpenCVConfig.cmake,找到如下内容:

#    This file will define the following variables:
#      - OpenCV_LIBS                     : The list of libraries to link against.
#      - OpenCV_INCLUDE_DIRS             : The OpenCV include directories.
#      - OpenCV_COMPUTE_CAPABILITIES     : The version of compute capability
#      - OpenCV_VERSION                  : The version of this OpenCV build: "4.10.0"
#      - OpenCV_VERSION_MAJOR            : Major version part of OpenCV_VERSION: "4"
#      - OpenCV_VERSION_MINOR            : Minor version part of OpenCV_VERSION: "10"
#      - OpenCV_VERSION_PATCH            : Patch version part of OpenCV_VERSION: "0"
#      - OpenCV_VERSION_STATUS           : Development status of this build: ""

说此文件定义了这几个变量,但是这只是注释,此文件并没有直接有声明比如 set( OpenCV_INCLUDE_DIRS ... )  的地方,可能是 该文件引用的其他文件声明了,在该文件中找到了如下内容:


function(check_one_config RES)set(${RES} "" PARENT_SCOPE)if(NOT OpenCV_RUNTIME OR NOT OpenCV_ARCH)return()endif()set(candidates)if(OpenCV_STATIC)list(APPEND candidates "${OpenCV_ARCH}/${OpenCV_RUNTIME}/staticlib")endif()if(OpenCV_CUDA)list(APPEND candidates "gpu/${OpenCV_ARCH}/${OpenCV_RUNTIME}/lib")endif()if(OpenCV_CUDA AND OpenCV_STATIC)list(APPEND candidates "gpu/${OpenCV_ARCH}/${OpenCV_RUNTIME}/staticlib")endif()list(APPEND candidates "${OpenCV_ARCH}/${OpenCV_RUNTIME}/lib")foreach(c ${candidates})set(p "${OpenCV_CONFIG_PATH}/${c}")if(EXISTS "${p}/OpenCVConfig.cmake")set(${RES} "${p}" PARENT_SCOPE)return()endif()endforeach()
endfunction()

定义了一个集合变量 candidates,如下一行:

 list(APPEND candidates "${OpenCV_ARCH}/${OpenCV_RUNTIME}/lib")

应该是往集合 candidates 中追加一个路径类型的元素,其中路径中的 OpenCV_ARCH 应该对应我电脑环境的 x64,OpenCV_RUNTIME 应该对应 vc16,果然在 D:\install\opencv\opencv\build\x64\vc16\lib 下面找到了 OpenCVConfig.cmake:

打开此文件,发现了定了定义变量 OpenCV_INCLUDE_DIRS 的地方:

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/49775.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SpringBoot 配置文件详解:properties 和 yml

目录 一、配置文件的作用 二、配置文件的格式 三、properties 配置文件说明 3.1 properties 基本语法 3.2 读取配置文件 四、yml 配置文件说明 4.1 yml基本语法 4.2 yml 读取文件 4.3 yml使用进阶 4.3.1 配置对象 4.3.2 配置集合 4.3.3 配置Map 一、配置文件的作用…

大数据之Oracle同步Doris数据不一致问题

数据同步架构如下&#xff1a; 出现的问题&#xff1a; doris中的数据条数 源库中的数据条数 总数完全不一致。 出现问题的原因&#xff1a; 在Dinky中建立表结构时&#xff0c;缺少对主键属性的限制 primary key(ID) not enforced 加上如上语句&#xff0c;数据条数解决一致 …

Internxt:适用于Linux开源安全云存储平台

有无数的云存储平台为您的文件提供安全可靠的存储空间。可在 Linux 上安装的热门云存储应用程序包括Dropbox、Nextcloud和Google Drive&#xff0c;遗憾的是&#xff0c;后者迄今为止不提供 Linux 客户端。 其他自托管选项包括OwnCloud、Pydio Cells、Seafile、Resilio和Synct…

学懂C语言(二十一):深入理解C语言中的函数指针和回调函数

C语言中的函数指针和回调函数是两个紧密相关的概念&#xff0c;它们在实现灵活和模块化的代码结构时非常有用。下面详细讲解这两个概念&#xff1a; 1、函数指针 函数指针是一个指向函数的指针变量。通过函数指针&#xff0c;可以间接调用函数&#xff0c;这在需要动态选择和…

matlab 小数取余 rem 和 mod有 bug

目录 前言Matlab取余函数1 mod 函数1.1 命令行输入1.2 命令行输出 2 rem 函数2.1 命令行输入2.2 命令行输出 分析原因注意 前言 在 Matlab 代码中mod(0.11, 0.1) < 0.01 判断为真&#xff0c;mod(1.11, 0.1) < 0.01判断为假&#xff0c;导致出现意料外的结果。 结果发现…

Leetcode509. 斐波那契数(递归和常规两种写法)

问题描述&#xff1a; 斐波那契数 &#xff08;通常用 F(n) 表示&#xff09;形成的序列称为 斐波那契数列 。该数列由 0 和 1 开始&#xff0c;后面的每一项数字都是前面两项数字的和。也就是&#xff1a; F(0) 0&#xff0c;F(1) 1 F(n) F(n - 1) F(n - 2)&#xff0c;…

代码自动化重构工具OpenRewrite介绍

OpenRewrite 是一个用于大规模自动化代码重构的开源框架&#xff0c;它极大地提升了开发人员的研发效率&#xff0c;通过自动化地进行代码重构和转换&#xff0c;帮助开发人员消除代码库中的技术债务。 通过 LST、访问器和配方的结合&#xff0c;OpenRewrite 能够实现准确的代…

Python知识点背诵手册,详细知识梳理

Python知识点背诵手册&#xff0c;超详细知识梳理 Python是一种广泛使用的高级编程语言&#xff0c;以其简洁的语法和强大的库支持而闻名。以下是对Python知识点的超详细梳理&#xff0c;旨在帮助学习者系统地掌握Python语言的基础知识和进阶技能。 一、Python基础 1. 语言基…

走进数组的奇妙之旅(1)-学习笔记

引言&#xff1a; 在前几篇文章中&#xff0c;我们深入探讨了函数的奥秘。在讲述函数知识的过程中&#xff0c;我们邂逅了一个新的概念&#xff0c;你或许还记得在演示 strcpy函数时&#xff0c;出现的这行代码&#xff1a;char1[20]{0};。当时&#xff0c;你是否感到好奇&…

【MSP430】MSP430是什么?与STM32对比哪个性能更佳?

一、MSP430是什么&#xff1f; MSP430F5529LP是一款由德州仪器&#xff08;TI&#xff09;推出的16位微控制器单元&#xff08;MCU&#xff09;开发板&#xff0c;具有USB功能&#xff0c;内存配置为128KB闪存和8KB RAM&#xff0c;工作频率高达25MHz。 这款MCU以其高性能和多…

软考中级网络工程师考什么?应该怎么正确备考

网络工程师软考中级难易度50%&#xff0c;不太难。但是如果准备不足就悬了&#xff0c;赶紧备考起来吧。 网络工程师每年考两次&#xff0c;相比其他的软考考试一年中考的机会又多了一次&#xff0c;而且软考网工也是挺热门的科目&#xff0c;每年很多人报考&#xff0c;相对的…

视觉语言动作模型:从网页知识到机器人控制的实战RT-2

作者&#xff1a; Anthony Brohan, Noah Brown, Justice Carbajal, Yevgen Chebotar, Xi Chen, Krzysztof Choromanski, Tianli Ding, Danny Driess, Avinava Dubey, Chelsea Finn, Pete Florence, Chuyuan Fu, Montse Gonzalez Arenas, Keerthana Gopalakrishnan, Kehang Han…

【深度学习】PyTorch框架(5):Transformer和多注意力机制

1、引言 在本文中&#xff0c;我们将探讨近两年来最具影响力的模型架构之一——Transformer模型。自从2017年Vaswani等人发表的论文《注意力是你所需要的全部》以来&#xff0c;Transformer架构在多个领域持续刷新着性能记录&#xff0c;尤其是在自然语言处理&#xff08;NLP&…

DEF_COLOR.py 终端打印显示颜色(Linux/Windows)

打印内容一多&#xff0c;不用颜色区分看着吃力 # -*- coding: utf8 -*- import os## 终端显示颜色 if os.name nt: # Windowsimport ctypes,sysSTD_OUTPUT_HANDLE -11# Windows CMD命令行 字体颜色定义 text colors黑字 0x00 # black.暗蓝字 0x01 # dark blue.暗绿…

C++学习补充2:MySQL select 查询

MySQL select 查询 MySQL 查询 select时&#xff0c; 不区分大小写的。 MySQL 在默认情况下是区分大小写的&#xff0c;但是它的行为可能因配置和使用的字符集而有所不同。以下是一些可能导致查询在 SELECT 语句中不区分大小写的原因&#xff1a; 字符集设置&#xff1a;如果…

释放硬件潜能:Xcode中应用硬件加速开发的深度指南

释放硬件潜能&#xff1a;Xcode中应用硬件加速开发的深度指南 在现代应用开发中&#xff0c;充分利用硬件资源是提升应用性能的关键。Xcode&#xff0c;作为苹果的官方集成开发环境&#xff08;IDE&#xff09;&#xff0c;提供了强大的工具和框架来支持硬件加速开发。本文将详…

CSI-RS在信道中传输的过程

简单介绍CSI-RS信号生成&#xff0c;在信道中传输和接收的过程 1.载波配置 首先需要配置载波相关的参数 系统带宽和子载波间隔 5G NR中&#xff0c;系统带宽和子载波间隔是两个关键参数&#xff0c;共同决定无线资源的分配和使用 系统带宽 5G NR支持广泛的系统带宽&…

Xcode应用开发:自定义图表的终极指南

Xcode应用开发&#xff1a;自定义图表的终极指南 在移动应用开发中&#xff0c;图表是一种展示数据的强大工具&#xff0c;它可以帮助用户直观地理解复杂信息。Xcode&#xff0c;作为苹果官方的集成开发环境&#xff08;IDE&#xff09;&#xff0c;提供了丰富的工具和框架来创…

碳酸锂溶液树脂吸附除钙镁的方法和工艺流程

碳酸锂溶液作为一种重要的化工原料&#xff0c;主要用于锂电池的制造和其他化学合成过程。它对纯度有较高要求&#xff0c;因此在制备和处理过程中&#xff0c;去除杂质如钙镁离子是非常关键的步骤。 关于碳酸锂溶液除钙镁的方法&#xff0c;几种常见的处理技术包括沉淀法、离…

C++ | Leetcode C++题解之第264题丑数II

题目&#xff1a; 题解&#xff1a; class Solution { public:int nthUglyNumber(int n) {vector<int> dp(n 1);dp[1] 1;int p2 1, p3 1, p5 1;for (int i 2; i < n; i) {int num2 dp[p2] * 2, num3 dp[p3] * 3, num5 dp[p5] * 5;dp[i] min(min(num2, num3…