一、简介

1 案例背景
随着国家对公路建设的大力投入,我国的公路通车总里程己经位居世界前列,这样进一步促进了我国经济建设的发展。随着公路的大量投运,公路日常养护和管理已经成为制约公路运营水平提高的瓶颈,特别是路面状态采集、检测维护等工作更是对传统的公路运维模式提出了挑战。路面裂缝是公路日常养护管理中最常见的路面损坏,也是影响公路状态评估和进行必要的公路维修的重要因素!。一般而言,如果路面裂缝能够在被恶化成坑槽之前得到及时修补,则可以大大节约公路的养护成本。传统的公路裂缝检测主要是人工检测,需要配置一定规模的人力、设备等资源来进行定期巡检。但是,面对日益增长的公路建设需求,人工检测具有运营效率低、主观性影响大、危险性较高等不足,已无法满足公路破损快速检测的要求。
随着计算机硬件设备和数字图像处理技术的发展,基于视觉的目标定位及检测技术也取得了不断的进步,由于其具有定位准确、检测快速、自动化操作、易于安装部署等特点,已经广泛应用于工业自动化检测过程,特别是在目标表面质量检测、目标物测量等领域的应用。因此,基于数字图像的路面裂缝检测技术可以提供一个安全、高效、成本低廉的道路状态监控服务,已有多种图像处理方法应用于路面裂缝检测并在一定程度上取得了实际应用。

