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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? effectdisplay.cpp

?? VS2005圖像處理程序的源代碼
?? CPP
字號:
#include "StdAfx.h"
#include "mainfrm.h"
#include "EffectDisplay.h"
#include <cmath>

// 靜態(tài)成員變量初始化
int	EffectDisplay::s_nOffsetX	= 0;
int	EffectDisplay::s_nOffsetY	= 0;
int	EffectDisplay::s_nPicWidth	= 0;
int	EffectDisplay::s_nPicHeight = 0;
int	EffectDisplay::s_nCDCWidth	= 0;
int	EffectDisplay::s_nCDCHeight = 0;

/******************************************************************************
*	作用:				延時函數(shù)
*	參數(shù):		
*		dwMilliseconds	延時時間,單位毫秒
******************************************************************************/
void EffectDisplay::DelayTime(DWORD dwMilliseconds)
{
	LARGE_INTEGER litmp; 
	LONGLONG lTimeBeign;
	LONGLONG lTimeEnd;
	double dMinus;
	double dFreq;
	double dTim;

	QueryPerformanceFrequency(&litmp);	// 獲得機(jī)器內(nèi)部定時器的時鐘頻率
	dFreq = (double)litmp.QuadPart;		// 獲得計數(shù)器的時鐘頻率
	QueryPerformanceCounter(&litmp);
	lTimeBeign = litmp.QuadPart;		// 獲得時間起始值
	do
	{
		QueryPerformanceCounter(&litmp);
		lTimeEnd = litmp.QuadPart;		//獲得中止值
		dMinus = (double)(lTimeEnd - lTimeBeign);
		dTim = dMinus / dFreq;			// 獲得對應(yīng)的時間值,單位為秒
	} while (dTim < dwMilliseconds * 0.001);
}

/******************************************************************************
*	作用:		向下掃描特效
******************************************************************************/
void EffectDisplay::ScanDownDisplay(CDC* pDC, CDC* pMemDC)
{
	// 掃描高度
	int nHeight = min(s_nPicHeight, s_nCDCHeight);

	// 掃描寬度
	int nWidth = min(s_nPicWidth, s_nCDCWidth);
	
	for (int i = 0; i <= nHeight; i += 1)
	{
		pDC->BitBlt(s_nOffsetX, i + s_nOffsetY, nWidth, 1, 
					pMemDC, s_nOffsetX, i + s_nOffsetY, SRCCOPY);
		DelayTime(1);
	}
}

/******************************************************************************
*	作用:		垂直雙重掃描特效
******************************************************************************/
void EffectDisplay::VSScanDisplay(CDC* pDC, CDC* pMemDC)
{
	// 掃描高度
	int nHeight = min(s_nPicHeight, s_nCDCHeight);

	// 掃描寬度
	int nWidth = min(s_nPicWidth, s_nCDCWidth);

	for (int i = 0; i <= nHeight / 2; i += 1)
	{
		// 上面部分
		pDC->BitBlt(s_nOffsetX, i + s_nOffsetY, nWidth, 1, 
					pMemDC, s_nOffsetX, i + s_nOffsetY, SRCCOPY);
		// 下面部分
		pDC->BitBlt(s_nOffsetX, nHeight - i + s_nOffsetY, nWidth, 1, 
					pMemDC, s_nOffsetX, nHeight - i + s_nOffsetY, SRCCOPY);
		DelayTime(2);
	}
}

/******************************************************************************
*	作用:		向右移動特效
******************************************************************************/
void EffectDisplay::MoveRightDisplay(CDC* pDC, CDC* pMemDC)
{
	// 掃描高度
	int nHeight = min(s_nPicHeight, s_nCDCHeight);

	for (int i = 0; i <= s_nCDCWidth - s_nOffsetX; i += 2)
	{
		pDC->BitBlt(0, s_nOffsetY, i, nHeight, 
					pMemDC, s_nCDCWidth - s_nOffsetX - i, s_nOffsetY, SRCCOPY);
		DelayTime(1);
	}

	// 修正圖像位置
	pDC->BitBlt(0, s_nOffsetY, s_nCDCWidth - s_nOffsetX, nHeight, 
				pMemDC, 0, s_nOffsetY, SRCCOPY);
}

