- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
IPL图像数据结构 IplImage* image = cvCreateImage( cvSize(width, height), depth,channel ); cv 基本图像处理(去噪、边缘检测、角点检测、采样与插值、色彩变换、形态学处理、直方图、图像金字塔结构) 结构分析(连通域/分支、轮廓处理、距离转换、图像矩、模板匹配、霍夫变换、多项式逼近、曲线拟合、椭圆拟合、狄劳尼三角化) 运动分析和目标识别(光流、动作分割、目标跟踪,特征方法、HMM模型) 摄像头定标与3D重构(寻找和跟踪定标模式、参数定标、基本矩阵估计、单应矩阵估计、立体视觉匹配) e.g.:去噪 使用扩展 Sobel 算子计算一阶、二阶、三阶或混合图像差分 :void cvSobel(); 采用 Canny 算法做边缘检测 void cvCanny(); Harris角点检测 void cvCornerHarris(); 计算图像的 Laplacian 变换 : IO/GUI (highgui) 图形用户界面: 处理窗口事件e.g.: cvNamedWindow() 处理滑动条事件e.g.:cvGetTrackbarPos() 处理鼠标/键盘输入事件e.g.:cvWaitKey() 读取与显示图像 e.g.: cvShowImage() 视频读写函数 e.g.: cvCaptureFromCAM() 实用函数与系统函数 highgui示例 #include cv.h #include highgui.h int main( int argc, char** argv ) { IplImage *frame; CvCapture *capture = cvCaptureFromAVI(1.avi); if( !capture) { printf( Can not open video file 1.avi\n); return -1; } cvNamedWindow(avi_output,1 ); 程序运行演示 while(frame = cvQueryFrame(capture)) { cvShowImage(avi_output,frame); if( cvWaitKey(2) = 0 ) break; } cvWaitKey(); cvDestroyWindow(avi_output); cvReleaseImage( frame ); cvReleaseCapture( capture ); } 程序运行演示 cvaux 立体视觉 通过立体视觉来实现的动作识别 基于轮廓线的形状匹配 模式识别 一维和二维隐马尔可夫模型 纹理描述 四. 例子:鼠标绘图 #include stdafx.h #include cv.h #include highgui.h #include stdio.h #include stdlib.h IplImage* inpaint_mask = 0, img0 = 0, *img = 0, *inpainted = 0; CvPoint prev_pt = {-1,-1}; void on_mouse( int event, int x, int y, int flags, void* zhang) { if( !img ) return; if( event == CV_EVENT_LBUTTONUP || !(flags CV_EVENT_FLAG_LBUTTON) ) prev_pt = cvPoint(-1,-1); else if( event == CV_EVENT_LBUTTONDOWN ) prev_pt = cvPoint(x,y); else if( event == CV_EVENT_MOUSEMOVE (flags CV_EVENT_FLAG_LBUTTON) ) { CvPoint pt = cvPoint(x,y); if( prev_pt.x 0 ) prev_pt = pt; cvLine( inpaint_mask, prev_pt, pt, cvScalarAll(255), 5, 8, 0 ); cvLine( img, prev_pt, pt, cvScalarAll(255), 5, 8, 0 ); prev_pt = pt;
文档评论(0)