基于MATLAB数字图像处理平台设计说明_第1页
基于MATLAB数字图像处理平台设计说明_第2页
基于MATLAB数字图像处理平台设计说明_第3页
基于MATLAB数字图像处理平台设计说明_第4页
基于MATLAB数字图像处理平台设计说明_第5页
已阅读5页,还剩21页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、 PAGE23 / NUMPAGES26基于MATLAB数字图像处理平台设计摘 要数字图像处理技术在各个行业得到广泛的应用,其交互式的图形界面是操作者方便使用这些技术的途径。本文主要介绍了基于MATLAB的图形用户界面(GUI)来设计一个简单实用的图像处理软件平台,其中具备图像处理的常用功能,以满足用户的使用。文章详细阐述了一下图像处理软件平台的设计过程。本文的GUI设计所制作的图像处理软件平台可以实现的功能有五个模块:图像变换、图像增强、图像分割、图像变形以与其它常用处理。其中也讲述了GUI的基本常用操作与文件的打开、保存与退出。文章基本介绍了以上的容,关于软件还有许多未能实现的功能有待于日

2、后的逐步开发和学习。关键词:GUI;图像变换;图像增强;图像分割;图像变形;图像处理ABSTRACTDigital image processing technology has been widely used in various industries, their interactive graphical interface is the way of the operator ease of use of these technologies.This article mainly introduced the graphical user interface (GUI) based

3、 on MATLAB to design a simple and practical platform for the image processing software, Which have commonly used image processing function, in order to meet the users use. The article expounds the design process of the image processing software platform. This paper made the GUI design of image proce

4、ssing software platform can realize the function of five modules: image transformation, image enhancement, image segmentation, image distortion and other commonly used processing. The basic common operations of which also tells the story of GUI and file open, save, and exit. The content of the artic

5、le introduces the above basic, about software and many fail to realize the function of the subject to the gradual development and learning in the future.Key words:GUI; Image transformation; Image enhancement; Image segmentation; Image deformation; The image processing目 录 TOC o 1-3 h z u HYPERLINK l

6、_Toc3771478351 绪论PAGEREF _Toc377147835 h1HYPERLINK l _Toc3771478361.1设计要求与目的PAGEREF _Toc377147836 h1HYPERLINK l _Toc3771478371.2 课题分析PAGEREF _Toc377147837 h1HYPERLINK l _Toc3771478381.3 总体设计PAGEREF _Toc377147838 h2HYPERLINK l _Toc3771478392 具体设计PAGEREF _Toc377147839 h2HYPERLINK l _Toc3771478402.1 菜单

7、设计PAGEREF _Toc377147840 h2HYPERLINK l _Toc3771478412.2 图像的打开、保存与退出PAGEREF _Toc377147841 h3HYPERLINK l _Toc3771478422.2.1 图像打开PAGEREF _Toc377147842 h3HYPERLINK l _Toc3771478432.2.2 图像保存PAGEREF _Toc377147843 h4HYPERLINK l _Toc3771478442.2.3程序退出PAGEREF _Toc377147844 h4HYPERLINK l _Toc3771478452.3 图像变换P

8、AGEREF _Toc377147845 h4HYPERLINK l _Toc3771478462.3.1 傅里叶变换PAGEREF _Toc377147846 h4HYPERLINK l _Toc3771478472.3.3 离散余弦变换PAGEREF _Toc377147847 h5HYPERLINK l _Toc3771478482.4 图像增强PAGEREF _Toc377147848 h5HYPERLINK l _Toc3771478492.4.1 空间域增强PAGEREF _Toc377147849 h5HYPERLINK l _Toc3771478502.4.2 频率域增强PAG

9、EREF _Toc377147850 h6HYPERLINK l _Toc3771478512.5 图像分割PAGEREF _Toc377147851 h7HYPERLINK l _Toc3771478522.5.1 阈值分割PAGEREF _Toc377147852 h8HYPERLINK l _Toc3771478532.5.2 梯度分割PAGEREF _Toc377147853 h8HYPERLINK l _Toc3771478542.6 图像变形PAGEREF _Toc377147854 h9HYPERLINK l _Toc3771478552.6.1 翻转PAGEREF _Toc37

