CdbImages::CdbImages(CDatabase* pdb)
: CRecordset(pdb)
{
//{{AFX_FIELD_INIT(CdbImages)
m_nFields = 2;//數(shù)據(jù)庫中有兩個(gè)字段
//}}AFX_FIELD_INIT
m_nDefaultType = snapshot;//數(shù)據(jù)庫以快照形式打開
}
CString CdbImages::GetDefaultConnect()
{
return _T("ODBC;DSN=MS access Database");//以O(shè)DBC操作數(shù)據(jù)庫
}
CString CdbImages::GetDefaultSQL()
{
return _T("[Images]");//默認(rèn)的操作是連接到數(shù)據(jù)庫中的Images表
} 
void CdbImages::DoFieldExchange(CFieldExchange* pFX)
{
//{{AFX_FIELD_MAP(CdbImages)
pFX->SetFieldType(CFieldExchange::outputColumn);
RFX_LongBinary(pFX, _T("[Image]"), m_Image);//記錄集中的成員對(duì)象和表中的OLE字段采用長(zhǎng)二進(jìn)制交換。
//}}AFX_FIELD_MAP
}
///////////////////////////////////////////////////////////
//從數(shù)據(jù)庫中顯示圖像數(shù)據(jù)
CDatabase m_DB;//定義的數(shù)據(jù)庫全局變量
CBitmap Bitmap;//定義的圖像類全局變量,用以存儲(chǔ)圖像數(shù)據(jù)
void CImageView::OnOpenDateBase() 
{
m_DB.Open(NULL, //以O(shè)DBC形式打開數(shù)據(jù)庫
FALSE,
FALSE,
"ODBC;DRIVER={
Microsof Access Driver (*.mdb)};DBQ=Photo.mdb");
CdbImages dbImages(m_DB);
CString strFileName ;// 用來存放臨時(shí)文件名,以該臨時(shí)文件存放讀取的數(shù)據(jù)庫的圖像數(shù)據(jù)。
i=1;//I為臨時(shí)文件號(hào)
StrFileName.Format("%s",i)
dbImages.Open();
if (dbImages.ISEOF())
AfxMessageBox("Unable to get image from db");
else
{
char tmpPath[_MAX_PATH+1];
GetTempPath(_MAX_PATH,tmpPath);//得到臨時(shí)文件的目錄;
strFileName.Insert(0,tmpPath);//生成臨時(shí)文件名
CFile outFile(strFileName,CFile::modeCreateCFile::modeWrite);
//向臨時(shí)文件寫數(shù)據(jù),數(shù)據(jù)庫中數(shù)據(jù)讀操作時(shí)要害是知道數(shù)據(jù)的長(zhǎng)度,這可以從記錄集的圖像字段對(duì)應(yīng)的長(zhǎng)二進(jìn)制成員變量m_Image的成員dwDataLength得到;
LPSTR buffer = (LPSTR)GlobalLock(dbImages.m_Image.m_hData);
outFile.WriteHuge(buffer,dbImages.m_Image.m_dwDataLength);
                         GlobalUnlock(dbImages.m_Image.m_hData);
outFile.Close();
//定義圖像句柄;
HBITMAP hbm = (HBITMAP)::LoadImage(NULL,
strFileName,
IMAGE_BITMAP,
0,
0,
LR_LOADFROMFILE);
if (Bitmap.Attach(hbm))//將圖像句柄和Cbitmap對(duì)象聯(lián)系起來
{
BITMAP bm;
Bitmap.GetBitmap(&bm);//獲取圖像尺寸
Bitmap.SetBitmapDimension(bm.bmWidth,bm.bmHeight);
return;
}
Invalidate();//重畫屏幕
}
/////////////////////////////////////////////
void CImageView::OnDraw(CDC* pDC)//顯示圖像
{
CDC memDC;
memDC.CreateCompatibleDC(pDC);
CBitmap* pImage = memDC.SelectObject(Bitmap);
CSize imageSize = Bitmap.GetBitmapDimension();
pDC->BitBlt(0,0,imageSize.cx,imageSize.cy,&memDC,0,0,SRCCOPY);
memDC.SelectObject(pImage);
}
//////////////////////////////////////////////////////
//以下是向數(shù)據(jù)中添加圖像記錄
void CImageView::OnSaveDateBase()
{//打開圖像文件
static char BASED_CODE szFilter[] = "Bitmap Files (*.bmp)*.bmp";
CdbImages dbImages(m_DB);
CFileDialog fd(TRUE,NULL,NULL,0,szFilter,this);
if (IDOK != fd.DoModal())
return;
dbImages.Open();//打開數(shù)據(jù)庫
dbImages.AddNew();//添加新的記錄
CFile fileImage;
CFileStatus fileStatus;
fileImage.Open(fd.GetPathName(), CFile::modeRead);
fileImage.GetStatus(fileStatus);//得到打開的圖像文件的狀態(tài)信息;
dbImages.m_Image.m_dwDataLength = fileStatus.m_size;
HGLOBAL hGlobal= GlobalAlloc(GPTR,fileStatus.m_size);//申請(qǐng)存放圖像數(shù)據(jù)的空間。
dbImages.m_Image.m_hData = GlobalLock(hGlobal);//將該空間付給m_hData成員;
//向緩沖區(qū)讀圖像數(shù)據(jù)
fileImage.ReadHuge(dbImages.m_Image.m_hData,fileStatus.m_size);//向m_Image讀圖像數(shù)據(jù)。
dbImages.SetFieldDirty(&dbImages.m_Image);//標(biāo)志數(shù)據(jù)庫已經(jīng)修改;
dbImages.SetFieldNull(&dbImages.m_Image,FALSE);//設(shè)置記錄為NULL;
dbImages.Update();//刷新數(shù)據(jù)庫的記錄
GlobalUnlock(hGlobal);
dbImages.Close();
} 更多內(nèi)容請(qǐng)看數(shù)據(jù)庫相關(guān)文章專題,或
 更多內(nèi)容請(qǐng)看數(shù)據(jù)庫相關(guān)文章專題,或新聞熱點(diǎn)
疑難解答
圖片精選
網(wǎng)友關(guān)注