C++ opencv
C++进阶:掌握STL和模板,参考《C++ Primer》 #生活技巧# #工作学习技巧# #编程语言学习路径#
Python版见https://blog.csdn.net/qq_40870689/article/details/88757081,
思路:
1,RGB转HSV,图中只保留红色,https://blog.csdn.net/coldwindha/article/details/82080176
2,通过腐蚀或者膨胀操作,改进将离散的区域的连通性,
3,查找轮廓,寻找最大外轮廓的索引,
4,在原图上绘制圆。
#include <stdio.h>
#include
#include <opencv2/core/core.hpp>
#include <opencv2/highgui/highgui.hpp>
#include <opencv2/imgproc/imgproc.hpp>
#include <opencv2/opencv.hpp>
using namespace std;
using namespace cv;
int hmin = 170, hmax = 180, smin = 43, smax = 255, vmin = 46, vmax = 255;
int g_nStructElementSize = 3;
int g_nGaussianBlurValue = 6;
int main()
{
Mat img = imread(“C:\TCDProjectFiles\ColorCycle\redtest.bmp”);
Mat imghsv;
cvtColor(img, imghsv, COLOR_BGR2HSV);//RGB to HSV
imshow(“hsv”, imghsv);
Mat mask;
inRange(imghsv, Scalar(hmin, smin, vmin), Scalar(hmax, smax, vmax), mask);//filter red color
imshow(“mask”, mask);
Mat out2;
Mat element = getStructuringElement(MORPH_RECT, Size(2 * g_nStructElementSize + 1, 2 * g_nStructElementSize + 1), Point(g_nStructElementSize, g_nStructElementSize));
erode(mask, out2, element); //erode
imshow(“腐蚀”, out2);
Mat gaussian;
GaussianBlur(out2, gaussian, Size(g_nGaussianBlurValue * 2 + 1, g_nGaussianBlurValue * 2 + 1), 0, 0);//模糊化
imshow(“高斯滤波”, gaussian);
vector<vector > contours;
vector hierarchy;
Mat imgcontours;
Point2f center;
float radius;
findContours(gaussian, contours, hierarchy, RETR_TREE, CHAIN_APPROX_SIMPLE);
double maxarea = 0;
int maxareaidx = 0;
for (int index = contours.size() - 1; index >= 0; index --)// find the maxarea return contour index
{
double tmparea = fabs(contourArea(contours[index]));
if (tmparea > maxarea)
{
maxarea = tmparea;
maxareaidx = index;
}
}
minEnclosingCircle(contours[maxareaidx], center, radius);//using index ssearching the min circle
circle(img, static_cast(center), (int)radius, Scalar(255,0,0), 3);//using contour index to drawing circle
imshow(“轮廓”, img);
waitKey();
}
网址:C++ opencv https://www.yuejiaxmz.com/news/view/625128
相关内容
OpenCV常见的优化方法和技巧总结python+opencv+mfcc+pygame+arduino多进程=简单的音视频采集分析系统
【计算机视觉】基于Python—OpenCV的手势识别详解(一)
基于opencv的家居智能安防机器视觉系统
碎点篇——opencv边缘检测报错
【未完成】opencv + 云台 + kcf
Python从0到100(七十三):Python OpenCV
基于opencv,使用python提取视频帧以及提取TVL1光流
基于树莓派opencv—Python的人脸面部特征框选(眼睛和微笑)
python opencv实现简易画图板