版權(quán)說(shuō)明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、軟件學(xué)院多媒體開(kāi)發(fā)與編程課程設(shè)計(jì)報(bào)告題 目: 多媒體數(shù)據(jù)庫(kù)應(yīng)用程序 專 業(yè): 軟件工程 2012年5 月26日一、 課程設(shè)計(jì)目的理解ODBC的基本原理,并且掌握基于Access 2003設(shè)計(jì)簡(jiǎn)單多媒體數(shù)據(jù)庫(kù)應(yīng)用程序,并根據(jù)對(duì)應(yīng)的數(shù)據(jù)顯示相應(yīng)的要求。二、課程設(shè)計(jì)內(nèi)容多媒體數(shù)據(jù)庫(kù)應(yīng)用程序圖像的操作三、實(shí)驗(yàn)要求設(shè)計(jì)要求當(dāng)運(yùn)行該程序時(shí),首先顯示數(shù)據(jù)庫(kù)的信息(已經(jīng)添加的或者即時(shí)添加的)會(huì)顯示基本信息,性別,年齡,學(xué)號(hào),姓名等基本信息以及信息人的頭像。然后可以在該信息基礎(chǔ)上修改信息,修改信息刪除等各項(xiàng)功能的操作。 數(shù)據(jù)的存放利用結(jié)構(gòu)體數(shù)組來(lái)實(shí)現(xiàn), 完成設(shè)計(jì)任務(wù)并書(shū)寫(xiě)課程設(shè)計(jì)報(bào)告四、設(shè)計(jì)思路基本數(shù)據(jù)庫(kù)信息管
2、理系統(tǒng)是一個(gè)管理數(shù)據(jù)的服務(wù)平臺(tái),它包括添加信息,修改信息,刪除信息等功能。分析任務(wù)書(shū)中的要求,根據(jù)各項(xiàng)要求給出相應(yīng)的代碼完善。主要根據(jù)數(shù)據(jù)庫(kù)設(shè)計(jì)的,所以,基本信息都應(yīng)該在數(shù)據(jù)庫(kù)中找到,圖片的顯示是重點(diǎn),由于數(shù)據(jù)庫(kù)識(shí)別的是BMP格式,以大二進(jìn)制保存在數(shù)據(jù)庫(kù)中,所以顯示的時(shí)候應(yīng)該先將圖片的格式轉(zhuǎn)換成BMP格式,不能直接修改圖片的后綴名而進(jìn)行。五、程序源代碼 1,為不同的成員函數(shù)之間傳遞數(shù)據(jù),為CMyDB2View聲明數(shù)據(jù)成員代碼如下class CMyDB2View : public CRecordViewpublic:CMyDB2Doc* GetDocument();HBITMAP m_hPhot
3、oBmp;DWORD m_nFileLength;BOOL m_RecordAddNew;BOOL m_RecordModify;char *m_pBmpBuffer;2,初始化m_pSet對(duì)象代碼如下:classCMyDB2View:CMyDB2View():CRecordView(CMyDB2View:IDD)m_pSet=NULL;3,在視圖的OnInitialUpdate()函數(shù)中初始化部分成員變量代碼如下:void CMyDB2View:OnInitialUpdate()m_pSet = &GetDocument()-m_myDB2Set;CRecordView:OnInitialU
4、pdate();GetParentFrame()-RecalcLayout();ResizeParentToFit(); CString strFileName=yyy.bmp ;char tmpPath_MAX_PATH+1; GetTempPath(_MAX_PATH,tmpPath); strFileName.Insert(0,tmpPath);CFile outFile(strFileName,CFile:modeCreate|CFile:modeWrite); LPSTR buffer = (LPSTR)GlobalLock(m_pSet-m_column5.m_hData); ou
5、tFile.WriteHuge(buffer,m_pSet-m_column5.m_dwDataLength); GlobalUnlock(m_pSet-m_column5.m_hData); outFile.Close(); LoadBmpFile(strFileName);m_hPhotoBmp = TransToBmp();m_Butt_Add.EnableWindow(TRUE); m_Butt_Edit.EnableWindow(TRUE); m_Butt_Del.EnableWindow(TRUE); m_Butt_QR.EnableWindow(FALSE); m_Butt_Pi
6、c.EnableWindow(FALSE); m_Butt_CX.EnableWindow(FALSE); m_RecordAddNew = FALSE;m_RecordModify=FALSE;4,加載指定圖像文件代碼如下: BOOL CMyDB2View:LoadBmpFile(const char *pBmpPathname)CFile file;if( !file.Open( pBmpPathname, CFile:modeRead) )return FALSE;m_nFileLength = file.GetLength();m_pBmpBuffer = new charm_nFil
7、eLength + 1;if(!m_pBmpBuffer)return FALSE;if(file.ReadHuge(m_pBmpBuffer,m_nFileLength) != m_nFileLength)return FALSE;return TRUE;5,函數(shù)TransToBmp()生成位圖對(duì)象代碼如下:HBITMAP CMyDB2View:TransToBmp()HBITMAPhBmp;LPSTRhDIB,lpBuffer = m_pBmpBuffer;LPVOIDlpDIBBits;BITMAPFILEHEADERbmfHeader;DWORDbmfHeaderLen;/獲得位圖的頭
8、信息bmfHeaderLen = sizeof(bmfHeader);strncpy(LPSTR)&bmfHeader,(LPSTR)lpBuffer,bmfHeaderLen);/根據(jù)獲得的信息頭判斷是否是位圖if (bmfHeader.bfType != (*(WORD*)BM) return NULL;/獲取位圖數(shù)據(jù)hDIB = lpBuffer + bmfHeaderLen;BITMAPINFOHEADER &bmiHeader = *(LPBITMAPINFOHEADER)hDIB ;BITMAPINFO &bmInfo = *(LPBITMAPINFO)hDIB ;lpDIBBit
9、s=(lpBuffer)+(BITMAPFILEHEADER *)lpBuffer)-bfOffBits;/創(chuàng)建位圖CClientDC dc(this);hBmp = CreateDIBitmap(dc.m_hDC,&bmiHeader,CBM_INIT,lpDIBBits,&bmInfo,DIB_RGB_COLORS);return hBmp;6,“添加”事件的代碼如下: void CMyDB2View:OnAdd() EnableEditCom(true);IniData();m_Butt_Add.EnableWindow(FALSE); m_Butt_Edit.EnableWindow(
10、FALSE); m_Butt_Del.EnableWindow(FALSE); m_Butt_QR.EnableWindow(FALSE); m_Butt_CX.EnableWindow(TRUE); m_Butt_Pic.EnableWindow(TRUE); m_pSet-CanAppend(); m_pSet-AddNew(); /m_pSet-GetDefaultSQL();/m_pSet-DoFieldExchange(FALSE);UpdateData (FALSE);m_RecordAddNew=TRUE;7,編輯框控件代碼如下: void CMyDB2View:EnableEd
11、itCom(bool Flag)m_XH.EnableWindow(Flag); m_XM.EnableWindow(Flag); m_NL.EnableWindow(Flag); m_XB.EnableWindow(Flag); 8,InitData()用于初始化空間數(shù)據(jù)代碼如下:void CMyDB2View:IniData()m_XH.SetWindowText(); m_XM.SetWindowText(); m_NL.SetWindowText(); m_XB.SetCurSel(-1); ClearPhoto();9,ClearPhoto()函數(shù)代碼如下:void CMyDB2Vi
12、ew:ClearPhoto()if(m_hPhotoBmp)DeleteObject(m_hPhotoBmp);m_hPhotoBmp = NULL;Invalidate();if(m_pBmpBuffer)delete m_pBmpBuffer;m_pBmpBuffer = NULL;10,幾個(gè)按鈕的OnChange()事件的相應(yīng)代碼:void CMyDB2View:OnChangeEditXh() m_Butt_QR.EnableWindow(TRUE);void CMyDB2View:OnChangeEditXm() m_Butt_QR.EnableWindow(TRUE);void C
13、MyDB2View:OnChangeEditNl() m_Butt_QR.EnableWindow(TRUE);void CMyDB2View:OnSelchangeComboXb() m_Butt_QR.EnableWindow(TRUE);11,瀏覽照片的響應(yīng)函數(shù)代碼如下:void CMyDB2View:OnBUTTONPic() static char BASED_CODE szFilter = BMP Files (*.bmp)|*.bmp|;CFileDialog dlg(TRUE,BMP,NULL, OFN_HIDEREADONLY | OFN_OVERWRITEPROMPT,sz
14、Filter);if(dlg.DoModal() = IDOK)CString pathname = dlg.GetPathName();ClearPhoto();LoadBmpFile(pathname);m_hPhotoBmp = TransToBmp();m_Butt_QR.EnableWindow(TRUE);Invalidate();視圖的OnPaint()函數(shù)代碼如下:void CMyDB2View:OnPaint() CPaintDC dc(this); if(!m_hPhotoBmp)return;CWnd *hwnd=GetDlgItem(IDC_Picture);RECT
15、rect;hwnd-GetClientRect(&rect);HBITMAP OldBitmap;CDC MemDC;MemDC.CreateCompatibleDC(hwnd-GetDC();OldBitmap=(HBITMAP)MemDC.SelectObject(m_hPhotoBmp);BITMAP bm;GetObject(m_hPhotoBmp,sizeof(BITMAP),&bm);hwnd-GetDC()-StretchBlt(rect.left,rect.top,rect.right,rect.bottom,&MemDC,0,0,bm.bmWidth,bm.bmHeight,
16、SRCCOPY);MemDC.SelectObject(OldBitmap);12,修改事件函數(shù)的響應(yīng)代碼如下:void CMyDB2View:OnEdit() EnableEditCom(true);m_Butt_Add.EnableWindow(FALSE); m_Butt_Edit.EnableWindow(FALSE); m_Butt_Del.EnableWindow(FALSE); m_Butt_QR.EnableWindow(FALSE); m_Butt_Pic.EnableWindow(TRUE); m_Butt_CX.EnableWindow(TRUE); m_RecordMo
17、dify=TRUE;13,確認(rèn)事件響應(yīng)代碼如下:void CMyDB2View:OnButtonQr() UpdateData (TRUE);m_pSet-m_column5.m_dwDataLength=m_nFileLength;m_pSet-m_column5.m_hData=m_pBmpBuffer;m_pSet-SetFieldDirty(&m_pSet-m_column5); m_pSet-SetFieldNull(&m_pSet-m_column5,FALSE);if(m_RecordAddNew)m_pSet-Update(); else if(m_RecordModify)m
18、_pSet-Edit(); m_pSet-Update(); m_Butt_QR.EnableWindow(FALSE); m_Butt_Add.EnableWindow(TRUE); m_Butt_Edit.EnableWindow(TRUE); m_Butt_Del.EnableWindow(TRUE); 撤銷事件代碼如下:void CMyDB2View:OnButtonCx() UpdateData (FALSE);m_pSet-CancelUpdate();EnableEditCom(FALSE);m_Butt_Add.EnableWindow(TRUE); m_Butt_Edit.E
19、nableWindow(TRUE); m_Butt_Del.EnableWindow(TRUE); m_Butt_Pic.EnableWindow(FALSE); m_Butt_QR.EnableWindow(FALSE); m_Butt_CX.EnableWindow(FALSE); 14,刪除按鈕的響應(yīng)函數(shù)代碼:void CMyDB2View:OnDelete() if(MessageBox(確實(shí)要?jiǎng)h除嗎?,刪除,MB_YESNO|MB_ICONQUESTION)=IDYES)m_pSet-Delete();UpdateData (FALSE);15,導(dǎo)航按鈕響應(yīng)函數(shù)代碼如下:BOOL C
20、MyDB2View:OnMove(UINT nIDMoveCommand) CRecordView:OnMove(nIDMoveCommand);CString strFileName=yyy.bmp ;char tmpPath_MAX_PATH+1; GetTempPath(_MAX_PATH,tmpPath); strFileName.Insert(0,tmpPath);CFileoutFile(strFileName,CFile:modeCreate|CFile:modeWrite); LPSTRbuffer=(LPSTR)GlobalLock(m_pSet-m_column5.m_hData); outFile.WriteHuge(buffer,m_pSet-m_column5.m_dwDataLength); GlobalUnlock(m_pSet-m_column5.m_hData); outFile.Close(); LoadBmpFile(strFileName);
溫馨提示
- 1. 本站所有資源如無(wú)特殊說(shuō)明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒(méi)有圖紙預(yù)覽就沒(méi)有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 2025年度行政合同行政主體特權(quán)在緊急情況下的適用合同4篇
- 2025版小學(xué)操場(chǎng)運(yùn)動(dòng)設(shè)施更新與維修合同3篇
- 體育會(huì)展客戶關(guān)系管理考核試卷
- 光纖通信在智能電網(wǎng)故障診斷中的應(yīng)用考核試卷
- 2025年土地轉(zhuǎn)讓合同
- 2025版停車場(chǎng)消防設(shè)施建設(shè)與維護(hù)服務(wù)合同3篇
- 2025版木工材料研發(fā)與勞務(wù)合作合同范本3篇
- 2025年寫(xiě)作創(chuàng)作分期付款合同
- 2025年加盟代理合約協(xié)議
- 2025年家庭矛盾仲裁協(xié)議
- 油氣行業(yè)人才需求預(yù)測(cè)-洞察分析
- 《數(shù)據(jù)采集技術(shù)》課件-Scrapy 框架的基本操作
- 2025年河北省單招語(yǔ)文模擬測(cè)試二(原卷版)
- 高一化學(xué)《活潑的金屬單質(zhì)-鈉》分層練習(xí)含答案解析
- DB34∕T 4010-2021 水利工程外觀質(zhì)量評(píng)定規(guī)程
- 理論力學(xué)智慧樹(shù)知到期末考試答案章節(jié)答案2024年中國(guó)石油大學(xué)(華東)
- 2024老年人靜脈血栓栓塞癥防治中國(guó)專家共識(shí)(完整版)
- 四年級(jí)上冊(cè)脫式計(jì)算100題及答案
- 上海市12校2023-2024學(xué)年高考生物一模試卷含解析
- 儲(chǔ)能電站火災(zāi)應(yīng)急預(yù)案演練
- 人教版(新插圖)二年級(jí)下冊(cè)數(shù)學(xué) 第4課時(shí)用“進(jìn)一法”和“去尾法”解決簡(jiǎn)單的實(shí)際問(wèn)題 教學(xué)課件
評(píng)論
0/150
提交評(píng)論