OpenCV – 使用findContours()查找图片轮廓线,并将轮廓线坐标点输出
本文作者:StubbornHuang
版权声明:本文为站长原创文章,如果转载请注明原文链接!
原文标题:OpenCV – 使用findContours()查找图片轮廓线,并将轮廓线坐标点输出
原文链接:https://www.stubbornhuang.com/441/
发布于:2019年11月18日 22:32:55
修改于:2019年11月18日 22:32:55

1 示例代码
使用findContours()查找图片轮廓线,并将轮廓线坐标点输出,访问二维vector,使用迭代器和下标两种方式。
#include <iostream>
#include <fstream>
#include <opencv2/opencv.hpp>
#include <opencv2/core/core.hpp>
#include<opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <math.h>
using namespace cv;
using namespace std;
int main()
{
//载入原始图,且必须以二值图模式载入
Mat M=imread("E:/A.bmp",0);
imshow("原始图",M);
waitKey(500); //等待5000ms后窗口自动关闭
//初始化结果图
Mat dstImage=Mat::zeros(M.rows,M.cols,CV_8UC3);
//M提取阈值小于250的部分
M=M<250;
imshow("阈值",M);
waitKey(50);
//定义轮廓和层次结构
vector<vector<Point>>contours;
vector<Vec4i>hierarchy;
findContours(M,contours,hierarchy,RETR_EXTERNAL,CHAIN_APPROX_NONE);
//迭代器输出
/*for (vector<vector<Point>>::iterator it=contours.begin();it!=contours.end();++it)
{
for (vector<Point>::iterator inner_it=it->begin();inner_it!=it->end();++inner_it)
{
cout<<*inner_it<<endl;
}
}
*/
//下标输出
for (int i=0;i<contours.size();i++)
{
for (int j=0;j<contours[i].size();j++)
{
cout<<contours[i][j].x<<" "<<contours[i][j].y<<endl;
ofstream f;
f.open("E:/坐标轮廓线.txt",ios::out|ios::app);
f<<contours[i][j].x<<" "<<contours[i][j].y<<endl;
}
}
//遍历顶层轮廓,以随机颜色绘制出每个连接组件颜色
int index=0;
for (;index>=0;index=hierarchy[index][0])
{
Scalar color(rand()%255,rand()%255,rand()%255);
drawContours(dstImage,contours,index,color,1,8,hierarchy);
}
imshow("轮廓图",dstImage);
waitKey(5000); //等待5000ms后窗口自动关闭
getchar();
}
当前分类随机文章推荐
- OpenCV - Mat与lplImage和CvMat的相互转换 阅读3494次,点赞0次
- OpenCV - linux上编译出现undefined reference to cv::dnn::experimental_dnn错误 阅读1287次,点赞0次
- OpenCV - linux上编译出现undefined reference to `cv::VideoCapture::VideoCapture()'错误 阅读1463次,点赞0次
- OpenCV - 读取一张图片显示,并将其重写为灰度图 阅读4316次,点赞0次
- OpenCV - 将OpenCV视频帧绘制到Win32窗口或者MFC控件上的CvvImage类,包括老版IplImage与新版Mat的绘制 阅读1125次,点赞0次
- OpenCV - 读取一个图像,并使用Canny算子进行边缘提取 阅读2866次,点赞0次
- OpenCV - 打开视频文件,并对其中的每一帧图像进行Canny算子边缘化提取,并将结果保存为视频文件 阅读2789次,点赞0次
- Ubuntu编译安装FFmpeg+libx264以及编译+安装Opencv+FFmpeg保姆教程 阅读1724次,点赞1次
- OpenCV - 指定插值方法改善resize函数缩放图片时出现锯齿、失真、清晰度降低问题 阅读306次,点赞0次
- OpenCV/FFmpeg - 使用FFmpeg编码OpenCV中的BGR视频流为H264视频流以及解码H264视频流为OpenCV中的BGR视频流 阅读989次,点赞1次
全站随机文章推荐
- Unity - 字节数组byte[]保存为文件 阅读3982次,点赞2次
- 资源分享 - Handbook of Computer Aided Geometric Design 英文高清PDF下载 阅读1537次,点赞0次
- C++ - std::string字符串格式化方法总结 阅读388次,点赞0次
- Python - 在子线程中使用OpenCV异步读取摄像头视频帧传递到主线程中进行处理 阅读663次,点赞1次
- 资源分享 - OpenGL Programming Guide (Eighth Edition) OpenGL红宝书英文第8版 英文高清PDF下载 阅读1610次,点赞0次
- Pytorch - 多GPU训练方式nn.DataParallel与nn.parallel.DistributedDataParallel的区别 阅读520次,点赞0次
- Pytorch - torch.nn.Conv1d参数详解与使用 阅读1145次,点赞0次
- 工具网站推荐 - 最好的8个免费下载Pbr贴图和材质的网站 阅读3346次,点赞2次
- 资源分享 - 深度学习的数学 (涌井良幸 涌井贞美著) 高清PDF下载 阅读3850次,点赞2次
- 资源分享 - Graphics Programming Methods 英文高清PDF下载 阅读1707次,点赞0次
评论
164