Mercurial > hg > ltpda
view m-toolbox/m/gui/gltpda/g_AnnotationUpdate.m @ 46:ca0b8d4dcdb6 database-connection-manager
Fix
author | Daniele Nicolodi <nicolodi@science.unitn.it> |
---|---|
date | Tue, 06 Dec 2011 19:07:27 +0100 |
parents | f0afece42f48 |
children |
line wrap: on
line source
function g_AnnotationUpdate(paramlist,varargin) % Update the block annotation (the text below the block) with all the % current parameters global selBlocks paramEnabled annotation = ''; numparams = nparams(paramlist); firstpar = 1; if strcmpi(get_param(gcbh,'Tag'),'arithmetic') eq = get(findobj('Tag','equationField'),'String'); if ~isempty(eq) if numel(eq)>40, eq(1:end-25) = []; eq = ['...',eq]; end for nn=1:length(selBlocks) set_param(selBlocks(nn),'AttributesFormatString',eq); end end return end for kk=1:numparams if paramEnabled(kk) paramkey = paramlist.params(kk).key; try %#ok<ALIGN> if strcmpi(paramkey(1:7),'addPar_'), paramkey(1:7)=[]; end catch, end paramval = paramlist.params(kk).val; switch class(paramval) case 'specwin' windowName = paramval.type; windowlength = size(paramval.win,2); if firstpar==1 % it's the first parameter annotation = ['(specwin) ',windowName,',',num2str(windowlength)]; firstpar=2; else % it's not the first parameter annotation = [annotation,'\n','(specwin) ',windowName,',',num2str(windowlength)]; end if strcmp(windowName,'Kaiser') windowPsll = paramval.psll; annotation = [annotation,',',num2str(windowPsll)]; end case 'double' paramval = mat2str(paramval); if numel(paramval)>25, paramval=['...',paramval(end-25:end)]; end if firstpar==1, annotation=[lower(paramkey),' ',paramval]; firstpar=2; else annotation = [annotation,'\n',lower(paramkey),' ',num2str(paramval)]; end case 'char' if numel(paramval)>25, paramval=['...',paramval(end-25:end)]; end paramval = strrep(paramval,'''''',''''); if firstpar==1, annotation=[lower(paramkey),' ',paramval]; firstpar=2; else annotation = [annotation,'\n',lower(paramkey),' ',paramval]; end case 'logical' if paramval, paramval = 'true'; else paramval = 'false'; end if firstpar==1, annotation=[lower(paramkey),' ',paramval]; firstpar=2; else annotation = [annotation,'\n',lower(paramkey),' ',paramval]; end case 'pzmodel' if firstpar==1, annotation='(pzmodel)'; firstpar=2; else annotation = [annotation,'\n','(pzmodel)']; end case 'cell' if isa(paramval{1},'char') && strcmp(paramval{1},'(-->)'), strParKey = '(-->)'; else strParKey = utils.prog.cell2str(paramval); end if firstpar==1 annotation = [lower(paramkey),' ',strParKey]; firstpar=2; else annotation = [annotation,'\n',lower(paramkey),' ',strParKey]; end case 'pz' for mm=1:numel(paramval) poleFreqs(mm,1) = paramval(mm).f; poleQs(mm,1) = paramval(mm).q; if ~isnan(poleQs(mm,1)) poleFQs{mm,1}=strcat(num2str(poleFreqs(mm,1)),',',num2str(poleQs(mm,1))); else poleFQs{mm,1}=num2str(poleFreqs(mm,1)); end end poleFQs=char(poleFQs); if firstpar==1 annotation = ['pz ',poleFQs(1,:)]; firstpar=2; for j=2:size(poleFQs,1), annotation = [annotation,'\n','(pz) ',poleFQs(j,:)]; end else annotation = [annotation,'\n','pole ',poleFQs(1,:)]; for j=2:size(poleFQs,1), annotation = [annotation,'\n','(pz) ',poleFQs(j,:)]; end end end end end % Finally set the block annotation: for nn=1:length(selBlocks), set_param(selBlocks(nn),'AttributesFormatString',annotation); end end