亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? segapi.cpp

?? 《Visual C++數字圖像獲取 處理及實踐應用》一書的源代碼
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
		nWeight[1][1][2] =  0 ;   
		nWeight[1][2][0] = -1 ;   
		nWeight[1][2][1] = -1 ;   
		nWeight[1][2][2] = -1 ;   
		
		
		
		//這個變量用來表示Laplacian算子象素值
		int nTmp[3][3];
		
		// 臨時變量
		double dGrad   ;
		double dGradOne;
		double dGradTwo;
		
		// 模板循環控制變量
		int yy ;
		int xx ;
		
		
		// 下面開始利用Prewitt算子進行計算,為了保證計算所需要的
		// 的數據位于圖像數據的內部,下面的兩重循環的條件是
		// y<nHeight-1 而不是y<nHeight,相應的x方向也是x<nWidth-1
		// 而不是x<nWidth
		for(y=1; y<nHeight-1 ; y++ )
			for(x=1 ; x<nWidth-1 ; x++ )
			{
				dGrad    = 0 ; 
				dGradOne = 0 ;
				dGradTwo = 0 ;
				// Laplacian算子需要的各點象素值
				
				// 模板第一行
				nTmp[0][0] = lpImage[(y-1)*nSaveWidth + x - 1 ] ; 
				nTmp[0][1] = lpImage[(y-1)*nSaveWidth + x     ] ; 
				nTmp[0][2] = lpImage[(y-1)*nSaveWidth + x + 1 ] ; 
				
				// 模板第二行
				nTmp[1][0] = lpImage[y*nSaveWidth + x - 1 ] ; 
				nTmp[1][1] = lpImage[y*nSaveWidth + x     ] ; 
				nTmp[1][2] = lpImage[y*nSaveWidth + x + 1 ] ; 
				
				// 模板第三行
				nTmp[2][0] = lpImage[(y+1)*nSaveWidth + x - 1 ] ; 
				nTmp[2][1] = lpImage[(y+1)*nSaveWidth + x     ] ; 
				nTmp[2][2] = lpImage[(y+1)*nSaveWidth + x + 1 ] ; 
				
				// 計算梯度
				for(yy=0; yy<3; yy++)
					for(xx=0; xx<3; xx++)
					{
						dGradOne += nTmp[yy][xx] * nWeight[0][yy][xx] ;
						dGradTwo += nTmp[yy][xx] * nWeight[1][yy][xx] ;
					}
					dGrad = dGradOne*dGradOne + dGradTwo*dGradTwo  ;
					dGrad = sqrt(dGrad) ;
					// 梯度值寫入內存
					*(pdGrad+y*nWidth+x)=dGrad;
			}
}

/*************************************************************************
 *
 * \函數名稱:
 *   EdgeTrack()
 *
 * \輸入參數:
 *   CDib * pDib					- 指向CDib類的指針,含有原始圖象信息
 *   unsigned char * pUnEdgeTrack	- 指向邊界跟蹤結果的指針
 *
 * \返回值:
 *   無
 *
 * \說明:
 *   pUnEdgeTrack指針指向的數據區存儲了邊界跟蹤的結果,其中1(邏輯)表示
 *	 對應象素為邊界點,0表示為非邊界點
 *
 *   串行邊界分割
 *
 *************************************************************************
 */