10、7147855 h9HYPERLINK l _Toc3771478562.6.2 旋转PAGEREF _Toc377147856 h10HYPERLINK l _Toc3771478572.7 其它常用处理PAGEREF _Toc377147857 h10HYPERLINK l _Toc3771478582.7.1 亮度PAGEREF _Toc377147858 h10HYPERLINK l _Toc3771478592.7.2 对比度PAGEREF _Toc377147859 h11HYPERLINK l _Toc3771478602.7.3 截图PAGEREF _Toc377147860

11、h11HYPERLINK l _Toc3771478612.7.4 底片效果PAGEREF _Toc377147861 h12HYPERLINK l _Toc3771478622.7.5 二值处理PAGEREF _Toc377147862 h12HYPERLINK l _Toc3771478633 结果分析PAGEREF _Toc377147863 h13HYPERLINK l _Toc3771478644 心得体会PAGEREF _Toc377147864 h13HYPERLINK l _Toc377147865附录PAGEREF _Toc377147865 h14基于MATLAB数字图像处

12、理平台设计MATLAB是近几年来国外使用最为广泛的优秀科技软件之一。其语法结构简单,具有极强的数值计算、数据分析、图形绘制与图像处理等功能。具有高质量的图形可视化效果和强大的界面设计能力。因而在数字图像处理中有着其他语言所无法比拟的优势。图形用户界面(GUI)是提供人机交互的工具和方法。利用GUI制作图像处理软件能够实现图像处理的各个容,主要有:图像空间变换:邻域和块操作;二值图像操作;线性滤波和滤波器设计;变换域处理;图像分析和增强;图像恢复;图像压缩;形态学运算等。1 绪论1.1设计要求与目的设计要求:以MATLAB作为工具,开发一个图像处理软件。主要进行图像处理的常用算法。由以下模块组成

13、:图像变换;图像增强;图像分割。按各个模块进行功能扩充,也可加入其它常用的图像处理功能。设计目的:MATLAB软件为数字图像处理提供了功能丰富的工具,应用MATLAB友好的界面和实用高效的指令与模块,可以使人较快地认识、理解图像处理的相关概念,逐步掌握图像处理的基本方法。此课题的设计目的是综合运用MATLAB工具箱实现图像处理的GUI程序设计,学会和掌握GUI的图像处理平台设计。1.2 课题分析图1.1 整体功能框图此课题利用MATLAB的GUI程序设计一个简单实用的图像处理程序。该程序具备图像处理的常用功能,以满足用户的使用。程序实现的图像处理功能分为五个模块:图像变换、图像增强、图像分割、

14、图像变形以与其它常用处理。如图1.1所示。除以上的数字图像处理的功能外,该程序还要实现图像的读取显示、图像的保存与退出等基本功能。从而实现完整的数字图像平台设计,具有更好的交互性。1.3 总体设计图1.2 界面布局软件的总体设计界面主要分为两个部分:显示区域与操作区域。具体界面布局如图1.2所示。显示区域:定义两个图形区域,左面为待处理图片来显示载入的原图像,右面为通过处理后的图像。操作区域:通过菜单栏的编辑实现对图像的各种处理,分为文件和编辑两大部分。通过文件中的打开操作显示出处理前的图像,在编辑中选择某个图像处理功能后,将在已处理图片下就会显示出处理后的图片。2 具体设计2.1 菜单设计通

15、过Menu Editor创建菜单栏如图2.1所示。菜单的设计主要分为两大部分:文件和编辑。文件包含图像的打开、保存和退出;编辑包含图像处理功能的五个模块:图像变换、图像增强、图像分割、图像变形与其它常用处理,还有各个模块的分支。通过此菜单来控制显示或隐藏功能键。以图2.1的傅里叶变换为例,当添加上某一菜单后,修改名称为傅里叶变换,句柄为FFT,从而会在M文件中自动生成傅里叶变换的功能函数function FFT_Callback(hObject, eventdata, handles),在此函数下编写能够实现傅里叶变换的程序便能实现对图像的傅里叶变换。图2.1 菜单栏2.2 图像的打开、保存与

