已阅读5页,还剩10页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
Opencv 提取轮廓(去掉面积小于某个值的轮廓) #include #include “cv.h“ #include “cxcore.h“ #include “highgui.h“ #include using namespace std; #pragma comment(lib,“cv.lib“) #pragma comment(lib,“cxcore.lib“) #pragma comment(lib,“highgui.lib“) struct Position int x,y; ; double per256;/ 保存灰度概率 IplImage *FindCountours(IplImage* src,IplImage *pContourImg); int ImageStretchByHistogram(IplImage *src,IplImage *dst); IplImage* Hist_Equalization(IplImage *srcimg); void proBorder(IplImage *src); / 边界的处理 void GetBackImage(IplImage* src,IplImage* src_back); void Threshold(IplImage *src); int GetThreshold(double *const prob); void Getprobability(IplImage *src); double Eccentricity(IplImage *src); void main() /IplImage * src = cvLoadImage(“C:image19A634.jpg“,-1);/灰度图的方式载入 IplImage * src = cvLoadImage(“C:image19A857.jpg“,-1); IplImage * dst = cvCreateImage(cvGetSize(src),IPL_DEPTH_8U,3); IplImage *src_back = cvCreateImage(cvGetSize(src),IPL_DEPTH_8U,src-nChannels); GetBackImage(src,src_back); dst = FindCountours(src_back,dst); cvNamedWindow(“test“,CV_WINDOW_AUTOSIZE); cvShowImage(“test“,dst); cvWaitKey(0); cvReleaseImage( cvReleaseImage( void GetBackImage(IplImage* src,IplImage* src_back) /cvCvtColor(src,src,CV_RGB2GRAY);/灰度化 IplImage *tmp = cvCreateImage(cvGetSize(src),IPL_DEPTH_8U,3); / 创建结构元素 IplConvKernel *element = cvCreateStructuringElementEx( 2, 2, 0, 0, CV_SHAPE_ELLIPSE,0); /用该结构对源图象进行数学形态学的开操作后,估计背景亮度 cvErode(src,tmp,element,9); /使用任意结构元素腐蚀图像 cvDilate(tmp,src_back, element,9); /使用任意结构元素膨胀图像 IplImage *FindCountours(IplImage* src,IplImage *pContourImg) CvMemStorage *storage = cvCreateMemStorage(0); /提取轮廓需要的储存容量 0为默认 64KB CvSeq * pcontour = 0; /提取轮廓的序列指针 IplImage *temp = cvCreateImage(cvGetSize(src),src-depth,1); /cvSmooth(src,temp,CV_GAUSSIAN,3,1,0); cvSmooth(src,src,CV_GAUSSIAN,3,1,0);/平滑处理 cvCvtColor(src,temp,CV_RGB2GRAY);/灰度化 Getprobability(temp); printf(“最好的阈值:%dn“,GetThreshold(per); /Threshold(temp); proBorder(temp); cvThreshold(temp,temp,GetThreshold(per),255,CV_THRESH_BINARY_INV); int contoursNum = 0; / 轮廓数量 /int mode = CV_RETR_LIST; int mode = CV_RETR_EXTERNAL;/ 提取最外层轮廓 contoursNum = cvFindContours(temp,storage, / contoursNum = cvFindContours(temp,storage, /二值图, 得到轮廓存储,轮廓指针序列,header_size,提取模式,逼近方法 CvScalar externalColor;/ 保存颜色值 CvScalar holeColor; /-画轮廓-/ for (; pcontour != 0; pcontour=pcontour - h_next) /holeColor=CV_RGB(rand() /externalColor=CV_RGB(rand() CvRect r = (CvContour *)pcontour)-rect; if(r.height * r.width width; int height = src-height; int i,j; for(i = 0; i = 0; i-) for(j = 0; j = 0; i-) for(j = 0 ; j s_dis) printf(“偏心率:%fn“,l_dis*1.0/s_dis); else tmp_dis = l_dis; l_dis = s_dis; s_dis = tmp_dis; printf(“偏心率:%fn“,l_dis*1.0/s_dis); return 0; void Getprobability(IplImage *src) memset(per,0,sizeof(per); int width = src-width; int height = src-height; for(int i = 0; i height; int width = src-width; int N = 100; for(i = 0; i imageDataindex = (char)255; int NN = 150; int sw = width * (height - NN);/ 左下角 三角形 int t = 1; for(i = sw; i imageDataindex = (char)255; int se = (height - NN - 1) * width; / 右下角 t = 0; for(i = se; i imageDataindex = (char)255; int ne = width - NN; / 右上角 三角形剪切 t = 0; for(i = ne; i imageDataindex = (char)255; void Threshold(IplImage *src) int width = src-width; int height = src-height; float minpixel = cvGet2D(src,0,0).val0; float maxpixel = cvGet2D(src,0,0).val0; CvScalar s; for(int i = 0; i maxpixel) maxpixel = s.val0; if(s.val0 minpixel) minpixel = s.val0; float firstgrey = (maxpixel + minpixel) / 2; printf(“%fn“,firstgrey); float lastgrey; float sum1 = 0,sum2 = 0; int num1 = 0,num2 = 0; int result = 0; while(1) result +; for(i = 0; i height; i+) for(int j = 0; j width; j+) s = cvGet2D(src,i,j); if(s.val0 firstgrey) sum1 += s.val0; num1+; if(s.val0 firstgrey) sum2 += s.val0; num2+; lastgrey = (sum
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年低空经济产业集群技术突破报告
- 2025年低空经济产业国际化人才培养路径分析报告
- 电力施工合作协议书模板
- 2026-2031中国广播电视设备制造行业市场运营态势研究报告
- 2026-2031中国槟榔市场竞争力分析及投资战略预测研发报告
- 共享仓库运营协议
- 某饭店消防安全灭火和应急疏散预案演练制度
- 瓦斯检查工考试试题及答案
- 2025年高级项目管理试题及答案
- 突发停电事故应急预案演练方案
- 气管导管气囊压力的监测
- cognos培训教程与函数ibm102report studio讲解
- YY/T 0031-2008输液、输血用硅橡胶管路及弹性件
- YC/T 280-2008烟草工业企业能源消耗
- GB/T 3836.1-2021爆炸性环境第1部分:设备通用要求
- GB/T 23341.1-2018涡轮增压器第1部分:一般技术条件
- 公路水运施工企业安全生产管理人员培训课件
- 全国一等奖高中英语优质课大赛《A Christmas Carol》教学设计+学案+教学反思
- 商务礼仪培训(完整版)课件
- 祥符东单元控规调整
- 基因编辑技术的概念和原理课件
评论
0/150
提交评论