void EdgeTrack(CDib * pDib, unsigned char * pUnEdgeTrack)
{
	static int nDx[8]={-1,-1,-1, 0, 0, 1, 1, 1};
	static int nDy[8]={-1, 0, 1,-1, 1,-1, 0, 1};

	// 遍歷圖象的縱坐標
	int y;

	// 遍歷圖象的橫坐標
	int x;

	// 圖象的長寬大小
	CSize sizeImage		= pDib->GetDimensions();
	int nWidth			= sizeImage.cx		;
	int nHeight			= sizeImage.cy		;
	
	// 指向梯度數據的指針
	double * pdGrad;

	// 按照圖像的大小開辟內存空間,存儲梯度計算的結果
	pdGrad=new double[nHeight*nWidth];

    // 調用Roberts算子求梯度
	RobertsOperator(pDib, pdGrad);

	// 定義當前象素梯度值
	double dCurrGrad = 0;
	
	// 定義最大梯度值
	double dMaxGrad;

	// 設置初值
	dMaxGrad = 0;

	// 最大梯度值對應的象素點坐標
	int nPx;
	int nPy;

	nPx = 0;
	nPy = 0;

	// 求梯度最大值所在的象素點坐標
	for(y=0; y<nHeight; y++)
	{
		for(x=0; x<nWidth; x++)
		{
			dCurrGrad = pdGrad[y*nWidth + x] ;
			if( dMaxGrad< dCurrGrad )
			{
				dMaxGrad = dCurrGrad;
				nPx = x ;
				nPy = y ; 
			}
		}
	}

	// 初始化
	memset(pUnEdgeTrack,0,sizeof(unsigned char)*nWidth*nHeight);
	dCurrGrad = pdGrad[nPy*nWidth + nPx] ;

	// 從(nPx,nPy)點開始進行邊界跟蹤
	pUnEdgeTrack[nPy*nWidth + nPx] = 255 ;

	// 循環變量,遍歷當前象素的8鄰域
	int i ;

	int yy;
	int xx;
	
	int nDetX;
	int nDetY;

	while(dCurrGrad>10)
	{
		// 設置當前點為邊界點
		pUnEdgeTrack[nPy*nWidth + nPx] = 255 ;

		dMaxGrad = 0 ;
		for(i=0; i<8; i++)
		{
			nDetX=nDx[i];
			nDetY=nDy[i];
			y = nPy + nDetY;
			x = nPx + nDetX;

			// 判斷是否在圖像內部
			if(x>=0 && x<nWidth && y>=0 && y<nHeight)
			{
				if( ( pdGrad[y*nWidth + x] > dMaxGrad)  && ( pUnEdgeTrack[y*nWidth + x] == 0) )
				{
					dMaxGrad = pdGrad[y*nWidth + x] ;
					yy = y;
					xx = x;
				}
			}
		}
		// 下一個邊界點的梯度,橫縱坐標
		dCurrGrad = dMaxGrad ;
		nPy = yy;
		nPx = xx;
	}

	//釋放內存
	delete pdGrad;
	pdGrad = NULL;

}

/*************************************************************************
 *
 * \函數名稱:
 *   MakeGauss()
 *
 * \輸入參數:
 *   double sigma									        - 高斯函數的標準差
 *   double **pdKernel										- 指向高斯數據數組的指針
 *   int *pnWindowSize										- 數據的長度
 *
 * \返回值:
 *   無
 *
 * \說明:
 *   這個函數可以生成一個一維的高斯函數的數字數據,理論上高斯數據的長度應
 *   該是無限長的,但是為了計算的簡單和速度,實際的高斯數據只能是有限長的
 *   pnWindowSize就是數據長度
 *   
 *************************************************************************
 */
void MakeGauss(double sigma, double **pdKernel, int *pnWindowSize)
{
	// 循環控制變量
	int i   ;
	
	// 數組的中心點
	int nCenter;

	// 數組的某一點到中心點的距離
	double  dDis  ; 

	double PI = 3.14159;
	// 中間變量
	double  dValue; 
	double  dSum  ;
	dSum = 0 ; 
	
	// 數組長度,根據概率論的知識,選取[-3*sigma, 3*sigma]以內的數據。
	// 這些數據會覆蓋絕大部分的濾波系數
	*pnWindowSize = 1 + 2 * ceil(3 * sigma);
	
	// 中心
	nCenter = (*pnWindowSize) / 2;
	
	// 分配內存
	*pdKernel = new double[*pnWindowSize] ;
	
	for(i=0; i< (*pnWindowSize); i++)
	{
		dDis = (double)(i - nCenter);
		dValue = exp(-(1/2)*dDis*dDis/(sigma*sigma)) / (sqrt(2 * PI) * sigma );
		(*pdKernel)[i] = dValue ;
		dSum += dValue;
	}
	
	// 歸一化
	for(i=0; i<(*pnWindowSize) ; i++)
	{
		(*pdKernel)[i] /= dSum;
	}
}

/*************************************************************************
 *
 * \函數名稱:
 *   GaussianSmooth()
 *
 * \輸入參數:
 *   unsigned char * pUnchImg				- 指向圖象數據的指針
 *   int nWidth											- 圖象數據寬度
 *   int nHeight										- 圖象數據高度
 *   double dSigma									- 高斯函數的標準差
 *   unsigned char * pUnchSmthdImg	- 指向經過平滑之后的圖象數據
 *
 * \返回值:
 *   無
 *
 * \說明:
 *   為了抑止噪聲,采用高斯濾波對圖象進行濾波,濾波先對x方向進行,然后對
 *   y方向進行。
 *   
 *************************************************************************
 */
