📄 iirexpogui.m
字号:
h34 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'FontSize',12,...
'HorizontalAlignment','right',...
'ListboxTop',0,...
'Position',[171.666666666667 33.75 10.1666666666667 1.75],...
'String','Order',...
'Style','text',...
'Tag','text11');
h35 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','iirexpogui(''plotfreqz_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[165.8 21.6923076923077 11.8 1.5],...
'String','Plot',...
'Tag','plotfreqz');
h36 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'BackgroundColor',[1 1 1],...
'Callback','iirexpogui(''fftdisplay_Callback'',gcbo,[],guidata(gcbo))',...
'Enable','inactive',...
'ListboxTop',0,...
'Position',[146.166666666667 11.5 17.5 1.5],...
'String',{ 'Sonogram' 'Waterfall' },...
'Style','popupmenu',...
'Value',1,...
'CreateFcn','iirexpogui(''fftdisplay_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','fftdisplay',...
'Visible','off');
h37 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'BackgroundColor',[1 1 1],...
'Callback','iirexpogui(''cut1_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[138.5 28.3333333333333 15 1.5],...
'String','1000',...
'Style','edit',...
'CreateFcn','iirexpogui(''cut1_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','cut1');
h38 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'BackgroundColor',[1 1 1],...
'Callback','iirexpogui(''cut2_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[157.166666666667 28.3333333333333 15 1.5],...
'String','5000',...
'Style','edit',...
'CreateFcn','iirexpogui(''cut2_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','cut2',...
'Visible','off');
h39 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'FontSize',10,...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[138.5 30 36.5 1.66666666666667],...
'String','Cutoff Frequencies (Hz)',...
'Style','text',...
'Tag','cutofftext');
h40 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','iirexpogui(''doFilter_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[139.8 21.6923076923077 11.8 1.5],...
'String','Apply',...
'Tag','doFilter');
h41 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','iirexpogui(''undo_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[153 21.6923076923077 11.8 1.5],...
'String','Undo',...
'Tag','undo');
h42 = uimenu(...
'Parent',h1,...
'Callback','iirexpogui(''Untitled_1_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Send Filter to...',...
'Tag','Untitled_1');
h43 = uimenu(...
'Parent',h42,...
'Callback','iirexpogui(''pzexpo_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Pole-Zero Explorer',...
'Tag','pzexpo');
h44 = uimenu(...
'Parent',h42,...
'Callback','iirexpogui(''pzfilterexpo_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Pole-Zero Filter Explorer',...
'Tag','pzfilterexpo');
h45 = uimenu(...
'Parent',h42,...
'Callback','iirexpogui(''convexpo_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Convolution Explorer',...
'Tag','convexpo');
h46 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[123.166666666667 6.66666666666667 9.66666666666667 1.25],...
'String','Filtered',...
'Style','text',...
'Tag','text13');
h47 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[136.666666666667 6.66666666666667 9.66666666666667 1.25],...
'String','Original',...
'Style','text',...
'Tag','text14');
h48 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'BackgroundColor',[0.9 0.9 0.9],...
'Callback','iirexpogui(''freqzoom_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[0.333333333333333 18.6666666666667 2.16666666666667 30.0833333333333],...
'String',{ '' },...
'Style','slider',...
'Value',1,...
'CreateFcn','iirexpogui(''freqzoom_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','freqzoom');
h49 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','iirexpogui(''zoomreset_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[148.6 5.15384615384615 13 1.5],...
'String','Zoom Reset',...
'Tag','zoomreset');
h50 = uimenu(...
'Parent',h1,...
'Callback','iirexpogui(''Untitled_2_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Send Data to...',...
'Tag','Untitled_2');
h51 = uimenu(...
'Parent',h50,...
'Callback','iirexpogui(''fourier_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Fourier Explorer',...
'Tag','fourier');
h52 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'Callback','iirexpogui(''normalize_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[123.166666666667 3 13 1.5],...
'String','Normalize',...
'Tag','normalize');
h53 = uimenu(...
'Parent',h1,...
'Callback','iirexpogui(''help_Callback'',gcbo,[],guidata(gcbo))',...
'Label','Help',...
'Tag','help');
h54 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'BackgroundColor',[1 1 1],...
'Callback','iirexpogui(''type_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[157.166666666667 32.0833333333333 16 1.5],...
'String',{ 'Butterworth' 'Elliptical' 'Chebyshev' },...
'Style','popupmenu',...
'Value',1,...
'CreateFcn','iirexpogui(''type_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','type');
h55 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'FontSize',12,...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[157.166666666667 33.5833333333333 17 2],...
'String','Type',...
'Style','text',...
'Tag','text15');
h56 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'FontSize',10,...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[138.5 25.9166666666667 22.8333333333333 1.58333333333333],...
'String','Peak-Peak Ripple (dB)',...
'Style','text',...
'Tag','text16');
h57 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'FontSize',10,...
'HorizontalAlignment','left',...
'ListboxTop',0,...
'Position',[161.333333333333 25.5833333333333 21.3333333333333 1.91666666666667],...
'String','Stop Attenuation (dB)',...
'Style','text',...
'Tag','text17');
h58 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'BackgroundColor',[1 1 1],...
'Callback','iirexpogui(''rp_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[138.5 24.4166666666667 15 1.5],...
'String','0.5',...
'Style','edit',...
'CreateFcn','iirexpogui(''rp_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','rp');
h59 = uicontrol(...
'Parent',h1,...
'Units','characters',...
'BackgroundColor',[1 1 1],...
'Callback','iirexpogui(''rs_Callback'',gcbo,[],guidata(gcbo))',...
'ListboxTop',0,...
'Position',[161.5 24.4166666666667 15 1.5],...
'String','20',...
'Style','edit',...
'CreateFcn','iirexpogui(''rs_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','rs',...
'Visible','off');
hsingleton = h1;
% --- Handles default GUIDE GUI creation and callback dispatchfunction varargout = gui_mainfcn(gui_State, varargin)
% GUI_MAINFCN provides these command line APIs for dealing with GUIs
%
% IIREXPOGUI, by itself, creates a new IIREXPOGUI or raises the existing
% singleton*.
%
% H = IIREXPOGUI returns the handle to a new IIREXPOGUI or the handle to
% the existing singleton*.
%
% IIREXPOGUI('CALLBACK',hObject,eventData,handles,...) calls the local
% function named CALLBACK in IIREXPOGUI.M with the given input arguments.
%
% IIREXPOGUI('Property','Value',...) creates a new IIREXPOGUI 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
% IIREXPOGUI
% create the GUI
gui_Create = 1;
elseif numargin > 3 & ischar(varargin{1}) & ishandle(varargin{2})
% IIREXPOGUI('CALLBACK',hObject,eventData,handles,...)
gui_Create = 0;
else
% IIREXPOGUI(...)
% 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
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -