#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/opencv.hpp>
using namespace cv;
// 图像差分操作
void diffOperation(const cv::Mat srcImage, cv::Mat& edgeXImage,
cv::Mat& edgeYImage)
{
cv::Mat tempImage = srcImage.clone();
int nRows = tempImage.rows;
int nCols = tempImage.cols;
for (int i = 0; i < nRows - 1; i++)
{
for (int j = 0; j < nCols - 1; j++)
{
// 计算垂直边边缘
edgeXImage.at<uchar>(i, j) =
abs(tempImage.at<uchar>(i + 1, j) -
tempImage.at<uchar>(i, j));
// 计算水平边缘
edgeYImage.at<uchar>(i, j) =
abs(tempImage.at<uchar>(i, j + 1) -
tempImage.at<uchar>(i, j));
}
}
}
int main()
{
cv::Mat srcImage = cv::imread("..\\images\\building.jpg", 0);
if (!srcImage.data)
return -1;
cv::imshow("srcImage", srcImage);
cv::Mat edgeXImage(srcImage.size(), srcImage.type());
cv::Mat edgeYImage(srcImage.size(), srcImage.type());
// 计算查分图像
diffOperation(srcImage, edgeXImage, edgeYImage);
cv::imshow("edgeXImage", edgeXImage);
cv::imshow("edgeYImage", edgeYImage);
cv::Mat edgeImage(srcImage.size(), srcImage.type());
// 水平与垂直边缘图像叠加
addWeighted(edgeXImage, 0.5, edgeYImage,
0.5, 0.0, edgeImage);
cv::imshow("edgeImage", edgeImage);
cv::waitKey(0);
return 0;
}
转载:http://blog.youkuaiyun.com/zhuwei1988
本文介绍了一种使用C++和OpenCV实现图像垂直和水平边缘检测的方法。通过差分运算计算像素间的差异来突出图像中的边界。文章展示了如何创建并显示处理后的图像。
1790

被折叠的 条评论
为什么被折叠?



