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

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

?? watermarking.cpp

?? 電子書《數(shù)字圖像處理學(xué)》Visual C++實(shí)現(xiàn) 郎銳編寫 所附源碼
?? CPP
字號(hào):
// ************************************************************************
//  文件名:WaterMarking.cpp
//
//   水印添加函數(shù)庫:
//
//  Set()				- 水印嵌入函數(shù)
//  Get()				- 水印檢測(cè)函數(shù)
//
// ************************************************************************

#include "stdafx.h"
#include "dip_system.h"
#include "WaterMarking.h"

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

#define WIDTH	100
#define HEIGHT	100

/////////////////////////////////////////////////////////////////////////////
// CWaterMarking

CWaterMarking::CWaterMarking()
{
}

CWaterMarking::~CWaterMarking()
{
}


BEGIN_MESSAGE_MAP(CWaterMarking, CWnd)
	//{{AFX_MSG_MAP(CWaterMarking)
		// NOTE - the ClassWizard will add and remove mapping macros here.
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()


/////////////////////////////////////////////////////////////////////////////
// CWaterMarking message handlers

/*************************************************************************
 *
 * 函數(shù)名稱:
 *   Set() 
 * 
 * 參數(shù):
 *   HDIB hDIB          - 待處理的DIB
 *
 * 返回值:
 *   void				- 無返回值
 *
 * 說明:
 *   該函數(shù)為DIB圖象添加水印
 *
 ************************************************************************/

void CWaterMarking::Set(HDIB hDIB)
{
	// 指向DIB的指針
	LPBYTE lpDIB;
	
	// 指向DIB象素指針
	LPBYTE lpDIBBits;
	
	// 鎖定DIB
	lpDIB = (LPBYTE) ::GlobalLock((HGLOBAL) hDIB);

	// 找到DIB圖像象素起始位置
	lpDIBBits = m_clsDIB.FindDIBBits(lpDIB);
	
	// 判斷是否是24-bpp位圖
	if (m_clsDIB.DIBBitCount(lpDIB) != 24)
	{
		// 提示用戶
		MessageBox("請(qǐng)先將其轉(zhuǎn)換為24位色位圖,再進(jìn)行處理!", "系統(tǒng)提示" , MB_ICONINFORMATION | MB_OK);
		
		// 解除鎖定
		::GlobalUnlock((HGLOBAL) hDIB);
		
		// 返回
		return;
	}

	// 更改光標(biāo)形狀
	BeginWaitCursor();
		
	// DIB的寬度
	LONG lWidth = m_clsDIB.DIBWidth(lpDIB);
	
	// DIB的高度
	LONG lHeight = m_clsDIB.DIBHeight(lpDIB);

	// 計(jì)算圖像每行的字節(jié)數(shù)
	LONG lLineBytes = WIDTHBYTES(lWidth * 24);
	
	// 從水印文件獲取相關(guān)信息
	char exeFullPath[MAX_PATH];
	CString strPath;
	GetModuleFileName(NULL, exeFullPath, MAX_PATH);
	strPath = CString(exeFullPath);
	strPath = strPath.Left(strPath.ReverseFind('\\'));
	strPath += "\\水印.bmp";

	CFile file;
	file.Open(strPath, CFile::modeReadWrite);
	int nFileLen = file.GetLength();
	unsigned char* lpBuf;
	lpBuf = new unsigned char[nFileLen];
	nFileLen = file.Read(lpBuf, nFileLen);
	file.Close();

	if (lLineBytes * lHeight < 4 * nFileLen)
	{
		// 提示用戶
		MessageBox("載體位圖太小,不能容納水??!", "系統(tǒng)提示" , MB_ICONINFORMATION | MB_OK);
		
		// 釋放內(nèi)存
		delete lpBuf;

		// 解除鎖定
		::GlobalUnlock((HGLOBAL) hDIB);
		
		// 返回
		return;
	}

	// 填冗余位時(shí)的移位序列
	int move1[13] = {6, 5, 2, 0, 7, 4, 2, 1, -2, 6, 4, 3, 0};
	
	// 待隱藏文件的字節(jié)掩碼序列
    unsigned char mask1[13]={192, 32, 28, 3, 128, 112, 12, 2, 1, 192, 48, 8, 7};
	
	// 位圖文件的字節(jié)掩碼序列
	unsigned char mask2[13]={252, 254, 248, 252, 254, 248, 252, 254, 251, 252, 252, 254, 248};
	
	// 為1時(shí)pointer1指針加一
	int add1[13]={0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1};

	// 為1時(shí)pointer2指針加一
	int add2[13]={1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1};

	// 臨時(shí)指針
	int pointer1 = 0;
	int pointer2 = 0;
	int pointer3 = 0;

	while(pointer1 <= nFileLen)
	{
		// 將水印比特流嵌入到載體位圖
		if (move1[pointer3] > 0)
			*(lpDIBBits + pointer2) = (*(lpDIBBits + pointer2) & mask2[pointer3])|((lpBuf[pointer1] & mask1[pointer3]) >> move1[pointer3]);
		else
			*(lpDIBBits + pointer2) = (*(lpDIBBits + pointer2) & mask2[pointer3])|((lpBuf[pointer1] & mask1[pointer3]) << move1[pointer3] * (-1));

		//修正指針
		if (add1[pointer3] == 1)
			pointer1++;
		if (add2[pointer3] == 1)
			pointer2++;
		pointer3++;
		pointer3 %= 13;
	}

	// 解除鎖定
	::GlobalUnlock((HGLOBAL) hDIB);

	delete lpBuf;//釋放緩存

	// 恢復(fù)光標(biāo)
	EndWaitCursor();
}


