This repository has been archived by the owner on Dec 1, 2022. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathFOBVisualizer.m
78 lines (66 loc) · 2.41 KB
/
FOBVisualizer.m
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
function varargout = FOBVisualizer
%% MAINCONTROLLER MainController
% controller knows about model and view
clear model;
model = FV_Model.Model(); % model is independent
includePath(model);
clear view;
view = FV_View.View();
FV_View.Window(model, view); % view has a reference of the model
controllers = controller(model, view);
model.controllers = controllers;
% add logging class
model.log = FV_Utils.Logging.Logging(model.pp, 'log.log');
model.log.write('');
model.log.write('#####################################################');
model.log.log('V/FOBVisualizer: Opened program.');
model.log.write('=====================================================');
set(view.figure, 'CloseRequestFcn', {@closeGUI, model, view, controllers});
controllers.closeGUI = @() closeGUI(0, 0, model, view, controllers);
if nargout > 0
varargout{1} = controllers;
end
if nargout > 1
varargout{2} = model;
end
if nargout > 2
varargout{3} = view;
end
end
function closeGUI(~, ~, model, view, controllers)
if isfield(view.Alignment, 'parent') && ishandle(view.Alignment.parent)
close(view.Alignment.parent);
delete(view.Alignment.parent);
end
if isfield(view.DensityMasking, 'parent') && ishandle(view.DensityMasking.parent)
close(view.DensityMasking.parent);
delete(view.DensityMasking.parent);
end
controllers.data.closeFile();
model.log.write('=====================================================');
model.log.log('V/FOBVisualizer: Closed program.');
delete(view.figure);
end
function controllers = controller(model, view)
data = FV_Controller.Data(model, view);
Brillouin = FV_Controller.Brillouin(model, view);
fluorescence = FV_Controller.Fluorescence(model, view);
ODT = FV_Controller.ODT(model, view);
density = FV_Controller.Density(model, view);
modulus = FV_Controller.Modulus(model, view);
help = FV_Controller.Help(model, view);
controllers = struct( ...
'data', data, ...
'Brillouin', Brillouin, ...
'fluorescence', fluorescence, ...
'ODT', ODT, ...
'density', density, ...
'modulus', modulus, ...
'help', help ...
);
end
function includePath(model)
fp = mfilename('fullpath');
[model.pp,~,~] = fileparts(fp);
addpath(model.pp);
end