根据下面代码写一篇答辩稿function varargout = image_enhancement_gui(varargin) gui_Singleton = 1; gui_State = struct('gui_Name', mfilename, ... 'gui_Singleton', gui_Singleton, ... 'gui_OpeningFcn', @image_enhancement_gui_OpeningFcn, ... 'gui_OutputFcn', @image_enhancement_gui_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 function image_enhancement_gui_OpeningFcn(hObject, eventdata, handles, varargin) handles.output = hObject; guidata(hObject, handles); function varargout = image_enhancement_gui_OutputFcn(hObject, eventdata, handles) varargout{1} = handles.output; function open_btn_Callback(hObject, eventdata, handles) [filename, pathname] = uigetfile({'*.jpg;*.jpeg;*.png;*.bmp;*.tif;*.tiff', 'Image Files (*.jpg, *.jpeg, *.png, *.bmp, *.tif, *.tiff)'}, 'Select an image'); if isequal(filename, 0) || isequal(pathname, 0) return; end img = imread(fullfile(pathname, filename)); imshow(img, 'Parent', handles.axes1); handles.img = img; guidata(hObject, handles); function clahe_btn_Callback(hObject, eventdata, handles) img = handles.img; if isempty(img) warndlg('Please open an image first.', 'Warning'); return; end if size(img, 3) == 1 img_clahe = adapthisteq(img, 'ClipLimit', 0.02); else img_ycbcr = rgb2ycbcr(img); img_ycbcr(:,:,1) = adapthisteq(img_ycbcr(:,:,1), 'ClipLimit', 0.02); img_clahe = ycbcr2rgb(img_ycbcr); end imshow(img_clahe, 'Parent', handles.axes2); function close_btn_Callback(hObject, eventdata, handles) close(handles.figure1); function save_Callback(hObject, eventdata, handles) new_f_handle=figure('visible','off'); new_axes=copyobj(handles.axes2,new_f_handle); set(new_axes,'units','default','position','default'); [filename,pathname,fileindex]=uiputfile({'*.jpg';'*.bmp';'*.png'},'save picture as'); if ~filename return else file=strcat(pathname,filename); switch fileindex case 1 print(new_f_handle,'-djpeg',file); case 2 print(new_f_handle,'-dbmp',file); case 3 print(new_f_handle,'-dpng',file) end end delete(new_f_handle); function retinex_btn_Callback(hObject, eventdata, handles) if ~isfield(handles, 'img') msgbox('请先选择图像!', 'error'); return end im = handles.img; im_retinex = retinex(im); axes(handles.axes2); imshow(im_retinex); [pathname, filename, ext] = fileparts(s); imwrite(im_retinex, [pathname, filesep, 'retinex_', filename, ext]); handles.im_retinex = im_retinex; guidata(hObject, handles); function im_retinex = retinex(im) im_log = log(double(im) + 1); im_mean = mean2(im_log); im_retinex = exp(im_log - im_mean);