forked from NOVACProject/MobileDOAS
-
Notifications
You must be signed in to change notification settings - Fork 0
/
DMSpecView.h
314 lines (219 loc) · 10.1 KB
/
DMSpecView.h
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
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
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
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
// DMSpecView.h : interface of the CDMSpecView class
//
/////////////////////////////////////////////////////////////////////////////
#if !defined(AFX_DMSPECVIEW_H__8A3F075C_24B5_4BB0_897A_E1285CBD8628__INCLUDED_)
#define AFX_DMSPECVIEW_H__8A3F075C_24B5_4BB0_897A_E1285CBD8628__INCLUDED_
#include "GPS.h"
#include "Spectrometer.h"
#include "Graphs/GraphCtrl.h"
#include "PostFluxDlg.h"
#include "RealTimeRoute.h"
#include "ShowFitDlg.h"
#include "Dialogs/SpectrumSettingsDlg.h"
#include "Dialogs/SpectrumScaleDlg.h"
#include "Dialogs/SpectrumCalibrationDlg.h"
#include "Common.h"
#include "Controls/Label.h"
#include "WavelengthCalibration.h"
#include "afxcmn.h"
#include "afxwin.h"
#if _MSC_VER > 1000
#pragma once
#endif // _MSC_VER > 1000
UINT CollectSpectra(LPVOID pParam);
UINT CollectSpectra_Wind(LPVOID pParam);
class CDMSpecView : public CFormView
{
protected: // create from serialization only
CDMSpecView();
virtual ~CDMSpecView();
DECLARE_DYNCREATE(CDMSpecView)
public:
// ------------------- DIALOG COMPONENTS -------------------------
/** The edit-box for the basename */
CEdit m_BaseEdit;
/** The background color for the main-plot */
COLORREF m_bkColor;
/** The colors for drawing the results from the master and slave channels */
COLORREF m_PlotColor[2];
/** The color of the master-channel spectrum */
COLORREF m_Spectrum0Color;
/** The color of the fit-region of the master-channel spectrum */
COLORREF m_Spectrum0FitColor;
/** The color of the slave-channel spectrum */
COLORREF m_Spectrum1Color;
/** The color of the fit-region of the slave-channel spectrum */
COLORREF m_Spectrum1FitColor;
/* Measurement points with intensity below 'intensityLimit' does not affect the column scale */
CSliderCtrl m_intensitySliderLow;
/** The actual graph, shows the columns, the spectra, the intensities, etc...*/
Graph::CGraphCtrl m_ColumnPlot;
DlgControls::CLabel m_expLabel;
DlgControls::CLabel m_scanNoLabel;
DlgControls::CLabel m_colLabel;
DlgControls::CLabel m_noSpecLabel;
DlgControls::CLabel m_shiftLabel;
DlgControls::CLabel m_squeezeLabel;
DlgControls::CLabel m_tempLabel;
DlgControls::CLabel m_gpsLatLabel;
DlgControls::CLabel m_gpsLonLabel;
DlgControls::CLabel m_gpsTimeLabel;
DlgControls::CLabel m_gpsNSatLabel;
DlgControls::CLabel m_colorLabelSpectrum1;
DlgControls::CLabel m_colorLabelSpectrum2;
DlgControls::CLabel m_colorLabelSeries1;
DlgControls::CLabel m_colorLabelSeries2;
CStatic m_legendSeries1, m_legendSeries2, m_legendSpectrum1, m_legendSpectrum2;
// ---------------------- PUBLIC DATA ----------------------------
enum { IDD = IDD_DMSPEC_FORM };
/** The wind-direction and wind-speed, used in the main window so that the user
can set the parameters for calculating flux. */
double m_WindDirection;
double m_WindSpeed;
/** The spectrometer. Takes care of spectral collection, evaluation
and storing of spectra and results. */
CSpectrometer* m_Spectrometer;
/** The wavelenth calibration object, only relevant (and not null) when
performing a wavelength calibration. */
CWavelengthCalibration *m_calibration;
/** The option whether we shall show the column-error bars or not */
BOOL m_showErrorBar;
// --------------------- EVENT HANDLERS ---------------------------
/** Starts the spectrum collection */
afx_msg void OnControlStart();
/** Starts the spectrum collection for wind measurements*/
afx_msg void OnControlStartWindMeasurement();
/** Stoppes the spectrum collections */
afx_msg void OnControlStop();
/** Starts the viewing of spectra from the spectrometer
and makes it possible for the user to control the
exposure-time and number of co-adds */
afx_msg void OnControlViewSpectra();
/** Starts the viewing of latest spectra from STD files sent to a directory. */
afx_msg void OnControlProcessSpectraFromDirectory();
/** Starts viewing spectra from the spectrometer, this makes
easier for the user to make a calibration of the spectrometer */
afx_msg void OnControlCalibrateSpectrometer();
/** Show the post-flux dialog */
afx_msg void OnMenuShowPostFluxDialog();
/** Shows the spectrum inspector */
afx_msg void OnMenuShowSpectrumInspectionDialog();
/** Calculate flux in real-time */
afx_msg void OnControlCountflux();
/** Called when the user wants to change the background color of the plot */
afx_msg void OnConfigurationPlotChangebackground();
/** Called when the user wants to change the plot color of the plot */
afx_msg void OnConfigurationPlotChangeplotcolor();
afx_msg void OnConfigurationPlotChangeplotcolor_Slave();
/** Shows the configuration dialog. Lets the user change
the operation-configuration */
afx_msg void OnConfigurationOperation();
/** ??? */
afx_msg BOOL OnHelpInfo(HELPINFO* pHelpInfo);
/** Called to draw a new column value, and to show the number in the
label on the lower part of the screen */
afx_msg LRESULT OnDrawColumn(WPARAM wParam, LPARAM lParam);
/** Updates the status-bar*/
afx_msg LRESULT OnShowStatus(WPARAM wParam, LPARAM lParam);
/** Called to update the GPS - reading in the bottom part of the screen */
afx_msg LRESULT OnReadGPS(WPARAM wParam, LPARAM lParam);
/** Called to update the integration time shown in the bottom part of the screen */
afx_msg LRESULT OnShowIntTime(WPARAM wParam, LPARAM lParam);
/** Called when the selected spectrometer has changed (very seldom!!) */
afx_msg LRESULT OnChangeSpectrometer(WPARAM wParam, LPARAM lParam);
/** Draws the last-collected spectrum */
afx_msg LRESULT OnDrawSpectrum(WPARAM wParam,LPARAM lParam);
/** Changes the saturation-ratio scale of the spectrum-view */
afx_msg LRESULT OnChangedSpectrumScale(WPARAM wParam,LPARAM lParam);
/** Shows a small-popup window above the main window, without anything
actually stopping. This is used instead of the MessageBox since
the program will then stop. The parameter wParam tells the kind
of information to show. */
afx_msg LRESULT OnShowInformationDialog(WPARAM wParam,LPARAM lParam);
/** Show the real-time route dialog */
afx_msg void OnViewRealtimeroute();
/** Show the real-time spectrum fit window */
afx_msg void OnViewSpectrumFit();
afx_msg void OnUpdateViewRealtimeroute(CCmdUI *pCmdUI);
afx_msg void OnUpdateViewSpectrumFit(CCmdUI *pCmdUI);
afx_msg void OnUpdateViewColumnError(CCmdUI *pCmdUI);
/** When the user wants to add a comment at this place in the traverse */
afx_msg void OnControlAddComment();
/** Called when the user wants to show the ReEvaluation dialog */
afx_msg void OnControlReevaluate();
afx_msg void OnUpdateControlReevaluate(CCmdUI *pCmdUI);
/** Called when the user wants to change the exposure time of the
spectrometer on the fly, while the program is running. */
afx_msg void OnConfigurationChangeexposuretime();
/** Called to show the wind-speed measurement analysis window */
afx_msg void OnMenuAnalysisWindSpeedMeasurement();
/** Called to show the plume-height measurement analysis window */
afx_msg void OnMenuAnalysisPlumeheightmeasurement();
afx_msg void OnMenuControlTestTheGPS();
afx_msg void OnMenuControlRunTheGPS();
//afx_msg void OnUpdate_TestTheGPS(CCmdUI *pCmdUI);
// Updating the interface
afx_msg void OnUpdate_EnableOnRun(CCmdUI *pCmdUI);
afx_msg void OnUpdate_DisableOnRun(CCmdUI *pCmdUI);
afx_msg void OnUpdateWindMeasurement(CCmdUI *pCmdUI);
afx_msg void OnUpdate_StartTheGps(CCmdUI *pCmdUI);
afx_msg void OnUpdate_CalibrateSpectrometer(CCmdUI *pCmdUI);
/** Toggles the showing of the column error bars */
afx_msg void OnViewColumnError();
// --------------------- PUBLIC METHODS ----------------------------
void DrawSpectrum();
CDMSpecDoc* GetDocument();
virtual BOOL PreCreateWindow(CREATESTRUCT& cs);
/* Drawing of the spectrum */
int m_SpectrumLineWidth;
/** Updates the labels explaining which color belongs to which series */
void UpdateLegend();
void ShowStatusMsg(CString &str);
/** Sound error alarm **/
void SoundAlarm();
#ifdef _DEBUG
virtual void AssertValid() const;
virtual void Dump(CDumpContext& dc) const;
#endif
protected:
// ------------------- PROTECTED DATA -------------------------
/** The real-time route window */
Dialogs::CRealTimeRoute m_realTimeRouteGraph;
/** The real-time spectrum fit window */
Dialogs::CShowFitDlg m_showFitDlg;
Dialogs::CSpectrumSettingsDlg m_specSettingsDlg;
Dialogs::CSpectrumScaleDlg m_specScaleDlg;
Dialogs::CSpectrumCalibrationDlg m_specCalibrationDlg;
/** The spectrometer thread */
CWinThread* pSpecThread = nullptr;
DECLARE_MESSAGE_MAP()
/** The X-Axis of the column bar-chart */
std::vector<double> m_columnChartXAxisValues;
/** The X-Axis of the spectrum chart */
std::vector<double> m_spectrumChartXAxisValues;
/** Used to set the range for the column plot*/
double m_columnLimit;
/** Used to set the range for the spectrum plot */
double m_minSaturationRatio;
double m_maxSaturationRatio;
/** Tells us the mode the spectrometer is running in, if it's running */
SPECTROMETER_MODE m_spectrometerMode;
// ------------------- PROTECTED METHODS -------------------------
/** Called to read the settings log-file that is generated by this program. */
void ReadMobileLog();
/** Exchanges data between the interface and the variables in this class */
virtual void DoDataExchange(CDataExchange* pDX); // DDX/DDV support
/** Called when the window is created */
virtual void OnInitialUpdate();
public:
afx_msg void OnClose();
afx_msg void OnDestroy();
};
#ifndef _DEBUG // debug version in DMSpecView.cpp
inline CDMSpecDoc* CDMSpecView::GetDocument()
{ return (CDMSpecDoc*)m_pDocument; }
#endif
/////////////////////////////////////////////////////////////////////////////
//{{AFX_INSERT_LOCATION}}
// Microsoft Visual C++ will insert additional declarations immediately before the previous line.
#endif // !defined(AFX_DMSPECVIEW_H__8A3F075C_24B5_4BB0_897A_E1285CBD8628__INCLUDED_)