Newer
Older
function error = headerForm(hTsgGUI)
%
% Input
% -----
% hTsgGUI ............ Handel to the main user interface
%
% Output
% ------
% error .............. 1: OK ; -1 : an error occured
% $Id$
error = -1;
% Get the data from the application GUI
% -------------------------------------

jacques.grelet_ird.fr
committed
tsg = getappdata(hTsgGUI, 'tsg_data');
% load platform mat file
% ----------------------
%load platform.mat;
% set default uicontrol size
% --------------------------
default_height = 0.03;
default_length = .15;
% Define uicontrol start position
% -------------------------------
left = .01;
bottom = .95;
inc_x = 3 * default_length;
inc_y = 0.01;

jacques.grelet_ird.fr
committed
% get actual date
% ---------------
date = datestr(now,30);
% Get global attributes list from class tsg_nc with file 'tsg_ncattr.csv'
% -----------------------------------------------------------------------
nca = tsg_nc('tsg_ncattr.csv');
nca_keys = keys(nca);
% set additionals variables, location may be change in the future
% ---------------------------------------------------------------
add_var = { 'SSPS_DEPH', 'SSPS_DEPH_MIN', 'SSPS_DEPH_MAX', ...
'SSTP_DEPH', 'SSTP_DEPH_MIN', 'SSTP_DEPH_MAX'};
% Load platform_info object from tsg_platform_info.csv
% ----------------------------------------------------
existPlatform(hTsgGUI);
platform_info = tsg_nc('tsg_platform.csv');
% header Uicontrols in a new figure
% ---------------------------------
hHeaderFig = figure(...
'BackingStore','off',...
'Name', 'TSG GLOBAL ATTRIBUTES', ...
'NumberTitle', 'off', ...
'Resize', 'on', ...
'Menubar','none', ...
'Toolbar', 'none', ...
'Tag', 'GLOBAL_ATTRIBUTES', ...
'Visible','on',...
'Units', 'normalized',...
'Position',get(hTsgGUI,'Position'), ...

jacques.grelet_ird.fr
committed
'Color', get(0, 'DefaultUIControlBackgroundColor'));

jacques.grelet_ird.fr
committed
% bg = [0.92549 0.913725 0.847059] = get(0, 'DefaultUIControlBackgroundColor');
% Iterate from each element from object nca and additional variables
% ------------------------------------------------------------------
for i = nca_keys

jacques.grelet_ird.fr
committed
% get key, use char because i is cell
% -----------------------------------
key = char(i);

jacques.grelet_ird.fr
committed
% get all structure for the key

jacques.grelet_ird.fr
committed
% -----------------------------

jacques.grelet_ird.fr
committed
% set tsg.DATE_UPDATE
% -------------------
if strcmp(key, 'DATE_UPDATE')
tsg.(key) = [date(1:8) date(10:15)];
end
% check for empty field and replace them by default value
% -------------------------------------------------------
% if isempty(s.length), s.length = default_length; end;
% if isempty(s.height), s.height = default_height; end;
s.length = default_length;
s.height = default_height;

jacques.grelet_ird.fr
committed
% display dynamically uicontrol text
% use of char function to prevent error when field is empty [] => ''
% ------------------------------------------------------------------
uicontrol(...
'Parent', hHeaderFig, ...
'Units', 'normalized', ...
'Style', 'Text', ...
'Fontsize', tsg.fontSize-1, ...
'HorizontalAlignment', 'left', ...
'Position',[left, bottom, s.length, s.height], ...
'TooltipString', char(s.comment), ...

jacques.grelet_ird.fr
committed
'String', char(s.name));
% display dynamically uicontrol
% -----------------------------
ui = uicontrol(...
'Parent', hHeaderFig, ...
'Units', 'normalized', ...
'BackgroundColor', 'w', ...
'Style', char(s.uicontrolType), ...
'Fontsize', tsg.fontSize-2, ...
'HorizontalAlignment', char(s.horizontalAlignment), ...
'Position', [left + s.length, bottom, s.length, s.height], ...
'String', char(s.string), ...
'Value', s.value, ...
'Tag', key);

jacques.grelet_ird.fr
committed
% display conventions field if exist
% ----------------------------------
uicontrol(...
'Parent', hHeaderFig, ...
'Units', 'normalized', ...
'Style', 'text', ...
'Fontsize', tsg.fontSize-2, ...

jacques.grelet_ird.fr
committed
'HorizontalAlignment', 'left', ...
'Position', [left + 2*s.length, bottom, s.length, s.height], ...

jacques.grelet_ird.fr
committed
'String', char(s.conventions));

