资源简介
利用LSB算法,完成的数字水印的嵌入和提取程序,VC++代码。
用VC6.0编译。如果转化为vs会报错,需要自己修改调试。
这个程序也是从CSDN上得到的,会有其他不同名字但是同内容的下载源存在。
当初花了好多积分下的都是一样的东西心疼我的积分泪。
希望能给需要的朋友提供到帮助。
代码片段和文件信息
// Dib.cpp: implementation of the CDib class.
//
//////////////////////////////////////////////////////////////////////
#include “StdAfx.h“
#include “Dib.h“
#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////
CDib::CDib()
{
m_hDrawDib=NULL;
m_pDib=NULL;
}
CDib::~CDib()
{
Close();
}
void CDib::Draw(CDC *pDCint nWidth int nHeight)
{
if(m_pDib!=NULL)
{
ASSERT(IsValid());
DrawDibRealize(m_hDrawDibpDC->GetSafeHdc()TRUE);
DrawDibDraw(m_hDrawDibpDC->GetSafeHdc()
0 //desktop left
0 //desktop top
nWidth
nHeight
(BITMAPINFOHEADER *)m_pDib
(LPVOID) GetBits()
0 //source left
0 //source top
((BITMAPINFOHEADER *)m_pDib)->biWidth
((BITMAPINFOHEADER *)m_pDib)->biHeight
DDF_BACKGROUNDPAL);
}
}
CSize CDib::GetSize()
{
return CSize(((BITMAPINFOHEADER *)m_pDib)->biWidth
((BITMAPINFOHEADER *)m_pDib)->biHeight);
}
LONG CDib::GetWidth()
{
return ((BITMAPINFOHEADER *)m_pDib)->biWidth;
}
LONG CDib::GetHeight()
{
return ((BITMAPINFOHEADER *)m_pDib)->biHeight;
}
void CDib::Close()
{
if(m_hDrawDib!=NULL)
{
DrawDibClose(m_hDrawDib);
m_hDrawDib=NULL;
}
if(m_pDib!=NULL)
{
delete m_pDib;
m_pDib=NULL;
}
}
BOOL CDib::Open(const char * pzFileName)
{
// BITMAPFILEHEADER bmpFileHeader;
CFile file;
int nBmpFileHeaderSize;
Close();
//drawdibopen initialize the diradib library and
//returns a handle for all drawdib operations
if(!(m_hDrawDib=DrawDibOpen()))
goto exit;
//open and read the DIB file header
nBmpFileHeaderSize=sizeof(BITMAPFILEHEADER);
if(!file.Open(pzFileNameCFile::modeRead | CFile::typeBinary))
goto exit;
if(file.Read((void *)&bmpFileHeadernBmpFileHeaderSize)!=(UINT)nBmpFileHeaderSize)
goto failure;
//validate the DIB file header by checking the first
//two characters for the signature “BM“
if(bmpFileHeader.bfType!=*((WORD *)“BM“))
goto failure;
//allocate a big chuck of global memory to store the DIB
m_pDib=(BYTE *)new char [bmpFileHeader.bfSize-nBmpFileHeaderSize];
//allocate memory fail
if(!m_pDib)
goto failure;
//read the dib into the buffer at a time using ReadHuge
file.ReadHuge(m_pDibbmpFileHeader.bfSize-nBmpFileHeaderSize);
if(((BITMAPINFOHEADER *)m_pDib)->biSizeImage==0)
{
//the application that create this bitmap didn‘t fill
//in the biSizeImage field. Let‘s fill it
//in even though the DrawDib * functions don‘t need it.
BITMAPINFOHEADER *pDib=(BITMAPINFOHEADER *)m_pDib;
//scan lines must be DWord aligned hence the strange bit stuff
pDib->biSizeImage=((((pDib->biWidth*pDib->biBitCount)+31)&~31)>>3)*pDib->biHeight;
}
m_pDibBits=GetBits();
file.Close();
ret
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
目录 0 2006-08-21 16:59 数字水印的嵌入和提取(vc)
文件 4429 2006-03-29 18:54 数字水印的嵌入和提取(vc)\Dib.cpp
文件 964 2006-03-29 18:16 数字水印的嵌入和提取(vc)\Dib.h
目录 0 2006-08-21 16:59 数字水印的嵌入和提取(vc)\Pic
文件 23610 2006-08-10 13:15 数字水印的嵌入和提取(vc)\Pic\11.bmp
文件 196662 1998-02-03 17:48 数字水印的嵌入和提取(vc)\Pic\Apple.bmp
文件 447390 1999-03-16 03:57 数字水印的嵌入和提取(vc)\Pic\BoatCake.BMP
文件 921654 1999-03-16 03:46 数字水印的嵌入和提取(vc)\Pic\Fruit.BMP
文件 138514 2002-11-29 19:41 数字水印的嵌入和提取(vc)\Pic\lena.bmp
文件 23610 2006-08-10 13:18 数字水印的嵌入和提取(vc)\Pic\MarkWater.bmp
文件 177356 2003-04-28 09:46 数字水印的嵌入和提取(vc)\Pic\plane24.bmp
文件 113334 2000-07-09 20:11 数字水印的嵌入和提取(vc)\Pic\street.bmp
..A.SH. 125952 2006-08-15 11:03 数字水印的嵌入和提取(vc)\Pic\Thumbs.db
目录 0 2006-08-21 16:59 数字水印的嵌入和提取(vc)\res
文件 1078 2006-04-01 12:48 数字水印的嵌入和提取(vc)\res\FACE.ICO
..A.SH. 10240 2006-08-15 11:03 数字水印的嵌入和提取(vc)\res\Thumbs.db
文件 1078 2006-03-20 22:23 数字水印的嵌入和提取(vc)\res\WaterMark.ico
文件 401 2006-03-20 22:23 数字水印的嵌入和提取(vc)\res\WaterMark.rc2
文件 1101 2006-04-02 20:34 数字水印的嵌入和提取(vc)\Resource.h
文件 211 2006-03-20 22:23 数字水印的嵌入和提取(vc)\StdAfx.cpp
文件 1054 2006-03-20 22:23 数字水印的嵌入和提取(vc)\StdAfx.h
文件 1483 2006-08-12 14:11 数字水印的嵌入和提取(vc)\WaterMark.clw
文件 2105 2006-03-20 22:23 数字水印的嵌入和提取(vc)\WaterMark.cpp
文件 4421 2006-04-01 14:03 数字水印的嵌入和提取(vc)\WaterMark.dsp
文件 541 2006-03-20 22:23 数字水印的嵌入和提取(vc)\WaterMark.dsw
文件 1357 2006-03-20 22:23 数字水印的嵌入和提取(vc)\WaterMark.h
文件 5971 2006-04-02 20:48 数字水印的嵌入和提取(vc)\WaterMark.rc
文件 21348 2006-04-02 21:58 数字水印的嵌入和提取(vc)\WaterMarkDlg.cpp
文件 2855 2006-04-02 21:33 数字水印的嵌入和提取(vc)\WaterMarkDlg.h
文件 21304 2006-08-11 15:58 数字水印的嵌入和提取(vc)\WaterMark.aps
............此处省略6个文件信息
- 上一篇:txt文件分割源代码vc6
- 下一篇:C++做的泊松分布,高斯分布,瑞利分布
相关资源
- 虹膜分割 Iris Segmentation C++和opencv实现
- (LSB算法)数字水印的VC++实现
- surf特征提取与匹配
- 编译原理LL1文法的mfc实现含消除左递
- Moravec算子
- stirmark数字水印攻击软件并包含源代码
- 特征点提取和影像匹配
- SIFT特征提取C++
- 基于VC++与OpenCV的圆心坐标提取
- 用于图像边缘提取的prewitt算子的C++代
- 数字水印的(LSB算法)嵌入和提取V
- 数字水印系统c++实现
- 汉字点阵字库建立与提取
- openCV纹理图像特征提取,比较两幅图
- VMTK Tutorials
- 信息隐藏数字水印LSB算法
- VC++ 图像文字提取
- LSD线特征提取方法+Opencv实现C++
- vibe运动目标提取opencv C++源代码
- C++ 从数据库中提取图片
- C++ 网页链接提取器
- HED 深度学习边缘提取 C++接口测试程序
- mfcc特征提取,c++代码实现
- 图像显著性特征处理、颜色特征提取
- 文字识别中的特征提取,C++
- 实验三-递归下降子程序分析(本代码
- Forstner点特征提取源文件,C++版本
- 大话西游2与梦幻西游的地图提取器(
- 语音信号MFCC特征提取
- BOW+SIFT特征提取OpenCV实现
评论
共有 条评论