opencv灰度处理角点检测.doc_第1页
opencv灰度处理角点检测.doc_第2页
opencv灰度处理角点检测.doc_第3页
opencv灰度处理角点检测.doc_第4页
opencv灰度处理角点检测.doc_第5页
已阅读5页,还剩1页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

#includestdafx.h#include#includeopencv/cv.hpp#includeopencv2/highgui/highgui.hpp#includeopencv2/imgproc/imgproc.hpp#include#include#include#define max_corners 100using namespace cv;using namespace std;void main()/進行灰度處理 /*IplImage* img = 0;int height,width,step,channels;char * data;int i,j,k;int min=0 ,max=0 ,mid = 0,k1 = 0,k2 = 1,k3 = 2;img = cvLoadImage(C:/Documents and Settings/F1656465/桌面/lena1.bmp);height = img-height;width = img-width;step = img-widthStep;coutwidthwidthheightheightnChannels ;data= (char*)img-imageData;/cvNamedWindow(mainWin,CV_WINDOW_AUTOSIZE);/cvMoveWindow(mainWin,100,100);for(int i = 0;iheight;i+)for (j = 0;jwidth;j+)for (k = 0 ;kchannels;k+) if(i=200)&(j=800)coutR:(int)datai*step+j*channels+k1endl;coutG(int)datai*step+j*channels+k2endl;coutB(int)datai*step+j*channels+k3max)max = datai*step+j*channels+k;if (datai*step+j*channels+k min)min = datai*step+j*channels+k;if (j = 900)&(i =900)&(mid100)mid+;cout(int)datai*step+j*channels+kendl;coutstepstependl;coutchannelschannelsendl;/ /coutdatai*step+j*channels+kendl;/datai*step+j*channels+k = 0 ; if(datai*step+j*channels+k10)&(datai*step+j*channels+k240)&(datai*step+j*channels+k240) /(datai*step+j*channels+k255)| datai*step+j*channels+k1= 255;datai*step+j*channels+k2= 255;datai*step+j*channels+k3= 255;else datai*step+j*channels+k1= 0;/ datai*step+j*channels+k = 255;datai*step+j*channels+k2= 0;datai*step+j*channels+k3= 0;/datai*step+j*channels+k = 0; /datai*step+j*channels+k= 255-datai*step+j*channels+k;/cvShowImage(mainWin,img);/cvWaitKey(0);/cvReleaseImage(&img);coutProcessing image withheightendlwidthchannelsendl;coutHello World endl;cout最小值:minendl;cout最大值:maxheight;width = srcImage-width;step = srcImage-widthStep;coutwidthwidthheightheightnChannels ;data= (char*)srcImage-imageData;for(int i = 0;iheight;i+)for (j = 0;jwidth;j+)if(i=80)&(j=690) coutR:(int)datai*step+j*channels+k1endl;coutG(int)datai*step+j*channels+k2endl;coutB(int)datai*step+j*channels+k3endl;/(datai*step+j*channels+k140)& if(datai*step+j*channels+k210)&(datai*step+j*channels+k340)&(datai*step+j*channels+k340) /(datai*step+j*channels+k255)| datai*step+j*channels+k1= 255;datai*step+j*channels+k2= 255;datai*step+j*channels+k3= 255;else datai*step+j*channels+k1= 0;/ datai*step+j*channels+k = 255;datai*step+j*channels+k2= 0;datai*step+j*channels+k3= 0;/datai*step+j*channels+k = 0; /datai*step+j*channels+k= 255-datai*step+j*channels+k;grayImage = cvCreateImage(cvGetSize(srcImage),IPL_DEPTH_8U,1);cvCvtColor(srcImage,grayImage,CV_BGR2GRAY);corners1 = cvCreateImage(cvGetSize(srcImage),IPL_DEPTH_32F,1);corners2 = cvCreateImage(cvGetSize(srcImage),IPL_DEPTH_32F,1);cvGoodFeaturesToTrack(grayImage,corners1,corners2,corners,&cornerCount,qualityLever,minDistance,0);coutnum corners foud :cornerCount0)for(int i1 = 0;i1cornerCount;+i1)cvCircle(srcImage,cvPoint(int)(cornersi1.x),(int)(cornersi1.y),6,color,2,CV_AA,0);coutcornersi1.xendlcornersi1.yendl;/cvResizeWindow( image,400,300 );/cvMoveWindow( image, -800, -600 );cvS

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论