jacques.grelet_ird.fr
committed
% set dynamically uicontrol from tsg struct
% -----------------------------------------
% for a popmenu control, set index position
% ---------------------------------
case 'popupmenu'
str = cellstr(get(ui,'String'));
ind = strfind(str,tsg.(key));
if ~isempty(ind{k})
set(ui, 'value', k);
end
end
% for edit control, set uicontrol with tsg.(key) value
% ----------------------------------------------------
set(ui, 'string', tsg.(key));
% for checkbox control, not yet implemented
% ------------------------------------------
case 'checkbox'
% not yet implemented !!!
end
% Check vertical position of last uicontrol and creation new colomn
% -----------------------------------------------------------------
bottom = bottom - inc_y - s.height;
if bottom < .1
bottom = 0.95;
left = left + inc_x;
end
end

jacques.grelet_ird.fr
committed
% additionnal variable here
% -------------------------
add_variables(bottom, left, s);

jacques.grelet_ird.fr
committed
% set a callback to PLATFORM_NAME uicontrol
% -----------------------------------------

jacques.grelet_ird.fr
committed
set(findobj('Tag', 'PLATFORM_NAME'), 'Callback', @updateForm);
% CONTINUE PUSH BUTTON
% --------------------
% The Continue (valid) button
uicontrol( ...
'Parent', hHeaderFig, ...
'Style','pushbutton',...
'Position',[.01, .01, .1, .04],...
'String','Continue',...
'Interruptible','off',...
'BusyAction','cancel',...
'Tag','PUSH_BUTTON',...
'Callback', @continueCallback);
% CANCEL PUSH BUTTON
% ------------------
% The cancel button
uicontrol( ...
'Parent', hHeaderFig, ...
'Style','pushbutton',...
'Position',[.2, .01, .1, .04],...
'String','Cancel',...
'Interruptible','off',...
'BusyAction','cancel',...
'Tag','PUSH_BUTTON',...
'Callback', @cancelCallback);
% Build structure container for graphic handles with tag property defined.
% ------------------------------------------------------------------------
data = guihandles(hHeaderFig);
% record data struct in application data object
% ---------------------------------------------
% stop execution until push-button Continue was press
% ---------------------------------------------------
uiwait(hHeaderFig);
%% Nested callback
% -----------------------------------------------------------------------
% Continue action, get uicontrol fields and populate tsg structure
% -----------------------------------------------------------------------
function continueCallback(obj, event)
% get the PLATFORM_NAME value, use tag to retrieve
% ------------------------------------------------
platform_name = get(findobj('Tag', 'PLATFORM_NAME'), 'string');
% get platform info structure from hashtable store in platform_info object
% ------------------------------------------------------------------------

jacques.grelet_ird.fr
committed
% get hashtable describing platform_info structure data type
% ----------------------------------------------------------
hdr = header(platform_info);
% Iterate from each element from object nca + additional variables
% ----------------------------------------------------------------
for ncak = nca_keys
% get key, use char for cell ncak
% ----------------------------
key = char(ncak);
% get all structure for the key, for additional variables, s = {}
% --------------------------------------------------------------
% get the corresponding string from uicontrol using guihandles
% data (dynamic)
% ------------------------------------------------------------
tsg.(key) = get(data.(key), 'string');
% if uicontrol is a popupmenu, string is cell array with all choices
% ------------------------------------------------------------------
if ~isempty(s) && strcmp(s.uicontrolType,'popupmenu')
% get the corresponding string from cell array using selected value
% ------------------------------------------------------------------
tsg.(key) = deblank(tsg.(key)(get(data.(key), 'value'),:));
% update p_i structure from tsg only with corresponding field
% -----------------------------------------------------------
if isfield(p_i, key)

jacques.grelet_ird.fr
committed
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
% get data type from platform_info structure
% ------------------------------------------
switch hdr.(key)
case 'char'
p_i.(key) = tsg.(key);
case 'byte'
p_i.(key) = int8(str2num(tsg.(key)));
case 'integer'
p_i.(key) = int16(str2num(tsg.(key)));
case 'float'
p_i.(key) = single(str2double(tsg.(key)));
case 'double'
p_i.(key) = str2double(tsg.(key));
otherwise
% by default, display a warning
% -----------------------------
warning('tsgqc:headerForm', ...
'unknow type ''%s'' for ''%s'' attribute.\nCheck your %s file', ...
hdr.(key), key, platform_info.file);
% and cast to char
% ----------------
p_i.(key) = tsg.(key);
end
% get additional variables from uicontrol and update tsg struct
% -------------------------------------------------------------
for kk = add_var
key = char(kk);
tsg.(key) = single(str2double(get(data.(key), 'string')));
p_i.(key) = tsg.(key);
end
% Save tsg structure