/******************************************************************************
*	作用:		水平雙重移動特效
******************************************************************************/
void EffectDisplay::HSMoveDisplay(CDC* pDC, CDC* pMemDC)
{
	// 掃描高度
	int nHeight = min(s_nPicHeight, s_nCDCHeight);

	// 掃描寬度
	int nWidth = min(s_nPicWidth, s_nCDCWidth);

	for (int i = 0; i <= s_nCDCWidth / 2; i += 2)
	{
		// 左面部分
		pDC->BitBlt(0, s_nOffsetY, i, nHeight, 
					pMemDC, nWidth / 2 - i + s_nOffsetX, s_nOffsetY, SRCCOPY);
		// 右面部分
		pDC->BitBlt(s_nCDCWidth - i, s_nOffsetY, i, nHeight, 
					pMemDC, nWidth / 2  + s_nOffsetX, s_nOffsetY, SRCCOPY);
		DelayTime(1);
	}

	// 修正圖像位置
	pDC->BitBlt(0, s_nOffsetY, s_nCDCWidth - s_nOffsetX, nHeight, 
				pMemDC, 0, s_nOffsetY, SRCCOPY);
}

/******************************************************************************
*	作用:		垂直百葉窗特效
******************************************************************************/
void EffectDisplay::VBlindDisplay(CDC* pDC, CDC* pMemDC)
{
	// 掃描高度
	int nHeight = min(s_nPicHeight, s_nCDCHeight);

	// 掃描寬度
	int nWidth = min(s_nPicWidth, s_nCDCWidth);

	// 百葉窗寬度
	int nScanLine = 8;
	for (int i = 0; i < nScanLine; i++)
	{
		for (int j = 0; j < nWidth; j += nScanLine)
		{
			pDC->BitBlt(j + i + s_nOffsetX, s_nOffsetY, 1, nHeight, 
						pMemDC, j + i + s_nOffsetX, s_nOffsetY, SRCCOPY);
		}

		DelayTime(50);
	}
}

/******************************************************************************
*	作用:		水平百葉窗特效
******************************************************************************/
void EffectDisplay::HBlindDisplay(CDC* pDC, CDC* pMemDC)
{
	// 掃描高度
	int nHeight = min(s_nPicHeight, s_nCDCHeight);

	// 掃描寬度
	int nWidth = min(s_nPicWidth, s_nCDCWidth);

	// 百葉窗寬度
	int nScanLine = 8;
	for (int i = 0; i < nScanLine; i++)
	{
		for (int j = 0; j < nHeight; j += nScanLine)
		{
			pDC->BitBlt(s_nOffsetX, j + i + s_nOffsetY, nWidth, 1, 
						pMemDC, s_nOffsetX, j + i + s_nOffsetY, SRCCOPY);
		}

		DelayTime(50);
	}
}

/******************************************************************************
*	作用:		垂直柵條特效
******************************************************************************/
void EffectDisplay::VRasterDisplay(CDC* pDC, CDC* pMemDC)
{
	// 掃描高度
	int nHeight = min(s_nPicHeight, s_nCDCHeight);

	// 掃描寬度
	int nWidth = min(s_nPicWidth, s_nCDCWidth);

	int nScanLine = 16;

	for (int i = 0; i <= nHeight + s_nOffsetY; i++)
	{
		for (int j = 0; j <= nWidth; j += 2 * nScanLine)
		{
			pDC->BitBlt(j + s_nOffsetX, 0, nScanLine, i, 
						pMemDC, j + s_nOffsetX, nHeight + s_nOffsetY - i, SRCCOPY);

			int k = j + nScanLine;
			pDC->BitBlt(k + s_nOffsetX, nHeight + s_nOffsetY - i, nScanLine, i + s_nOffsetY, 
						pMemDC, k + s_nOffsetX, 0, SRCCOPY);
		}

		DelayTime(1);
	}
}

/******************************************************************************
*	作用:		水平柵條特效
******************************************************************************/
void EffectDisplay::HRasterDisplay(CDC* pDC, CDC* pMemDC)
{
	// 掃描高度
	int nHeight = min(s_nPicHeight, s_nCDCHeight);

	// 掃描寬度
	int nWidth = min(s_nPicWidth, s_nCDCWidth);

	int nScanLine = 16;

	for (int i = 0; i <= nWidth + s_nOffsetX; i++)
	{
		for (int j = 0; j <= nHeight; j += 2 * nScanLine)
		{
			pDC->BitBlt(0, j + s_nOffsetY, i, nScanLine, 
						pMemDC, nWidth + s_nOffsetX - i, j + s_nOffsetY, SRCCOPY);

			int k = j + nScanLine;
			pDC->BitBlt(nWidth + s_nOffsetX - i, k + s_nOffsetY, i + s_nOffsetX, nScanLine, 
						pMemDC, 0, k + s_nOffsetY, SRCCOPY);
		}

		DelayTime(1);
	}
}