2 理论基础
路面裂缝检测从视觉上来看是典型的线状目标检测,因此路面裂缝图像的增强与定位属于线状目标检测的研究领域,路面裂缝与一般线状目标相比,具有其自身的特点:目标宽度相对较小、图像对比度较低、具有自然间断、具有分叉和杂点等,并且路面裂缝只是在视觉总体上呈现出线状特征.传统的裂缝自动检测算法,如基于阈值分割、边缘检测、小波变换等算法,往往都假设路面裂缝在整幅图像中具有较高的对比度和较好的连续性,但这种假设在实际的工程项目中往往不成立。由于受拍摄天气、路面损耗、裂缝退化等因素的影响,有一定比例的裂缝相对于路面背景具有极低的对比度,这也会引起传统裂缝检测算法的失效,因此需要在裂缝图像处理前加入一定的预处理步骤。图像预处理一般是应用于图像识别、图像表示等领域的一种前期处理。在图像的采集和传输过程中,往往会因为某些原因导致图像质量降低。例如,从视觉主观上观察图像中
的物体,可能会发觉其轮廓位置过于鲜艳而显得突兀:从被检测目标物的大小和形状来看,图像特征比较模糊、难以定位;从图像对比度的角度来看,可能会受到某些噪声的影响;从图像整体来看,可能会发生某种失真、变形等,因此,待处理图像在视觉直观性和处理可行性等方面可能存在诸多干扰,我们不妨将其统称为图像质量问题。图像预处理正是用于图像质量的改善处理,通过一定的计算步骤进行适当的变换进面突出图像中某些感兴趣的信息,消除或降低干扰信息,如图像对比度增强、图像去噪或边缘提取等处理印,一般情况下,由于裂缝图像的采集需要涉及室外作业,所得图片难免会存在一定的噪声干扰、畸变等各种问题,直接进行裂缝目标的检测和提取往往会遇到困难。因此,本案例首先将裂缝图像进行预处理,改善图像质量,进而提高实验的优化效果。图像预处理的基本方法有图像灰度变换、频域变换、直方图变换、图像去噪、图像锐化、图像色彩变换等。本案例将选择其中的部分方法来进行裂缝图像的预处理操作。
2.1 图像灰度化
自然界中绝大部分的可见光谱均能通过红®、绿(G)、蓝(B)三色光按不同比例和强度进行混合而得到, 我们将其称为RGB色彩模式。该模式以RGB模型为基础, 对图像的每个像素值的RGB分量均分配一个Uint 8类型(0~255) 的强度值。例如, 纯红色的R值为255, G值为0, B值为0; 品红色的R值为255, G值为0, B值为255。RGB图像的红、绿、蓝分量各占8位,因此是24位图像,并且不同亮度的基色混合后,会产生出256x256x 256-16777216种颜色。RGB模型图形化表示如图所示。
【裂缝识别】基于matlab GUI路面裂缝识别【含Matlab源码 009期】_其他
假设F(i, j) 为RGB模型中的某像素, 若其3种基色的亮度值相等, 则会产生灰度颜色,将该R=G=B的值称为灰度值(或者称为强度值、亮度值)。因此,灰度图像就是包含多个量化灰度级的图像。假设该灰度级用Uint 8类型数值表示, 则图像的灰度级就是256(即2°=256)。本案例所选择的灰度图像灰度级均为256,其像素灰度值为0~255的某个值,当亮度值都是255时产生纯白色,当亮度值都是0时产生纯黑色,并且亮度从0到255呈现逐渐增加的趋势。RGB图像包含了由红、绿、蓝三种分量组成的大量的色彩信息, 灰度图像只有亮度信息而没有色彩信息。针对路面裂缝图像的检测要求,一般需要去除不必要的色彩信息, 将所采集到的RGB图像转换为灰度图像。RGB图像的灰度化方法有以下几种。
(1)分量值
选取像素F(i.j)的R、G、B分量中的某个值作为该像素的灰度值,即
【裂缝识别】基于matlab GUI路面裂缝识别【含Matlab源码 009期】_灰度值_02
式中,Fg(i,j)为转换后的灰度图像在(i.j)处的灰度值。
(2)最大值
选取像素F(i,j)的R、G、B分量中的最大值作为该像素的灰度值,即
【裂缝识别】基于matlab GUI路面裂缝识别【含Matlab源码 009期】_灰度值_03
(3)平均值
选取像素F(i,j)的R、G、B分量的亮度均值作为该像素的灰度值,即
【裂缝识别】基于matlab GUI路面裂缝识别【含Matlab源码 009期】_灰度_04
(4)加权平均值
选取像素F(i,j)的R、G、B分量的亮度加权均值作为该像素的灰度值,权值的选取一般是根据分量的重要性等指标,将3个分量以加权平均的方式进行计算得到灰度值。人眼在视觉主观上一般对绿色分量敏感度较高, 对蓝色分量敏感度较低, 因此对RGB三分量进行加权平均能得到较合理的灰度图像,常用的计算公式如下:
F.(i.j)=0.299R(i,j)+0.587G(i,j)+0.114*B(i,j)
采用加权平均计算灰度图像的方式对裂缝图像进行灰度化,所得结果如图所示。
【裂缝识别】基于matlab GUI路面裂缝识别【含Matlab源码 009期】_其他_05
2.2 图像滤波
裂缝图像在采集或传输的过程中往往会受到成像设备与传输介质等因素的干扰而产生噪声,因此待处理的裂缝图像可能会存在边缘模糊、黑白杂点等问题,这在一定程度上会对裂缝目标的检测和识别产生影响,干扰实验结果的判断,因此需要对裂缝图像进行滤波去噪。本节将从均值滤波和中值滤波两方面来进行图像去噪的处理。均值滤波也称为邻域平均滤波,该方法假设待处理图像是由许多灰度值为常量的小区域组成的,并且相邻区域间存在较高的空间相关性,而噪声则显得相对独立。因此,通过将单个像素及其指定邻域内的所有像素按某种规则计算平均灰度值,再作为新图像中的对应像素值,可达到滤波去噪的目的,这一过程被称为均值滤波。邻域平均法属于非加权邻域平均范畴,是最常用的均值滤波操作。
图像边缘一般集中了图像的细节和高频信息,如果通过邻域平均法进行去噪,则往往会引起图像边缘的模糊,这也会对裂缝目标的检测带来不利影响。中值滤波是常用的非线性滤波方法,其主要思想是对像素邻域向量化取中值来进行滤波,具有运算简单、高效,能有效去除脉冲噪声的特点,在去噪的同时它也可以有效地保护图像的边缘细节信息。因此,本案例将采用中值滤波的方法来对裂缝图像进行去噪处理,其处理步骤如下。
(1)定位
在图像中移动模板,将模板中心与图像中的某个像素重合。
(2)计算
选择模板对应于图像的各像素灰度值,进行向量化,并将其进行排序。
(3)赋值
选择序列的中间值,作为输出赋予模板中心对应的像素。
如图2所示,根据中值滤波器形状和维数的不同,其模板有线形、十字形、方形、菱形等,不同形状的窗口也会产生不同的滤波效果。在对裂缝图像进行中值滤波处理时,其关键在于选择合适的模板形状和模板大小。
【裂缝识别】基于matlab GUI路面裂缝识别【含Matlab源码 009期】_二值图像_06
2.3 图像增强
路面裂缝图像的采集一般在室外进行,容易受到大气、光照、机械振动等因素的影响,采集到的裂缝图像可能存在整体偏暗或偏亮等问题,进而产生对比度较低的图像。此类图像的特点是灰度分布范围较小,集中在少量的灰度区间内,这也给后续的裂缝检测和识别带来了不利影响,因此需要对此类图像进行增强处理来提高对比度。直方图作为图像灰度级分布的统计表,能在一定程度上反映图像的对比度详情。图像的灰度直方图表示该图像所属灰度类型中不同灰度级像素出现的相对频率,并且直方图的横坐标表示灰度,纵坐标表示灰度出现的次数或概率。直方图均衡化利用灰度直方图进行图像对比度的调整,以达到增强图像视觉效果的目标。直方图均衡化的基本思想是通过某种变换,将原始图像的灰度直方图从集中于某个较小的灰度区间变成在更大灰度区间内均匀分布的形式,得到灰度级差式分布,从而达到增强图像整体对比度的目标。裂缝图像区域通常属于颜色较暗的灰度区间,背景区域则属于相对较亮的灰度区间。但在采集裂缝图像的过程中,往往会由于天气干扰、曝光不足等原因而造成图像整体偏暗,使裂缝区域与背景区域亮度特征相近而不易辨别,如图所示。从原始裂缝图像的灰度直方图可以看出,其灰度值分布主要集中在0100的低层次灰度区间。因此,为了提高裂缝与背景的对比度,需要将原图像的灰度值范围进行扩大,形成较为明显的灰度级差,进而增加裂缝图像的对比度。经过灰度直方图均衡化处理,裂缝图像的灰度范围扩到了0255,得到对比度增强后的裂缝图像,更加突出了裂缝与背景的差异程度。
2.4 图像二值化
灰度图像二值化是指通过约定一个灰度阈值来分割目标与背景,在阀值之内的像素于目标即记为1,其他则属于背景即记为0。在裂缝目标检测与识别的过程中,可以采用裂缝边缘、面积等特征来进行判别,也可以采用裂缝目标与周围背景的灰度差异值作为个判别依据,这就要求引入阈值来进行图像二值化处理。假设一幅灰度裂缝图像用f(x,y)表示,其中,(x,y)表示图像中像素的位置坐标,T为阈值,则阈值分割后的二值图像b(x,y)满足:
【裂缝识别】基于matlab GUI路面裂缝识别【含Matlab源码 009期】_其他_07
裂缝目标或背景区域的像素灰度通常是高度相关的,但裂缝目标与背景区域之间的灰度值则通常存在较大差异,一般包含明显的边缘等特征。因此,为了从更大程度上分割裂缝目标与背景,则需要对其进行灰度阈值分割选取合适的阈值。阈值计算方法根据其计算过程可以分为两种:全局阈值和基本自适应阈值,如下所述。
(1)全局阈值是最常见的阈值计算方法,它一般以图像的直方图或灰度空间分布为基础来确定一个阈值,进而实现灰度图像的二值化。特别是当图像的灰度直方图分布呈双峰时,全局阈值法可以明显地将目标和背景分量,得到较为理想的图像分割效果。但裂缝图像一般具有光照不均匀、噪声干扰等特点,其灰度直方图往往不会呈双峰分布,因此全局阈值分割方法效果较差。
(2)基本自适应阀值是一种比较基础的图像自适应分割方法,它一般以图像像素自身及其邻域灰度变化的特征为基础进行阈值分割,进而实现灰度图像的二值化。该方法充分考虑了每个像素邻域的特征,所以一般能更好地突出目标和背景的边界。
裂缝图像的背景在多数情况下比较固定,如路面、桥面、墙体等。但由于图像采集一般在室外进行,会受到拍摄条件、路面杂物等因素的影响,所以图像容易出现退化或噪声干扰。本案例通过分析裂缝图像目标和背景的特点,采用自定义和迭代法优化相结合的方法。