16、退出2.2.1 图像打开图像的打开主要是通过以下程序来实现的:“filename,pathname=uigetfile(*.jpg;*.bmp;*.tif;*.*,载入图像);” 选择相应路径打开图像;“file=pathname,filename;x=imread(file);”读取选中的图像;“imshow(x);”在显示区域上显示图像。图2.2 图像的打开 具体操作如图2.2所示,选择“文件”菜单中的“打开”后,出现“载入图像”,选中想要处理的图片后点击“打开”,即可在显示区域中显示出处理前的图片。2.2.2 图像保存图像的保存主要是通过以下程序来实现的:“sfilename,sfile

17、path=uiputfile(*.jpg;*.bmp;*.tif;*.*,保存图像文件,untitled.jpg);” 选择图像文件保存的路径与格式;“sfilefullname=sfilepath ,sfilename;imwrite(handles.img,sfilefullname);”实现对图像的保存。图2.3 图像的保存具体操作如图2.3所示,选择“文件”菜单中的“保存”后,出现“保存图像文件”,修改文件名后点击“保存”,即可将处理后的图像保存到keshe的文件夹下。2.2.3程序退出程序的退出是通过“clc;”,“close all;”,“close(gcf);”,“clear;”

18、这些指令来清除指令窗,窗口,存变量与函数。具体操为选择“文件”菜单中的“退出”后,便关闭了执行界面的窗口并清除了指令窗的所有指令。2.3 图像变换2.3.1 傅里叶变换傅里叶变换(FFT)实际上是将信号f(t)与一组不同频率的复正弦作积,这一组复正弦是变换的基向量,傅里叶系数或傅里叶变换是f(t)在这一组基向量上的投影。在图像处理技术的发展过程中,FFT起着十分重要的作用。它是线性系统分析的一个有力工具,它能够定量地分析诸如数字图像之类的数字化系统。FFT主要分为连续傅里叶变换和离散傅里叶变换,在数字图像处理中经常用到的是二维离散傅里叶变换。程序中主要是通过二维离散傅里叶变换函数fft2(),

19、变换后四个角部分对应于低频成分,中央部分对应于高频成分。若想使低频成分出现在中央位置,则通过函数fftshift()将图像频谱中心从矩阵的原点移到矩阵中心。从而实现图像的二维傅里叶变换。具体程序见附录。原图像与傅里叶变换后的图像如图2.4所示。图2.4 傅里叶变换2.3.3 离散余弦变换离散余弦变换(DFT)在图像处理中占有重要的位置,它实际上是傅里叶变换的实数部分,但是它比傅里叶变换有更强的信息集中能力。对于大多数自然图像,DCT能将大多数的信息放到较少的系数上去,因此就更能提高编码的效率。图2.5 离散余弦变换程序中主要是通过灰度变换函数rgb2gray()与二维离散余弦变换函数dct2(

20、)来实现对图像的二维离散余弦变换,具体程序见附录。其变换后的图像低频能量都集中在左上角区域,而向着右下角方向,频率越来越高。原图像与离散余弦变换后的图像如图2.5所示。2.4 图像增强图像增强是图像处理中的一类基本技术,其主要的目的改善图像的视觉效果,提高图像的清晰度。图像增强能够扩展对比度,增强图像中对象的边缘,消除或抑制噪声或保留图像中感兴趣的某些特性而抑制另一些特性等。图像增强方法按其处理所进行的空间不同,可分为空间域法和频率域法。2.4.1 空间域增强空间域法是在空间域直接对像素灰度值进行运算处理,常用的空间域法有图像的直接灰度变换和直方图均衡化,下面分别介绍两种空域上的图像增强方法。

21、(1)灰度变换通过灰度变换可使图像动态围加大,图像对比度扩展,图像清晰,特征明显,大大改善人眼的视觉效果。图2.6 灰度变换程序中主要通过灰度处理函数rgb2gray()对图像进行灰度变换,将彩色图像转换成灰度图像。原图像与灰度图像如图2.6所示。(2) 直方图均衡化直方图均衡化是对原始图像中的像素灰度作某种映射变换,使变换后的图像灰度的概率密度是均匀分布的,即变换后图像是一幅灰度级均匀分布图像,这意味着图像灰度的动态围得到了增加,从而可提高图像的对比度。图2.7 直方图均衡化程序中主要通过灰度处理函数rgb2gray()先对图像进行灰度变换,然后通过直方图均衡化处理函数histeq()对灰度