jacques.grelet_ird.fr
committed
setappdata(hTsgGUI, 'tsg_data', tsg);
% test if uicontrol not empty
% ---------------------------
warndlg({'PLATFORM NAME is empty';'';'Please, enter a valid PLATFORM name'},...
'Invalid PLATFORM name');
else
% Update plateform_info object with this PLATFORM_NAME value and
% platform info updated structure
% --------------------------------------------------------------
platform_info = set(platform_info, platform_name, p_i);
% save object in csv file
% -----------------------
save(platform_info);
% close windows (replace call to uiresume(hHeaderFig))
% ----------------------------------------------------
close(hHeaderFig);
% flushes the event queue and updates the figure window
% -----------------------------------------------------
drawnow;
% return with no error code (true)
% --------------------------------
error = 1;
return
end
% -----------------------------------------------------------------------
% Cancel button, no action
% -----------------------------------------------------------------------
function cancelCallback(obj, event)
% close windows
% -------------
close(hHeaderFig);
% flushes the event queue and updates the figure window
% -----------------------------------------------------
drawnow;
% return error code (no change)
% -----------------------------
error = -1;
% -----------------------------------------------------------------------
% Callback when uicontrol PLATFORM_NAME is modified
% -----------------------------------------------------------------------
function updateForm(obj, event)
% get the new value, use tag to retrieve
% --------------------------------------
platform_name = get(findobj('Tag', 'PLATFORM_NAME'), 'string');
% get platform info structure from hashtable store in platform_info object
% ------------------------------------------------------------------------

jacques.grelet_ird.fr
committed
% get hashtable describing platform_info structure data type
% ----------------------------------------------------------

jacques.grelet_ird.fr
committed
% if this platform exist, structure not empty
% -------------------------------------------
if ~isempty(p_i)

jacques.grelet_ird.fr
committed
% iterate on all members of platform_info structure, filenames return
% a cell array of string
% -------------------------------------------------------------------
for ii = fieldnames(p_i)

jacques.grelet_ird.fr
committed
% convert each cell to char
% -------------------------
key = char(ii);

jacques.grelet_ird.fr
committed
% update tsg with data from platform_info struct
% TODOS:
% may be add color test here
% ----------------------------------------------
tsg.(key) = p_i.(key);

jacques.grelet_ird.fr
committed
% get uicontrol style
% -------------------
type = get(data.(key), 'style');
% update headerform fields
% ------------------------
switch type
case 'edit'
set(data.(key), 'string', tsg.(key));
case 'popupmenu'
indice = strmatch(tsg.(key), get(data.(key), 'string'));
set(data.(key), 'value', indice);
end
% with different color
% --------------------

jacques.grelet_ird.fr
committed
set(findobj('Tag', key), 'foregroundColor', 'r');

jacques.grelet_ird.fr
committed
% if user enter a new PLATFORM_NAME, open a question dialog box for
% confirmation
% -----------------------------------------------------------------
questdlg(['PLATFORM NAME: ' platform_name ' is new. Do you want to use and save it ?'],...
'Create new PLATFORM NAME ?',...
'Yes', 'No', 'No');

jacques.grelet_ird.fr
committed
% if yes, continue, create and save new hash for PLATFORM_NAME in csv file
% ------------------------------------------------------------------------
if strcmp(selection, 'Yes')
return;

jacques.grelet_ird.fr
committed
% if not, reset field
% -------------------
else
set(findobj('Tag','PLATFORM_NAME'),'string', '');
end
end

jacques.grelet_ird.fr
committed

jacques.grelet_ird.fr
committed
% additionnal variable here
% -------------------------
function add_variables(bottom, left, s)
% get the PLATFORM_NAME value, use tag to retrieve
% ------------------------------------------------
platform_name = get(findobj('Tag', 'PLATFORM_NAME'), 'string');
% get platform info structure from hashtable store in platform_info object
% ------------------------------------------------------------------------
p_i = get(platform_info, platform_name);
% display dynamically uicontrol text over add_var list
% ----------------------------------------------------
for ad = add_var
key = char(ad);
uicontrol(...
'Parent', hHeaderFig, ...
'Units', 'normalized', ...
'Style', 'Text', ...
'Fontsize', tsg.fontSize-1, ...
'HorizontalAlignment', 'left', ...
'Position',[left, bottom, s.length, s.height], ...
'TooltipString', '', ...
ui = uicontrol(...
'Parent', hHeaderFig, ...
'Units', 'normalized', ...
'BackgroundColor', 'w', ...
'Style', 'edit', ...
'Fontsize', tsg.fontSize-2, ...
'HorizontalAlignment', 'right', ...
'Position', [left + s.length, bottom, s.length, s.height], ...
'String', '', ...
% Check vertical position of last uicontrol and creation new colomn
% -----------------------------------------------------------------
bottom = bottom - inc_y - s.height;
if bottom < .1
bottom = 0.95;
left = left + inc_x;
end
% update uicontrol from tsg structure or plateform_info
% -----------------------------------------------------
if isempty( tsg.(key) )
% get value from platform_info
% ----------------------------
if ~isempty(p_i)
set(ui, 'string', p_i.(key));
end
else
set(ui, 'string', tsg.(key));
end
end % end of add_variables nested function
end % end of headerForm