3 程序实现
根据裂缝图像的特点,在对其进行目标检测和识别之前,需要进行图像预处理,主要包括:直方图均衡化增强、中值滤波去噪、对比度增强、二值化处理、二值图像滤波等步骤。其中,在二值化过程中对阈值的确定选择自定义阈值法与迭代自适应法相结合的方式来计算;二值图像滤波主要是连通区域的面积滤波,通过去除小面积的杂点噪声来进行滤波去噪。裂缝图像经过预处理可以得到突出裂缝目标的二值图像,然后可以根据形态学区域特征来获取裂缝目标并进行检测识别。对于裂缝的形状识别可以通过计算图像中裂缝目标的外接矩形的长宽比来确定。
备注:简介部分摘自互联网,若有侵权,联系博主删除。

二、部分源代码

function varargout = Gui_Main(varargin)
% GUI_MAIN M-file for Gui_Main.fig
%      GUI_MAIN, by itself, creates a new GUI_MAIN or raises the existing
%      singleton*.
%
%      H = GUI_MAIN returns the handle to a new GUI_MAIN or the handle to
%      the existing singleton*.
%
%      GUI_MAIN('CALLBACK',hObject,eventData,handles,...) calls the local
%      function named CALLBACK in GUI_MAIN.M with the given input arguments.
%
%      GUI_MAIN('Property','Value',...) creates a new GUI_MAIN or raises the
%      existing singleton*.  Starting from the left, property value pairs are
%      applied to the GUI before Gui_Main_OpeningFcn gets called.  An
%      unrecognized property name or invalid value makes property application
%      stop.  All inputs are passed to Gui_Main_OpeningFcn via varargin.
%
%      *See GUI Options on GUIDE's Tools menu.  Choose "GUI allows only one
%      instance to run (singleton)".
%
% See also: GUIDE, GUIDATA, GUIHANDLES
 
