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

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

?? dib.cpp

?? 圖象模式識別工程從簡單到復雜的各個舉例工程的源代碼
?? CPP
?? 第 1 頁 / 共 4 頁
字號:
						GetHeight()-i,	//depth
						&MemDC,
						0,				//x source
						0,			//y source
						SRCCOPY);

			pDC->Rectangle(x, y+i-nDeta,
						   x+GetWidth()/2, y+i);

			pDC->BitBlt(x+GetWidth()/2,  			//x dest
						y,		//y dest
	      				GetWidth(),		//width
						GetHeight()-i,	//depth
						&MemDC,
						GetWidth()/2,				//x source
						i,			//y source
						SRCCOPY);

			pDC->Rectangle( x+GetWidth()/2,
							y+GetHeight()-i,
							x+GetWidth(),
							y+GetHeight());
			break;
		}
		case EFFECT_HCROSSMOVE:
		{
			i += nDeta;
			if (i > GetWidth())
			{
				i = GetWidth();
				bDone = TRUE;
			}
			pDC->BitBlt(x+i,  			//x dest
						y,		//y dest
      					GetWidth()-i,		//width
						GetHeight()/2,	//depth
						&MemDC,
						0,				//x source
						0,			//y source
						SRCCOPY);

			pDC->Rectangle(x+i-nDeta, y,
						   x+i, y+GetHeight()/2);
	
			pDC->BitBlt(x,  			//x dest
						y+GetHeight()/2,	//depth
	      				GetWidth()-i,		//width
						GetHeight(),	//depth
						&MemDC,
						i,			//y source
						GetHeight()/2,	//depth
						SRCCOPY);

			pDC->Rectangle( x+GetWidth()-i,
							y+GetHeight()/2,
							x+GetWidth(),
							y+GetHeight());
			break;
		}
		case EFFECT_VSPLITMOVE:
		{
			i += nDeta;
			if (i > GetHeight()/2)
			{
				i = GetHeight()/2;
				bDone = TRUE;
			}
			pDC->BitBlt(x,  			//x dest
						y,		//y dest
			  			GetWidth(),		//width
						GetHeight()/2-i,	//depth
						&MemDC,
						0,				//x source
						i,			//y source
						SRCCOPY);

			pDC->BitBlt(x,  			//x dest
						y+GetHeight()/2+i,		//y dest
      					GetWidth(),		//width
						GetHeight()/2-i,	//depth
						&MemDC,
						0,				//x source
						GetHeight()/2,			//y source
						SRCCOPY);

			pDC->Rectangle( x,
							y+GetHeight()/2-i,
							x+GetWidth(),
							y+GetHeight()/2+i+1);
			break;
		}
		case EFFECT_HSPLITMOVE:
		{
			i += nDeta;
			if (i > GetWidth()/2)
			{
				i = GetWidth()/2;
				bDone = TRUE;
			}
			pDC->BitBlt(x,  			//x dest
						y,		//y dest
	      				GetWidth()/2-i,		//width
						GetHeight(),	//depth
						&MemDC,
						i,			//y source
						0,				//x source
						SRCCOPY);

			pDC->BitBlt(x+GetWidth()/2+i,  			//x dest
						y,		//y dest
      					GetWidth()/2-i,		//width
						GetHeight(),	//depth
						&MemDC,
						GetWidth()/2,				//x source
						0,			//y source
						SRCCOPY);

			pDC->Rectangle( x+GetWidth()/2-i,
							y,
							x+GetWidth()/2+i+1,
							y+GetHeight());
			break;
		}
		case EFFECT_VRASTER:
		{
			if (i > GetHeight())
			{
				i = GetHeight();
				bDone = TRUE;
			}
			LONG j = 0;
			BOOL bQuitLoop = FALSE;
			while (! bQuitLoop)
			{
				if (j > GetWidth())
				{
					j = GetWidth();
					bQuitLoop = TRUE;
				}
				pDC->BitBlt(x+j,  			//x dest
							y+i,		//y dest
      						nDeta,		//width
							GetHeight()-i,	//depth
							&MemDC,
							j,				//x source
							0,			//y source
							SRCCOPY);

				pDC->Rectangle(x+j, y+i-1,
							   x+j+nDeta, y+i);
				j += nDeta;
				if (j > GetWidth())
				{
					j = GetWidth();
					bQuitLoop = TRUE;
				}
	
				pDC->BitBlt(x+j,  			//x dest
							y,		//y dest
				  			nDeta,		//width
							GetHeight()-i,	//depth
							&MemDC,
							j,			//y source
							i,				//x source
							SRCCOPY);

				pDC->Rectangle( x+j,
								y+GetHeight()-i,
								x+j+nDeta,
								y+GetHeight());
				j += nDeta;
			}
			i++;
			break;
		}
		case EFFECT_HRASTER:
		{
			if (i > GetWidth())
			{
				i = GetWidth();
				bDone = TRUE;
			}
			LONG j = 0;
			BOOL bQuitLoop = FALSE;
			while (! bQuitLoop)
			{
				if (j > GetHeight())
				{
					j = GetHeight();
					bQuitLoop = TRUE;
				}
				pDC->BitBlt(x+i,  			//x dest
							y+j,		//y dest
      						GetWidth()-i,		//width
							nDeta,	//depth
							&MemDC,
							0,				//x source
							j,			//y source
							SRCCOPY);
				pDC->Rectangle(x+i-1, y+j,
							   x+i, y+j+nDeta);
				j += nDeta;
				if (j > GetHeight())
				{
					j = GetHeight();
					bQuitLoop = TRUE;
				}
				pDC->BitBlt(x,  			//x dest
							y+j,		//y dest
				  			GetWidth()-i,		//width
							nDeta,	//depth
							&MemDC,
							i,			//y source
							j,				//x source
							SRCCOPY);
				pDC->Rectangle( x+GetWidth()-i,
								y+j,
								x+GetWidth(),
								y+j+nDeta);
				j += nDeta;
			}
			i++;
			break;
		}
		case EFFECT_HBLIND:
		{
			if (i > nDeta)
			{
				i = nDeta;
				bDone = TRUE;
			}
			for (LONG j=i; j<GetHeight(); j+=nDeta)
				pDC->Rectangle( x,
								y+j,
								x+GetWidth(),
								y+j+1);
			i++;
			break;
		}
		case EFFECT_VBLIND:
			if (i > nDeta)
			{
				i = nDeta;
				bDone = TRUE;
			}
			for (LONG j=i; j<GetWidth(); j+=nDeta)
				pDC->Rectangle( x+j,
								y,
								x+j+1,
								y+GetHeight());
			i++;
			break;
		}	// end of switch
		//Delay(dwDelayTime);
	}	// end of while

	MemDC.SelectObject(pOldBmp);
	pDC->SelectPalette(pOldPal, TRUE);

	return TRUE;
}

