




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、软件学院多媒体开发与编程课程设计报告题 目: 多媒体数据库应用程序 专 业: 软件工程 2012年5 月26日一、 课程设计目的理解ODBC的基本原理,并且掌握基于Access 2003设计简单多媒体数据库应用程序,并根据对应的数据显示相应的要求。二、课程设计内容多媒体数据库应用程序图像的操作三、实验要求设计要求当运行该程序时,首先显示数据库的信息(已经添加的或者即时添加的)会显示基本信息,性别,年龄,学号,姓名等基本信息以及信息人的头像。然后可以在该信息基础上修改信息,修改信息删除等各项功能的操作。 数据的存放利用结构体数组来实现, 完成设计任务并书写课程设计报告四、设计思路基本数据库信息管
2、理系统是一个管理数据的服务平台,它包括添加信息,修改信息,删除信息等功能。分析任务书中的要求,根据各项要求给出相应的代码完善。主要根据数据库设计的,所以,基本信息都应该在数据库中找到,图片的显示是重点,由于数据库识别的是BMP格式,以大二进制保存在数据库中,所以显示的时候应该先将图片的格式转换成BMP格式,不能直接修改图片的后缀名而进行。五、程序源代码 1,为不同的成员函数之间传递数据,为CMyDB2View声明数据成员代码如下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对象代码如下:classCMyDB2View:CMyDB2View():CRecordView(CMyDB2View:IDD)m_pSet=NULL;3,在视图的OnInitialUpdate()函数中初始化部分成员变量代码如下: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,函数TransToBmp()生成位图对象代码如下:HBITMAP CMyDB2View:TransToBmp()HBITMAPhBmp;LPSTRhDIB,lpBuffer = m_pBmpBuffer;LPVOIDlpDIBBits;BITMAPFILEHEADERbmfHeader;DWORDbmfHeaderLen;/获得位图的头
8、信息bmfHeaderLen = sizeof(bmfHeader);strncpy(LPSTR)&bmfHeader,(LPSTR)lpBuffer,bmfHeaderLen);/根据获得的信息头判断是否是位图if (bmfHeader.bfType != (*(WORD*)BM) return NULL;/获取位图数据hDIB = lpBuffer + bmfHeaderLen;BITMAPINFOHEADER &bmiHeader = *(LPBITMAPINFOHEADER)hDIB ;BITMAPINFO &bmInfo = *(LPBITMAPINFO)hDIB ;lpDIBBit
9、s=(lpBuffer)+(BITMAPFILEHEADER *)lpBuffer)-bfOffBits;/创建位图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()用于初始化空间数据代码如下:void CMyDB2View:IniData()m_XH.SetWindowText(); m_XM.SetWindowText(); m_NL.SetWindowText(); m_XB.SetCurSel(-1); ClearPhoto();9,ClearPhoto()函数代码如下: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,几个按钮的OnChange()事件的相应代码: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,浏览照片的响应函数代码如下: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()函数代码如下: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,修改事件函数的响应代码如下: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,确认事件响应代码如下: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,删除按钮的响应函数代码:void CMyDB2View:OnDelete() if(MessageBox(确实要删除吗?,删除,MB_YESNO|MB_ICONQUESTION)=IDYES)m_pSet-Delete();UpdateData (FALSE);15,导航按钮响应函数代码如下: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. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 课题开题报告:新媒介生态中的老年群体身份认同研究
- 人教版初中历史与社会九年级上册 1.1 第一次世界大战 教学设计
- 课题开题报告:西藏学校教育数字化转型的区域实践探索研究
- 大数据驱动的旅游行业市场分析
- 个人信息超范围收集与泄露问题分析研究报告
- 2024年五年级语文下册 第二单元 8 红楼春趣新学习单教学实录 新人教版
- 2024年苏州市吴江区事业单位招聘工作人员笔试真题
- 印章风险防控课件
- 学生宿舍节能降耗的实践与成效分析
- B2B公司的销售团队建设与管理
- 工程项目部安全生产治本攻坚三年行动实施方案
- 部编小学语文单元作业设计四年级上册第三单元 3
- 邻近铁路营业线施工安全监测技术规程 (TB 10314-2021)
- 新生儿防烫伤
- 光伏验收报告
- 成语故事对牛弹琴篇
- 中国石油天然气股份有限公司油气田站场目视化设计规定
- 《钢筋工安全培训》课件
- 腹腔引流管护理技术操作规程及评分标准
- 2024年中国电信山东分公司招聘笔试参考题库含答案解析
- 少年管乐团管理制度
评论
0/150
提交评论