22、图像进行直方图均衡化处理。原图像与直方图均衡化后的图像如图2.7所示。2.4.2 频率域增强频率域法就是在图像的某种变换域,对图像的变换值进行运算,然后通过逆变换获得图像增强效果。这是一种间接处理方法,一般采用二维数字滤波方法来进行频率域的图像增强。(1) 低通滤波图像的边缘以与噪声干扰在图像的频域上对应于图像傅里叶变换中的高频部分,而图像的背景区则对应于低频部分,因此可以用频域低通滤波法去除图像的高频成分,以去掉噪声,使图像平滑。图2.8 低通滤波器程序中采用二阶巴特沃斯低通滤波器,先用函数fft2()对图像进行二维离散傅里叶变换,然后通过低通滤波器进行滤波后,再对滤波后的图像数据通过iff

23、t2()进行傅里叶反变换,从而得到低通滤波后的图像。如图2.8所示。(2) 高通滤波图像中的边缘或线条与图像频谱中的高频分量相对应,因此采用高通滤波器让高频分量顺利通过,可以使图像的边缘或线条变得更清楚,可实现图像的锐化。图2.9 高通滤波器程序中采用二阶巴特沃斯高通滤波器,与低通滤波过程一样,先进行傅里叶变换,然后通过高通滤波器,再进行傅里叶反变换,从而得到高通滤波后的图像,具体程序见附录。原图像与滤波后的图像如图2.9所示。2.5 图像分割 图像分割是一种重要的图像分析技术。为了识别和分析图像中的目标,需要将它们从图像中分离提取出来,在此基础上才有可能进一步对目标进行测量和对图像进行利用。

24、图像分割就是指把图像分成各具特性的区域并提取出感兴趣目标的技术和过程。2.5.1 阈值分割灰度阈值法是把图像的灰度分成不同的等级,然后用设置灰度阈值的方法确定有意义的区域或欲分割物的边界,该方法中最简单的就是二值化的阈值分割。图2.10 阈值分割程序中先通过函数graythresh()即用Otsu方法计算出全局图像阈值,再通过函数im2bw( , )基于一定阈值将图像转换成二值图像。原图像与阈值分割后的图像如图2.10所示。2.5.2 梯度分割 梯度分割即对图像进行边缘检测,图像边缘对图像识别和计算机分析十分有用。边缘能勾划出目标物体,使观察者一目了然。边缘蕴含了丰富的在信息,是图像识别中抽取

25、图像特征的重要属性。(1) Roberts算子图2.11 Roberts算子程序中先通过函数rgb2gray()对图像进行灰度变换,再通过函数edge( ,roberts) 即用Roberts算子识别灰度图像的轮廓,从而实现对图像的边缘检测。如图2.11所示。(2) Canny算子程序中先通过函数rgb2gray()对图像进行灰度变换,再通过函数edge( ,canny) 即用Canny算子识别灰度图像的轮廓,如图2.12所示。(3) Sobel算子程序中先通过函数rgb2gray()进行灰度变换,再通过函数edge( ,sobel) 即用Sobel算子识别灰度图像的轮廓,从而实现对图像的边缘

26、检测。如图2.13所示。图2.13 Sobel算子图2.12 Canny算子2.6 图像变形2.6.1 翻转图2.14 上下翻转上下翻转:程序过函数flipud()对图像数据矩阵进行上下翻转,由于彩色图像不能直接进行矩阵翻转,因此需要先将彩色图像通过灰度变换处理后再进行翻转,原图与翻转后的图像如图2.14所示。图2.15 左右翻转左右翻转:与上下翻转一样,先将图像进行灰度变换后,通过函数fliplr()将图像数据矩阵进行左右翻转,原图与翻转后的图像如图2.15所示。2.6.2 旋转打开图片后,选择“编辑”菜单“图像变形”中的“旋转”后,执行界面会出现调整角度的输入对话框,在对话框中输入任意角度