HDIB CDib::CopyRect(CRect rc)
{
	return CropDIB(m_hDib, rc);
}

BOOL CDib::CutRect(CRect rc)
{
	HDIB hNewDib = CutDIB(m_hDib, rc);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::MergeDib(HDIB hDib, CPoint ptTopLeft)
{
	POINT pt;
	pt.x = ptTopLeft.x;
	pt.y = ptTopLeft.y;
	HDIB hNewDib = MergeDIB(m_hDib, hDib, pt);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::	Crop(CRect rc)
{
	HDIB hNewDib = CropDIB(m_hDib, rc);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::Rotate90()
{
	HDIB hNewDib = RotateDIB(m_hDib);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::Rotate180()
{
	HDIB h = RotateDIB(m_hDib);
	if (! h)
		return FALSE;
	HDIB hNewDib = RotateDIB(h);
	DestroyDIB(h);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::Rotate270()
{
	HDIB h1 = RotateDIB(m_hDib);
	if (! h1)
		return FALSE;
	HDIB h2 = RotateDIB(h1);
	DestroyDIB(h1);
	if (! h2)
		return FALSE;
	HDIB hNewDib = RotateDIB(h2);
	DestroyDIB(h2);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::FlipHorz()
{
	HDIB hNewDib = FlipHorzDIB(m_hDib);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::FlipVert()
{
	HDIB hNewDib = FlipVertDIB(m_hDib);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::	ChangeImageSize(int nWidth, int nHeight)
{
	HDIB hNewDib = ChangeDIBSize(m_hDib, nWidth, nHeight);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::Zoom(double fRatioX, double fRatioY)
{
	int nWidth = (int)(fRatioX * (double)GetWidth());
	int nHeight = (int)(fRatioY * (double)GetHeight());

	HDIB hNewDib = ChangeDIBSize(m_hDib, nWidth, nHeight);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::	ChangeCanvasSize(int nWidth, int nHeight, int nPosition)
{
	HDIB hNewDib = ChangeDIBCanvasSize(m_hDib, nWidth, nHeight, nPosition);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::IsRequireDither(CDC* pDC)
{
	// if device can not display DIB color, dithering DIB
	if (GetBitCount() == 24 && 
		pDC->GetDeviceCaps(BITSPIXEL) <= 8)
		return TRUE;

	return FALSE;
}

BOOL CDib::DitherDisplay(CDC* pDC, CRect rcDest, CRect rcSrc, DWORD dwRop)
{
	return DitherDisplayDIB(pDC->GetSafeHdc(), 
							rcDest, 
							m_hDib, 
							rcSrc, 
							dwRop);
}

BOOL CDib::AdjustColor(int nColorModel, int v1, int v2, int v3)
{
	if (! AdjustDIBColor(m_hDib, nColorModel, v1, v2, v3))
		return FALSE;

	return UpdateInternal();
}

BOOL CDib::AdjustBrightness(int v)
{
	if (! AdjustDIBBrightness(m_hDib, v))
		return FALSE;

	return UpdateInternal();
}

BOOL CDib::AdjustContrast(int v)
{
	if (! AdjustDIBContrast(m_hDib, v))
		return FALSE;

	return UpdateInternal();
}

BOOL CDib::SeparateRGB(int nIndex)
{
	HDIB hNewDib = SeparateRGBfromDIB(m_hDib, nIndex);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::FilteRGB(int nIndex)
{
	HDIB hNewDib = FilteRGBfromDIB(m_hDib, nIndex);
	if (! hNewDib)
		return FALSE;

	// set to m_hDib
	Destroy();
	m_hDib = hNewDib;

	// return
	return UpdateInternal();
}

BOOL CDib::ColorQuantize(int nColorBits)
{
	HDIB hNewDib;

	if (nColorBits > 8)
		hNewDib = ConvertDIBFormat(m_hDib, nColorBits, NULL); 
	else
	{
		int nColors = 1<<nColorBits;
		hNewDib = ColorQuantizeDIB(m_hDib, nColorBits, nColors);
	}

	if (! hNewDib)
		return FALSE;

	Destroy();
	m_hDib = hNewDib;
	
	return UpdateInternal();
}

BOOL CDib::ChangeToGrayscale(int nMethod, double fRedWeight, double fGreenWeight, double fBlueWeight)
{
	HPALETTE hPal = ConvertToGrayscale(m_hDib, nMethod, fRedWeight, fGreenWeight, fBlueWeight);
	if (hPal == NULL)
		return FALSE;

	// set new palette
	if (m_pPalette != NULL)
		delete m_pPalette;

	m_pPalette = new CPalette;
	m_pPalette->Attach(hPal);

	// rebuild bitmap
	return UpdateInternal();
}

BOOL CDib::HighPass(int Strength, int nAlgorithm)
{
	if (! HighPassDIB(m_hDib, Strength, nAlgorithm))
		return FALSE;

	// return
	return UpdateInternal();
}

BOOL CDib::LowPass(int Strength, int nAlgorithm)
{
	if (! LowPassDIB(m_hDib, Strength, nAlgorithm))
		return FALSE;

	// return
	return UpdateInternal();
}

BOOL CDib::EdgeEnhance(int Strength, int nAlgorithm)
{
	if (! EdgeEnhanceDIB(m_hDib, Strength, nAlgorithm))
		return FALSE;

	// return
	return UpdateInternal();
}

BOOL CDib::MedianFilter()
{
	if (! MedianFilterDIB(m_hDib))
		return FALSE;

	// return
	return UpdateInternal();
}

BOOL CDib::ConvertFormat(WORD wBitCount)
{
	if (IsEmpty())
		return FALSE;

	if (GetBitCount() == wBitCount)
		return TRUE;

	HDIB hNewDib = ConvertDIBFormat(m_hDib, wBitCount, NULL); 
	if (! hNewDib)
		return FALSE;

	Destroy();
	m_hDib = hNewDib;
	return UpdateInternal();
}

BYTE CDib::GetPixel8(LONG x, LONG y)
{
	BYTE result;
	switch (GetBitCount())
	{
		case 1 :	result = 0;
					break;
		case 4 :	result = 0;
					break;
		case 8 :	
				{
					result = *(BYTE*)(GetBitsPtr()+GetPixelOffset(x, y));
				}
					break;
		default:	result = 0;
					break;
	}
	return result;
}

BOOL CDib::SetPixel8(LONG x, LONG y, BYTE value)
{
	if(GetBitCount() != 8)
		return false;

	else
	{
		*(BYTE*)(GetBitsPtr()+GetPixelOffset(x, y)) = value;
		return true;
	}
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久精品视频免费观看| 亚洲福利国产精品| 亚洲男人天堂一区| 蜜桃精品视频在线观看| 国产91精品在线观看| 欧美精品日日鲁夜夜添| 国产精品久久久久久久久久久免费看| 午夜精彩视频在线观看不卡| 成人激情小说网站| 久久午夜免费电影| 蜜臀精品久久久久久蜜臀| 91在线国产福利| 国产亚洲人成网站| 久88久久88久久久| 欧美一区二区三区四区视频| 一区二区不卡在线播放| 成年人国产精品| 久久精品欧美一区二区三区不卡 | 欧美tk—视频vk| 亚洲资源在线观看| 91在线视频播放地址| 国产人伦精品一区二区| 国产在线观看免费一区| 精品999久久久| 狠狠色综合日日| 精品少妇一区二区三区视频免付费 | 成人高清免费观看| 久久综合九色综合97_久久久| 午夜欧美在线一二页| 欧美中文字幕一区二区三区亚洲| 最新中文字幕一区二区三区| 成人动漫av在线| 国产三级欧美三级日产三级99| 精品亚洲国产成人av制服丝袜| 欧美一卡二卡在线观看| 日本特黄久久久高潮| 欧美一区二区三区四区视频| 蜜桃精品视频在线观看| 欧美tk丨vk视频| 国产精品一级黄| 欧美国产激情二区三区| www..com久久爱| 亚洲一区二区五区| 欧美军同video69gay| 蜜臀久久久久久久| 国产亚洲欧美日韩在线一区| www.欧美.com| 亚洲在线视频免费观看| 91精品国产aⅴ一区二区| 久久97超碰色| 国产亚洲女人久久久久毛片| 91影院在线免费观看| 亚洲午夜精品网| 精品捆绑美女sm三区| 国产成人免费视频一区| 亚洲美女在线一区| 欧美一级片在线看| 国产69精品久久久久777| 亚洲蜜臀av乱码久久精品| 欧美日韩和欧美的一区二区| 精品一区二区三区视频在线观看 | 国产欧美精品区一区二区三区| 成人美女在线视频| 调教+趴+乳夹+国产+精品| 精品成人佐山爱一区二区| 成人性生交大片免费看中文| 亚洲永久免费av| 日韩欧美国产1| 色综合久久久久综合体| 美腿丝袜亚洲色图| 综合久久国产九一剧情麻豆| 91麻豆精品国产91久久久更新时间| 国产精品亚洲专一区二区三区 | 日本中文字幕不卡| 欧美经典一区二区三区| 欧美三级电影网站| 成人动漫在线一区| 麻豆成人91精品二区三区| 国产精品电影一区二区| 日韩欧美另类在线| 在线视频亚洲一区| 国产成人aaa| 日本成人在线一区| 亚洲精品乱码久久久久久| 久久日韩粉嫩一区二区三区| 欧美日韩卡一卡二| 91视频国产观看| 国产福利精品导航| 蜜臀99久久精品久久久久久软件| 亚洲视频网在线直播| 久久免费看少妇高潮| 91精品国产高清一区二区三区蜜臀| 成人午夜碰碰视频| 精品亚洲国内自在自线福利| 亚洲图片一区二区| 中文字幕一区二区三区蜜月| 欧美第一区第二区| 欧美日韩一区小说| 91网页版在线| 99久久99久久久精品齐齐| 国产很黄免费观看久久| 经典三级视频一区| 美洲天堂一区二卡三卡四卡视频| 亚洲最大成人综合| 亚洲精品成人少妇| 亚洲日韩欧美一区二区在线| 欧美经典一区二区三区| 国产三级欧美三级日产三级99| 欧美tk丨vk视频| 精品日韩在线观看| 精品乱码亚洲一区二区不卡| 日韩欧美中文一区| 欧美电影免费观看高清完整版在线观看| 欧美体内she精高潮| 在线免费观看日本一区| 在线观看中文字幕不卡| 欧美影院精品一区| 欧美在线观看视频一区二区三区| 日本高清不卡aⅴ免费网站| 日本韩国一区二区| 欧美午夜影院一区| 欧美精品一卡两卡| 7777精品伊人久久久大香线蕉 | 91激情五月电影| 色久综合一二码| 欧美午夜影院一区| 欧美精品日韩精品| 欧美本精品男人aⅴ天堂| 久久精品视频免费观看| 综合久久给合久久狠狠狠97色| 亚洲天堂av一区| 午夜久久久久久| 美女国产一区二区| 国产激情偷乱视频一区二区三区| 成人免费毛片app| 色综合天天综合网国产成人综合天| 色综合久久天天综合网| 69久久99精品久久久久婷婷 | 国产精品视频免费看| 亚洲黄色录像片| 久久精品国内一区二区三区| 国产一区二区三区av电影| 国产精品性做久久久久久| eeuss鲁一区二区三区| 欧美日韩精品系列| 久久久久9999亚洲精品| 亚洲色图制服诱惑 | 日韩美女视频一区二区| 亚洲综合久久久| 激情国产一区二区 | 欧美色国产精品| 精品国产91洋老外米糕| 亚洲精品综合在线| 美女国产一区二区| 成人av资源下载| 日韩一区二区三区视频| 国产精品青草久久| 偷拍与自拍一区| 不卡视频一二三| 日韩精品一区二区在线观看| 国产精品二三区| 九一久久久久久| 欧美日韩在线免费视频| 欧美激情在线一区二区| 日本系列欧美系列| 日本韩国欧美在线| 国产拍欧美日韩视频二区| 天堂久久一区二区三区| av一区二区三区四区| 精品国产伦理网| 天天做天天摸天天爽国产一区| a在线欧美一区| 26uuu欧美| 日韩av电影天堂| 色综合久久99| 国产精品传媒入口麻豆| 加勒比av一区二区| 欧美日韩国产综合一区二区| 日本一区二区动态图| 日本欧美加勒比视频| 色婷婷综合久色| 国产精品乱码人人做人人爱| 国产精品一区专区| 日韩午夜中文字幕| 日本中文一区二区三区| 欧美日韩免费一区二区三区| 亚洲视频一二区| 色综合天天天天做夜夜夜夜做| 久久精品免费在线观看| 麻豆免费看一区二区三区| 欧美一区二区三区四区久久| 五月天一区二区三区| 日本黄色一区二区| 一级日本不卡的影视| 色婷婷一区二区| 一区二区成人在线观看| 欧美性欧美巨大黑白大战| 亚洲男人的天堂av| 日本国产一区二区| 亚洲高清在线视频|