/*************************************************************************
 *
 * 函數(shù)名稱:
 *   Get() 
 * 
 * 參數(shù):
 *   HDIB hDIB          - 待處理的DIB
 *	 CFile& file		- 水印文件
 *
 * 返回值:
 *   void				- 無返回值
 *
 * 說明:
 *   該函數(shù)從DIB圖象提取出水印
 *
 ************************************************************************/

void CWaterMarking::Get(HDIB hDIB, CFile &file)
{
	// 嵌入水印的長(zhǎng)度
	int nFileLen = 54 + 3 * WIDTH * HEIGHT;

	// 指向DIB的指針
	LPBYTE lpDIB;
	
	// 指向DIB象素指針
	LPBYTE lpDIBBits;
	
	// 鎖定DIB
	lpDIB = (LPBYTE) ::GlobalLock((HGLOBAL) hDIB);

	// 找到DIB圖像象素起始位置
	lpDIBBits = m_clsDIB.FindDIBBits(lpDIB);
	
	// 判斷是否是24-bpp位圖
	if (m_clsDIB.DIBBitCount(lpDIB) != 24)
	{
		// 提示用戶
		MessageBox("請(qǐng)先將其轉(zhuǎn)換為24位色位圖,再進(jìn)行處理!", "系統(tǒng)提示" , MB_ICONINFORMATION | MB_OK);
		
		// 解除鎖定
		::GlobalUnlock((HGLOBAL) hDIB);
		
		// 返回
		return;
	}

	// 更改光標(biāo)形狀
	BeginWaitCursor();
		
	// DIB的寬度
	LONG lWidth = m_clsDIB.DIBWidth(lpDIB);
	
	// DIB的高度
	LONG lHeight = m_clsDIB.DIBHeight(lpDIB);

	// 計(jì)算圖像每行的字節(jié)數(shù)
	LONG lLineBytes = WIDTHBYTES(lWidth * 24);
	
	// 分配并初始化內(nèi)存
	unsigned char* lpBuf1;
	unsigned char* lpBuf2;

	lpBuf1 = new unsigned char [lLineBytes * lHeight];
	lpBuf2 = new unsigned char [lLineBytes * lHeight];

	memset(lpBuf1, 0, lLineBytes * lHeight);
	memset(lpBuf2, 0, lLineBytes * lHeight);

	//拼合文件信息字節(jié)時(shí)的移位序列
	int move2[13] = {6, 5, 2, 0, 7, 4, 2, 1, -2, 6, 4, 3, 0};

	//位圖文件字節(jié)的掩碼序列
    unsigned char mask2[13]={3, 1, 7, 3, 1, 7, 3, 1, 4, 3, 3, 1, 7};

	// 為1時(shí)pointer1指針加一
	int add1[13]={0, 0, 0, 1, 0, 0, 0, 0, 1, 0, 0, 0, 1};

	// 為1時(shí)pointer2指針加一
	int add2[13]={1, 1, 1, 1, 1, 1, 1, 1, 0, 1, 1, 1, 1};

	// 臨時(shí)指針
	int pointer1 = 0;
	int pointer2 = 0;
	int pointer3 = 0;
	int pointer4 = 0;

	// 提取水印數(shù)據(jù)
	while(true)
	{
		// 從DIB字節(jié)流中提取出水印數(shù)據(jù)
		if(move2[pointer3] > 0)
			lpBuf2[pointer1] |= (*(lpDIBBits + pointer2) & mask2[pointer3]) << move2[pointer3];
		else
			lpBuf2[pointer1] |= (*(lpDIBBits + pointer2) & mask2[pointer3]) >> (move2[pointer3] * (-1));
		
		if(add1[pointer3] == 1)
		{
			lpBuf1[pointer4] = lpBuf2[pointer1];
			pointer4++;

			// 水印提取完畢,跳出循環(huán)
			if(pointer4 > nFileLen)
				break;

			//修正指針
			pointer1++;
		}
		
		//修正指針
		if(add2[pointer3] == 1)
			pointer2++;
		pointer3++;
		pointer3 %= 13;
	}

	file.Write(lpBuf1, nFileLen);

	// 解除鎖定
	::GlobalUnlock((HGLOBAL) hDIB);

	//釋放緩存
	delete lpBuf1;
	delete lpBuf2;

	// 恢復(fù)光標(biāo)
	EndWaitCursor();
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产亚洲欧美日韩在线一区| 日韩一级二级三级精品视频| 国产精品国产三级国产aⅴ中文 | 欧美性生活久久| 亚洲激情图片qvod| 精品视频在线免费观看| 视频一区欧美精品| 91精品福利在线一区二区三区| 日本美女视频一区二区| 91麻豆精品国产综合久久久久久| 日韩精品一二三四| 精品国偷自产国产一区| 国产精品乡下勾搭老头1| 国产精品高清亚洲| 在线精品视频免费播放| 免费观看一级特黄欧美大片| 久久综合狠狠综合久久综合88| 成人免费黄色大片| 亚洲国产日韩在线一区模特 | 韩国欧美国产1区| 中文久久乱码一区二区| 91成人在线精品| 美女一区二区视频| 国产精品成人一区二区三区夜夜夜| 色婷婷综合久色| 久久av中文字幕片| 国产精品久久久久aaaa樱花| 欧美精品vⅰdeose4hd| 国产精品亚洲一区二区三区在线 | 欧美在线免费视屏| 国产美女娇喘av呻吟久久| 亚洲婷婷在线视频| 欧美tk丨vk视频| 日本大香伊一区二区三区| 免费人成黄页网站在线一区二区| 中文字幕不卡在线观看| 欧美高清hd18日本| 波多野结衣在线一区| 欧美aa在线视频| 亚洲精品视频免费看| 久久亚洲私人国产精品va媚药| 在线观看日韩一区| 成人精品电影在线观看| 无码av免费一区二区三区试看| 国产欧美日韩不卡免费| 欧美一级片免费看| 欧美日韩一区高清| 成人国产亚洲欧美成人综合网| 久久精品国产免费看久久精品| 亚洲欧美激情小说另类| 国产亚洲精久久久久久| 欧美一区永久视频免费观看| 91浏览器在线视频| 成人综合婷婷国产精品久久蜜臀| 午夜国产精品影院在线观看| 一区二区三区中文在线观看| 欧美经典一区二区| 久久久精品国产免大香伊| 欧美电视剧在线观看完整版| 精品视频在线视频| 欧美三级视频在线| 91国偷自产一区二区三区成为亚洲经典 | 欧美日韩免费观看一区三区| 97久久超碰国产精品电影| 国产成人高清视频| 精品在线观看视频| 另类成人小视频在线| 蜜臀av一区二区在线免费观看 | 免费在线观看不卡| 日韩在线卡一卡二| 国产一区二区不卡在线 | 成人欧美一区二区三区视频网页 | 中文字幕视频一区| 国产精品成人免费精品自在线观看| 国产午夜亚洲精品不卡| 久久久精品国产免费观看同学| 久久一区二区三区国产精品| 亚洲精品一区二区三区四区高清| 欧美成人精品高清在线播放| 日韩写真欧美这视频| 日韩精品专区在线| 欧美精品一区二区三区很污很色的| 91精品国产高清一区二区三区| 欧美一区二区三区爱爱| 91精品国产一区二区| 日韩一区二区三| 精品免费日韩av| 国产日产欧美一区二区视频| 国产精品无人区| 亚洲欧洲综合另类| 亚洲v精品v日韩v欧美v专区| 日韩av一级片| 国产精品一区二区三区网站| 成人av网址在线观看| 在线视频欧美精品| 4438x亚洲最大成人网| 欧美一级理论片| 国产偷国产偷亚洲高清人白洁| 国产精品久久久久久久久快鸭| 亚洲三级在线免费观看| 丝袜亚洲另类欧美| 国产美女娇喘av呻吟久久| 成人国产精品免费观看视频| 在线观看亚洲a| 日韩亚洲欧美综合| 中文字幕欧美国产| 亚洲国产视频一区| 国产麻豆9l精品三级站| 色哟哟一区二区在线观看| 欧美日韩大陆一区二区| 国产校园另类小说区| 亚洲专区一二三| 国产自产高清不卡| 欧洲另类一二三四区| 久久影视一区二区| 亚洲一区二区三区视频在线播放| 激情综合网最新| 91丨九色porny丨蝌蚪| 欧美一区二区三区四区在线观看| 久久久天堂av| 午夜不卡av在线| 成人黄色一级视频| 日韩视频123| 亚洲日本va午夜在线电影| 精品写真视频在线观看| 色94色欧美sute亚洲线路一久| 欧美一区二区三区爱爱| 国产精品美女一区二区三区| 日韩高清欧美激情| 色婷婷激情综合| 国产亚洲一本大道中文在线| 日本欧美一区二区| 91丨九色丨蝌蚪丨老版| 久久综合九色综合久久久精品综合| 一区二区三区在线免费视频 | 92国产精品观看| 亚洲一区二区三区三| 国产高清在线精品| 欧美日韩国产免费| 亚洲激情校园春色| aaa亚洲精品| 久久久亚洲高清| 极品销魂美女一区二区三区| 日本道精品一区二区三区| 中文字幕第一区二区| 国产一区二区视频在线| 日韩欧美一级精品久久| 五月激情六月综合| 欧美日韩国产片| 亚洲综合清纯丝袜自拍| 一本一道波多野结衣一区二区 | 亚洲欧美电影院| 成人av在线一区二区| 久久嫩草精品久久久精品| 蜜桃91丨九色丨蝌蚪91桃色| 欧美日韩日日摸| 亚洲成人动漫一区| 欧美日韩一区不卡| 亚洲成va人在线观看| 欧美性猛交xxxx黑人交| 亚洲图片欧美色图| 在线观看日韩一区| 樱花影视一区二区| 欧美在线free| 亚洲一线二线三线久久久| 91蜜桃传媒精品久久久一区二区| 国产欧美日产一区| 成人黄色电影在线| 国产精品热久久久久夜色精品三区| 国产乱码字幕精品高清av| 精品国免费一区二区三区| 久久成人综合网| 久久久久久久久久久电影| 国产精品系列在线播放| 国产精品天美传媒| 97精品超碰一区二区三区| 亚洲欧洲中文日韩久久av乱码| 在线免费观看日韩欧美| 亚洲一区二区三区四区五区黄 | 日韩欧美一级片| 国产高清久久久久| 国产日韩v精品一区二区| 成人av资源下载| 亚洲一线二线三线视频| 欧美男人的天堂一二区| 日韩高清一区二区| 国产亚洲美州欧州综合国| 99精品欧美一区二区蜜桃免费| 樱花影视一区二区| 欧美一级日韩不卡播放免费| 国产精品一线二线三线精华| 中文字幕av一区二区三区免费看| 91原创在线视频| 日本欧美韩国一区三区| 国产亚洲人成网站| 91成人免费网站| 精品亚洲成a人在线观看| 亚洲欧洲一区二区在线播放| 精品视频资源站| 国产精一区二区三区|