27、,则原图像将会旋转任意角度,输入正数逆时针旋转,输入负数顺时针旋转。以90为例,在对话框中输入90,则图像逆时针旋转90。,如图2.16所示。图2.16 图像旋转在程序中由prompt=调整角度;来显示输入对话框,函数inputdlg()创建对话框和输入框,输入角度后通过函数imrotate()进行相应的旋转。2.7 其它常用处理2.7.1 亮度当在“编辑”菜单中选择“亮度”后,会出现调整倍数的输入对话框,默认值为1,在对话框中输入数值后图像便会相应变换亮度。输入数值小于1时,图像变亮,输入数值大于1时,图像变暗。程序过函数imadjust()来实现,即将原图像的亮度值以输入数值描述的曲线关系

28、映射到新的数值中,从而实现亮度的变化。以输入值0.5为例,变换后的图像如图2.17所示。图2.17 亮度调整2.7.2 对比度图2.18 对比度增强对比度增强:选择菜单中“对比度增强”后,弹出输入参数的对话框,以输入参数2为例,对比度增强后的图像如图2.18所示。程序过乘法函数immultiply()将原图像数据与输入数值相乘,从而增强图像的对比度。图2.19 对比度减弱对比度减弱:选择菜单中“对比度减弱”后,弹出输入参数的对话框,同样以输入参数2为例,对比度减弱后的图像如图2.19所示。程序过除法函数imdivide()将原图像数据与输入数值相除,从而减弱图像的对比度。2.7.3 截图图2.

29、20 截图当选择完菜单中的“截图”后,鼠标箭头会变成一个十字,能够选择想要截取的图像部分,选中后就会直接显示出截取后的图像,如图2.20所示。程序过函数imcrop()来实现的,即返回图像的一个裁剪区域,允许用户以交互方式使用鼠标选定要剪切的区域。2.7.4 底片效果图2.21 底片效果程序过函数imcomplement()对图像数据矩阵进行取反运算,即可实现底片效果,原图像与底片效果的图像如图2.21所示。2.7.5 二值处理图2.22 二值处理二值化即将彩色图像转换成只有0和1两个数值的图像,程序过二值转换函数im2bw()将彩色图像转换为二值图像。原图像与转换后的二值图像如图2.22所示

30、。3 结果分析经过我们小组的不断调试,软件已经得到了完善,达到了课设的基本要求,基于MATLAB数字图像处理平台设计能实现的全部功能如下:设计图形用户界面,实现了图像的打开、保存与退出实现了对图像的傅里叶变换与离散余弦变换,其中离散余弦变换只能对灰度图像处理。实现了图像空间域增强包括灰度变换和直方图均衡化,还有图像频率域增强包括低通滤波器和高通滤波器。其中直方图均衡化,低通滤波和高通滤波均只支持对灰度图像处理。实现了图像分割:阈值分割和梯度分割,梯度分割有Roberts算子、Canny算子、Sobel算子。其中梯度分割需要对图像先进行灰度变换。实现了图像的翻转和旋转。图像的翻转只支持灰度图像。

31、实现了图像的亮度,对比度的调整,能够对图像截图、做出底片效果与二值化处理。实验程序虽然基本实现了以上这些功能,但遗憾的是有些功能只支持对灰度的图像处理,还不能直接对彩色图像进行处理。4 心得体会通过两周的MATLAB课程设计实践,使我对MATLAB的使用有了进一步的了解和熟悉。还记得当初我们小组抽到这个题目的时候,每个人看到这个题目都无所适从。虽然曾经学过关于数字图像处理的课程,但对于MATLAB的数字图像处理的实际运用并不是很熟悉,特别是对此次GUI设计更是没有丝毫接触过的。虽然对课题感到很懵懂,但在指导老师的提示与指导后,我们开始找到了解决问题的路径。我们到图书馆借了几本相关的书,又从网上