% Edit the above text to modify the response to help Gui_Main
 
% Last Modified by GUIDE v2.5 29-Mar-2011 22:28:58
 
% Begin initialization code - DO NOT EDIT
gui_Singleton = 1;
gui_State = struct('gui_Name',       mfilename, ...
    'gui_Singleton',  gui_Singleton, ...
    'gui_OpeningFcn', @Gui_Main_OpeningFcn, ...
    'gui_OutputFcn',  @Gui_Main_OutputFcn, ...
    'gui_LayoutFcn',  [] , ...
    'gui_Callback',   []);
if nargin && ischar(varargin{1})
    gui_State.gui_Callback = str2func(varargin{1});
end
 
if nargout
    [varargout{1:nargout}] = gui_mainfcn(gui_State, varargin{:});
else
    gui_mainfcn(gui_State, varargin{:});
end
% End initialization code - DO NOT EDIT
 
 
% --- Executes just before Gui_Main is made visible.
function Gui_Main_OpeningFcn(hObject, eventdata, handles, varargin)
% This function has no output args, see OutputFcn.
% hObject    handle to figure
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
% varargin   command line arguments to Gui_Main (see VARARGIN)
 
% Choose default command line output for Gui_Main
handles.output = hObject;
handles.Result = [];
handles.File = [];
% Update handles structure
guidata(hObject, handles);
clc; warning off all;
InitAxes(handles);
 
% UIWAIT makes Gui_Main wait for user response (see UIRESUME)
% uiwait(handles.figure1);
 
 
% --- Outputs from this function are returned to the command line.
function varargout = Gui_Main_OutputFcn(hObject, eventdata, handles)
% varargout  cell array for returning output args (see VARARGOUT);
% hObject    handle to figure
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
 