void GaussianSmooth(unsigned char *pUnchImg, int nWidth, int nHeight, 
										double sigma, unsigned char * pUnchSmthdImg)
{
	// 循環控制變量
  int y;
	int x;
	
	int i;
	
	// 高斯濾波器的數組長度
	
	int nWindowSize;
	
	//  窗口長度的1/2
	int	nHalfLen;   
	
	// 一維高斯數據濾波器
	double *pdKernel ;
	
	// 高斯系數與圖象數據的點乘
	double  dDotMul     ;
	
	// 高斯濾波系數的總和
	double  dWeightSum     ;          
  
	// 中間變量
	double * pdTmp ;
	
	// 分配內存
	pdTmp = new double[nWidth*nHeight];
	
	// 產生一維高斯數據濾波器
	// MakeGauss(sigma, &dKernel, &nWindowSize);
	MakeGauss(sigma, &pdKernel, &nWindowSize) ;
	
	// MakeGauss返回窗口的長度,利用此變量計算窗口的半長
	nHalfLen = nWindowSize / 2;
	
  // x方向進行濾波
	for(y=0; y<nHeight; y++)
	{
		for(x=0; x<nWidth; x++)
		{
			dDotMul		= 0;
			dWeightSum = 0;
			for(i=(-nHalfLen); i<=nHalfLen; i++)
			{
				// 判斷是否在圖象內部
				if( (i+x) >= 0  && (i+x) < nWidth )
				{
					dDotMul += (double)pUnchImg[y*nWidth + (i+x)] * pdKernel[nHalfLen+i];
					dWeightSum += pdKernel[nHalfLen+i];
				}
			}
			pdTmp[y*nWidth + x] = dDotMul/dWeightSum ;
		}
	}
	
	// y方向進行濾波
	for(x=0; x<nWidth; x++)
	{
		for(y=0; y<nHeight; y++)
		{
			dDotMul		= 0;
			dWeightSum = 0;
			for(i=(-nHalfLen); i<=nHalfLen; i++)
			{
				// 判斷是否在圖象內部
				if( (i+y) >= 0  && (i+y) < nHeight )
				{
					dDotMul += (double)pdTmp[(y+i)*nWidth + x] * pdKernel[nHalfLen+i];
					dWeightSum += pdKernel[nHalfLen+i];
				}
			}
			pUnchSmthdImg[y*nWidth + x] = (unsigned char)(int)dDotMul/dWeightSum ;
		}
	}

	// 釋放內存
	delete []pdKernel;
	pdKernel = NULL ;
	
	delete []pdTmp;
	pdTmp = NULL;
}


/*************************************************************************
 *
 * \函數名稱:
 *   DirGrad()
 *
 * \輸入參數:
 *   unsigned char *pUnchSmthdImg					- 經過高斯濾波后的圖象
 *   int nWidht														- 圖象寬度
 *   int nHeight      										- 圖象高度
 *   int *pnGradX                         - x方向的方向導數
 *   int *pnGradY                         - y方向的方向導數
 * \返回值:
 *   無
 *
 * \說明:
 *   這個函數計算方向倒數,采用的微分算子是(-1 0 1) 和 (-1 0 1)'(轉置)
 *   計算的時候對邊界象素采用了特殊處理
 *   
 *   
 *************************************************************************
 */