32、收集了大量的资料,为这次课设做了较为充分的准备,在参考了相关材料与程序后,我对自己要做的课设容有了进一步的了解,并对MATLAB的使用有了更深的体会。当然,在课设的进行过程中,我们还是遇到了不少问题。例如,起初由于我对句柄使用以与一些函数使用的不恰当,使得在对图像文件的保存上就遇到了问题,不过在我们小组的讨论研究下轻松的就解决了。随着课设的进行,对matlab的的熟悉度逐步加深。在基本功能已经完成的基础上,我们开始进行一些扩功能的尝试,比如图像的旋转、翻转,图像亮度、对比度的调整,截图等功能,也实现了较为理想的结果。虽然这课题最终的功能还不是很完善,但是我还是较为满意的。本次的课程设计,不但鞭

33、策着我去巩固MATLAB的理论知识,还提高了我对MATLAB的实际操作运用,使得理论与实践相结合,为进一步学MATLAB打下了坚实的基础。附录function varargout = keshe(varargin)gui_Singleton = 1;gui_State = struct(gui_Name, mfilename, . gui_Singleton, gui_Singleton, . gui_OpeningFcn, keshe_OpeningFcn, . gui_OutputFcn, keshe_OutputFcn, . gui_LayoutFcn, , . gui_Callback

34、, );if nargin & ischar(varargin1) gui_State.gui_Callback = str2func(varargin1);endif nargout varargout1:nargout = gui_mainfcn(gui_State, varargin:);else gui_mainfcn(gui_State, varargin:);end% function keshe_OpeningFcn(hObject, eventdata, handles, varargin)handles.output = hObject;guidata(hObject, ha

35、ndles);% function varargout = keshe_OutputFcn(hObject, eventdata, handles) varargout1 = handles.output;% function open_Callback(hObject, eventdata, handles)% hObject handle to open (see GCBO)% eventdata reserved - to be defined in a future version of MATLAB% handles structure with handles and user d

36、ata (see GUIDATA)filename,pathname=uigetfile(*.jpg;*.bmp;*.tif;*.*,载入图像); %选择路径打开图像if isequal(filename,0)|isequal(pathname,0) %若filename为0或pathname为0,即未选中文件 errordlg(未选中文件,警告); %建立一个名为警告的错误对话框,容为“未选中文件” return;else file=pathname,filename; %将文件名和目录名组合成一个完整的路径 x=imread(file); %读入图像 set(handles.axes1,H

37、andleVisibility,ON); %设置图形对象属性,可从命令窗口中和GUIs中访问 axes(handles.axes1); %定义图形区域axes1 imshow(x); %显示图像 set(handles.axes1,HandleVisibility,OFF); %设置图形对象属性,不可从命令窗口中和GUIs中访问 axes(handles.axes2); %定义图形区域axes2 imshow(x); %显示图像 handles.img=x; %把图像发给handles.img guidata(hObject,handles); %把handles句柄更新end% functi

38、on save_Callback(hObject, eventdata, handles)% hObject handle to save (see GCBO)% eventdata reserved - to be defined in a future version of MATLAB% handles structure with handles and user data (see GUIDATA)sfilename ,sfilepath=uiputfile(*.jpg;*.bmp;*.tif;*.*,保存图像文件,untitled.jpg); %返回要保存的图像文件 if iseq

39、ual(sfilename,sfilepath,0,0) %如果不是取消保存 sfilefullname=sfilepath ,sfilename; %将文件名和目录名组合成一个完整的路径 imwrite(handles.img,sfilefullname); %保存图像 else msgbox(取消保存?,保存图像文件); %弹出一个名为保存图像文件的对话框,容为“取消保存?” end% function exit_Callback(hObject, eventdata, handles)% hObject handle to exit (see GCBO)% eventdata reser

40、ved - to be defined in a future version of MATLAB% handles structure with handles and user data (see GUIDATA)clc; %清除指令窗close all; %关闭所有句柄可见的窗口close(gcf); %关闭当前窗口clear; %清除存变量和函数% function change_Callback(hObject, eventdata, handles)function enhance_Callback(hObject, eventdata, handles)function feng

41、e_Callback(hObject, eventdata, handles)function file_Callback(hObject, eventdata, handles)function edit_Callback(hObject, eventdata, handles)function fanzhuan_Callback(hObject, eventdata, handles)% function FFT_Callback(hObject, eventdata, handles)% hObject handle to FFT (see GCBO)% eventdata reserv

