source: trunk/src/uigetfile_uvmat.m @ 1022

Last change on this file since 1022 was 1022, checked in by sommeria, 6 years ago

opendap reading intreoduced

File size: 20.2 KB
RevLine 
[646]1%'uigetfile_uvmat': browser, and display of directories, faster than the Matlab fct uigetfile
[606]2%------------------------------------------------------------------------
[648]3% fileinput=uigetfile_uvmat(title,InputName,FilterExt)
[606]4%
5% OUTPUT:
[609]6% fileinput: detected file name, including path
[606]7%
8% INPUT:
[648]9% title: = displayed title,
10%        if title='status_display': display advancement of a series calculation,
11%        else uigetfile_uvmat used as browser.
12% InputName: initial file or directory selection for the browser
13% FilterExt: string to filter the file display:
14%          '*' (default) all files displayed
15%          'image': any image or movie
16%          '.ext': display only files with extension '.ext'
[651]17%          'uigetdir'; browser used to select a directory (like the matlab browser 'uigetdir')
[606]18
[809]19%=======================================================================
[977]20% Copyright 2008-2017, LEGI UMR 5519 / CNRS UGA G-INP, Grenoble, France
[809]21%   http://www.legi.grenoble-inp.fr
22%   Joel.Sommeria - Joel.Sommeria (A) legi.cnrs.fr
23%
24%     This file is part of the toolbox UVMAT.
25%
26%     UVMAT is free software; you can redistribute it and/or modify
27%     it under the terms of the GNU General Public License as published
28%     by the Free Software Foundation; either version 2 of the license,
29%     or (at your option) any later version.
30%
31%     UVMAT is distributed in the hope that it will be useful,
32%     but WITHOUT ANY WARRANTY; without even the implied warranty of
33%     MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
34%     GNU General Public License (see LICENSE.txt) for more details.
35%=======================================================================
36
[641]37function fileinput=uigetfile_uvmat(title,InputName,FilterExt)
38if ~exist('FilterExt','var')
39    FilterExt='*';
40end
[609]41fileinput=''; %default file selection
[610]42if strcmp(title,'status_display')
43    option='status_display';
[609]44else
45    option='browser';
[606]46end
[615]47InputDir=pwd;%look in the current work directory if the input file does not exist
48InputFileName='';%default
49if ischar(InputName)
[1022]50    if isempty(regexp(InputName,'^http://'))%usual files
51        if exist(InputName,'dir')
52            InputDir=InputName;
53            InputFileName='';
54        elseif exist(InputName,'file')
55            [InputDir,InputFileName,Ext]=fileparts(InputName);
56            if isempty(InputFileName)% if InputName is already the root
57                InputFileName=InputDir;
58                if  ~isempty(strcmp (computer, {'PCWIN','PCWIN64'}))%case of Windows systems
59                    %                 InputDir=[InputDir '\'];% append '\' for a correct action of dir
60                    InputFileName=[InputFileName '\'];
61                end
[615]62            end
[1022]63            if isdir(InputName)
64                InputFileName=['+/' InputFileName Ext];
65            end
[610]66        end
[1022]67        if  ismember(computer,{'PCWIN','PCWIN64'})%case of Windows systems
68            InputDir=[InputDir '\'];% append '\' for a correct action of dir
[615]69        end
[1022]70    else
71        [InputDir,InputFileName,Ext]=fileparts(InputName);
[610]72    end
[609]73end
[1022]74
[609]75hfig=findobj(allchild(0),'tag',option);
[606]76if isempty(hfig)
[609]77    set(0,'Unit','points')
[606]78    ScreenSize=get(0,'ScreenSize');% get the size of the screen, to put the fig on the upper right
[609]79    Width=350;% fig width in points (1/72 inch)
80    Height=min(0.8*ScreenSize(4),500);
[651]81    Left=ScreenSize(3)- Width-40; %right edge close to the right, with margin=40
[609]82    Bottom=ScreenSize(4)-Height-40; %put fig at top right
83    hfig=figure('name',option,'tag',option,'MenuBar','none','NumberTitle','off','Unit','points','Position',[Left,Bottom,Width,Height],'UserData',InputDir);
[611]84    BackgroundColor=get(hfig,'Color');
[651]85    path_title=uicontrol('Style','text','Units','normalized', 'Position', [0.02 0.97 0.9 0.03],'BackgroundColor',BackgroundColor,'Tag','Path_title',...
86        'String','path:','FontUnits','points','FontSize',12,'FontWeight','bold','ForegroundColor','blue','HorizontalAlignment','left');
87    htitlebox=uicontrol('Style','edit','Units','normalized', 'Position', [0.02 0.89 0.96 0.08],'tag','titlebox','Max',2,'BackgroundColor',[1 1 1],'Callback',@titlebox_Callback,...
88        'String',InputDir,'FontUnits','points','FontSize',12,'FontWeight','bold','TooltipString','''titlebox'':current path');
89    uicontrol('Style','pushbutton','Tag','backward','Units','normalized','Position',[0.02 0.77 0.1 0.05],...
90        'String','<--','FontWeight','bold','FontUnits','points','FontSize',12,'Callback',@backward,'TooltipString','move backward');
[653]91    home_button=uicontrol('Style','pushbutton','Units','normalized', 'Position', [0.14 0.77 0.2 0.05],...
92        'String','Work dir','FontWeight','bold','FontUnits','points','FontSize',12,'Callback',@home_dir,'TooltipString','reach the current Matlab working directory');
93    uicontrol('Style','pushbutton','Tag','refresh','Units','normalized','Position', [0.36 0.77 0.2 0.05],'Callback',@refresh_GUI,...
94        'String','Refresh','FontWeight','bold','FontUnits','points','FontSize',12);
95    uicontrol('Style','popupmenu','Units','normalized', 'Position', [0.75 0.74 0.23 0.05],'tag','sort_option','Callback',@refresh_GUI,'Visible','off',...
[651]96        'String',{'sort name';'sort date'},'FontUnits','points','FontSize',12,'FontWeight','bold','TooltipString','''sort_option'': sort the files by names or dates');
97    uicontrol('Style','listbox','Units','normalized', 'Position',[0.02 0.08 0.96 0.66], 'Callback', @(src,event)list_Callback(option,FilterExt,src,event),'tag','list',...
98        'FontUnits','points','FontSize',12,'TooltipString','''list'':current list of directories, marked by +/, and files');
[653]99   
100    OK_button=uicontrol('Style','pushbutton','Units','normalized', 'Position', [0.58 0.005 0.2 0.07],'BackgroundColor',[0 1 0],...
[651]101        'String','OK','FontWeight','bold','FontUnits','points','FontSize',12,'Callback',@(src,event)OK_Callback(option,FilterExt,src,event));
[653]102    close_button=uicontrol('Style','pushbutton','Units','normalized', 'Position', [0.78 0.005 0.2 0.07],'Callback',@(src,event)close(option,src,event),...
103        'FontWeight','bold','FontUnits','points','FontSize',12);
[606]104    %set(hrefresh,'UserData',StatusData)
[610]105    if strcmp(option,'status_display') %put a run advancement display
[635]106        set(hfig,'DeleteFcn',@(src,event)close(option,src,event))
[651]107        uicontrol('Style','frame','Units','normalized', 'Position', [0.02 0.85 0.9 0.04]);
108        uicontrol('Style','frame','Units','normalized', 'Position',[0.02 0.85 0.01 0.04],'BackgroundColor',[1 0 0],'tag','waitbar');
109        %             uicontrol('Style','text','Units','normalized', 'Position', [0.4 0.8 0.35 0.03],'BackgroundColor',BackgroundColor,...
110        %             'String','sort: ','FontUnits','points','FontSize',12,'FontWeight','bold','HorizontalAlignment','right');
111        delete(home_button)
[653]112        set(OK_button,'String','Open')
113        set(close_button,'String','Close')
[651]114    elseif strcmp(FilterExt,'uigetdir') %pick a  directory
115        set(path_title,'String',title); %show the input title for path (directory)
[653]116        set(OK_button,'String','Select')
117        set(close_button,'String','Cancel')
[609]118    else  %put a title and additional pushbuttons
[651]119        uicontrol('Style','text','Units','normalized', 'Position', [0.02 0.74 0.6 0.03],'BackgroundColor',BackgroundColor,...
[609]120            'String',title,'FontUnits','points','FontSize',12,'FontWeight','bold','ForegroundColor','blue','HorizontalAlignment','left');
[651]121        uicontrol('Style','togglebutton','Units','normalized', 'Position', [0.75 0.78 0.23 0.04],'tag','check_date','Callback',@dates_Callback,...
122            'String','show dates','FontUnits','points','FontSize',12,'FontWeight','bold','TooltipString','''check_date'':press button to display dates');
123%         uicontrol('Style','text','Units','normalized', 'Position', [0.37 0.8 0.35 0.03],'BackgroundColor',BackgroundColor,...
124%             'String','sort: ','FontUnits','points','FontSize',12,'FontWeight','bold','HorizontalAlignment','right');
[653]125         set(OK_button,'String','Open')
126         set(close_button,'String','Cancel')   
[606]127    end
128    drawnow
129end
[651]130refresh_GUI(findobj(hfig,'Tag','refresh'),InputFileName,FilterExt)% refresh the list of content of the current dir
131if ~strcmp(option,'status_display')
[609]132    uiwait(hfig)
[620]133    if ishandle(hfig)
[651]134        htitlebox=findobj(hfig,'Tag','titlebox');
135        fileinput=get(htitlebox,'String');% retrieve the input file selection
136        delete(hfig)
[620]137    end
[609]138end
139
[615]140%------------------------------------------------------------------------   
141% --- launched by refreshing the display figure
[651]142%------------------------------------------------------------------------
[615]143function titlebox_Callback(hObject,event)
144refresh_GUI(hObject)
[651]145
146%------------------------------------------------------------------------   
147% --- launched by selecting OK (relevant for FilterExt='uigetdir')
[615]148%------------------------------------------------------------------------
[651]149function OK_Callback(option,filter_ext,hObject,event)
[714]150set(hObject,'backgroundColor',[1 1 0])% indicate button activation
[651]151hfig=get(hObject,'parent');%handle of the fig
152htitlebox=findobj(hfig,'tag','titlebox');  % display the current dir name 
153DirName=get(htitlebox,'String');
154if ~strcmp(filter_ext,'uigetdir')% a file is expected as output, not a dir
155    hlist=findobj(hfig,'Tag','list');
156    list=get(hlist,'String');
157    index=get(hlist,'Value');
[664]158    if ~isempty(regexp(list{index},'^\+/'))
159        return % quit if a dir has been opened
160    end
161    %SelectName=regexprep(list{index},'^\+/','');% remove the +/ used to mark dir
162    SelectName=list{index};
[651]163    ind_dot=regexp(SelectName,'\s*\.\.\.');%remove what is beyond  '...'
164    if ~isempty(ind_dot)
165        SelectName=SelectName(1:ind_dot-1);
166    end
[1022]167    if isempty(regexp(DirName,'^http://'))% if the input dir is not a web site (begins by http://)
168        FullSelectName=fullfile(DirName,SelectName);
169        check_exist=exist(FullSelectName,'file');
170    else
171        FullSelectName=[DirName '/' SelectName];
172        check_exist=1;
173    end
174    if check_exist
[651]175        switch option
176            case 'browser'
177                set(htitlebox,'String',FullSelectName);
178                uiresume(hfig)
179            case 'status_display'
[784]180                FileInfo=get_file_info(FullSelectName);
[783]181                if strcmp(FileInfo.FileType,'txt')
[651]182                    edit(FullSelectName)
[783]183                elseif strcmp(FileInfo.FileType,'xml')
[651]184                    editxml(FullSelectName)
[783]185                elseif strcmp(FileInfo.FileType,'figure')
[651]186                    open(FullSelectName)
187                else
188                    uvmat(FullSelectName);
189                end
190        end
191    end
192end
[714]193set(hObject,'backgroundColor',[0 1 0])% indicate end button activation
[651]194uiresume(get(hObject,'parent'))
195
[1022]196%------------------------------------------------------------------------
[610]197% --- launched by refreshing the display figure
[641]198function refresh_GUI(hObject,InputFileName,FilterExt)
[610]199%------------------------------------------------------------------------
200if ~exist('InputFileName','var')
201    InputFileName='';
202end
[648]203if ~exist('FilterExt','var')
204    FilterExt='*';
205end
[651]206if strcmp(FilterExt,'uigetdir')
207    FilterExt='*';
208end
[610]209hfig=get(hObject,'parent');
[613]210hlist=findobj(hfig,'tag','list');% find the list object
211set(hlist,'BackgroundColor',[1 1 0])
212drawnow
[611]213htitlebox=findobj(hfig,'tag','titlebox');
214DirName=get(htitlebox,'String');
[612]215hsort_option=findobj(hfig,'tag','sort_option');
[1022]216% use with GUI series
217if strcmp(get(hfig,'Tag'),'status_display') % use with GUI series
[610]218    hseries=findobj(allchild(0),'tag','series');
[635]219    hstatus=findobj(hseries,'tag','status');
[610]220    StatusData=get(hstatus,'UserData');
221    TimeStart=0;
222    if isfield(StatusData,'TimeStart')
223        TimeStart=StatusData.TimeStart;
[635]224    end
[610]225    hlist=findobj(hfig,'tag','list');
[1022]226    testrecent=0;
[610]227    NbOutputFile=[];
[635]228    if isfield(StatusData,'NbOutputFile')
229        NbOutputFile=StatusData.NbOutputFile;
230        NbOutputFile_str=num2str(NbOutputFile);
[610]231    end
[644]232    [ListFiles,NumFiles]=list_files(DirName,1,TimeStart);% list the directory content
[610]233   
[1022]234    % update the waitbar
[610]235    hwaitbar=findobj(hfig,'tag','waitbar');
236    if ~isempty(NbOutputFile)
237        BarPosition=get(hwaitbar,'Position');
[635]238        BarPosition(3)=0.9*max(0.01,NumFiles/NbOutputFile);% the bar width cannot be set to 0, set to 0.01 instead
[610]239        set(hwaitbar,'Position',BarPosition)
240    end
[1022]241else  %use as usual browser
[635]242    sort_option='name';
243    if strcmp(get(hsort_option,'Visible'),'on')&& isequal(get(hsort_option,'Value'),2)
244        sort_option='date';
245    end
246    hcheck_date=findobj(hfig,'tag','check_date');
[641]247    [ListFiles,NumFiles]=list_files(DirName,get(hcheck_date,'Value'),sort_option,FilterExt);% list the directory content
[610]248end
249
[635]250set(hlist,'String',ListFiles)
251Value=[];
252if ~isempty(InputFileName)
253    Value=find(strcmp(InputFileName,ListFiles));
254end
255if isempty(Value)
256    Value=1;
257end
258set(hlist,'Value',Value)
259set(hlist,'BackgroundColor',[0.7 0.7 0.7])
[651]260
[610]261%------------------------------------------------------------------------   
[609]262% --- launched by selecting an item on the file list
[651]263%------------------------------------------------------------------------
[612]264function dates_Callback(hObject,event)
[651]265
[612]266hfig=get(hObject,'parent');
267hsort_option=findobj(hfig,'tag','sort_option');
268if get(hObject,'Value')
269    set(hsort_option,'Visible','on')
270    set(hsort_option,'Value',2)
271else
272    set(hsort_option,'Visible','off')
273end
274refresh_GUI(hObject,[])
275
[651]276
[612]277%------------------------------------------------------------------------   
278% --- launched by selecting an item on the file list
[641]279function list_Callback(option,filter_ext,hObject,event)
[612]280%------------------------------------------------------------------------
[617]281hfig=get(hObject,'parent');%handle of the fig
282set(hObject,'BackgroundColor',[1 1 0])% paint list in yellow to indicate action
[615]283    drawnow
[606]284list=get(hObject,'String');
285index=get(hObject,'Value');
[617]286
[611]287htitlebox=findobj(hfig,'tag','titlebox');  % display the new dir name 
288DirName=get(htitlebox,'String');
[1022]289CheckSubDir=~isempty(regexp(list{index},'^\+'));
[609]290SelectName=regexprep(list{index},'^\+/','');% remove the +/ used to mark dir
[612]291ind_dot=regexp(SelectName,'\s*\.\.\.');%remove what is beyond  '...'
292if ~isempty(ind_dot)
293    SelectName=SelectName(1:ind_dot-1);
294end
[609]295if strcmp(SelectName,'..')% the upward dir option has been selected
[606]296    FullSelectName=fileparts(DirName);
297else
[1022]298    if isempty(regexp(DirName,'^http://'))% usual files
299        FullSelectName=fullfile(DirName,SelectName);
300    else
301        FullSelectName=[DirName '/' SelectName];
302    end
[606]303end
[1022]304if CheckSubDir%exist(FullSelectName,'dir')% a directory has been selected
[613]305    set(hObject,'BackgroundColor',[1 1 0])% paint list in yellow to indicate action
306    drawnow
[609]307    hbackward=findobj(hfig,'Tag','backward');
308    set(hbackward,'UserData',DirName); %store the current dir for future backward action
[612]309    hsort_option=findobj(hfig,'tag','sort_option');
310    sort_option='name';%default
311    if strcmp(get(hsort_option,'Visible'),'on')&& isequal(get(hsort_option,'Value'),2)
312        sort_option='date';
313    end
314    hcheck_date=findobj(hfig,'tag','check_date');
[613]315   
[641]316    ListFiles=list_files(FullSelectName,get(hcheck_date,'Value'),sort_option,filter_ext);% list the directory content
[606]317    set(hObject,'Value',1)
318    set(hObject,'String',ListFiles)
[613]319    set(hObject,'BackgroundColor',[0.7 0.7 0.7])
[611]320    set(htitlebox,'String',FullSelectName)% record the new dir name
[606]321end
[615]322set(hObject,'BackgroundColor',[0.7 0.7 0.7])% paint list in grey to indicate action end
[606]323
[610]324%-------------------------------------------------------------------------   
325% list the content of a directory
[641]326function [ListFiles,NumFiles]=list_files(DirName,check_date,sort_option,filter_ext)
[610]327%-------------------------------------------------------------------------
[1022]328ListStruct=dir_uvmat(DirName);% get structure of the current directory
[635]329NumFiles=0; %default
[611]330if numel(ListStruct)<1  % case of empty dir
[610]331    ListFiles={};
332    return
333end
334ListCells=struct2cell(ListStruct);% transform dir struct to a cell arrray
335ListFiles=ListCells(1,:);%list of file names
[611]336check_dir=cell2mat(ListCells(4,:));% =1 for directories, =0 for files
[1022]337% for ilist=1:numel(check_dir)
338%     if check_dir(ilist)
[610]339ListFiles(check_dir)=regexprep(ListFiles(check_dir),'^.+','+/$0');% put '+/' in front of dir name display
[1022]340%     end
341% end
[651]342if exist('filter_ext','var') && ~strcmp(filter_ext,'*') &&~strcmp(filter_ext,'uigetdir')
[648]343    if strcmp(filter_ext,'image')
344        check_keep=cellfun(@isimage,ListFiles) ;
345    elseif strcmp(filter_ext(1),'.')
346        ind_ext=regexp(ListFiles,[filter_ext '$']);%look for the input file extension
347        check_keep=~cellfun('isempty',ind_ext);
348    end
349    check_keep=check_keep|check_dir;
350    ListFiles=ListFiles(check_keep);
351    ListCells=ListCells(:,check_keep);
352    check_dir=check_dir(check_keep);
353end
[651]354check_emptydate=cellfun('isempty',ListCells(5,:));% = 1 if datenum undefined
355ListCells(5,find(check_emptydate))={0}; %set to 0 the empty dates
[635]356ListDates=cell2mat(ListCells(5,:));%list of numerical dates
357if isnumeric(sort_option)
358    check_old=ListDates<sort_option-1;% -1 is put to account for a 1 s delay in the record of starting time
359    NumFiles=numel(find(~check_old&~check_dir));
360end
361if ~isempty(find(~check_dir))
362ListDates(check_dir)=max(ListDates(~check_dir))+1000; % we set the dir in front
363end
[641]364
[635]365if isnumeric(sort_option)|| strcmp(sort_option,'date')
[612]366    [tild,index_sort]=sort(ListDates,2,'descend');% sort files by chronological order, recent first, put the dir first in the list
367else
368    [tild,index_sort]=sort(check_dir,2,'descend');% put the dir first in the list
369end
370ListFiles=ListFiles(index_sort);% list of names sorted by alaphabetical order and dir and file
[610]371cell_remove=regexp(ListFiles,'^(-|\.|\+/\.)');% detect strings beginning by '-' ,'.' or '+/.'(dir beginning by . )
[612]372check_keep=cellfun('isempty', cell_remove);
[610]373ListFiles=[{'+/..'} ListFiles(check_keep)];
[612]374if check_date
[635]375    ListDateString=ListCells(2,:);%list of file dates
376    if isnumeric(sort_option)
377        ListDateString(check_old)={'--OLD--'};
378    end
379    ListDateString(check_dir)={''};
380    ListDateString=ListDateString(index_sort);% sort the corresponding dates
381    ListDateString=[{''} ListDateString(check_keep)];
382    ListFiles=[ListFiles; ListDateString];
383    ListFiles=cell2tab(ListFiles','...');
[612]384end
[610]385
[606]386%------------------------------------------------------------------------   
387% --- launched by selecting home
388function home_dir(hObject,event)
[609]389%------------------------------------------------------------------------
[606]390DirName=pwd;
391hfig=get(hObject,'parent');
[613]392hlist=findobj(hfig,'tag','list');% find the list object
393set(hlist,'BackgroundColor',[1 1 0])
394drawnow
[612]395sort_option='name';%default
396hsort_option=findobj(hfig,'tag','sort_option');
397if strcmp(get(hsort_option,'Visible'),'on')&& isequal(get(hsort_option,'Value'),2)
398    sort_option='date';
399end
400hcheck_date=findobj(hfig,'tag','check_date');
401ListFiles=list_files(DirName,get(hcheck_date,'Value'),sort_option);% list the directory content
[611]402htitlebox=findobj(hfig,'Tag','titlebox');
403set(htitlebox,'String',DirName)% record the new dir name
[613]404set(hlist,'Value',1)
[606]405set(hlist,'String',ListFiles)
[613]406set(hlist,'BackgroundColor',[0.7 0.7 0.7])
[606]407%------------------------------------------------------------------------
408
409%------------------------------------------------------------------------   
[609]410% --- launched by pressing the backward (<--) button
411function backward(hObject,event)
412%------------------------------------------------------------------------
413PrevDir=get(hObject,'UserData');
414if ~isempty(PrevDir)
415hfig=get(hObject,'parent');
416htitlebox=findobj(hfig,'tag','titlebox');  % display the new dir name
417set(htitlebox,'String',PrevDir)
418refresh_GUI(findobj(hfig,'Tag','refresh'))
419end
420
[606]421%-------------------------------------------------------------------------   
[641]422% --- launched by deleting the status figure (only used in mode series status')
423%-------------------------------------------------------------------------
[609]424function close(option,hObject, eventdata)
[641]425
[610]426if strcmp(option,'status_display')
[635]427    hseries=findobj(allchild(0),'Tag','series');
428    hstatus=findobj(hseries,'Tag','status');
429    set(hstatus,'value',0) %reset the status uicontrol in the GUI series
430    set(hstatus,'BackgroundColor',[0 1 0])
[609]431end
[606]432delete(gcbf)
433
[641]434%-------------------------------------------------------------------------
435% --- check whether a file is has an image name extension
436%-------------------------------------------------------------------------
437function CheckImage=isimage(filename)
438
439[pp,name,ext]=fileparts(filename);
[809]440CheckImage=~isempty(ext)&&~strcmp(ext,'.')&&~isempty(imformats(regexprep(ext,'^.','')));
Note: See TracBrowser for help on using the repository browser.