Code covered by the BSD License  

Highlights from
World Tides

image thumbnail
from World Tides by John Boon
GUI-based program for tidal analysis and prediction using up to 35 tidal harmonic constituents.

worldtides(varargin)
function varargout = worldtides(varargin)
% WORLDTIDES Application M-file for worldtides.fig
%   WORLDTIDES, by itself, creates a new WORLDTIDES or raises the existing
%   singleton*.
%
%   H = WORLDTIDES returns the handle to a new WORLDTIDES or the handle to
%   the existing singleton*.
%
%   WORLDTIDES('CALLBACK',hObject,eventData,handles,...) calls the local
%   function named CALLBACK in WORLDTIDES.M with the given input arguments.
%
%   WORLDTIDES('Property','Value',...) creates a new WORLDTIDES or raises the
%   existing singleton*.  Starting from the left, property value pairs are
%   applied to the GUI before worldtides_OpeningFunction gets called.  An
%   unrecognized property name or invalid value makes property application
%   stop.  All inputs are passed to worldtides_OpeningFcn via varargin.
%
%   *See GUI Options - GUI allows only one instance to run (singleton).
%
% See also: GUIDE, GUIDATA, GUIHANDLES

% Edit the above text to modify the response to help worldtides

% Last Modified by GUIDE v2.5 21-Jul-2006 18:55:40

% Begin initialization code - DO NOT EDIT
gui_Singleton = 1;
gui_State = struct('gui_Name',          mfilename, ...
                   'gui_Singleton',     gui_Singleton, ...
                   'gui_OpeningFcn',    @worldtides_OpeningFcn, ...
                   'gui_OutputFcn',     @worldtides_OutputFcn, ...
                   'gui_LayoutFcn',  @worldtides_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 worldtides is made visible.
function worldtides_OpeningFcn(hObject, eventdata, handles, varargin)
% This function has no output args, see OutputFcn.
% hObject    handle to figure
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
% varargin   command line arguments to worldtides (see VARARGIN)

I=imread('Logo1c.jpg');
A=axes('Units','normalized','position',[0.125 0.16 0.75 0.45]);
image(I)
%set(A,'Visible','off')
%set(A,'Visible','off','HandleVisibility','off')
set(A,'Visible','off')

% Choose default command line output for worldtides
handles.output = hObject;

% Update handles structure
guidata(hObject, handles);
    initial_dir = pwd;
    
% UIWAIT makes worldtides wait for user response (see UIRESUME)
% uiwait(handles.figure1);

%print

% --- Outputs from this function are returned to the command line.
function varargout = worldtides_OutputFcn(hObject, eventdata, handles)
% varargout  cell array for returning output args (see VARARGOUT);
% hObject    handle to figure
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)

% Get default command line output from handles structure
varargout{1} = handles.output;

