发布于2020-02-26 11:56 阅读(1534) 评论(0) 点赞(20) 收藏(1)
统计下图中的对象个数
主要方法:高斯滤波函数,Canny边缘检测函数,形态学闭运算,寻找并绘制轮廓等。
原文来自公众号:OpenCV学堂 gloomyfish
结果:
代码:
- Mat srcImage = imread("1.jpg");
- namedWindow("原始图");
- imshow("原始图", srcImage);
-
- Mat gaussImage;
- GaussianBlur(srcImage, gaussImage, Size(3, 3), 0);
- namedWindow("高斯滤波图");
- imshow("高斯滤波图", gaussImage);
-
- Mat grayImage;
- cvtColor(gaussImage, grayImage, COLOR_RGB2GRAY);
-
- Mat cannyImage;
- Canny(grayImage, cannyImage, 50, 100);
- namedWindow("cannyImage");
- imshow("cannyImage", cannyImage);
-
- Mat kernal = getStructuringElement(MORPH_ELLIPSE, Size(10, 10));
-
- Mat closeImage;
- morphologyEx(cannyImage, closeImage, MORPH_CLOSE, kernal);
- namedWindow("closeImage");
- imshow("closeImage", closeImage);
-
- vector<vector<Point> > contours;
- vector<Vec4i> hierarchy;
- findContours(closeImage, contours, hierarchy, CV_RETR_EXTERNAL, CV_CHAIN_APPROX_SIMPLE);
-
- int count = 0;
- for (int i = 0; i < contours.size(); i++)
- {
- double area = contourArea(contours[i]);
- if (area < 100) continue;
-
- count++;
- RotatedRect rect = minAreaRect(contours[i]);
-
- Point2f rectVertex[4];
- rect.points(rectVertex);
-
- for (int i = 0; i < 4; i++)
- {
- line(srcImage, rectVertex[i], rectVertex[(i + 1) % 4], Scalar(100, 255, 0), 2, 8);
- }
- }
-
- namedWindow("原始图2");
- imshow("原始图2", srcImage);
- imwrite("result.jpg", srcImage);
-
- waitKey(0);
作者:787sds
链接:https://www.pythonheidong.com/blog/article/234093/5805ed5f795371335c92/
来源:python黑洞网
任何形式的转载都请注明出处,如有侵权 一经发现 必将追究其法律责任
昵称:
评论内容:(最多支持255个字符)
---无人问津也好,技不如人也罢,你都要试着安静下来,去做自己该做的事,而不是让内心的烦躁、焦虑,坏掉你本来就不多的热情和定力
Copyright © 2018-2021 python黑洞网 All Rights Reserved 版权所有,并保留所有权利。 京ICP备18063182号-1
投诉与举报,广告合作请联系vgs_info@163.com或QQ3083709327
免责声明:网站文章均由用户上传,仅供读者学习交流使用,禁止用做商业用途。若文章涉及色情,反动,侵权等违法信息,请向我们举报,一经核实我们会立即删除!