zoukankan      html  css  js  c++  java
  • 基于腐蚀的二值图像距离变换

    

    取图像的骨架,方法是不断对图像进行腐蚀并且标记每个像素腐蚀到值不再变化的次数。得到的图像可以进一步被利用,如进行细化。

    上代码

    void erode(LPBYTE lpDst, LPBYTE lpDst1, int nW, int nH)
    {
    	bool flag;
    	for (int j = 0; j < nH; j++)
    	{
    		for (int i = 0; i < nW; i++)
    		{
    			//目标图像中的当前点先赋成白色
    			lpDst[j*nW + i] = (unsigned char)255;//前景为黑色,背景为白色
    			if (lpDst1[j*nW + i] == 0)
    			{
    				flag = true;
    				for (int sub_row = -1; sub_row < 2; sub_row++)
    				{
    					for (int sub_col = -1; sub_col < 2; sub_col++)
    					{
    						if (j + sub_row < nH&&j + sub_row >= 0 && i + sub_col < nW&&i + sub_col >= 0)
    						{
    							if (lpDst1[(j + sub_row)*nW + i + sub_col] != 0)
    							{
    								flag = false; break;
    							}
    						}
    					}
    					if (!flag)
    						break;
    				}
    				if (flag)
    					lpDst[j*nW + i] = 0;
    			}
    		}
    	}
    	for (int j = 0; j < nH; j++)
    	{
    		for (int i = 0; i < nW; i++)
    		{
    			lpDst1[j*nW + i] = lpDst[j*nW + i];
    		}
    	}
    
    }
    void CImageColorProcess::DistanceTransform(LPBYTE lpSrc, LPBYTE lpDst, LPBYTE lpDst_, int nSrcCount, int nW, int nH)
    {
    	this->OSTUThreshold(lpSrc, lpDst_, nSrcCount, nW, nH);
    	int*array = new int[nW*nH];//存储每个像素点被腐蚀掉之前所经历的腐蚀次数
    	//memset(array, 255, nW*nH);//初始化
    	for (int j = 0; j < nH; j++)
    	{
    		for (int i = 0; i < nW; i++)
    		{
    			array[j*nW + i] = 255;
    		}
    	}
    	bool flag1 = true;//设置标志
    	int count(0);//记录腐蚀操作的次数
    	while (flag1)
    	{
    		erode(lpDst, lpDst_, nW, nH);//标记为真进行腐蚀
    		for (int j = 0; j < nH; j++)
    		{
    			for (int i = 0; i < nW; i++)
    			{
    				if (lpDst[j*nW + i] == 0)
    					array[j*nW + i] = array[j*nW + i]-5;
    			}
    		}
    		for (int j = 0; j < nH; j++)
    		{
    			flag1 = false;
    			for (int i = 0; i < nW; i++)
    			{
    				if (lpDst[j*nW + i] == 0)
    				{
    					flag1 = true;
    					count++;
    					break;
    				}
    			}
    			if (flag1)
    				break;
    		}
    	}
    	for (int j = 0; j < nH; j++)
    	{
    		for (int i = 0; i < nW; i++)
    		{
    			lpDst[j*nW + i] = (array[j*nW + i] < 0 ? 0 : array[j*nW + i]);
    		}
    	}
    }
    
    还可以继续优化下
    调试的时候最开始用memset初始化,总得不到结果,改成两个for循环初始化后问题解决,不知道是什么原因,还望高人指点。

    版权声明:

  • 相关阅读:
    3.请问配置JDK时环境变量path和JAVA_HOME的作用是什么?
    2.请尝试安装和配置JDK,并给出安装、配置JDK的步骤。
    1.Java为什么能跨平台运行?请简述原理
    字符集
    Java程序输出打字
    <marquee>,视频和音频的插入,正则表达式
    windows.document对象
    while;do while;switch;break;continue
    循环语句 ,for语句
    PHP判断一个文件是否能够被打开
  • 原文地址:https://www.cnblogs.com/walccott/p/4957134.html
Copyright © 2011-2022 走看看