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

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

?? watermarking.cpp

?? 其中包括圖像壓縮的基本編碼方法如Huffman編碼算術編碼JPEG 2000H.261壓縮編碼標準小波變換編碼運動估計算法視頻圖象采集的VC實現等.
?? CPP
字號:
// ************************************************************************
//  文件名:WaterMarking.cpp
//
//   水印添加函數庫:
//
//  Set()				- 水印嵌入函數
//  Get()				- 水印檢測函數
//
// ************************************************************************

#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

/*************************************************************************
 *
 * 函數名稱:
 *   Set() 
 * 
 * 參數:
 *   HDIB hDIB          - 待處理的DIB
 *
 * 返回值:
 *   void				- 無返回值
 *
 * 說明:
 *   該函數為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("請先將其轉換為24位色位圖,再進行處理!", "系統提示" , MB_ICONINFORMATION | MB_OK);
		
		// 解除鎖定
		::GlobalUnlock((HGLOBAL) hDIB);
		
		// 返回
		return;
	}

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

	// 計算圖像每行的字節數
	LONG lLineBytes = WIDTHBYTES(lWidth * 24);
	
	// 從水印文件獲取相關信息
	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("載體位圖太小,不能容納水印!", "系統提示" , MB_ICONINFORMATION | MB_OK);
		
		// 釋放內存
		delete lpBuf;

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

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

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

	// 臨時指針
	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;//釋放緩存

	// 恢復光標
	EndWaitCursor();
}


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

void CWaterMarking::Get(HDIB hDIB, CFile &file)
{
	// 嵌入水印的長度
	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("請先將其轉換為24位色位圖,再進行處理!", "系統提示" , MB_ICONINFORMATION | MB_OK);
		
		// 解除鎖定
		::GlobalUnlock((HGLOBAL) hDIB);
		
		// 返回
		return;
	}

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

	// 計算圖像每行的字節數
	LONG lLineBytes = WIDTHBYTES(lWidth * 24);
	
	// 分配并初始化內存
	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);

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

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

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

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

	// 臨時指針
	int pointer1 = 0;
	int pointer2 = 0;
	int pointer3 = 0;
	int pointer4 = 0;

	// 提取水印數據
	while(true)
	{
		// 從DIB字節流中提取出水印數據
		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++;

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

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

	file.Write(lpBuf1, nFileLen);

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

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

	// 恢復光標
	EndWaitCursor();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
91亚洲男人天堂| 在线观看国产精品网站| 久久综合久久综合久久| www.综合网.com| 日本91福利区| 亚洲欧洲av在线| 国产欧美久久久精品影院| 成人免费毛片嘿嘿连载视频| 日韩伦理电影网| 亚洲国产电影在线观看| 精品国产自在久精品国产| 日韩一区二区电影在线| 欧美一区永久视频免费观看| 欧美午夜电影一区| 在线欧美日韩国产| 欧美日韩免费视频| 在线免费视频一区二区| 在线精品视频免费观看| 欧美天堂一区二区三区| 91久久精品一区二区三区| 色域天天综合网| 在线视频观看一区| 91麻豆免费看片| 99精品国产91久久久久久| www.日韩在线| 欧美日本韩国一区| 日韩一区二区三区四区| 精品国免费一区二区三区| www国产精品av| 国产精品网站在线| ㊣最新国产の精品bt伙计久久| 亚洲天堂精品在线观看| 一区二区三区欧美久久| 亚洲成av人片在线观看无码| 青娱乐精品视频| 日韩在线a电影| 久久99国产精品麻豆| 国产成人午夜精品5599| 丁香五精品蜜臀久久久久99网站 | 亚洲第一福利一区| 亚洲成av人片在线| 国产精品一区二区三区四区 | 日本一区二区三区在线观看| 18成人在线观看| 亚洲国产欧美日韩另类综合 | 69精品人人人人| 久久综合99re88久久爱| 国产精品毛片高清在线完整版| 欧美国产精品一区| 丝袜亚洲另类丝袜在线| 国产精品影视网| 2021久久国产精品不只是精品| 亚洲免费观看高清| 国产精品久久久久久久久免费丝袜| 99久久综合色| 国产成人aaa| 精品久久国产字幕高潮| 久久福利视频一区二区| 欧美变态凌虐bdsm| 久久se精品一区二区| 精品福利视频一区二区三区| 九九国产精品视频| 久久精品亚洲麻豆av一区二区| 国产精品影视天天线| 国产精品成人在线观看| 色视频欧美一区二区三区| 亚洲一区在线观看免费| 成人18视频在线播放| 国产精品久久久久久妇女6080| heyzo一本久久综合| 亚洲精品成人精品456| 久久久久久99久久久精品网站| 激情综合网最新| 国产精品理论片在线观看| 91亚洲国产成人精品一区二三| 亚洲一区二区三区四区中文字幕| 在线播放91灌醉迷j高跟美女| 麻豆精品一区二区| 国产蜜臀av在线一区二区三区| 一本一道综合狠狠老| 自拍偷拍欧美激情| 91精品婷婷国产综合久久| 蜜桃久久av一区| 国产精品久久久久一区二区三区 | 国内精品伊人久久久久av影院| 久久视频一区二区| 色综合色狠狠综合色| 日韩中文字幕91| 中文字幕在线一区| 在线不卡的av| 91丨porny丨最新| 美女视频第一区二区三区免费观看网站| 欧美激情一区三区| 色综合色综合色综合色综合色综合| 日韩av在线播放中文字幕| 国产精品家庭影院| 精品国内片67194| 色94色欧美sute亚洲线路二| 久久99精品网久久| 亚洲人成在线播放网站岛国| 日韩免费性生活视频播放| 99久精品国产| 国产一区二区三区视频在线播放| 亚洲自拍偷拍九九九| 国产精品国产三级国产普通话蜜臀 | 日韩精品一区在线观看| 91婷婷韩国欧美一区二区| 久久99九九99精品| 日韩精品电影在线观看| 亚洲免费观看高清完整版在线观看| 欧美日韩国产欧美日美国产精品| 国产精品亚洲一区二区三区妖精 | 国产午夜三级一区二区三| 欧美日本在线视频| 91视频免费观看| 国产91精品一区二区麻豆亚洲| 视频一区视频二区中文字幕| 亚洲欧美日韩电影| 26uuu精品一区二区| 日韩一区二区精品葵司在线| 欧美三级在线看| 99精品欧美一区二区三区小说 | 欧美日韩美女一区二区| 99精品黄色片免费大全| 国产精品一二一区| 蜜臀久久久久久久| 一区二区三区国产精华| 中文字幕一区二区三中文字幕| 久久视频一区二区| 久久先锋影音av鲁色资源网| 欧美精品日韩一区| 欧美日韩aaaaa| 欧美猛男超大videosgay| 欧美最新大片在线看| 欧美综合天天夜夜久久| 欧美性猛交xxxxxxxx| 欧美日韩专区在线| 欧美日韩一区二区三区四区| 欧美午夜片在线观看| 欧美日韩成人综合天天影院| 91麻豆精品国产91久久久资源速度| 欧美三级中文字幕在线观看| 欧美日韩精品欧美日韩精品一综合| 欧美伊人久久大香线蕉综合69| 欧美三日本三级三级在线播放| 欧美日韩在线播放三区| 欧美一区日韩一区| 日韩精品一区二区三区四区| 国产亚洲人成网站| 国产精品久久久久久妇女6080 | 中文字幕综合网| 日本不卡视频在线观看| 成人性色生活片免费看爆迷你毛片| 在线日韩av片| 久久精品一区二区三区av| 亚洲一区在线观看免费观看电影高清 | 亚洲午夜电影在线观看| 国产真实乱子伦精品视频| 色婷婷激情综合| 久久久99久久精品欧美| 香蕉成人伊视频在线观看| 国产盗摄一区二区三区| 91精品国产一区二区三区 | 成人高清免费观看| 日韩视频免费直播| 亚洲综合一区在线| 成人一区二区在线观看| 欧美一区二区日韩一区二区| 国产精品初高中害羞小美女文| 久久av中文字幕片| 欧美视频你懂的| 亚洲免费观看视频| 不卡视频在线观看| 久久蜜桃av一区精品变态类天堂| 亚洲成人福利片| 在线精品视频免费播放| 中文字幕一区日韩精品欧美| 国产一区二区中文字幕| 欧美一激情一区二区三区| 亚洲国产三级在线| 97久久精品人人做人人爽50路| 久久精品在这里| 国产精品中文欧美| 精品久久久久久久久久久久包黑料 | 久久一日本道色综合| 秋霞电影网一区二区| 欧美日韩aaaaaa| 婷婷国产在线综合| 欧美日韩的一区二区| 香蕉久久一区二区不卡无毒影院| av爱爱亚洲一区| 国产精品美女一区二区三区| 97久久精品人人做人人爽50路| 午夜精品福利在线| 中文在线资源观看网站视频免费不卡| 欧美日韩不卡一区二区| 99精品视频在线免费观看| 国产精品一区一区| 波多野结衣在线aⅴ中文字幕不卡| 久久综合九色综合欧美亚洲|