void DirGrad(unsigned char *pUnchSmthdImg, int nWidth, int nHeight,
										 int *pnGradX , int *pnGradY)
{
	// 循環控制變量
	int y ;
	int x ;
	
	// 計算x方向的方向導數,在邊界出進行了處理,防止要訪問的象素出界
	for(y=0; y<nHeight; y++)
	{
		for(x=0; x<nWidth; x++)
		{
			pnGradX[y*nWidth+x] = (int) ( pUnchSmthdImg[y*nWidth+min(nWidth-1,x+1)]  
													          - pUnchSmthdImg[y*nWidth+max(0,x-1)]     );
		}
	}

	// 計算y方向的方向導數,在邊界出進行了處理,防止要訪問的象素出界
	for(x=0; x<nWidth; x++)
	{
		for(y=0; y<nHeight; y++)
		{
			pnGradY[y*nWidth+x] = (int) ( pUnchSmthdImg[min(nHeight-1,y+1)*nWidth + x]  
																		- pUnchSmthdImg[max(0,y-1)*nWidth+ x ]     );
		}
	}
}
/*************************************************************************
 *
 * \函數名稱:
 *   GradMagnitude()
 *
 * \輸入參數:
 *   int *pnGradX                         - x方向的方向導數
 *   int *pnGradY                         - y方向的方向導數
 *   int nWidht														- 圖象寬度
 *   int nHeight      										- 圖象高度
 *   int *pnMag                           - 梯度幅度   
 *
 * \返回值:
 *   無
 *
 * \說明:
 *   這個函數利用方向倒數計算梯度幅度,方向倒數是DirGrad函數計算的結果
 *   
 *************************************************************************
 */
