目录
1 概念讲解及用处
顶帽操作(Top Hat)是形态学操作中的一种,它是原始图像与开运算之差,其中开运算是先进行腐蚀操作,然后再进行膨胀操作。顶帽操作可用于检测图像中的小尺寸目标或局部对比度变化。
因为开运算带来的结果是放大了裂缝或者局部低亮度的区域,因此,从原图中减去开运算后的图,得到的效果图突出了比原图轮廓周围的区域更明亮的区域,且这一操作和选择的核的大小相关。 顶帽运算往往用来分离比邻近点亮一些的斑块。当一幅图像具有大幅的背景的时候,而微小物品比较有规律的情况下,可以使用顶帽运算进行背景提取。
2 API函数详解
在OpenCV中,可以通过morphologyEx()函数来实现图像的顶帽操作。函数的定义如下:
void cv::morphologyEx(InputArray src, OutputArray dst, int op,
InputArray kernel, Point anchor = Point(-1,-1), int iterations = 1,
int borderType = BORDER_CONSTANT,
const Scalar& borderValue = morphologyDefaultBorderValue());
src: 输入的源图像。
dst: 输出的目标图像,用于存储开运算结果。
op: 形态学操作类型,使用MORPH_OPEN表示开运算操作。
kernel: 结构元素,用于指定形态学操作的邻域大小和形状。
anchor: 结构元素的锚点,默认为(-1,-1)表示位于结构元素的中心。
iterations: 操作的迭代次数,默认为1。
borderType: 图像边界的处理方式,默认为BORDER_CONSTANT表示用常数填充边界。
borderValue: 边界填充的颜色,默认为默认值。
3 用C++编写代码进行实现
下面是使用OpenCV库在C++中实现图像顶帽操作的示例代码:
#include <opencv2/opencv.hpp>
using namespace cv;
int main()
{
Mat srcImage = imread("input.jpg", IMREAD_GRAYSCALE);
if (srcImage.empty())
{
printf("Failed to load image\n");
return -1;
}
Mat dstImage;
Mat kernel = getStructuringElement(MORPH_RECT, Size(3, 3)); // 定义3x3的矩形结构元素
morphologyEx(srcImage, dstImage, MORPH_TOPHAT, kernel);
imshow("Source Image", srcImage);
imshow("TOPHAT Result", dstImage);
waitKey(0);
return 0;
}
在代码中,首先加载输入图像srcImage,然后定义了一个11x11的矩形结构元素kernel。接下来,使用morphologyEx()函数进行顶帽运算操作,并将结果保存在dstImage中。最后,显示原始图像和顶帽运算结果图像,并等待按键退出程序。