/******************************************************************************
*	作用:		馬賽克特效
******************************************************************************/
void EffectDisplay::MosaicDisplay(CDC* pDC, CDC* pMemDC)
{
	int nTileSize = 24;	// 馬賽克小方塊大小
	int nRw = 0;
	int nRh = 0;
	
	if (s_nPicWidth % nTileSize != 0)
		nRw = 1;
	if (s_nPicHeight % nTileSize != 0)
		nRh = 1;

	// 計算小方塊的個數(shù)
	int nTileCount = (s_nPicWidth / nTileSize + nRw) * (s_nPicHeight / nTileSize + nRh);

	CPtrArray	points;		// 保存所有小方塊的左上坐標(biāo)
	long		lx = 0;
	long		ly = 0;

	for (int k = 0; k < nTileCount; k++)
	{
		CPoint* point = new CPoint;
		point->x = lx;
		point->y = ly;
		lx = lx + nTileSize;
		if (lx >= s_nPicWidth)
		{
			lx = 0;
			ly = ly + nTileSize;
		}

		points.Add(point);
	}

	int nDelayTime = 2;
	if (s_nPicHeight * s_nPicWidth > 600 * 500)
		nDelayTime = 1;

	LARGE_INTEGER seed;
	QueryPerformanceFrequency(&seed);
	QueryPerformanceCounter(&seed);

	//初始化一個以微秒為單位的時間種子
	srand((int)seed.QuadPart);

	for (int i = nTileCount - 1; i >= 0; i--)
	{
		int n = rand() % (i + 1);
		CPoint* point = (CPoint*)points[n];

		lx = point->x;
		ly = point->y;

		pDC->BitBlt(lx + s_nOffsetX, ly + s_nOffsetY, nTileSize, nTileSize, 
					pMemDC, lx + s_nOffsetX, ly + s_nOffsetY, SRCCOPY);

		SAFE_DELETE (point);
		points.RemoveAt(n);

		DelayTime(nDelayTime);
	}
}

