gusucode.com > 声音的处理有:LPC,FFT,共振峰,频谱源码程序 > siganlandsystemusingMatlab/SSUM/spectrum/image/imgspectrumexpogui.m
function varargout = imgspectrumexpogui(varargin) % IMGSPECTRUMEXPOGUI M-file for imgspectrumexpogui.fig % IMGSPECTRUMEXPOGUI, by itself, creates a new IMGSPECTRUMEXPOGUI or raises the existing % singleton*. % % H = IMGSPECTRUMEXPOGUI returns the handle to a new IMGSPECTRUMEXPOGUI or the handle to % the existing singleton*. % % IMGSPECTRUMEXPOGUI('CALLBACK',hObject,eventData,handles,...) calls the local % function named CALLBACK in IMGSPECTRUMEXPOGUI.M with the given input arguments. % % IMGSPECTRUMEXPOGUI('Property','Value',...) creates a new IMGSPECTRUMEXPOGUI or raises the % existing singleton*. Starting from the left, property value pairs are % applied to the GUI before imgspectrumexpogui_OpeningFunction gets called. An % unrecognized property name or invalid value makes property application % stop. All inputs are passed to imgspectrumexpogui_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 imgspectrumexpogui % Last Modified by GUIDE v2.5 14-Aug-2004 13:35:55 % Begin initialization code - DO NOT EDIT gui_Singleton = 1; gui_State = struct('gui_Name', mfilename, ... 'gui_Singleton', gui_Singleton, ... 'gui_OpeningFcn', @imgspectrumexpogui_OpeningFcn, ... 'gui_OutputFcn', @imgspectrumexpogui_OutputFcn, ... 'gui_LayoutFcn', @imgspectrumexpogui_LayoutFcn, ... 'gui_Callback', []); if nargin & isstr(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 imgspectrumexpogui is made visible. function imgspectrumexpogui_OpeningFcn(hObject, eventdata, handles, varargin) handles.output = hObject; guidata(hObject, handles); set(gcf,'UserData',handles); imgspectrumexpofn; if (nargin > 3) datastruct = varargin{1}; imgspectrumexpofn('readinput',datastruct); end % --- Outputs from this function are returned to the command line. function varargout = imgspectrumexpogui_OutputFcn(hObject, eventdata, handles) varargout{1} = handles.output; % -------------------------------------------------------------------- function FileMenu_Callback(hObject, eventdata, handles) % -------------------------------------------------------------------- function OpenMenuItem_Callback(hObject, eventdata, handles) imgspectrumexpofn 'load'; % -------------------------------------------------------------------- function PrintMenuItem_Callback(hObject, eventdata, handles) imgspectrumexpofn 'print'; % -------------------------------------------------------------------- function CloseMenuItem_Callback(hObject, eventdata, handles) imgspectrumexpofn 'close'; % --- Executes on button press in inverse. function inverse_Callback(hObject, eventdata, handles) imgspectrumexpofn 'inverse'; % --- Executes on button press in print. function print_Callback(hObject, eventdata, handles) imgspectrumexpofn 'print'; % --- Executes on button press in scale. function scale_Callback(hObject, eventdata, handles) imgspectrumexpofn 'scale'; % --- Executes on button press in zoomreset. function zoomreset_Callback(hObject, eventdata, handles) imgspectrumexpofn 'zoom_reset'; % --- Executes on button press in horizontal. function horizontal_Callback(hObject, eventdata, handles) set(handles.vertical,'Value',0); set(handles.kernel,'Value',0); % --- Executes on button press in vertical. function vertical_Callback(hObject, eventdata, handles) set(handles.horizontal,'Value',0); set(handles.kernel,'Value',0); % --- Executes on button press in kernel. function kernel_Callback(hObject, eventdata, handles) set(handles.horizontal,'Value',0); set(handles.vertical,'Value',0); % --- Executes during object creation, after setting all properties. function colormap_CreateFcn(hObject, eventdata, handles) % hObject handle to colormap (see GCBO) % eventdata reserved - to be defined in a future version of MATLAB % handles empty - handles not created until after all CreateFcns called % Hint: popupmenu controls usually have a white background on Windows. % See ISPC and COMPUTER. if ispc set(hObject,'BackgroundColor','white'); else set(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor')); end % --- Executes on selection change in colormap. function colormap_Callback(hObject, eventdata, handles) % hObject handle to colormap (see GCBO) % eventdata reserved - to be defined in a future version of MATLAB % handles structure with handles and user data (see GUIDATA) % Hints: contents = get(hObject,'String') returns colormap contents as cell array % contents{get(hObject,'Value')} returns selected item from colormap imgspectrumexpofn 'colormap'; % --- Executes on button press in inversecolor. function inversecolor_Callback(hObject, eventdata, handles) % hObject handle to inversecolor (see GCBO) % eventdata reserved - to be defined in a future version of MATLAB % handles structure with handles and user data (see GUIDATA) % Hint: get(hObject,'Value') returns toggle state of inversecolor imgspectrumexpofn 'inversecolor'; % --- Executes during object creation, after setting all properties. function drawmenu_CreateFcn(hObject, eventdata, handles) % hObject handle to drawmenu (see GCBO) % eventdata reserved - to be defined in a future version of MATLAB % handles empty - handles not created until after all CreateFcns called % Hint: popupmenu controls usually have a white background on Windows. % See ISPC and COMPUTER. if ispc set(hObject,'BackgroundColor','white'); else set(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor')); end % --- Executes on selection change in drawmenu. function drawmenu_Callback(hObject, eventdata, handles) imgspectrumexpofn 'drawmenu'; % -------------------------------------------------------------------- function help_Callback(hObject, eventdata, handles) % hObject handle to help (see GCBO) % eventdata reserved - to be defined in a future version of MATLAB % handles structure with handles and user data (see GUIDATA) imgspectrumexpofn 'help'; % -------------------------------------------------------------------- function Untitled_1_Callback(hObject, eventdata, handles) % hObject handle to Untitled_1 (see GCBO) % eventdata reserved - to be defined in a future version of MATLAB % handles structure with handles and user data (see GUIDATA) % -------------------------------------------------------------------- function imgfilterexpo_Callback(hObject, eventdata, handles) % hObject handle to imgfilterexpo (see GCBO) % eventdata reserved - to be defined in a future version of MATLAB % handles structure with handles and user data (see GUIDATA) imgspectrumexpofn 'imgfilterexpo'; % -------------------------------------------------------------------- function imgaliasexpo_Callback(hObject, eventdata, handles) % hObject handle to imgaliasexpo (see GCBO) % eventdata reserved - to be defined in a future version of MATLAB % handles structure with handles and user data (see GUIDATA) imgspectrumexpofn 'imgaliasexpo'; % --- Creates and returns a handle to the GUI figure. function h1 = imgspectrumexpogui_LayoutFcn(policy) % policy - create a new figure or use a singleton. 'new' or 'reuse'. persistent hsingleton; if strcmpi(policy, 'reuse') & ishandle(hsingleton) h1 = hsingleton; return; end h1 = figure(... 'Units','characters',... 'Color',[0.925490196078431 0.913725490196078 0.847058823529412],... 'Colormap',[0 0 0.5625;0 0 0.625;0 0 0.6875;0 0 0.75;0 0 0.8125;0 0 0.875;0 0 0.9375;0 0 1;0 0.0625 1;0 0.125 1;0 0.1875 1;0 0.25 1;0 0.3125 1;0 0.375 1;0 0.4375 1;0 0.5 1;0 0.5625 1;0 0.625 1;0 0.6875 1;0 0.75 1;0 0.8125 1;0 0.875 1;0 0.9375 1;0 1 1;0.0625 1 1;0.125 1 0.9375;0.1875 1 0.875;0.25 1 0.8125;0.3125 1 0.75;0.375 1 0.6875;0.4375 1 0.625;0.5 1 0.5625;0.5625 1 0.5;0.625 1 0.4375;0.6875 1 0.375;0.75 1 0.3125;0.8125 1 0.25;0.875 1 0.1875;0.9375 1 0.125;1 1 0.0625;1 1 0;1 0.9375 0;1 0.875 0;1 0.8125 0;1 0.75 0;1 0.6875 0;1 0.625 0;1 0.5625 0;1 0.5 0;1 0.4375 0;1 0.375 0;1 0.3125 0;1 0.25 0;1 0.1875 0;1 0.125 0;1 0.0625 0;1 0 0;0.9375 0 0;0.875 0 0;0.8125 0 0;0.75 0 0;0.6875 0 0;0.625 0 0;0.5625 0 0],... 'DoubleBuffer','on',... 'IntegerHandle','off',... 'InvertHardcopy',get(0,'defaultfigureInvertHardcopy'),... 'MenuBar','none',... 'Name','imgspectrumexpo',... 'NumberTitle','off',... 'PaperPosition',get(0,'defaultfigurePaperPosition'),... 'Pointer','crosshair',... 'Position',[128.6 21.3846153846154 92.8 52.3846153846154],... 'Renderer',get(0,'defaultfigureRenderer'),... 'RendererMode','manual',... 'HandleVisibility','callback',... 'Tag','imgspectrumexpo_fig',... 'UserData',zeros(1,0)); setappdata(h1, 'GUIDEOptions', struct(... 'active_h', [], ... 'taginfo', struct(... 'figure', 2, ... 'axes', 9, ... 'pushbutton', 15, ... 'popupmenu', 11, ... 'listbox', 2, ... 'text', 20, ... 'slider', 2, ... 'checkbox', 6, ... 'radiobutton', 8, ... 'frame', 3, ... 'edit', 8), ... 'override', 1, ... 'release', 13, ... 'resize', 'simple', ... 'accessibility', 'callback', ... 'mfile', 1, ... 'callbacks', 1, ... 'singleton', 1, ... 'syscolorfig', 1, ... 'lastSavedFile', 'C:\Documents and Settings\Bob\Desktop\SSUM_WIN\spectrum\image\imgspectrumexpo.m', ... 'blocking', 0)); h2 = uimenu(... 'Parent',h1,... 'Callback','imgspectrumexpogui(''FileMenu_Callback'',gcbo,[],guidata(gcbo))',... 'Label','File',... 'Tag','FileMenu'); h3 = uimenu(... 'Parent',h2,... 'Callback','imgspectrumexpogui(''OpenMenuItem_Callback'',gcbo,[],guidata(gcbo))',... 'Label','Open Image',... 'Tag','open'); h4 = uimenu(... 'Parent',h2,... 'Callback','imgspectrumexpogui(''print_Callback'',gcbo,[],guidata(gcbo))',... 'Label','Print',... 'Tag','print'); h5 = uimenu(... 'Parent',h2,... 'Callback','imgspectrumexpogui(''CloseMenuItem_Callback'',gcbo,[],guidata(gcbo))',... 'Label','Close',... 'Separator','on',... 'Tag','CloseMenuItem'); h6 = uicontrol(... 'Parent',h1,... 'Units','characters',... 'Callback','imgspectrumexpogui(''inverse_Callback'',gcbo,[],guidata(gcbo))',... 'FontName','default',... 'ListboxTop',0,... 'Position',[63.4 0.230769230769231 11 1.46153846153846],... 'String','Inverse',... 'Style','checkbox',... 'Tag','inverse'); h7 = uicontrol(... 'Parent',h1,... 'Units','characters',... 'Callback','imgspectrumexpogui(''scale_Callback'',gcbo,[],guidata(gcbo))',... 'FontName','default',... 'ListboxTop',0,... 'Position',[79.6 0.230769230769231 11 1.46153846153846],... 'String','Scale',... 'Style','checkbox',... 'Value',1,... 'Tag','scale'); h8 = axes(... 'Parent',h1,... 'Units','characters',... 'CameraPosition',[0.5 0.5 9.16025403784439],... 'CameraPositionMode',get(0,'defaultaxesCameraPositionMode'),... 'Color',get(0,'defaultaxesColor'),... 'ColorOrder',get(0,'defaultaxesColorOrder'),... 'DrawMode','fast',... 'FontName','default',... 'Position',[9.8 13.1538461538462 81 8],... 'XColor',get(0,'defaultaxesXColor'),... 'YColor',get(0,'defaultaxesYColor'),... 'ZColor',get(0,'defaultaxesZColor'),... 'Tag','horizontal_spectrum'); h9 = get(h8,'title'); set(h9,... 'Parent',h8,... 'Color',[0 0 0],... 'HorizontalAlignment','center',... 'Position',[0.498958333333333 1.046875 1.00005459937205],... 'VerticalAlignment','bottom',... 'HandleVisibility','off'); h10 = get(h8,'xlabel'); set(h10,... 'Parent',h8,... 'Color',[0 0 0],... 'HorizontalAlignment','center',... 'Position',[0.498958333333333 -0.213541666666667 1.00005459937205],... 'VerticalAlignment','cap',... 'HandleVisibility','off'); h11 = get(h8,'ylabel'); set(h11,... 'Parent',h8,... 'Color',[0 0 0],... 'HorizontalAlignment','center',... 'Position',[-0.0489583333333333 0.484375 1.00005459937205],... 'Rotation',90,... 'VerticalAlignment','bottom',... 'HandleVisibility','off'); h12 = get(h8,'zlabel'); set(h12,... 'Parent',h8,... 'Color',[0 0 0],... 'HorizontalAlignment','right',... 'Position',[-0.144791666666667 5.69270833333333 1.00005459937205],... 'HandleVisibility','off',... 'Visible','off'); h13 = axes(... 'Parent',h1,... 'Units','characters',... 'CameraPosition',[0.5 0.5 9.16025403784439],... 'CameraPositionMode',get(0,'defaultaxesCameraPositionMode'),... 'Color',get(0,'defaultaxesColor'),... 'ColorOrder',get(0,'defaultaxesColorOrder'),... 'DrawMode','fast',... 'FontName','default',... 'Position',[9.8 3.46153846153846 81 8],... 'XColor',get(0,'defaultaxesXColor'),... 'YColor',get(0,'defaultaxesYColor'),... 'ZColor',get(0,'defaultaxesZColor'),... 'Tag','vertical_spectrum'); h14 = get(h13,'title'); set(h14,... 'Parent',h13,... 'Color',[0 0 0],... 'HorizontalAlignment','center',... 'Position',[0.498958333333333 1.046875 1.00005459937205],... 'VerticalAlignment','bottom',... 'HandleVisibility','off'); h15 = get(h13,'xlabel'); set(h15,... 'Parent',h13,... 'Color',[0 0 0],... 'HorizontalAlignment','center',... 'Position',[0.498958333333333 -0.213541666666667 1.00005459937205],... 'VerticalAlignment','cap',... 'HandleVisibility','off'); h16 = get(h13,'ylabel'); set(h16,... 'Parent',h13,... 'Color',[0 0 0],... 'HorizontalAlignment','center',... 'Position',[-0.0489583333333333 0.484375 1.00005459937205],... 'Rotation',90,... 'VerticalAlignment','bottom',... 'HandleVisibility','off'); h17 = get(h13,'zlabel'); set(h17,... 'Parent',h13,... 'Color',[0 0 0],... 'HorizontalAlignment','right',... 'Position',[-0.142708333333333 6.90104166666667 1.00005459937205],... 'HandleVisibility','off',... 'Visible','off'); h18 = axes(... 'Parent',h1,... 'Units','characters',... 'CameraPosition',[0.5 0.5 9.16025403784439],... 'CameraPositionMode',get(0,'defaultaxesCameraPositionMode'),... 'Color',get(0,'defaultaxesColor'),... 'ColorOrder',get(0,'defaultaxesColorOrder'),... 'FontName','default',... 'Position',[9.8 25.5384615384615 81 25],... 'XColor',get(0,'defaultaxesXColor'),... 'YColor',get(0,'defaultaxesYColor'),... 'ZColor',get(0,'defaultaxesZColor'),... 'Tag','spectrum'); h19 = get(h18,'title'); set(h19,... 'Parent',h18,... 'Color',[0 0 0],... 'HorizontalAlignment','center',... 'Position',[0.498958333333333 1.01527777777778 1.00005459937205],... 'VerticalAlignment','bottom',... 'HandleVisibility','off'); h20 = get(h18,'xlabel'); set(h20,... 'Parent',h18,... 'Color',[0 0 0],... 'HorizontalAlignment','center',... 'Position',[0.498958333333333 -0.0569444444444445 1.00005459937205],... 'VerticalAlignment','cap',... 'HandleVisibility','off'); h21 = get(h18,'ylabel'); set(h21,... 'Parent',h18,... 'Color',[0 0 0],... 'HorizontalAlignment','center',... 'Position',[-0.0489583333333333 0.495833333333333 1.00005459937205],... 'Rotation',90,... 'VerticalAlignment','bottom',... 'HandleVisibility','off'); h22 = get(h18,'zlabel'); set(h22,... 'Parent',h18,... 'Color',[0 0 0],... 'HorizontalAlignment','right',... 'Position',[-0.144791666666667 1.02638888888889 1.00005459937205],... 'HandleVisibility','off',... 'Visible','off'); h23 = uicontrol(... 'Parent',h1,... 'Units','characters',... 'FontName','default',... 'FontSize',12,... 'HorizontalAlignment','left',... 'ListboxTop',0,... 'Position',[30.6 22.1538461538462 14.6 1.69230769230769],... 'String','Colormap',... 'Style','text',... 'Tag','text15'); h24 = uicontrol(... 'Parent',h1,... 'Units','characters',... 'BackgroundColor',[1 1 1],... 'Callback','imgspectrumexpogui(''colormap_Callback'',gcbo,[],guidata(gcbo))',... 'FontName','default',... 'ListboxTop',0,... 'Position',[46 22.3846153846154 13.8 1.46153846153846],... 'String',{ 'Jet' 'Bone' 'HSV' 'Gray' 'Hot' 'Cool' 'Prism' },... 'Style','popupmenu',... 'Value',1,... 'CreateFcn','imgspectrumexpogui(''colormap_CreateFcn'',gcbo,[],guidata(gcbo))',... 'Tag','colormap'); h25 = uicontrol(... 'Parent',h1,... 'Units','characters',... 'Callback','imgspectrumexpogui(''inversecolor_Callback'',gcbo,[],guidata(gcbo))',... 'FontName','default',... 'ListboxTop',0,... 'Position',[62.6 22.3846153846154 12 1.46153846153846],... 'String','Inverse',... 'Style','checkbox',... 'Tag','inversecolor'); h26 = uicontrol(... 'Parent',h1,... 'Units','characters',... 'FontName','default',... 'FontSize',12,... 'HorizontalAlignment','left',... 'ListboxTop',0,... 'Position',[10.4 21.3076923076923 17 1.53846153846154],... 'String','Horizontal',... 'Style','text',... 'Tag','text16'); h27 = uicontrol(... 'Parent',h1,... 'Units','characters',... 'FontName','default',... 'FontSize',12,... 'HorizontalAlignment','left',... 'ListboxTop',0,... 'Position',[10.4 0.384615384615385 15.8 1.53846153846154],... 'String','Vertical',... 'Style','text',... 'Tag','text17'); h28 = uicontrol(... 'Parent',h1,... 'Units','characters',... 'BackgroundColor',[1 1 1],... 'Callback','imgspectrumexpogui(''drawmenu_Callback'',gcbo,[],guidata(gcbo))',... 'FontName','default',... 'ListboxTop',0,... 'Position',[77 21.6153846153846 14 1.46153846153846],... 'String',{ 'Spectrum' 'Values' },... 'Style','popupmenu',... 'Value',1,... 'CreateFcn','imgspectrumexpogui(''drawmenu_CreateFcn'',gcbo,[],guidata(gcbo))',... 'Tag','drawmenu'); h29 = uimenu(... 'Parent',h1,... 'Callback','imgspectrumexpogui(''Untitled_1_Callback'',gcbo,[],guidata(gcbo))',... 'Label','Send to...',... 'Tag','Untitled_1'); h30 = uimenu(... 'Parent',h29,... 'Callback','imgspectrumexpogui(''imgfilterexpo_Callback'',gcbo,[],guidata(gcbo))',... 'Label','Image Filter Explorer',... 'Tag','imgfilterexpo'); h31 = uimenu(... 'Parent',h29,... 'Callback','imgspectrumexpogui(''imgaliasexpo_Callback'',gcbo,[],guidata(gcbo))',... 'Label','Image Aliasing Explorer',... 'Tag','imgaliasexpo'); h32 = uicontrol(... 'Parent',h1,... 'Units','characters',... 'FontName','default',... 'FontSize',12,... 'HorizontalAlignment','left',... 'ListboxTop',0,... 'Position',[24.8 56.7692307692308 57 1.61538461538462],... 'String','Two-Dimenesional Fourier Transform',... 'Style','text',... 'Tag','text18'); h33 = uimenu(... 'Parent',h1,... 'Callback','imgspectrumexpogui(''help_Callback'',gcbo,[],guidata(gcbo))',... 'Label','Help',... 'Tag','help'); h34 = uicontrol(... 'Parent',h1,... 'Units','characters',... 'FontName','default',... 'FontSize',12,... 'HorizontalAlignment','left',... 'ListboxTop',0,... 'Position',[23.2 50.6923076923077 54.4 1.53846153846154],... 'String','Two-Dimensional Fourier Transform',... 'Style','text',... 'Tag','text19'); hsingleton = h1; % --- Handles default GUIDE GUI creation and callback dispatch function varargout = gui_mainfcn(gui_State, varargin) % GUI_MAINFCN provides these command line APIs for dealing with GUIs % % IMGSPECTRUMEXPOGUI, by itself, creates a new IMGSPECTRUMEXPOGUI or raises the existing % singleton*. % % H = IMGSPECTRUMEXPOGUI returns the handle to a new IMGSPECTRUMEXPOGUI or the handle to % the existing singleton*. % % IMGSPECTRUMEXPOGUI('CALLBACK',hObject,eventData,handles,...) calls the local % function named CALLBACK in IMGSPECTRUMEXPOGUI.M with the given input arguments. % % IMGSPECTRUMEXPOGUI('Property','Value',...) creates a new IMGSPECTRUMEXPOGUI or raises the % existing singleton*. Starting from the left, property value pairs are % applied to the GUI before untitled_OpeningFunction gets called. An % unrecognized property name or invalid value makes property application % stop. All inputs are passed to untitled_OpeningFcn via varargin. % % *See GUI Options on GUIDE's Tools menu. Choose "GUI allows only one % instance to run (singleton)". % Copyright 1984-2002 The MathWorks, Inc. % $Revision: 1.4 $ $Date: 2002/05/31 21:44:31 $ gui_StateFields = {'gui_Name' 'gui_Singleton' 'gui_OpeningFcn' 'gui_OutputFcn' 'gui_LayoutFcn' 'gui_Callback'}; gui_Mfile = ''; for i=1:length(gui_StateFields) if ~isfield(gui_State, gui_StateFields{i}) error('Could not find field %s in the gui_State struct in GUI M-file %s', gui_StateFields{i}, gui_Mfile); elseif isequal(gui_StateFields{i}, 'gui_Name') gui_Mfile = [getfield(gui_State, gui_StateFields{i}), '.m']; end end numargin = length(varargin); if numargin == 0 % IMGSPECTRUMEXPOGUI % create the GUI gui_Create = 1; elseif numargin > 3 & ischar(varargin{1}) & ishandle(varargin{2}) % IMGSPECTRUMEXPOGUI('CALLBACK',hObject,eventData,handles,...) gui_Create = 0; else % IMGSPECTRUMEXPOGUI(...) % create the GUI and hand varargin to the openingfcn gui_Create = 1; end if gui_Create == 0 varargin{1} = gui_State.gui_Callback; if nargout [varargout{1:nargout}] = feval(varargin{:}); else feval(varargin{:}); end else if gui_State.gui_Singleton gui_SingletonOpt = 'reuse'; else gui_SingletonOpt = 'new'; end % Open fig file with stored settings. Note: This executes all component % specific CreateFunctions with an empty HANDLES structure. % Do feval on layout code in m-file if it exists if ~isempty(gui_State.gui_LayoutFcn) gui_hFigure = feval(gui_State.gui_LayoutFcn, gui_SingletonOpt); else gui_hFigure = local_openfig(gui_State.gui_Name, gui_SingletonOpt); % If the figure has InGUIInitialization it was not completely created % on the last pass. Delete this handle and try again. if isappdata(gui_hFigure, 'InGUIInitialization') delete(gui_hFigure); gui_hFigure = local_openfig(gui_State.gui_Name, gui_SingletonOpt); end end % Set flag to indicate starting GUI initialization setappdata(gui_hFigure,'InGUIInitialization',1); % Fetch GUIDE Application options gui_Options = getappdata(gui_hFigure,'GUIDEOptions'); if ~isappdata(gui_hFigure,'GUIOnScreen') % Adjust background color if gui_Options.syscolorfig set(gui_hFigure,'Color', get(0,'DefaultUicontrolBackgroundColor')); end % Generate HANDLES structure and store with GUIDATA guidata(gui_hFigure, guihandles(gui_hFigure)); end % If user specified 'Visible','off' in p/v pairs, don't make the figure % visible. gui_MakeVisible = 1; for ind=1:2:length(varargin) if length(varargin) == ind break; end len1 = min(length('visible'),length(varargin{ind})); len2 = min(length('off'),length(varargin{ind+1})); if ischar(varargin{ind}) & ischar(varargin{ind+1}) & ... strncmpi(varargin{ind},'visible',len1) & len2 > 1 if strncmpi(varargin{ind+1},'off',len2) gui_MakeVisible = 0; elseif strncmpi(varargin{ind+1},'on',len2) gui_MakeVisible = 1; end end end % Check for figure param value pairs for index=1:2:length(varargin) if length(varargin) == index break; end try, set(gui_hFigure, varargin{index}, varargin{index+1}), catch, break, end end % If handle visibility is set to 'callback', turn it on until finished % with OpeningFcn gui_HandleVisibility = get(gui_hFigure,'HandleVisibility'); if strcmp(gui_HandleVisibility, 'callback') set(gui_hFigure,'HandleVisibility', 'on'); end feval(gui_State.gui_OpeningFcn, gui_hFigure, [], guidata(gui_hFigure), varargin{:}); if ishandle(gui_hFigure) % Update handle visibility set(gui_hFigure,'HandleVisibility', gui_HandleVisibility); % Make figure visible if gui_MakeVisible set(gui_hFigure, 'Visible', 'on') if gui_Options.singleton setappdata(gui_hFigure,'GUIOnScreen', 1); end end % Done with GUI initialization rmappdata(gui_hFigure,'InGUIInitialization'); end % If handle visibility is set to 'callback', turn it on until finished with % OutputFcn if ishandle(gui_hFigure) gui_HandleVisibility = get(gui_hFigure,'HandleVisibility'); if strcmp(gui_HandleVisibility, 'callback') set(gui_hFigure,'HandleVisibility', 'on'); end gui_Handles = guidata(gui_hFigure); else gui_Handles = []; end if nargout [varargout{1:nargout}] = feval(gui_State.gui_OutputFcn, gui_hFigure, [], gui_Handles); else feval(gui_State.gui_OutputFcn, gui_hFigure, [], gui_Handles); end if ishandle(gui_hFigure) set(gui_hFigure,'HandleVisibility', gui_HandleVisibility); end end function gui_hFigure = local_openfig(name, singleton) if nargin('openfig') == 3 gui_hFigure = openfig(name, singleton, 'auto'); else % OPENFIG did not accept 3rd input argument until R13, % toggle default figure visible to prevent the figure % from showing up too soon. gui_OldDefaultVisible = get(0,'defaultFigureVisible'); set(0,'defaultFigureVisible','off'); gui_hFigure = openfig(name, singleton); set(0,'defaultFigureVisible',gui_OldDefaultVisible); end