void GradMagnitude(int *pnGradX, int *pnGradY, int nWidth, int nHeight, int *pnMag)
{
	
	// 循環控制變量
	int y ;
	int x ;

	// 中間變量
	double dSqtOne;
	double dSqtTwo;
	
	for(y=0; y<nHeight; y++)
	{
		for(x=0; x<nWidth; x++)
		{
			dSqtOne = pnGradX[y*nWidth + x] * pnGradX[y*nWidth + x];
			dSqtTwo = pnGradY[y*nWidth + x] * pnGradY[y*nWidth + x];
			pnMag[y*nWidth + x] = (int)(sqrt(dSqtOne + dSqtTwo) + 0.5);
		}
	}
}
/*************************************************************************
 *
 * \函數名稱:
 *   NonmaxSuppress()
 *
 * \輸入參數:
 *   int *pnMag                - 梯度圖
 *   int *pnGradX							 - x方向的方向導數	
 *   int *pnGradY              - y方向的方向導數

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲高清一区二区三区| 亚洲日本中文字幕区| 337p粉嫩大胆色噜噜噜噜亚洲| 精品对白一区国产伦| 亚洲一区二区三区在线| 国产成人午夜电影网| 欧美精品一二三| 亚洲欧美视频一区| 国产不卡视频在线播放| 日韩一区二区不卡| 婷婷国产在线综合| 色婷婷久久99综合精品jk白丝| 国产日韩欧美激情| 国产在线视频不卡二| 91精品国产91久久久久久一区二区| 亚洲柠檬福利资源导航| 床上的激情91.| 久久精品一区四区| 精品一区二区三区av| 欧美精品免费视频| 亚洲国产wwwccc36天堂| 日本电影亚洲天堂一区| 亚洲人妖av一区二区| 9人人澡人人爽人人精品| 国产欧美日韩在线| 国产**成人网毛片九色| 久久久噜噜噜久噜久久综合| 久久99国产精品久久99| 精品少妇一区二区三区免费观看| 轻轻草成人在线| 欧美变态凌虐bdsm| 久久精品国产99| 欧美精品一区男女天堂| 精品一区二区三区久久| 久久久一区二区三区捆绑**| 国产精品白丝av| 国产日产欧美一区| 不卡的av电影| 亚洲乱码中文字幕| 欧美日韩一区久久| 日韩高清不卡一区二区三区| 91精品国产91久久久久久最新毛片 | 天天影视色香欲综合网老头| 欧美三级电影网站| 免费看黄色91| 久久奇米777| gogogo免费视频观看亚洲一| 中文字幕日本不卡| 欧美在线观看你懂的| 日韩影院在线观看| 久久久99久久| 色综合夜色一区| 日本美女一区二区三区视频| 精品国产精品一区二区夜夜嗨| 风间由美性色一区二区三区| 亚洲私人黄色宅男| 欧美色倩网站大全免费| 看电视剧不卡顿的网站| 国产精品―色哟哟| 欧美另类高清zo欧美| 国产一区二区福利| 一区二区三区**美女毛片| 91精品在线观看入口| 国产99久久久国产精品| 亚洲制服欧美中文字幕中文字幕| 日韩欧美国产系列| av成人老司机| 日本不卡的三区四区五区| 国产精品三级在线观看| 欧美美女直播网站| 国模少妇一区二区三区| 亚洲午夜久久久久中文字幕久| 欧美xxxx在线观看| 91国产丝袜在线播放| 国产一本一道久久香蕉| 夜色激情一区二区| 国产日产欧产精品推荐色| 在线播放亚洲一区| 99国产一区二区三精品乱码| 老司机午夜精品99久久| 亚洲综合男人的天堂| 欧美韩日一区二区三区| 欧美一区二区美女| 日本韩国欧美三级| 成人免费高清视频在线观看| 美国毛片一区二区| 亚洲一区二区在线视频| 国产精品久久久久久久久免费桃花 | 99视频超级精品| 国产河南妇女毛片精品久久久| 综合欧美亚洲日本| 2020国产精品| 欧美一级搡bbbb搡bbbb| 欧美性xxxxxx少妇| 91影院在线观看| 从欧美一区二区三区| 激情图片小说一区| 男人操女人的视频在线观看欧美| 依依成人精品视频| 亚洲免费av网站| 国产精品卡一卡二| 国产精品乱人伦一区二区| 久久久久久综合| 久久久久综合网| 久久久99精品免费观看| 国产视频一区二区在线观看| 精品国产一区二区三区四区四| 欧美一区日本一区韩国一区| 欧美日韩国产一级| 欧美男人的天堂一二区| 欧美三级视频在线观看| 欧洲一区二区三区在线| 色婷婷av一区二区| 在线免费观看日本一区| 欧美羞羞免费网站| 欧美日韩在线电影| 欧美日韩国产另类不卡| 69堂国产成人免费视频| 欧美一区二区三区四区视频| 日韩亚洲欧美在线| 日韩亚洲欧美高清| 国产亚洲污的网站| 国产精品久99| 一区二区三区免费观看| 亚洲一区在线看| 日韩电影免费一区| 精品无码三级在线观看视频 | 国产欧美一区二区精品秋霞影院| 国产亚洲短视频| 中文字幕在线不卡| 亚洲一区二区高清| 免费不卡在线视频| 国产精品资源在线看| 波波电影院一区二区三区| 欧美自拍丝袜亚洲| 日本高清免费不卡视频| 3751色影院一区二区三区| wwwwxxxxx欧美| 一区二区三区影院| 青青草伊人久久| 国产91精品一区二区麻豆亚洲| 91久久免费观看| 日韩欧美亚洲国产精品字幕久久久| 国产亚洲自拍一区| 一区二区三区欧美激情| 蜜芽一区二区三区| 成人国产视频在线观看| 欧美视频日韩视频| 久久久久久久久久久久久久久99| 国产精品福利一区二区三区| 亚洲丰满少妇videoshd| 国产精品一卡二卡| 在线精品视频免费播放| 久久蜜臀精品av| 亚洲乱码一区二区三区在线观看| 精品一区中文字幕| 91久久精品一区二区| 久久先锋影音av| 亚洲已满18点击进入久久| 国产美女视频91| 免费成人av在线| 视频一区二区三区入口| 国产91在线观看丝袜| 538在线一区二区精品国产| 国产精品国产精品国产专区不蜜| 亚洲va中文字幕| 成人在线一区二区三区| 制服丝袜日韩国产| 亚洲三级电影网站| 国产成人亚洲精品狼色在线| 欧美日韩国产免费一区二区 | 亚洲视频一区二区在线观看| 蜜臀av性久久久久av蜜臀妖精| 不卡av在线网| 国产香蕉久久精品综合网| 日韩av在线免费观看不卡| 99视频有精品| 国产午夜亚洲精品理论片色戒| 奇米精品一区二区三区在线观看一| 99久久99久久精品免费看蜜桃| 久久久精品天堂| 久久精品噜噜噜成人av农村| 欧美精品精品一区| 一区二区三区精品在线观看| jlzzjlzz国产精品久久| 国产日本亚洲高清| 国产乱色国产精品免费视频| 精品国产成人在线影院| 午夜精彩视频在线观看不卡| 色婷婷综合久久久中文一区二区 | 91福利国产成人精品照片| 国产精品乱人伦中文| 成人黄色电影在线 | 日韩电影免费一区| 欧美人与z0zoxxxx视频| 亚洲一区在线免费观看| 欧美三级一区二区| 三级成人在线视频| 欧美一区在线视频| 日本免费新一区视频|