课程设计---基于VC的BMP图像二值化处理平台.doc
课 程 设 计 说 明 书学生姓名: 学 号: 学生姓名: 学 号: 学生姓名: 学 号: 学生姓名: 学 号: 学 院:中北大学信息商务学院 专 业: 电子信息工程 题 目:专用基本技能实践: 基于VC的BMP图像二值化处理平台 指导教师: 陈平 职称: 副教授 2014 年 12 月 26 日 课程设计任务书 14/15 学年第 一 学期学 院:中北大学信息商务学院 专 业: 电子信息工程 学 生 姓 名: 学 号: 学 生 姓 名: 学 号: 学 生 姓 名: 学 号: 学 生 姓 名: 学 号: 课程设计题目:专用基本技能实践: 基于VC的BMP图像二值化处理平台 起 迄 日 期: 2014年 12 月 29 日2015年1月10日 课程设计地点: C304教室 指 导 教 师: 系 主 任: 下达任务书日期: 2014 年12 月26日课 程 设 计 任 务 书1设计目的:(1) 掌握VC+程序开发平台;(2) 掌握对话框模式的可视化实现和按钮消息的响应;(3)掌握应用VC+库函数实现BMP图像文件的打开、显示和二值化处理等功能。2设计内容和要求(包括原始数据、技术参数、条件、设计要求等):(1)查阅相关资料,掌握基于面向对象的编程方法;(2)主界面采用对话框或菜单模式,通过文件对话框,打开图像文件;(3)通过控件控制关联,实现BMP图像数据的显示;(4)通过对图像的灰度数据进行有条件的赋值,实现图像的二值化处理并显示。(5)要求3位同学各自实现不同分工。3设计工作任务及工作量的要求包括课程设计计算说明书(论文)、图纸、实物样品等:(1) 要求设计组的每个成员都要了解设计的要求和思路;(2) 编写详细的设计说明书三份;(3) 要求有正确的运行结果及结果分析。课 程 设 计 任 务 书4主要参考文献:1 王华, 叶爱亮, 祁立学等. Visual C+ 6.0 编程实例与技巧. 北京:机械工业出版社, 1999.2 李光明. Visual C+ 6.0 经典实例大制作. 北京:中国人事出版社,2000.3 严华峰. Visual C+ 课程设计案例精编. 北京:中国水利水电出版社,2002.4 官章全, 刘加明. Visual C+ 6.0 类库大全. 北京:电子工业出版社,1999.5 张荣梅,梁晓林. Visual C+实用教程. 北京:冶金工业出版社,2004.6 魏亮,李春葆. Visual C+程序设计例学与实践. 北京:清华大学出版社,2006.7 陈清华, 朱红. Visual C+课程设计案例精选与编程指导. 南京:东南大学出版社,2004.5设计成果形式及要求:提供详细的设计说明书三份软件设计结果6工作计划及进度:2014年12月29日 12月31日: 学习VC有关编程方法;20151月1日 1月6日: 在指导教师指导下实现程序设计;1月7日 1月9日: 撰写课程设计说明书; 1月10日:答辩系主任审查意见: 签字: 年 月 日目录一、设计目的-1二、设计主要方案及理论介绍-1三、设计主要步骤-2四、运行结果-6五、设计评述-7六、参考文献-7七、代码-8一、设计目的: 1.掌握VC+程序开发平台; 2.掌握对话框模式的可视化实现和按钮消息的响应; 3.掌握应用VC+库函数实现BMP图像文件的打开、显示和二值化处理等功能。二、设计主要方案及理论介绍 通过vc实现bmp图像二值化处理图像灰度变换模块图像灰度变换模块实现了彩色图像变灰度格式,灰度图像变彩色格式和二值化操作。经过分析图像灰度变换功能,得出图像处理的功能模块图如图4.4所示:灰度变换模块块 二值化 图 灰度变换模块功能结构图灰度变换类GrayTrans是在基类ImgCenterDib基础上派生出来的, 灰度变换类设计代码如下:class GrayTrans:public ImgCenterDibpublic:int m_nBitCountOut; /输出图像每像素位数unsigned char * m_pImgDataOut; /输出图像位图数据指针LPRGBQUAD m_lpColorTableOut; /输出图像颜色表private:int m_imgWidthOut; /图像的宽,像素为单位int m_imgHeightOut; /图像的高 int m_nColorTableLengthOut; /输出图像颜色表长度public:GrayTrans();/不带参数的构造函数GrayTrans(CSize size, int nBitCount, LPRGBQUAD lpColorTable, unsigned char *pImgData); /带参数的构造函数GrayTrans();CSize GetDimensions();/以像素为单位返回输出图像的宽和高 void Binary(int threshold=128); /二值化;利用类向导,给相应的控件定义消息处理函数,如下表表2 主要的消息处理函数表序号ID号及类名消息处理函数函数功能3ID_BinTwoOnBinTwo二值化在picture_sysView.cpp重载消息处理函数,这三个消息处理函数代码基本相似,共同操作伪代码如下:获取文档类中m_dib的指针,访问当前DIB数据;判断灰度图像还是彩色图像;分别定义GrayTrans类的对象,调用相应的函数;建立一个新视图,显示分割结果; 三、设计主要步骤 新建建立菜单 找类文件名选择ClassView视图,编辑菜单资源选ResourceView视图。单击File按Ctrl+w打开类向导添加菜单处理函数3然后点击Edit Code,直接复制代码就可添加新类CDib类定义在Dib.h中复制代码添加类CDib类中处理函数定义复制代码程序运行,点击File,选择*.bmp文件,点击打开,在选择Process2Value。四、运行结果原图 二值化处理后的图五、 设计评述 这次课程设计是以Microsoft Visual C+ 6.0 文档视图编程为基础实现的,这就要求对MFC文档视图操作有一定的了解和操作编程能力,在做课程设计前,我查阅了该方面相关的书籍,对我完成欢迎界面和主界面的设计有很大的帮助。编程中在不同类之间函数参数和变量的传递和函数的调用出了问题,但是理清函数的编译编译顺序和变量的类型这些问题都逐一解决,同时增强了对工具栏,菜单栏的手动操作能力。 另外一点是对.bmp图像处理的实现,数字图像处理关键是算法的设计思想和算法的实现,通过这次课程设计,使我了解到了算法设计的重要性(算法设计是编程实现的前提),提高了自己动手编程的能力和汲取一些先进算法的思想,这对以后图像处理的深入学习大有帮助。 该数字图像界面是基于Microsoft Visual C+ 6.0的MFC多文档实现的,在界面设计上看起来过于单调,界面设计简单,但易于操作; Visual C+ 6.0的MFC对话框的编程是界面看起来更加美观,更接近软件系统,给人不一样的感觉,提高了工具栏和菜单栏的编程实现难度和设计的复杂度,这是今后学习的方向。六、参考文献:1 郑莉 董渊 张瑞丰, C+语言程序设计(第三版), 清华大学出版社 20032David J.Kruglinski(美)等, Visual C+ 6.0技术内幕,北京希望电子出版社,20023谢凤英 赵丹培, Visual C+ 数字图像处理,电子工业出版社,20084求是科技 张宏林,精通Visual C+ 数字图像处理典型算法及实现,人民邮电出版社,20085刘锐宁 宋坤等, Visual C+从入门到精通,清华大学出版社,2008七、 代码/ DIB.h /添加新类CDib类定义#ifndef _DIB_H_#define _DIB_H_#include "ShowDIB.h"class CDibpublic:CDib();CDib();BOOL Draw( CDC *pDC, int nX = -1, int nY = -1, int nWidth = -1, int nHeight = -1, int Style = 1);BOOL Save( const char *pszFilename );BOOL Load( const char * );BOOL SetPalette( CDC * );/bool Valid;public:int m_BitCount;WORD * m_pWordData;CPalette m_Palette;unsigned char *m_pDib, *m_pDibBits;DWORD m_dwDibSize;BITMAPINFOHEADER *m_pBIH;RGBQUAD *m_pPalette;int m_nPaletteEntries;public:bool ConvertToTwoValue();#endif/ DIB.cpp/添加类CDib类中处理函数定义#include "stdafx.h"#include "DIB.h"CDib:CDib()m_pDib = NULL;m_pWordData = NULL;CDib:CDib()if( m_pDib != NULL )delete m_pDib;if( m_pWordData != NULL )delete m_pWordData;BOOL CDib:Load( const char *pszFilename )CFile cf;if( !cf.Open( pszFilename, CFile:modeRead ) )return( FALSE );DWORD dwDibSize;dwDibSize =cf.GetLength() - sizeof( BITMAPFILEHEADER );pDib = new unsigned char dwDibSize;if( pDib = NULL )return( FALSE );BITMAPFILEHEADER BFH;tryif( cf.Read( &BFH, sizeof( BITMAPFILEHEADER ) )!= sizeof( BITMAPFILEHEADER ) |BFH.bfType != 'MB' |cf.Read( pDib, dwDibSize ) != dwDibSize )delete pDib;return( FALSE );catch( CFileException *e )e->Delete();delete pDib;return( FALSE );cf.Close();if( m_pDib != NULL )delete m_pDib;m_pDib = pDib;m_dwDibSize = dwDibSize;m_pBIH = (BITMAPINFOHEADER *) m_pDib;m_pPalette =(RGBQUAD *) &m_pDibsizeof(BITMAPINFOHEADER);m_nPaletteEntries = 1 << m_pBIH->biBitCount;if( m_pBIH->biBitCount > 8 )m_nPaletteEntries = 0;else if( m_pBIH->biClrUsed != 0 )m_nPaletteEntries = m_pBIH->biClrUsed;m_pDibBits =&m_pDibsizeof(BITMAPINFOHEADER)+m_nPaletteEntries*sizeof(RGBQUAD);if( m_Palette.GetSafeHandle() != NULL )m_Palette.DeleteObject();if( m_nPaletteEntries != 0 )LOGPALETTE *pLogPal = (LOGPALETTE *) new charsizeof(LOGPALETTE)+m_nPaletteEntries*sizeof(PALETTEENTRY);if( pLogPal != NULL )pLogPal->palVersion = 0x300;pLogPal->palNumEntries = m_nPaletteEntries;for( int i=0; i<m_nPaletteEntries; i+ )pLogPal->palPalEntryi.peRed =m_pPalettei.rgbRed;pLogPal->palPalEntryi.peGreen =m_pPalettei.rgbGreen;pLogPal->palPalEntryi.peBlue =m_pPalettei.rgbBlue;m_Palette.CreatePalette( pLogPal );delete pLogPal;m_BitCount = 8;return( TRUE );BOOL CDib:Save( const char *pszFilename )if( m_pDib = NULL )return( FALSE );CFile cf;if( !cf.Open( pszFilename,CFile:modeCreate | CFile:modeWrite ) )return( FALSE );tryBITMAPFILEHEADER BFH;memset( &BFH, 0, sizeof( BITMAPFILEHEADER ) );BFH.bfType = 'MB'BFH.bfSize = sizeof( BITMAPFILEHEADER ) + m_dwDibSize;BFH.bfOffBits = sizeof( BITMAPFILEHEADER ) +sizeof( BITMAPINFOHEADER ) +m_nPaletteEntries * sizeof( RGBQUAD );cf.Write( &BFH, sizeof( BITMAPFILEHEADER ) );cf.Write( m_pDib, m_dwDibSize );catch( CFileException *e )e->Delete();return( FALSE );return( TRUE );BOOL CDib:Draw( CDC *pDC, int nX, int nY, int nWidth, int nHeight, int Style ) long i,j; if( m_pDib = NULL )return( FALSE ); long vWidth = (4 - m_pBIH->biWidth % 4) % 4 + m_pBIH->biWidth; /*if ( m_BitCount != 8)for (i = 0; i< m_pBIH->biHeight; i+) for (j = 0; j < m_pBIH->biWidth; j+) *(m_pDibBits+i*vWidth+j) = (m_pWordDatai*m_pBIH->biWidth+j >> (m_BitCount-8); else if ( m_BitCount = 16) for (i = 0; i< m_pBIH->biWidth*m_pBIH->biHeight; i+) m_pDibBitsi = (m_pWordDatai >> 8); */ if( nWidth = -1 ) nWidth = m_pBIH->biWidth;if( nHeight = -1 ) nHeight = m_pBIH->biHeight; if (Style) StretchDIBits( pDC->m_hDC, nX, nY, nWidth, nHeight, 0, 0, m_pBIH->biWidth, m_pBIH->biHeight, m_pDibBits, (BITMAPINFO *) m_pBIH,BI_RGB, SRCCOPY ); else SetDIBitsToDevice( pDC->m_hDC, nX, nY, m_pBIH->biWidth, m_pBIH->biHeight,0, 0, 0, m_pBIH->biHeight, m_pDibBits, (BITMAPINFO *) m_pBIH, BI_RGB); return( TRUE );BOOL CDib:SetPalette( CDC *pDC )if( m_pDib = NULL )return( FALSE );if( m_Palette.GetSafeHandle() = NULL )return( TRUE );pOldPalette = pDC->SelectPalette( &m_Palette, FALSE );pDC->RealizePalette();pDC->SelectPalette( pOldPalette, FALSE );return( TRUE );bool CDib:ConvertToTwoValue()DWORD i,size;unsigned char *p;/ 一个二值化程序/ 以128为界划分p = m_pDibBits;size = m_dwDibSize - (m_pDibBits - m_pDib);for (i = 0; i < size;i+)if (*p < 128) *p = 0;else*p = 255;p+;return true;void CShowDIBView:OnFileOpen() /打开一张bmp图像static char szFilter = "BMP Files(*.BMP)|*.BMP|All Files(*.*)|*.*|"CFileDialog FileDlg( TRUE, NULL, NULL,OFN_HIDEREADONLY, szFilter );if( FileDlg.DoModal() = IDOK &&m_Dib.Load( FileDlg.GetPathName() ) )InvalidateRect( NULL, TRUE );UpdateWindow();void CShowDIBView:OnFileSave() /文件保存/ TODO: Add your command handler code herestatic char szFilter = "BMP Files(*.BMP)|*.BMP|All Files(*.*)|*.*|"CFileDialog FileDlg( FALSE, "bmp", NULL,OFN_HIDEREADONLY|OFN_OVERWRITEPROMPT, szFilter );if( FileDlg.DoModal() = IDOK &&m_Dib.Save( FileDlg.GetPathName() ) )InvalidateRect( NULL, TRUE );UpdateWindow();void CShowDIBView:OnPROCESS2value() / TODO: Add your command handler code here if (m_Dib.ConvertToTwoValue()InvalidateRect( NULL, TRUE );UpdateWindow();1. 基于C8051F单片机直流电动机反馈控制系统的设计与研究2. 基于单片机的嵌入式Web服务器的研究 3. MOTOROLA单片机MC68HC(8)05PV8/A内嵌EEPROM的工艺和制程方法及对良率的影响研究 4. 基于模糊控制的电阻钎焊单片机温度控制系统的研制 5. 基于MCS-51系列单片机的通用控制模块的研究 6. 基于单片机实现的供暖系统最佳启停自校正(STR)调节器7. 单片机控制的二级倒立摆系统的研究8. 基于增强型51系列单片机的TCP/IP协议栈的实现 9. 基于单片机的蓄电池自动监测系统 10. 基于32位嵌入式单片机系统的图像采集与处理技术的研究11. 基于单片机的作物营养诊断专家系统的研究 12. 基于单片机的交流伺服电机运动控制系统研究与开发 13. 基于单片机的泵管内壁硬度测试仪的研制 14. 基于单片机的自动找平控制系统研究 15. 基于C8051F040单片机的嵌入式系统开发 16. 基于单片机的液压动力系统状态监测仪开发 17. 模糊Smith智能控制方法的研究及其单片机实现 18. 一种基于单片机的轴快流CO,2激光器的手持控制面板的研制 19. 基于双单片机冲床数控系统的研究 20. 基于CYGNAL单片机的在线间歇式浊度仪的研制 21. 基于单片机的喷油泵试验台控制器的研制 22. 基于单片机的软起动器的研究和设计 23. 基于单片机控制的高速快走丝电火花线切割机床短循环走丝方式研究 24. 基于单片机的机电产品控制系统开发 25. 基于PIC单片机的智能手机充电器 26. 基于单片机的实时内核设计及其应用研究 27. 基于单片机的远程抄表系统的设计与研究 28. 基于单片机的烟气二氧化硫浓度检测仪的研制 29. 基于微型光谱仪的单片机系统 30. 单片机系统软件构件开发的技术研究 31. 基于单片机的液体点滴速度自动检测仪的研制32. 基于单片机系统的多功能温度测量仪的研制 33. 基于PIC单片机的电能采集终端的设计和应用 34. 基于单片机的光纤光栅解调仪的研制 35. 气压式线性摩擦焊机单片机控制系统的研制 36. 基于单片机的数字磁通门传感器 37. 基于单片机的旋转变压器-数字转换器的研究 38. 基于单片机的光纤Bragg光栅解调系统的研究 39. 单片机控制的便携式多功能乳腺治疗仪的研制 40. 基于C8051F020单片机的多生理信号检测仪 41. 基于单片机的电机运动控制系统设计 42. Pico专用单片机核的可测性设计研究 43. 基于MCS-51单片机的热量计 44. 基于双单片机的智能遥测微型气象站 45. MCS-51单片机构建机器人的实践研究 46. 基于单片机的轮轨力检测 47. 基于单片机的GPS定位仪的研究与实现 48. 基于单片机的电液伺服控制系统 49. 用于单片机系统的MMC卡文件系统研制 50. 基于单片机的时控和计数系统性能优化的研究 51. 基于单片机和CPLD的粗光栅位移测量系统研究 52. 单片机控制的后备式方波UPS 53. 提升高职学生单片机应用能力的探究 54. 基于单片机控制的自动低频减载装置研究 55. 基于单片机控制的水下焊接电源的研究 56. 基于单片机的多通道数据采集系统 57. 基于uPSD3234单片机的氚表面污染测量仪的研制 58. 基于单片机的红外测油仪的研究 59. 96系列单片机仿真器研究与设计 60. 基于单片机的单晶金刚石刀具刃磨设备的数控改造 61. 基于单片机的温度智能控制系统的设计与实现 62. 基于MSP430单片机的电梯门机控制器的研制 63. 基于单片机的气体测漏仪的研究 64. 基于三菱M16C/6N系列单片机的CAN/USB协议转换器 65. 基于单片机和DSP的变压器油色谱在线监测技术研究 66. 基于单片机的膛壁温度报警系统设计 67. 基于AVR单片机的低压无功补偿控制器的设计 68. 基于单片机船舶电力推进电机监测系统 69. 基于单片机网络的振动信号的采集系统 70. 基于单片机的大容量数据存储技术的应用研究 71. 基于单片机的叠图机研究与教学方法实践 72. 基于单片机嵌入式Web服务器技术的研究及实现 73. 基于AT89S52单片机的通用数据采集系统 74. 基于单片机的多道脉冲幅度分析仪研究 75. 机器人旋转电弧传感角焊缝跟踪单片机控制系统 76. 基于单片机的控制系统在PLC虚拟教学实验中的应用研究77. 基于单片机系统的网络通信研究与应用 78. 基于PIC16F877单片机的莫尔斯码自动译码系统设计与研究79. 基于单片机的模糊控制器在工业电阻炉上的应用研究 80. 基于双单片机冲床数控系统的研究与开发 81. 基于Cygnal单片机的C/OS-的研究82. 基于单片机的一体化智能差示扫描量热仪系统研究 83. 基于TCP/IP协议的单片机与Internet互联的研究与实现 84. 变频调速液压电梯单片机控制器的研究 85. 基于单片机-免疫计数器自动换样功能的研究与实现 86. 基于单片机的倒立摆控制系统设计与实现 87. 单片机嵌入式以太网防盗报警系统 88. 基于51单片机的嵌入式Internet系统的设计与实现 89. 单片机监测系统在挤压机上的应用 90. MSP430单片机在智能水表系统上的研究与应用 91. 基于单片机的嵌入式系统中TCP/IP协议栈的实现与应用92. 单片机在高楼恒压供水系统中的应用 93. 基于ATmega16单片机的流量控制器的开发 94. 基于MSP430单片机的远程抄表系统及智能网络水表的设计95. 基于MSP430单片机具有数据存储与回放功能的嵌入式电子血压计的设计 96. 基于单片机的氨分解率检测系统的研究与开发 97. 锅炉的单片机控制系统 98. 基于单片机控制的电磁振动式播种控制系统的设计 99. 基于单片机技术的WDR-01型聚氨酯导热系数测试仪的研制 100. 一种RISC结构8位单片机的设计与实现 101. 基于单片机的公寓用电智能管理系统设计 102. 基于单片机的温度测控系统在温室大棚中的设计与实现103. 基于MSP430单片机的数字化超声电源的研制 104. 基于ADC841单片机的防爆软起动综合控制器的研究105. 基于单片机控制的井下低爆综合保护系统的设计 106. 基于单片机的空调器故障诊断系统的设计研究 107. 单片机实现的寻呼机编码器 108. 单片机实现的鲁棒MRACS及其在液压系统中的应用研究 109. 自适应控制的单片机实现方法及基上隅角瓦斯积聚处理中的应用研究110. 基于单片机的锅炉智能控制器的设计与研究 111. 超精密机床床身隔振的单片机主动控制 112. PIC单片机在空调中的应用 113. 单片机控制力矩加载控制系统的研究 项目论证,项目可行性研究报告,可行性研究报告,项目推广,项目研究报告,项目设计,项目建议书,项目可研报告,本文档支持完整下载,支持任意编辑!选择我们,选择成功!项目论证,项目可行性研究报告,可行性研究报告,项目推广,项目研究报告,项目设计,项目建议书,项目可研报告,本文档支持完整下载,支持任意编辑!选择我们,选择成功!单片机论文,毕业设计,毕业论文,单片机设计,硕士论文,研究生论文,单片机研究论文,单片机设计论文,优秀毕业论文,毕业论文设计,毕业过关论文,毕业设计,毕业设计说明,毕业论文,单片机论文,基于单片机论文,毕业论文终稿,毕业论文初稿,本文档支持完整下载,支持任意编辑!本文档全网独一无二,放心使用,下载这篇文档,定会成功!20