42、ed - to be defined in a future version of MATLAB% handles structure with handles and user data (see GUIDATA)axes(handles.axes2);i1=handles.img; %获取图像i2=im2double(i1); %图像矩阵转换成双精度浮点类型f1=fft2(i2); %对图像进行二维离散傅里叶变换fc1=fftshift(f1); %将变换后的图象频谱中心从矩阵的原点移到矩阵的中心i=log(1+abs(fc1); %对变换后的图像矩阵数据求绝对值后取自然对数imshow(

43、i); xlabel(傅里叶变换图像);handles.img=i;guidata(hObject,handles); %把handles句柄更新% function DCT_Callback(hObject, eventdata, handles)% hObject handle to DCT (see GCBO)% eventdata reserved - to be defined in a future version of MATLAB% handles structure with handles and user data (see GUIDATA)axes(handles.ax

44、es2);j1=handles.img; %获取图像j2=rgb2gray(j1); %灰度变换d=dct2(j2); %对图像进行二维离散余弦变换j=log(abs(d); %对变换后的图像矩阵数据求绝对值后取自然对数imshow(j);xlabel(离散余弦变换图像);handles.img=j;guidata(hObject,handles); %把handles句柄更新% function huidu_Callback(hObject, eventdata, handles)% hObject handle to huidu (see GCBO)% eventdata reserved

45、 - to be defined in a future version of MATLAB% handles structure with handles and user data (see GUIDATA)global T %定义全局变量axes(handles.axes2); %定义图形区域axes2T=getimage; %从坐标轴获取图像数据x=rgb2gray(handles.img); %利用 rgb2gray函数对源图像进行灰度处理 imshow(x); %显示图像xlabel(灰度图像); % x轴名为“灰度图像”handles.img=x; %把图像发给handles.i

46、mgguidata(hObject,handles); %把handles句柄更新% function zhifangtu_Callback(hObject, eventdata, handles)% hObject handle to zhifangtu (see GCBO)% eventdata reserved - to be defined in a future version of MATLAB% handles structure with handles and user data (see GUIDATA)axes(handles.axes2); %定义图形区域axes2T=

47、getimage; %从坐标轴获取图像数据x=rgb2gray(handles.img); %对图像进行灰度处理h=histeq(x); %对图像进行直方图均衡化处理 imshow(h); %显示图像xlabel(直方图均衡化后的图像); handles.img=h;guidata(hObject,handles); %把handles句柄更新% function low_Callback(hObject, eventdata, handles)% hObject handle to low (see GCBO)% eventdata reserved - to be defined in a

48、 future version of MATLAB% handles structure with handles and user data (see GUIDATA)axes(handles.axes2);y1=handles.img; %获取图像x=rgb2gray(handles.img); %灰度变换f=double(x); %数据类型转换为双精度数值g=fft2(f); %二维离散傅里叶变换g=fftshift(g); %将变换后的图象频谱中心从矩阵的原点移到矩阵的中心M,N=size(g); %返回矩阵g的大小,即M为行数,N为列数nn=2; %二阶巴特沃斯低通滤波器d0=50;

49、 %截止频率50Hzm=fix(M/2); n=fix(N/2); %取矩阵g的行数和列数一半的整数for i=1:M for j=1:N % 循环 d=sqrt(i-m)2+(j-n)2); h=1/(1+0.414*(d/d0)(2*nn); %计算低通滤波器传递函数 result(i,j)=h*g(i,j); %结果返回到result endendresult=ifftshift(result); %将图象频谱中心从矩阵的中心移到矩阵的原点y2=ifft2(result); %二维离散傅里叶反变换y3=uint8(real(y2); %把矩阵y2实部转换成8位无符号数据imshow(y3

50、); %显示低通滤波后的图像xlabel(低通滤波图像);handles.img=y3;guidata(hObject,handles); %把handles句柄更新% function high_Callback(hObject, eventdata, handles)% hObject handle to high (see GCBO)% eventdata reserved - to be defined in a future version of MATLAB% handles structure with handles and user data (see GUIDATA)axe

51、s(handles.axes2);x=handles.img; %获取图像y=rgb2gray(handles.img); %灰度变换 f=double(y); %数据类型转换为双精度数值k=fft2(f); %二维离散傅里叶变换g=fftshift(k); %将变换后的图象频谱中心从矩阵的原点移到矩阵的中心M,N=size(g); %返回矩阵g的大小,即M为行数,N为列数nn=2; %二阶d0=25; %截止频率25Hzm=fix(M/2); n=fix(N/2);for i=1:M for j=1:N %循环 d=sqrt(i-m)2+(j-n)2); if d=d0 h=0; else

52、h=1; end result(i,j)=h*g(i,j); %结果返回到result endendresult=ifftshift(result); %将图象频谱中心从矩阵的中心移到矩阵的原点y2=ifft2(result); %二维离散傅里叶反变换y3=uint8(real(y2); %把矩阵y2实部转换成8位无符号数据imshow(y3); %显示高通滤波后的图像xlabel(高通滤波图像);handles.img=y3;guidata(hObject,handles); %把handles句柄更新% function yuzhi_Callback(hObject, eventdata,

53、 handles)% hObject handle to yuzhi (see GCBO)% eventdata reserved - to be defined in a future version of MATLAB% handles structure with handles and user data (see GUIDATA)axes(handles.axes2);T=getimage; %从坐标轴获取图像数据level=graythresh(T); %用Otsu方法计算全局图像阈值BW=im2bw(T,level); %基于一定阈值把图像转换为二值图像imshow(BW); %

54、显示阈值分割后的图像xlabel(阈值分割图像);handles.img=BW;guidata(hObject,handles); %把handles句柄更新% function tidu_Callback(hObject, eventdata, handles)function kongyu_Callback(hObject, eventdata, handles)function pinyu_Callback(hObject, eventdata, handles)function bianxing_Callback(hObject, eventdata, handles)function

55、 qita_Callback(hObject, eventdata, handles)function duibidu_Callback(hObject, eventdata, handles)% function roberts_Callback(hObject, eventdata, handles)% hObject handle to roberts (see GCBO)% eventdata reserved - to be defined in a future version of MATLAB% handles structure with handles and user d

56、ata (see GUIDATA)axes(handles.axes2);T=getimage; %从坐标轴获取图像数据R1=rgb2gray(T); %灰度变换R2=edge(R1,roberts); %用roberts算子识别灰度图像的轮廓imshow(R2); %显示图像xlabel(Roberts算子图像);handles.img=R2;guidata(hObject,handles) %把handles句柄更新% function canny_Callback(hObject, eventdata, handles)% hObject handle to canny (see GCB

57、O)% eventdata reserved - to be defined in a future version of MATLAB% handles structure with handles and user data (see GUIDATA)axes(handles.axes2);T=getimage; %从坐标轴获取图像数据C1=rgb2gray(T); %灰度变换C2=edge(C1,canny); %用canny算子识别灰度图像的轮廓imshow(C2);xlabel(Canny算子图像);handles.img=C2;guidata(hObject,handles); %

58、把handles句柄更新% function sobel_Callback(hObject, eventdata, handles)% hObject handle to sobel (see GCBO)% eventdata reserved - to be defined in a future version of MATLAB% handles structure with handles and user data (see GUIDATA)axes(handles.axes2);T=getimage; %从坐标轴获取图像数据L1=rgb2gray(T); %灰度变换L2=edge(

59、L1,sobel); %用sobel算子识别灰度图像的轮廓imshow(L2);xlabel(Sobel 算子图像);handles.img=L2;guidata(hObject,handles); %把handles句柄更新% function xuanzhuan_Callback(hObject, eventdata, handles)% hObject handle to xuanzhuan (see GCBO)% eventdata reserved - to be defined in a future version of MATLAB% handles structure wit

60、h handles and user data (see GUIDATA)axes(handles.axes2);T=getimage; %从坐标轴获取图像数据prompt=调整角度; %用于显示可提示用户进行输入角度的对话框defans=0; %对话框显示默认数值为0p=inputdlg(prompt,input,1,defans); %创建并打开标题为input的输入对话框,包含“调整角度”,输入框为1行, 对话框中默认显示数值为0p1=str2num(p1); %将字符串转换为数值f=imrotate(handles.img,p1,bilinear,crop); %将图像handles.

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论