先看提取轮廓的代码:
Mat image = imread("D:/picture/images/binaryGroup.bmp",0);
if(!image.data)
return -1;
imshow("源图像",image);
//获取轮廓
std::vector<std::vector<Point>> contours;
//获取轮廓:
findContours(image, //图像
contours, //轮廓点
//包含图像拓扑结构的信息(可选参数,这里没有选)
CV_RETR_EXTERNAL, //获取轮廓的方法(这里获取外围轮廓)
CV_CHAIN_APPROX_NONE); //轮廓近似的方法(这里不近似,获取全部轮廓)
//打印轮廓信息
std::cout<<"共有外围轮廓:"<<contours.size()<<"条"<<std::endl;
std::vector<std::vector<Point>>::const_iterator itContours = contours.begin();
for(;itContours != contours.end();++itContours)
{
std::cout<<"每个轮廓的长度: "<<itContours->size()<<std::endl;
}
注意到轮廓的存储格式为std::vector<std::vector<Point>>,他说明整个轮廓是若干条轮廓按一定顺序组成的,而每个轮