/******************************************************************************
*	作用:		雨滴特效
******************************************************************************/
void EffectDisplay::RaindropDisplay(CDC* pDC, CDC* pMemDC)
{
	// 掃描高度
	int nHeight = min(s_nPicHeight, s_nCDCHeight);

	// 掃描寬度
	int nWidth = min(s_nPicWidth, s_nCDCWidth);

	for (int i = 0; i <= nHeight + s_nOffsetY; i++)
	{
		for (int j = 0; j <= nHeight + s_nOffsetY - i; j++)
		{
			pDC->BitBlt(s_nOffsetX, j, nWidth, 1, 
						pMemDC, s_nOffsetX, nHeight + s_nOffsetY - i, SRCCOPY);
		}

		DelayTime(1);
	}
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
成人短视频下载 | 欧美视频一区在线| 亚洲国产你懂的| 精品区一区二区| 色婷婷av一区二区| 国产久卡久卡久卡久卡视频精品| 椎名由奈av一区二区三区| 欧美精品高清视频| 粉嫩欧美一区二区三区高清影视| 欧美在线不卡一区| 亚洲女爱视频在线| 成人免费视频视频在线观看免费| 中文字幕一区二区三区在线观看| 久久综合网色—综合色88| 国产精品入口麻豆原神| 国产精品欧美一级免费| 日韩欧美你懂的| 日本不卡不码高清免费观看| 8v天堂国产在线一区二区| 亚洲一区二区三区影院| 欧美日韩综合在线免费观看| 天天综合天天做天天综合| 欧美一区二区在线视频| 久久国内精品视频| 欧美激情中文字幕一区二区| 成人午夜在线播放| 亚洲激情五月婷婷| 91麻豆精品国产91久久久资源速度 | 五月婷婷久久丁香| 欧美一区二区三区在线电影| 久久草av在线| 一区二区三区欧美久久| 欧美电影免费观看高清完整版在 | 欧美片在线播放| 91网站视频在线观看| 麻豆精品视频在线观看免费| 国产视频一区二区在线| 精品日韩一区二区三区| 精品乱人伦小说| 亚洲综合色丁香婷婷六月图片| 中文字幕乱码亚洲精品一区| 久久夜色精品国产噜噜av| 欧美tk—视频vk| 欧美xxxx老人做受| 国产一区二区三区视频在线播放| 国产欧美一区二区精品久导航| 欧美又粗又大又爽| 国产成人精品1024| 久久成人精品无人区| 中文字幕在线一区| 国产精品伦理一区二区| 久久久久99精品国产片| 不卡视频一二三| 国产ts人妖一区二区| 国内精品国产三级国产a久久 | 亚洲欧美自拍偷拍色图| 亚洲欧洲成人av每日更新| 国产精品久久国产精麻豆99网站| 国产精品乱子久久久久| 亚洲精选一二三| 亚洲福利视频一区二区| 热久久国产精品| 男女男精品网站| 国产一区二区福利| 丁香婷婷综合网| 色哟哟一区二区在线观看| 欧美丝袜自拍制服另类| 欧美一区二区三区白人| 久久夜色精品国产欧美乱极品| 中文字幕av一区二区三区高| 国产精品久久久久久久久搜平片| 亚洲精品视频自拍| 日日夜夜精品视频天天综合网| 奇米影视一区二区三区小说| 国产美女精品人人做人人爽| 99免费精品在线| 欧美日韩日本视频| 久久久久国产一区二区三区四区 | 亚洲综合成人网| 日本va欧美va欧美va精品| 国产福利91精品一区| 91天堂素人约啪| 欧美日韩国产综合久久| 久久网站最新地址| 亚洲色图一区二区| 喷水一区二区三区| 不卡的av网站| 欧美一区三区四区| 国产精品亲子乱子伦xxxx裸| 五月天激情综合网| 国产1区2区3区精品美女| 欧美日韩精品一区二区三区四区 | 欧美日韩小视频| 国产婷婷色一区二区三区| 亚洲国产精品欧美一二99| 91精品一区二区三区久久久久久 | 日韩高清不卡一区二区| 福利一区二区在线| 欧美女孩性生活视频| 国产日韩欧美精品电影三级在线| 亚洲成av人**亚洲成av**| 国产91精品一区二区麻豆亚洲| 欧美日韩在线免费视频| 久久精品夜色噜噜亚洲a∨| 欧美成人精品3d动漫h| 亚洲精品网站在线观看| 国产在线不卡一区| 色婷婷久久综合| 91国产丝袜在线播放| 国产色综合一区| 亚洲小说春色综合另类电影| 久久黄色级2电影| 91小视频免费看| 日韩三级视频在线观看| 久久精品水蜜桃av综合天堂| 日韩激情中文字幕| 成人精品免费网站| 日韩欧美国产精品一区| 亚洲乱码国产乱码精品精的特点| 亚洲自拍与偷拍| 成人免费毛片片v| 欧美一级久久久久久久大片| 亚洲欧美视频在线观看| 国产一区二区91| 日韩视频在线永久播放| 亚洲日本一区二区| 国产成人在线电影| 日韩一区二区三区av| 亚洲激情自拍偷拍| 麻豆91精品91久久久的内涵| 色哟哟一区二区三区| 欧美激情在线观看视频免费| 午夜私人影院久久久久| 在线观看免费视频综合| 国产欧美日韩视频在线观看| 奇米影视在线99精品| 欧美日韩一级黄| 亚洲男同1069视频| 91视频xxxx| 中文字幕精品一区二区精品绿巨人 | 精品一区二区在线免费观看| 欧美性生活一区| 国产精品夫妻自拍| 国产一区二区三区免费观看| 7777女厕盗摄久久久| 亚洲国产日日夜夜| 99久久er热在这里只有精品66| 2023国产精华国产精品| 久色婷婷小香蕉久久| 欧美男人的天堂一二区| 亚洲一区二区四区蜜桃| 欧美视频在线不卡| 亚洲国产成人av网| 欧洲精品一区二区三区在线观看| 亚洲人成在线观看一区二区| 99re这里只有精品视频首页| 亚洲激情图片小说视频| 在线中文字幕一区二区| 亚洲人成在线观看一区二区| 一本久久a久久精品亚洲| 亚洲欧洲精品成人久久奇米网| 国产精品99久久久久久久vr| 国产日韩欧美精品综合| 成人精品免费视频| 亚洲欧洲成人精品av97| 91在线观看美女| 亚洲国产精品久久久久婷婷884| 欧美色图天堂网| 午夜久久久久久久久| 欧美日韩精品系列| 日本人妖一区二区| 欧美丰满美乳xxx高潮www| 国产在线一区二区综合免费视频| 337p粉嫩大胆噜噜噜噜噜91av | 麻豆精品视频在线观看视频| 精品美女一区二区| 国产精品综合在线视频| 亚洲国产高清在线观看视频| 国产91综合网| 亚洲成人资源网| 欧美一区二区三区免费视频 | 国产尤物一区二区在线 | 亚洲欧美乱综合| 欧美片在线播放| 紧缚捆绑精品一区二区| 亚洲欧美日韩电影| 在线成人av影院| 国产乱淫av一区二区三区| 国产精品欧美一区喷水| 欧美在线观看18| 粗大黑人巨茎大战欧美成人| 亚洲黄色片在线观看| 欧美一区二区三区在线观看| 国产精品888| 国产欧美精品一区aⅴ影院| 51精品国自产在线| 国产精品一二三区| 一区二区高清免费观看影视大全| 日韩女优毛片在线| 日本高清无吗v一区|