轮廓提取算法contourextraction.DOC

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
轮廓提取算法(contour extraction) ??轮廓提取的目的就是获得图像的外部特征,是进行图像分析的有用手段之一.二值图像轮廓提取的算法非常简单,就是掏空内部点:如果原图中有一点为黑,且它的8个相临点都是黑色时,则将该黑点删掉. 下面是轮廓提取和跟踪的简单实现: /************************************************************************* * * 函数名称: *?? ContourDIB() * * 参数: *?? LPSTR lpDIBBits????- 指向源DIB图像指针 *?? LONG??lWidth?????? - 源图像宽度(象素数,必须是4的倍数) *?? LONG??lHeight??????- 源图像高度(象素数) * 返回值: *?? BOOL?????????????? - 运算成功返回TRUE,否则返回FALSE。 * * 说明: * 该函数用于对图像进行轮廓提取运算。 * * 要求目标图像为只有0和255两个灰度值的灰度图像。 ************************************************************************/ BOOL WINAPI ContourDIB(LPSTR lpDIBBits, LONG lWidth, LONG lHeight) { // 指向源图像的指针 LPSTR lpSrc; // 指向缓存图像的指针 LPSTR lpDst; // 指向缓存DIB图像的指针 LPSTR lpNewDIBBits; HLOCAL hNewDIBBits; //循环变量 long i; long j; unsigned char n,e,s,w,ne,se,nw,sw; //像素值 unsigned char pixel; // 暂时分配内存,以保存新图像 hNewDIBBits = LocalAlloc(LHND, lWidth * lHeight); if (hNewDIBBits == NULL) { ??// 分配内存失败 ??return FALSE; } // 锁定内存 lpNewDIBBits = (char * )LocalLock(hNewDIBBits); // 初始化新分配的内存,设定初始值为255 lpDst = (char *)lpNewDIBBits; memset(lpDst, (BYTE)255, lWidth * lHeight); for(j = 1; j lHeight-1; j++) { ??for(i = 1;i lWidth-1; i++) ??{ ?? ?? // 指向源图像倒数第j行,第i个象素的指针?? ?? lpSrc = (char *)lpDIBBits + lWidth * j + i; ?? ?? // 指向目标图像倒数第j行,第i个象素的指针?? ?? lpDst = (char *)lpNewDIBBits + lWidth * j + i; ?? ?? //取得当前指针处的像素值,注意要转换为unsigned char型 ?? pixel = (unsigned char)*lpSrc; ?? //目标图像中含有0和255外的其它灰度值 //?? if(pixel != 255 pixel != 0) //????return FALSE; ?? if(pixel == 0) ?? { ????*lpDst = (unsigned char)0; ????nw = (unsigned char)*(lpSrc + lWidth -1); ????n??= (unsigned char)*(lpSrc + lWidth ); ????ne = (unsigned char)*(lpSrc + lWidth +1); ????w = (unsigned char)*(lpSrc -1); ????e = (unsigned char)*(lpSrc +1); ????sw = (unsigned char)*(lpSrc - lWidth -1); ????s??= (unsigned char)*(lpSrc - lWidth ); ????se = (unsigned char)*(lpSrc - lWidth +1); ????//如果相邻的八个点都是黑点 ????if(nw+n+ne+w+e+sw+s+se==0) ????{ ???? *lpDst = (unsigned char)255; ????} ?? } ??} } // 复制腐蚀后的图像 memcpy(

文档评论(0)

xiaozu + 关注
实名认证
内容提供者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档