% Get default command line output from handles structure
varargout{1} = handles.output;
 
 
% --- Executes on button press in pushbuttonOpenFile.
function pushbuttonOpenFile_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonOpenFile (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
[filename, pathname] = uigetfile({'*.jpg;*.tif;*.png;*.gif;*.bmp','All Image Files';...
    '*.*','All Files' },'载入图像',...
    fullfile(pwd, 'images'));
if isequal(filename, 0) || isequal(pathname, 0)
    return;
end
I = imread(fullfile(pathname, filename));
Result = Process_Main(I);
handles.File = fullfile(pathname, filename);
handles.Result = Result;
guidata(hObject, handles);
InitAxes(handles)
axes(handles.axes1); imshow(handles.Result.Image); title('原图像');
 
 
% --- Executes on button press in pushbuttonHisteq.
function pushbuttonHisteq_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonHisteq (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
if ~isempty(handles.Result)
    axes(handles.axes1); imshow(handles.Result.Image); title('原图像');
    axes(handles.axes2); imshow(handles.Result.hist); title('直方图均衡化图像');
end
 
 
 
% --- Executes on button press in pushbuttonMedfilt.
function pushbuttonMedfilt_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonMedfilt (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
if ~isempty(handles.Result)
    axes(handles.axes1); imshow(handles.Result.Image); title('原图像');
    axes(handles.axes2); imshow(handles.Result.Medfilt); title('中值滤波图像');
end
 
 
% --- Executes on button press in pushbuttonBw.
function pushbuttonBw_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonBw (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
if ~isempty(handles.Result)
    axes(handles.axes1); imshow(handles.Result.Image); title('原图像');
    axes(handles.axes2); imshow(handles.Result.Bw); title('二值图像');
end
 
% --- Executes on button press in pushbuttonEnance.
function pushbuttonEnance_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonEnance (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
if ~isempty(handles.Result)
    axes(handles.axes1); imshow(handles.Result.Image); title('原图像');
    axes(handles.axes2); imshow(handles.Result.Enance); title('增强图像');
end
 
% --- Executes on button press in pushbuttonBwfilter.
function pushbuttonBwfilter_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonBwfilter (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
if ~isempty(handles.Result)
    axes(handles.axes1); imshow(handles.Result.Image); title('原图像');
    axes(handles.axes2); imshow(handles.Result.Bw); title('二值图像');
    axes(handles.axes3); imshow(handles.Result.BwFilter); title('二值图像滤波');
end
 
% --- Executes on button press in pushbuttonCrackRec.
function pushbuttonCrackRec_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonCrackRec (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
if ~isempty(handles.Result)
    axes(handles.axes1); imshow(handles.Result.Image); title('原图像');
    axes(handles.axes2); imshow(handles.Result.Bw); title('二值图像');
    axes(handles.axes3); imshow(handles.Result.BwFilter); title('二值图像滤波');
    axes(handles.axes4); imshow(handles.Result.CrackRec); title('裂缝识别');
end
 
 
% --- Executes on button press in pushbuttonCrackJudge.
function pushbuttonCrackJudge_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonCrackJudge (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
if ~isempty(handles.Result)
    axes(handles.axes1); imshow(handles.Result.Image); title('原图像');
    axes(handles.axes2); imshow(handles.Result.BwFilter); title('二值图像滤波');
    axes(handles.axes3); imshow(handles.Result.CrackRec); title('裂缝识别');
    axes(handles.axes4); imshow(handles.Result.CrackJudge); title('裂缝判断');
end
 
% --- Executes on button press in pushbuttonCrackLoc.
function pushbuttonCrackLoc_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonCrackLoc (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
if ~isempty(handles.Result)
    axes(handles.axes1); imshow(handles.Result.Image); title('原图像');
    axes(handles.axes2); imshow(handles.Result.CrackJudge); title('裂缝图像');
    axes(handles.axes3); imshow(handles.Result.CrackJudge); title(handles.Result.str);
    axes(handles.axes4); imshow(handles.Result.CrackJudge); title('裂缝标记图像');
    hold on;
    rectangle('Position', handles.Result.rect, 'EdgeColor', 'g', 'LineWidth', 2);
    hold off;
end
 
% --- Executes on button press in pushbuttonProject.
function pushbuttonProject_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonProject (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
if ~isempty(handles.Result)
    axes(handles.axes1); imshow(handles.Result.Image); title('原图像');
    axes(handles.axes2); imshow(handles.Result.CrackJudge); title('裂缝图像');
    axes(handles.axes3); plot(1:size(handles.Result.Image, 1), handles.Result.Projectr);
    title('行投影');
    axes(handles.axes4); plot(1:size(handles.Result.Image, 2), handles.Result.Projectc);
    title('列投影');
end
 
 
% --- Executes on button press in pushbuttonClose.
function pushbuttonClose_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonClose (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
choice = questdlg('确定退出?', ...
    '退出', ...
    '是','否','否');
switch choice
    case '是'
        close;
    otherwise
        return;
end
 
 
 
% --- Executes on button press in pushbuttonSaveResult.
function pushbuttonSaveResult_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonSaveResult (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
try
    if ~isempty(handles.File)
        raw = [];
        xlsfile = fullfile(pwd, 'Result/result.xls');
        if exist(xlsfile, 'file')
            [num, txt, raw] = xlsread(xlsfile);
        end
        
        F = [];
        F{1, 1} = '文件名';
        F{1, 2} = '阈值信息';
        F{1, 3} = '面积信息';
        F{1, 4} = '长度信息';
        F{1, 5} = '最大宽度信息';
        F{1, 6} = '最小宽度信息';
        F{1, 7} = '形状信息';
        
        F{2, 1} = handles.File;
        F{2, 2} = handles.Result.BwTh;
        F{2, 3} = handles.Result.BwArea;
        F{2, 4} = handles.Result.BwLength;
        F{2, 5} = handles.Result.BwWidthMax;
        F{2, 6} = max(handles.Result.BwWidthMin,0.01);
        F{2, 7} = handles.Result.str;
        
        F = [raw; F];
        xlswrite(xlsfile, F);
        
        msgbox('保存结果成功!', '信息提示框');
    end
catch
    msgbox('保存结果失败,请检查程序!', '信息提示框');
end
 
 
% --- Executes on button press in pushbuttonBridge.
function pushbuttonBridge_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonBridge (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
if ~isempty(handles.Result)
    axes(handles.axes1); imshow(handles.Result.Image); title('原图像');
    axes(handles.axes2); imshow(handles.Result.BwFilter); title('二值图像滤波');
    axes(handles.axes3); imshow(handles.Result.CrackJudge); title('裂缝判断');
    axes(handles.axes4); imshow(handles.Result.CrackBridge); title('裂缝拼接');
end
 
 
% --- Executes on button press in pushbuttonSaveImage.
function pushbuttonSaveImage_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonSaveImage (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
[filename, pathname] = uiputfile({'*.jpg;*.tif;*.png;*.gif','All Image Files';...
    '*.*','All Files' },'Save Image',...
    fullfile(pwd, 'Result/result.png'));
if ~isequal(filename, 0)
    imwrite(handles.Result.BwEnd, fullfile(pathname, filename));
    msgbox('保存图像成功!', '信息提示框');
end
 
 
% --- Executes on button press in pushbuttonDiplay.
function pushbuttonDiplay_Callback(hObject, eventdata, handles)
% hObject    handle to pushbuttonDiplay (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
if ~isempty(handles.File)
    F = [];
    F{1} = sprintf('文件名:%s', handles.File);
    F{2} = sprintf('阈值信息%.2f', handles.Result.BwTh);
    F{3} = sprintf('面积信息%.2f', handles.Result.BwArea);
    F{4} = sprintf('长度信息%.2f', handles.Result.BwLength);
    F{5} = sprintf('最大宽度信息%.2f', handles.Result.BwWidthMax);
    F{6} = sprintf('最小宽度信息%.2f', max(handles.Result.BwWidthMin,0.01));
    F{7} = sprintf('形状信息%s', handles.Result.str);
    listdlg('PromptString', '参数显示:',...
        'Name', '参数信息', ...
        'ListSize', [300, 150], ...
        'SelectionMode','single',...
        'ListString', F);
end

三、运行结果

【裂缝识别】基于matlab GUI路面裂缝识别【含Matlab源码 009期】_其他_08

四、matlab版本及参考文献

1 matlab版本
2014a

2 参考文献
[1] 蔡利梅.MATLAB图像处理——理论、算法与实例分析[M].清华大学出版社,2020.
[2]杨丹,赵海滨,龙哲.MATLAB图像处理实例详解[M].清华大学出版社,2013.
[3]周品.MATLAB图像处理与图形用户界面设计[M].清华大学出版社,2013.
[4]刘成龙.精通MATLAB图像处理[M].清华大学出版社,2015.