gpt4 book ai didi

c++ - 访问违规读取位置 OpenCV Canny 函数

转载 作者:行者123 更新时间:2023-11-28 06:04:58 25 4
gpt4 key购买 nike

我在 OpeCV 中的项目有问题。我想获取图片,这是两张图片相减的结果,然后使用 Canny Edge Detector 获取标记边缘,但只有我得到的是异常。

这是一个异常(exception)的打印屏幕:

enter image description here

这是我的代码:

#pragma once
#include <opencv2/core/core.hpp>
#include <opencv2/imgcodecs.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/opencv.hpp>
#include <iostream>
#include <string>

using namespace cv;
using namespace std;

int main(int argc, char** argv)
{
Mat pierwszy = imread("one.jpg", IMREAD_COLOR);
Mat drugi = imread("two.jpg", IMREAD_COLOR);
Mat wynik;
subtract(pierwszy, drugi , wynik);
imwrite("../../images/wynik.jpg", wynik);
Canny(wynik, wynik, 33, 100);
namedWindow("Display window", WINDOW_AUTOSIZE);
imshow("Display window", wynik);
waitKey(0);
return 0;
}

Mat 的对象大小相同。

最佳答案

要使用 Cany Edge Detector,我们需要制作灰度图像,如 Miki 所说。现在我将函数 cvtColorCOLOR_BGR2GRAY 一起使用,我的代码如下所示:

#pragma once
#include <opencv2/core/core.hpp>
#include <opencv2/imgcodecs.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/opencv.hpp>
#include <iostream>
#include <string>

using namespace cv;
using namespace std;

int main(int argc, char** argv)
{
Mat pierwszy = imread("one.jpg", IMREAD_COLOR);
Mat drugi = imread("two.jpg", IMREAD_COLOR);
Mat wynik;
subtract(pierwszy, drugi , wynik);
imwrite("../../images/wynik.jpg", wynik);
Mat wynik_gray;
cvtColor(wynik, wynik_gray, COLOR_BGR2GRAY);
Canny(wynik_gray, wynik_gray, 33, 100);
namedWindow("Display window", WINDOW_AUTOSIZE);
imshow("Display window", wynik_gray);
waitKey(0);
return 0;
}

关于c++ - 访问违规读取位置 OpenCV Canny 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32571274/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com