以下是使用 OpenCV 进行图像阈值分割的 C++ 代码示例:
#include <opencv2/opencv.hpp>
#include <iostream>
using namespace cv;
using namespace std;
int main(int argc, char** argv)
{
// 读取输入图像
Mat src = imread("input.jpg", IMREAD_GRAYSCALE);
// 判断图像是否加载成功
if (src.empty())
{
cout << "Error: Failed to load image." << endl;
return -1;
}
// 应用二值化阈值
Mat dst;
threshold(src, dst, 128, 255, THRESH_BINARY);
// 显示结果图像
imshow("Input Image", src);
imshow("Thresholded Image", dst);
// 等待用户按下任意按键退出程序
waitKey(0);
return 0;
}
在上述代码中,我们首先使用 `imread` 函数读取输入图像,并判断是否成功加载。然后,我们使用 `threshold` 函数将输入图像进行二值化处理,生成输出图像。最后,我们使用 `imshow` 函数将输入和输出图像显示出来,并使用 `waitKey` 函数等待用户按下任意按键,以便退出程序。
在 `threshold` 函数中,我们给定了两个阈值参数。第一个参数是阈值,如果输入图像的像素值大于阈值,则将其转换为白色;否则,将其转换为黑色。第二个参数是输出像素的最大值,该参数在二值化过程中使用。