从OpenCV坎尼边缘检测器获取角度
Get angle from OpenCV Canny edge detector
我想使用OpenCV的Canny边缘检测器,如本问题中所述。例如:
cv::Canny(image,contours,10,350);
但是,我不仅希望获得最终的阈值图像,而且还希望获得每个像素处检测到的边缘角度。这在OpenCV中可能吗?
>canny
没有直接给你这个。但是,您可以从 Sobel 变换计算角度,该变换在 canny()
内部使用。
伪代码:
cv::Canny(image,contours,10,350);
cv::Sobel(image, dx, CV_64F, 1, 0, 3, 1, 0, cv::BORDER_REPLICATE);
cv::Sobel(image, dy, CV_64F, 0, 1, 3, 1, 0, cv::BORDER_REPLICATE);
cv::Mat angle(image.size(), CV_64F)
foreach (i,j) such that contours[i, j] > 0
{
angle[i, j] = atan2(dy[i,j], dx[i , j])
}
除了使用 for 循环之外,您还可以向返回角度方向灰度图像的函数提供dx
和dy
渐变phase
然后将其传递给applyColorMap
函数,然后用边缘遮罩它,因此背景是黑色的。
以下是工作流程:
-
获取角度
Mat angles; phase(dx, dy, angles, true);
true
参数表明角度以度为单位返回。 -
将角度范围更改为 0-255,以便您可以转换为CV_8U而不会丢失数据
angles = angles / 360 * 255;
请注意,
angles
仍然是CV_64F
类型,因为它来自 Sobel 函数 -
转换为
CV_8U
angles.convertTo(angles, CV_8U);
-
应用您选择的色彩图
applyColorMap(angles, angles, COLORMAP_HSV);
在这种情况下,我选择HSV颜色图。有关详细信息,请参阅以下内容:https://www.learnopencv.com/applycolormap-for-pseudocoloring-in-opencv-c-python/
-
应用边缘蒙版,使背景为黑色
Mat colored; angles.copyTo(colored, contours);
-
最后显示图像:D
imshow("Colored angles", colored);
如果您的源是视频或网络摄像头,则在应用边缘遮罩之前,您还必须清除colored
图像,以防止聚合:
colored.release();
angles.copyTo(colored, contours);
完整代码在这里:
Mat angles, colored;
phase(dx, dy, angles, true);
angles = angles / 360 * 255;
angles.convertTo(angles, CV_8U);
applyColorMap(angles, angles, COLORMAP_HSV);
colored.release();
angles.copyTo(colored, contours);
imshow("Colored angles", colored);
相关文章:
- C++为构建时间获取QDateTime的可靠方法
- lambda参数转换为constexpr技巧,然后获取带链接的数组
- 如何使用 < 和 > 命令获取 c++ 中的输入和输出?
- 使用指针从C++中的数组中获取最大值
- 如何获取std::result_of函数的返回类型
- 如何在openssl-ecc中获取十六进制格式的私钥
- 使用Unreal C++获取VR耳机的世界位置/方向
- 获取日期异步信号安全吗?如果在信号处理程序中使用,它会导致死锁吗
- 从C字符串中获取奇怪的字符串长度
- 为什么我的for循环不能正确获取argv
- 从python中调用C++函数并获取返回值
- 如何获取一个数字的前3位
- 获取字符串的长度并将其分配给数组
- 无法获取菜单选择以运行函数.C++
- 数组长度,为什么从命令行获取时不能使用它?
- Boost Spirit,获取迭代器内部语义动作
- 尝试通过OCI例程从Oracle获取blob数据,但出现错误:ORA-01008:并非所有变量都绑定
- 具有默认值的引用获取函数
- xmake总是报告:错误:无法获取cxx的程序,为什么
- 从OpenCV坎尼边缘检测器获取角度