% ------------------------------------------------------------
% Callback for list box - open .fig with guide, otherwise use open
% ------------------------------------------------------------
function varargout = MAT_file_Callback(h, eventdata, handles)
% hObject    handle to MAT_file (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 MAT_file contents as cell array
%        contents{get(hObject,'Value')} returns selected item from MAT_file


% --- Executes during object creation, after setting all properties.
function MAT_file_CreateFcn(hObject, eventdata, handles)
% hObject    handle to MAT_file (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    empty - handles not created until after all CreateFcns called

% Hint: listbox controls usually have a white background, change
%       'usewhitebg' to 0 to use default.  See ISPC and COMPUTER.
usewhitebg = 1;
if usewhitebg
    set(hObject,'BackgroundColor','white');
else
    set(hObject,'BackgroundColor',get(0,'defaultUicontrolBackgroundColor'));
end



% --- Executes on button press in tide_analysis.
function tide_analysis_Callback(hObject, eventdata, handles)
% hObject    handle to tide_analysis (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
try
 wta2009_export
catch
 wta103_export
end

% --- Executes on button press in tide_prediction.
function tide_prediction_Callback(hObject, eventdata, handles)
% hObject    handle to tide_prediction (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)
try
 wtp2009_export
catch
 wtp103_export
end


% --- Executes during object creation, after setting all properties.
function figure1_CreateFcn(hObject, eventdata, handles)
% hObject    handle to figure1 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    empty - handles not created until after all CreateFcns called


% --- Creates and returns a handle to the GUI figure. 
function h1 = worldtides_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',...
'PaperUnits','centimeters',...
'Color',[0.016 0.412 0.851],...
'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],...
'IntegerHandle','off',...
'InvertHardcopy',get(0,'defaultfigureInvertHardcopy'),...
'MenuBar','none',...
'Name','World Tides',...
'NumberTitle','off',...
'PaperOrientation','landscape',...
'PaperPosition',[0.6345175 6.345175 20.30456 15.22842],...
'PaperSize',[27.91877 21.573595],...
'Position',[0.85 2.57 166 41.8],...
'Resize','off',...
'CreateFcn','worldtides(''figure1_CreateFcn'',gcbo,[],guidata(gcbo))',...
'Tag','figure1',...
'UserData',struct(...
'active_h', 100.005004882813, ...
'taginfo', struct(...
'figure', 2, ...
'listbox', 2, ...
'text', 2), ...
'resize', 'none', ...
'accessibility', 'off', ...
'mfile', 1, ...
'callbacks', 1, ...
'singleton', 1, ...
'blocking', 0, ...
'syscolorfig', 1));

setappdata(h1, 'GUIDEOptions',struct(...
'active_h', 104.011840820313, ...
'taginfo', struct(...
'radiobutton', 7, ...
'text', 44, ...
'edit', 79, ...
'axes', 3, ...
'togglebutton', 2, ...
'frame', 6, ...
'popupmenu', 5, ...
'pushbutton', 52, ...
'checkbox', 2), ...
'override', 1, ...
'resize', 'simple', ...
'accessibility', 'off', ...
'mfile', 1, ...
'callbacks', 1, ...
'singleton', 1, ...
'blocking', 0, ...
'syscolorfig', 1, ...
'lastSavedFile', 'C:\My Documents\Book 3\Programs\Currents\worldtides.m', ...
'release', 13));


h2 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'FontAngle','normal',...
'FontName','MS Roman',...
'FontSize',36,...
'FontWeight','bold',...
'ForegroundColor',[0.016 0.412 0.851],...
'ListboxTop',0,...
'Position',[0.184863523573201 0.764705882352941 0.633995037220844 0.119485294117647],...
'String','WORLD TIDES',...
'Style','text',...
'Tag','main');


h3 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'Callback','worldtides(''tide_analysis_Callback'',gcbo,[],guidata(gcbo))',...
'CData',[],...
'FontSize',12,...
'FontWeight','demi',...
'ListboxTop',0,...
'Position',[0.246898263027295 0.65625 0.194789081885856 0.0827205882352941],...
'String','Tide Analysis',...
'Tag','Tide_analysis',...
'UserData',[]);


h4 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'Callback','worldtides(''tide_prediction_Callback'',gcbo,[],guidata(gcbo))',...
'FontSize',12,...
'FontWeight','demi',...
'ListboxTop',0,...
'Position',[0.544665012406948 0.65625 0.214640198511166 0.0827205882352941],...
'String','Tide Prediction',...
'Tag','tide_prediction');

h5 = uicontrol(...
'Parent',h1,...
'Units','normalized',...
'FontAngle','normal',...
'FontName','MS Roman',...
'FontSize',8,...
'FontWeight','bold',...
'ForegroundColor',[0.016 0.412 0.851],...
'ListboxTop',0,...
'Position',[0.184863523573201 0.764705882352941 0.633995037220844 0.029485294117647],...
'String','2009 Version 1.0: MATLAB versions 7.1.0 - 7.5.0 (R2007b) compatible',...
'Style','text',...
'Tag','text44');


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
%
%      WORLDTIDES, by itself, creates a new WORLDTIDES or raises the existing
%      singleton*.
%
%      H = WORLDTIDES returns the handle to a new WORLDTIDES or the handle to
%      the existing singleton*.
%
%      WORLDTIDES('CALLBACK',hObject,eventData,handles,...) calls the local
%      function named CALLBACK in WORLDTIDES.M with the given input arguments.
%
%      WORLDTIDES('Property','Value',...) creates a new WORLDTIDES 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.5 $ $Date: 2003/07/17 18:28:28 $

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
    % WORLDTIDES
    % create the GUI
    gui_Create = 1;
elseif numargin > 3 & ischar(varargin{1}) & ishandle(varargin{2})
    % WORLDTIDES('CALLBACK',hObject,eventData,handles,...)
    gui_Create = 0;
else
    % WORLDTIDES(...)
    % 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)
try
    gui_hFigure = openfig(name, singleton, 'auto');
catch
    % 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




function edit79_Callback(hObject, eventdata, handles)
% hObject    handle to edit79 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    structure with handles and user data (see GUIDATA)

% Hints: get(hObject,'String') returns contents of edit79 as text
%        str2double(get(hObject,'String')) returns contents of edit79 as a double


% --- Executes during object creation, after setting all properties.
function edit79_CreateFcn(hObject, eventdata, handles)
% hObject    handle to edit79 (see GCBO)
% eventdata  reserved - to be defined in a future version of MATLAB
% handles    empty - handles not created until after all CreateFcns called

% Hint: edit controls usually have a white background on Windows.
%       See ISPC and COMPUTER.
if ispc && isequal(get(hObject,'BackgroundColor'), get(0,'defaultUicontrolBackgroundColor'))
    set(hObject,'BackgroundColor','white');
end


Contact us at files@mathworks.com