OpenCV – 使用findContours()查找图片轮廓线,并将轮廓线坐标点输出
原创文章,作者:StubbornHuang,如若转载,请注明出处:《OpenCV – 使用findContours()查找图片轮廓线,并将轮廓线坐标点输出》https://www.stubbornhuang.com/441/
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 - 打开摄像头并用窗口显示摄像头的内容
- OpenCV - 读取一个图像,并使用Canny算子进行边缘提取
- OpenCV - 打开视频文件,并对其中的每一帧图像进行Canny算子边缘化提取,并将结果保存为视频文件
- OpenCV - 读取一张图片显示,并将其重写为灰度图
- OpenCV - 静态图片人脸检测和摄像头人脸检测
- OpenCV - 使用findContours()查找图片轮廓线,并将轮廓线坐标点输出
- OpenCV - 创建新图像以及遍历图片像素值和设置像素值
- OpenCV - 打开摄像头并对摄像头获取的每一帧图像进行Canny算子边缘化提取操作
- OpenCV - Mat与lplImage和CvMat的相互转换
- OpenCV - 新建一个图片,并在图片上画由一点到另一点的直线,采用反走样形式
全站随机文章推荐
- 资源分享 - GPU Gems 2 - Programming Techniques for High-Performance Graphics and General-Purpose Computation 英文高清PDF下载
- 资源分享 - The HDRI Handbook- High Dynamic Range Imaging for Photographers and CG Artists英文高清PDF下载
- 姿态估计之COCO数据集骨骼关节keypoint标注对应
- VTK - 冠脉重建点匹配坐标数据下载
- OpenCV - 打开摄像头并用窗口显示摄像头的内容
- 资源分享 - 深度学习入门之Pytorch(廖星宇著)PDF下载
- C++11/std::shared_ptr - 循环引用问题
- 资源分享 - Qt5.9 c++开发指南 PDF下载
- 资源分享 - Computer Graphics Through OpenGL - From Theory to Experiments (Third Edition) 英文高清原版 PDF下载
- Alphapose - Windows下Alphapose(Pytorch 1.1+)版本2021最新环境配置步骤以及踩坑说明