资源简介
VS2013下用OPENCV完成对圆轮廓获取后,计算圆面积和圆心位置
代码片段和文件信息
#include
#include
#include
#include
#include
#include
using namespace cv;
using namespace std;
const int kvalue = 15;//双边滤波邻域大小
void main()
{
Mat image = imread(“1-1.bmp“);
Mat img = image.clone();
Mat grayimg;
Mat grayGlobalBinayThr;
Mat blackMask;
//画十字架
line(image cvPoint(1975 1200) cvPoint(1975 1600) CV_RGB(0 255 255) 8 CV_AA 0);
line(image cvPoint(1775 1400) cvPoint(2175 1400) CV_RGB(0 255 255) 8 CV_AA 0);
namedWindow(“1“ WINDOW_NORMAL);
imshow(“1“ image);
//图像灰度化
cvtColor(img grayimg cv::COLOR_RGB2GRAY);
//截取要处理的图像区域
Mat imgROI(grayimg Rect(850 330 3100 - 850 2470 - 330));
//二值化
threshold(imgROI grayGlobalBinayThr 100 255 0);
blackMask = ~grayGlobalBinayThr;//按位取反,得到轮胎为1,背景为0的二值图像
//计算轮胎面积
int area = countNonZero(blackMask);
printf(“%d\n“ area);
namedWindow(“2“ WINDOW_NORMAL);
imshow(“2“ blackMask);
//获取轮胎轮廓
vector< vector > contours;//轮廓点
vector hierarchy;
findContours(blackMask contours hierarchyCV_RETR_EXTERNAL CV_CHAIN_APPROX_NONEPoint());
Mat imageContours = Mat::zeros(blackMask.size() CV_8UC1);
//判断轮胎与中心位置偏差
for (int i = 0; i < contours.size(); i++)
{
drawContours(imageContours contours i Scalar(255) 1);
RotatedRect rect = minAreaRect(contours[i]);
int x = rect.center.x;
int y = rect.center.y;
if (abs(x - 1125) <= 10 & abs(y - 1070) <= 10)
{
printf(“OK“);
break;
}
printf(“%d\n“ x);
printf(“%d\n“ y);
printf(“\n“);
}
namedWindow(“3“ WINDOW_NORMAL);
imshow(“3“ imgROI);
waitKey();
}
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 87040 2016-11-28 15:18 计算面积提取圆心\Debug\计算面积提取圆心.exe
文件 482012 2016-11-28 15:18 计算面积提取圆心\Debug\计算面积提取圆心.ilk
文件 3403776 2016-11-28 15:18 计算面积提取圆心\Debug\计算面积提取圆心.pdb
文件 822272 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug\vc120.idb
文件 1855488 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug\vc120.pdb
文件 314933 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug\源.obj
文件 2849 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug\计算面积提取圆心.log
文件 572 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug\计算面积提取圆心.tlog\cl.command.1.tlog
文件 16312 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug\计算面积提取圆心.tlog\CL.read.1.tlog
文件 336 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug\计算面积提取圆心.tlog\CL.write.1.tlog
文件 2686 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug\计算面积提取圆心.tlog\li
文件 5096 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug\计算面积提取圆心.tlog\li
文件 320 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug\计算面积提取圆心.tlog\li
文件 176 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug\计算面积提取圆心.tlog\计算面积提取圆心.lastbuildstate
文件 1849 2016-11-28 15:36 计算面积提取圆心\计算面积提取圆心\源.cpp
文件 4601 2016-11-25 20:30 计算面积提取圆心\计算面积提取圆心\计算面积提取圆心.vcxproj
文件 944 2016-11-25 20:25 计算面积提取圆心\计算面积提取圆心\计算面积提取圆心.vcxproj.filters
文件 18874368 2016-11-28 15:36 计算面积提取圆心\计算面积提取圆心.sdf
文件 1018 2016-11-25 20:18 计算面积提取圆心\计算面积提取圆心.sln
..A..H. 23040 2016-11-28 15:36 计算面积提取圆心\计算面积提取圆心.v12.suo
目录 0 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug\计算面积提取圆心.tlog
目录 0 2016-11-28 15:18 计算面积提取圆心\计算面积提取圆心\Debug
目录 0 2016-11-28 15:18 计算面积提取圆心\Debug
目录 0 2016-11-29 12:50 计算面积提取圆心\计算面积提取圆心
目录 0 2016-11-28 15:36 计算面积提取圆心
----------- --------- ---------- ----- ----
25899688 25
相关资源
- 服务器截屏并使用socket发送给客户端
- Keras图像深度学习实战原版
- 训练得到的900维 HOG特征-检测算子进行
- msvcp120d .dll、msvcr120d.dll包括32位和64位
- qt+opencv的视频采集 与保存
- opencv做的姿态检测项目
- opencv运动目标检测帧差法
- 基于opencv的双目摄像头图像获取
- opencv vlc 访问海康网络摄像头
- 快速小波变换 基于opencv带注释
- opencvman_old.pdf
- 车牌识别系统vc源码基于opencv
- 基于opencv的双摄像头读取程序含Dire
- 序列图像16位转8位OpenCV
- Opencv图像Mat写入中文汉字
- opencv学习,道路检测
- 基于OpenCV的二维码检测识别基础demo
- Wallis滤波
- Opencv 人脸图像素描化
- 基于OpenCV读取摄像头的人脸检测和识
- 基于OpenCv的旋转匹配
- opencv果实分割与识别
- qt环境下使用opencv打开双摄像头并保存
- opencv学习手势轮廓识别源代码
- OpenCV2 计算机视觉编程手册 配套源代
- 基于opencv的双目测距代码+文章
- opencvc车流量统计
- 车辆与车道线的检测与跟踪
- 基于opencv实现的图像拼接
- ROI区域&图像混合例程by浅墨
评论
共有 条评论