时间:2021-05-20
本文实例为大家分享了OpenCV学习笔记之针对二值图像的边缘光滑处理(突出部消除),供大家参考,具体内容如下
处理代码分为两部分,第一部分用于去除边缘的突出部,第二部分用于边缘光滑。具体如下所示
1.去除边缘突出部
//去除二值图像边缘的突出部//uthreshold、vthreshold分别表示突出部的宽度阈值和高度阈值//type代表突出部的颜色,0表示黑色,1代表白色 void delete_jut(Mat& src, Mat& dst, int uthreshold, int vthreshold, int type){ int threshold; src.copyTo(dst); int height = dst.rows; int width = dst.cols; int k; //用于循环计数传递到外部 for (int i = 0; i < height - 1; i++) { uchar* p = dst.ptr<uchar>(i); for (int j = 0; j < width - 1; j++) { if (type == 0) { //行消除 if (p[j] == 255 && p[j + 1] == 0) { if (j + uthreshold >= width) { for (int k = j + 1; k < width; k++) p[k] = 255; } else { for (k = j + 2; k <= j + uthreshold; k++) { if (p[k] == 255) break; } if (p[k] == 255) { for (int h = j + 1; h < k; h++) p[h] = 255; } } } //列消除 if (p[j] == 255 && p[j + width] == 0) { if (i + vthreshold >= height) { for (k = j + width; k < j + (height - i)*width; k += width) p[k] = 255; } else { for (k = j + 2 * width; k <= j + vthreshold*width; k += width) { if (p[k] == 255) break; } if (p[k] == 255) { for (int h = j + width; h < k; h += width) p[h] = 255; } } } } else //type = 1 { //行消除 if (p[j] == 0 && p[j + 1] == 255) { if (j + uthreshold >= width) { for (int k = j + 1; k < width; k++) p[k] = 0; } else { for (k = j + 2; k <= j + uthreshold; k++) { if (p[k] == 0) break; } if (p[k] == 0) { for (int h = j + 1; h < k; h++) p[h] = 0; } } } //列消除 if (p[j] == 0 && p[j + width] == 255) { if (i + vthreshold >= height) { for (k = j + width; k < j + (height - i)*width; k += width) p[k] = 0; } else { for (k = j + 2 * width; k <= j + vthreshold*width; k += width) { if (p[k] == 0) break; } if (p[k] == 0) { for (int h = j + width; h < k; h += width) p[h] = 0; } } } } } }}效果如下:
2.边缘光滑处理
//图片边缘光滑处理//size表示取均值的窗口大小,threshold表示对均值图像进行二值化的阈值void imageblur(Mat& src, Mat& dst, Size size, int threshold){ int height = src.rows; int width = src.cols; blur(src, dst, size); for (int i = 0; i < height; i++) { uchar* p = dst.ptr<uchar>(i); for (int j = 0; j < width; j++) { if (p[j] < threshold) p[j] = 0; else p[j] = 255; } } imshow("Blur", dst);}效果如下:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
本文实例为大家分享了Opencv实现最小外接矩形和圆的具体代码,供大家参考,具体内容如下步骤:将一幅图像先转灰度,再canny边缘检测得到二值化边缘图像,再寻找
本文实例为大家分享了OpenCV实现图像转换为漫画的具体代码,供大家参考,具体内容如下From《OpenCVByExample》1、先canny提取图像的边缘并
本文实现功能:利用opencv获取鼠标左键点击位置图像的像素值(RGB像)vs2015+opencv3.1#include#includeusingnamesp
图像轮廓Contours:轮廓轮廓是将没有连着一起的边缘连着一起。边缘检测检测出边缘,边缘有些未连接在一起。注意问题1.对象为二值图像,首先进行阈值分割或者边缘
python+OpenCV图像礼帽图像礼帽也叫图像顶帽礼帽图像=原始图像-开运算图像得到噪声图像开运算:先腐蚀再膨胀使用对象:二值图像使用方法:morpholo