source: ntrip/trunk/BNC/src/bncwindow.cpp@ 5440

Last change on this file since 5440 was 5376, checked in by mervart, 11 years ago
File size: 156.2 KB
Line 
1// Part of BNC, a utility for retrieving decoding and
2// converting GNSS data streams from NTRIP broadcasters.
3//
4// Copyright (C) 2007
5// German Federal Agency for Cartography and Geodesy (BKG)
6// http://www.bkg.bund.de
7// Czech Technical University Prague, Department of Geodesy
8// http://www.fsv.cvut.cz
9//
10// Email: euref-ip@bkg.bund.de
11//
12// This program is free software; you can redistribute it and/or
13// modify it under the terms of the GNU General Public License
14// as published by the Free Software Foundation, version 2.
15//
16// This program is distributed in the hope that it will be useful,
17// but WITHOUT ANY WARRANTY; without even the implied warranty of
18// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19// GNU General Public License for more details.
20//
21// You should have received a copy of the GNU General Public License
22// along with this program; if not, write to the Free Software
23// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24
25/* -------------------------------------------------------------------------
26 * BKG NTRIP Client
27 * -------------------------------------------------------------------------
28 *
29 * Class: bncWindow
30 *
31 * Purpose: This class implements the main application window.
32 *
33 * Author: L. Mervart
34 *
35 * Created: 24-Dec-2005
36 *
37 * Changes:
38 *
39 * -----------------------------------------------------------------------*/
40
41#include <iostream>
42
43#include <unistd.h>
44#include "bncwindow.h"
45#include "bnccore.h"
46#include "bncgetthread.h"
47#include "bnctabledlg.h"
48#include "bncipport.h"
49#include "bncudpport.h"
50#include "bncserialport.h"
51#include "bnchlpdlg.h"
52#include "bnchtml.h"
53#include "bnctableitem.h"
54#include "bncsettings.h"
55#include "bncfigure.h"
56#include "bncfigurelate.h"
57#include "bncfigureppp.h"
58#include "bncversion.h"
59#include "bncbytescounter.h"
60#include "bncsslconfig.h"
61#include "upload/bnccustomtrafo.h"
62#include "upload/bncephuploadcaster.h"
63#include "qtfilechooser.h"
64#include "reqcdlg.h"
65#include "bncmap.h"
66#ifdef QT_WEBKIT
67# include "map/bncmapwin.h"
68#endif
69#ifdef USE_POSTPROCESSING
70# include "rinex/bncpostprocess.h"
71# include "rinex/reqcedit.h"
72# include "rinex/reqcanalyze.h"
73#endif
74
75using namespace std;
76
77#ifdef GNSSCENTER_PLUGIN
78Q_EXPORT_PLUGIN2(gnsscenter_bnc, t_bncFactory)
79#endif
80
81// Constructor
82////////////////////////////////////////////////////////////////////////////
83bncWindow::bncWindow() {
84
85#ifdef GNSSCENTER_PLUGIN
86 BNC_CORE->setConfFileName("");
87#endif
88
89 _caster = 0;
90 _casterEph = 0;
91
92 _bncFigure = new bncFigure(this);
93 _bncFigureLate = new bncFigureLate(this);
94 _bncFigurePPP = new bncFigurePPP(this);
95 _runningRealTime = false;
96 _runningPostProcessingPPP = false;
97 _runningPostProcessingReqc = false;
98 _postProcessing = 0;
99
100 _pppSPPComboBox = 0; // necessary for enableStartStop()
101 _reqcActionComboBox = 0; // necessary for enableStartStop()
102
103 _mapWin = 0;
104
105 int ww = QFontMetrics(this->font()).width('w');
106
107 static const QStringList labels = QString("account, Streams: resource loader / mountpoint, decoder, lat, long, nmea, ntrip, bytes").split(",");
108
109 setMinimumSize(85*ww, 65*ww);
110
111 setWindowTitle(tr("BKG Ntrip Client (BNC) Version " BNCVERSION));
112
113 connect(BNC_CORE, SIGNAL(newMessage(QByteArray,bool)),
114 this, SLOT(slotWindowMessage(QByteArray,bool)));
115
116 // Create Actions
117 // --------------
118 _actHelp = new QAction(tr("&Help Contents"),this);
119 connect(_actHelp, SIGNAL(triggered()), SLOT(slotHelp()));
120
121 _actAbout = new QAction(tr("&About BNC"),this);
122 connect(_actAbout, SIGNAL(triggered()), SLOT(slotAbout()));
123
124 _actFlowchart = new QAction(tr("&Flow Chart"),this);
125 connect(_actFlowchart, SIGNAL(triggered()), SLOT(slotFlowchart()));
126
127 _actFontSel = new QAction(tr("Select &Font"),this);
128 connect(_actFontSel, SIGNAL(triggered()), SLOT(slotFontSel()));
129
130 _actSaveOpt = new QAction(tr("&Save && Reread Configuration"),this);
131 connect(_actSaveOpt, SIGNAL(triggered()), SLOT(slotSaveOptions()));
132
133 _actQuit = new QAction(tr("&Quit"),this);
134 connect(_actQuit, SIGNAL(triggered()), SLOT(close()));
135
136 _actAddMountPoints = new QAction(tr("Add &Stream"),this);
137 connect(_actAddMountPoints, SIGNAL(triggered()), SLOT(slotAddMountPoints()));
138
139 _actDeleteMountPoints = new QAction(tr("&Delete Stream"),this);
140 connect(_actDeleteMountPoints, SIGNAL(triggered()), SLOT(slotDeleteMountPoints()));
141 _actDeleteMountPoints->setEnabled(false);
142
143 _actMapMountPoints = new QAction(tr("Streams &Map"),this);
144 connect(_actMapMountPoints, SIGNAL(triggered()), SLOT(slotMapMountPoints()));
145
146 _actStart = new QAction(tr("Sta&rt"),this);
147 connect(_actStart, SIGNAL(triggered()), SLOT(slotStart()));
148
149 _actStop = new QAction(tr("Sto&p"),this);
150 connect(_actStop, SIGNAL(triggered()), SLOT(slotStop()));
151
152 _actwhatsthis= new QAction(tr("Help ?=Shift+F1"),this);
153 connect(_actwhatsthis, SIGNAL(triggered()), SLOT(slotWhatsThis()));
154
155 CreateMenu();
156 AddToolbar();
157
158 bncSettings settings;
159
160 // Network Options
161 // ---------------
162 _proxyHostLineEdit = new QLineEdit(settings.value("proxyHost").toString());
163 _proxyPortLineEdit = new QLineEdit(settings.value("proxyPort").toString());
164
165 connect(_proxyHostLineEdit, SIGNAL(textChanged(const QString &)),
166 this, SLOT(slotBncTextChanged()));
167
168 _sslCaCertPathLineEdit = new QLineEdit(settings.value("sslCaCertPath").toString());
169 _ignoreSslErrorsCheckBox = new QCheckBox();
170 _ignoreSslErrorsCheckBox->setCheckState(Qt::CheckState(
171 settings.value("ignoreSslErrors").toInt()));
172
173 // General Options
174 // ---------------
175 _logFileLineEdit = new QLineEdit(settings.value("logFile").toString());
176 _rawOutFileLineEdit = new QLineEdit(settings.value("rawOutFile").toString());
177 _rnxAppendCheckBox = new QCheckBox();
178 _rnxAppendCheckBox->setCheckState(Qt::CheckState(
179 settings.value("rnxAppend").toInt()));
180 _onTheFlyComboBox = new QComboBox();
181 _onTheFlyComboBox->setEditable(false);
182 _onTheFlyComboBox->addItems(QString("1 day,1 hour,5 min,1 min").split(","));
183 int ii = _onTheFlyComboBox->findText(settings.value("onTheFlyInterval").toString());
184 if (ii != -1) {
185 _onTheFlyComboBox->setCurrentIndex(ii);
186 }
187 _autoStartCheckBox = new QCheckBox();
188 _autoStartCheckBox->setCheckState(Qt::CheckState(
189 settings.value("autoStart").toInt()));
190
191 // RINEX Observations Options
192 // --------------------------
193 _rnxPathLineEdit = new QLineEdit(settings.value("rnxPath").toString());
194 _rnxIntrComboBox = new QComboBox();
195 _rnxIntrComboBox->setEditable(false);
196 _rnxIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
197 ii = _rnxIntrComboBox->findText(settings.value("rnxIntr").toString());
198 if (ii != -1) {
199 _rnxIntrComboBox->setCurrentIndex(ii);
200 }
201 _rnxSamplSpinBox = new QSpinBox();
202 _rnxSamplSpinBox->setMinimum(0);
203 _rnxSamplSpinBox->setMaximum(60);
204 _rnxSamplSpinBox->setSingleStep(5);
205 _rnxSamplSpinBox->setValue(settings.value("rnxSampl").toInt());
206 _rnxSamplSpinBox->setSuffix(" sec");
207 _rnxSkelLineEdit = new QLineEdit(settings.value("rnxSkel").toString());
208 _rnxSkelLineEdit->setMaximumWidth(5*ww);
209 _rnxScrpLineEdit = new QLineEdit(settings.value("rnxScript").toString());
210 _rnxV3CheckBox = new QCheckBox();
211 _rnxV3CheckBox->setCheckState(Qt::CheckState(settings.value("rnxV3").toInt()));
212
213 connect(_rnxPathLineEdit, SIGNAL(textChanged(const QString &)),
214 this, SLOT(slotBncTextChanged()));
215
216 // RINEX Ephemeris Options
217 // -----------------------
218 _ephPathLineEdit = new QLineEdit(settings.value("ephPath").toString());
219 _ephIntrComboBox = new QComboBox();
220 _ephIntrComboBox->setEditable(false);
221 _ephIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
222 int jj = _ephIntrComboBox->findText(settings.value("ephIntr").toString());
223 if (jj != -1) {
224 _ephIntrComboBox->setCurrentIndex(jj);
225 }
226 _outEphPortLineEdit = new QLineEdit(settings.value("outEphPort").toString());
227 _ephV3CheckBox = new QCheckBox();
228 _ephV3CheckBox->setCheckState(Qt::CheckState(settings.value("ephV3").toInt()));
229
230 connect(_outEphPortLineEdit, SIGNAL(textChanged(const QString &)),
231 this, SLOT(slotBncTextChanged()));
232
233 connect(_ephPathLineEdit, SIGNAL(textChanged(const QString &)),
234 this, SLOT(slotBncTextChanged()));
235
236 // Broadcast Corrections Options
237 // -----------------------------
238 _corrPathLineEdit = new QLineEdit(settings.value("corrPath").toString());
239 _corrIntrComboBox = new QComboBox();
240 _corrIntrComboBox->setEditable(false);
241 _corrIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
242 int mm = _corrIntrComboBox->findText(settings.value("corrIntr").toString());
243 if (mm != -1) {
244 _corrIntrComboBox->setCurrentIndex(mm);
245 }
246 _corrPortLineEdit = new QLineEdit(settings.value("corrPort").toString());
247 _corrTimeSpinBox = new QSpinBox();
248 _corrTimeSpinBox->setMinimum(0);
249 _corrTimeSpinBox->setMaximum(60);
250 _corrTimeSpinBox->setSingleStep(1);
251 _corrTimeSpinBox->setSuffix(" sec");
252 _corrTimeSpinBox->setValue(settings.value("corrTime").toInt());
253
254 connect(_corrPathLineEdit, SIGNAL(textChanged(const QString &)),
255 this, SLOT(slotBncTextChanged()));
256
257 connect(_corrPortLineEdit, SIGNAL(textChanged(const QString &)),
258 this, SLOT(slotBncTextChanged()));
259
260 // Feed Engine Options
261 // -------------------
262 _outPortLineEdit = new QLineEdit(settings.value("outPort").toString());
263 _waitTimeSpinBox = new QSpinBox();
264 _waitTimeSpinBox->setMinimum(1);
265 _waitTimeSpinBox->setMaximum(30);
266 _waitTimeSpinBox->setSingleStep(1);
267 _waitTimeSpinBox->setSuffix(" sec");
268 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
269 _binSamplSpinBox = new QSpinBox();
270 _binSamplSpinBox->setMinimum(0);
271 _binSamplSpinBox->setMaximum(60);
272 _binSamplSpinBox->setSingleStep(5);
273 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
274 _binSamplSpinBox->setSuffix(" sec");
275 _outFileLineEdit = new QLineEdit(settings.value("outFile").toString());
276 _outUPortLineEdit = new QLineEdit(settings.value("outUPort").toString());
277
278 connect(_outPortLineEdit, SIGNAL(textChanged(const QString &)),
279 this, SLOT(slotBncTextChanged()));
280
281 connect(_outFileLineEdit, SIGNAL(textChanged(const QString &)),
282 this, SLOT(slotBncTextChanged()));
283
284 // Serial Output Options
285 // ---------------------
286 _serialMountPointLineEdit = new QLineEdit(settings.value("serialMountPoint").toString());
287 _serialPortNameLineEdit = new QLineEdit(settings.value("serialPortName").toString());
288 _serialBaudRateComboBox = new QComboBox();
289 _serialBaudRateComboBox->addItems(QString("110,300,600,"
290 "1200,2400,4800,9600,19200,38400,57600,115200").split(","));
291 int kk = _serialBaudRateComboBox->findText(settings.value("serialBaudRate").toString());
292 if (kk != -1) {
293 _serialBaudRateComboBox->setCurrentIndex(kk);
294 }
295 _serialFlowControlComboBox = new QComboBox();
296 _serialFlowControlComboBox->addItems(QString("OFF,XONXOFF,HARDWARE").split(","));
297 kk = _serialFlowControlComboBox->findText(settings.value("serialFlowControl").toString());
298 if (kk != -1) {
299 _serialFlowControlComboBox->setCurrentIndex(kk);
300 }
301 _serialDataBitsComboBox = new QComboBox();
302 _serialDataBitsComboBox->addItems(QString("5,6,7,8").split(","));
303 kk = _serialDataBitsComboBox->findText(settings.value("serialDataBits").toString());
304 if (kk != -1) {
305 _serialDataBitsComboBox->setCurrentIndex(kk);
306 }
307 _serialParityComboBox = new QComboBox();
308 _serialParityComboBox->addItems(QString("NONE,ODD,EVEN,SPACE").split(","));
309 kk = _serialParityComboBox->findText(settings.value("serialParity").toString());
310 if (kk != -1) {
311 _serialParityComboBox->setCurrentIndex(kk);
312 }
313 _serialStopBitsComboBox = new QComboBox();
314 _serialStopBitsComboBox->addItems(QString("1,2").split(","));
315 kk = _serialStopBitsComboBox->findText(settings.value("serialStopBits").toString());
316 if (kk != -1) {
317 _serialStopBitsComboBox->setCurrentIndex(kk);
318 }
319 _serialAutoNMEAComboBox = new QComboBox();
320 _serialAutoNMEAComboBox->addItems(QString("Auto,Manual").split(","));
321 kk = _serialAutoNMEAComboBox->findText(settings.value("serialAutoNMEA").toString());
322 if (kk != -1) {
323 _serialAutoNMEAComboBox->setCurrentIndex(kk);
324 }
325 _serialFileNMEALineEdit = new QLineEdit(settings.value("serialFileNMEA").toString());
326 _serialHeightNMEALineEdit = new QLineEdit(settings.value("serialHeightNMEA").toString());
327
328 connect(_serialMountPointLineEdit, SIGNAL(textChanged(const QString &)),
329 this, SLOT(slotBncTextChanged()));
330
331 connect(_serialAutoNMEAComboBox, SIGNAL(currentIndexChanged(const QString &)),
332 this, SLOT(slotBncTextChanged()));
333
334 // Outages Options
335 // ---------------
336 _obsRateComboBox = new QComboBox();
337 _obsRateComboBox->setEditable(false);
338 _obsRateComboBox->addItems(QString(",0.1 Hz,0.2 Hz,0.5 Hz,1 Hz,5 Hz").split(","));
339 kk = _obsRateComboBox->findText(settings.value("obsRate").toString());
340 if (kk != -1) {
341 _obsRateComboBox->setCurrentIndex(kk);
342 }
343 _adviseFailSpinBox = new QSpinBox();
344 _adviseFailSpinBox->setMinimum(0);
345 _adviseFailSpinBox->setMaximum(60);
346 _adviseFailSpinBox->setSingleStep(1);
347 _adviseFailSpinBox->setSuffix(" min");
348 _adviseFailSpinBox->setValue(settings.value("adviseFail").toInt());
349 _adviseRecoSpinBox = new QSpinBox();
350 _adviseRecoSpinBox->setMinimum(0);
351 _adviseRecoSpinBox->setMaximum(60);
352 _adviseRecoSpinBox->setSingleStep(1);
353 _adviseRecoSpinBox->setSuffix(" min");
354 _adviseRecoSpinBox->setValue(settings.value("adviseReco").toInt());
355 _adviseScriptLineEdit = new QLineEdit(settings.value("adviseScript").toString());
356
357 connect(_obsRateComboBox, SIGNAL(currentIndexChanged(const QString &)),
358 this, SLOT(slotBncTextChanged()));
359
360 // Miscellaneous Options
361 // ---------------------
362 _miscMountLineEdit = new QLineEdit(settings.value("miscMount").toString());
363 _perfIntrComboBox = new QComboBox();
364 _perfIntrComboBox->setEditable(false);
365 _perfIntrComboBox->addItems(QString(",2 sec, 10 sec,1 min,5 min,15 min,1 hour,6 hours,1 day").split(","));
366 int ll = _perfIntrComboBox->findText(settings.value("perfIntr").toString());
367 if (ll != -1) {
368 _perfIntrComboBox->setCurrentIndex(ll);
369 }
370 _scanRTCMCheckBox = new QCheckBox();
371 _scanRTCMCheckBox->setCheckState(Qt::CheckState(
372 settings.value("scanRTCM").toInt()));
373
374 connect(_miscMountLineEdit, SIGNAL(textChanged(const QString &)),
375 this, SLOT(slotBncTextChanged()));
376
377 // PPP Options
378 // -----------
379 _pppMountLineEdit = new QLineEdit(settings.value("pppMount").toString());
380 _pppMountLineEdit->setMaximumWidth(8*ww);
381 _pppCorrMountLineEdit = new QLineEdit(settings.value("pppCorrMount").toString());
382 _pppMountLineEdit->setMinimumWidth(8*ww);
383 _pppCorrMountLineEdit->setMinimumWidth(8*ww);
384 _pppCorrMountLineEdit->setMaximumWidth(8*ww);
385 _pppNMEALineEdit = new QLineEdit(settings.value("nmeaFile").toString());
386 _pppNMEALineEdit->setMinimumWidth(15*ww);
387 _pppNMEAPortLineEdit = new QLineEdit(settings.value("nmeaPort").toString());
388 _pppNMEAPortLineEdit->setMaximumWidth(8*ww);
389 _pppNMEAPortLineEdit->setMinimumWidth(8*ww);
390 _pppSigCLineEdit = new QLineEdit(settings.value("pppSigmaCode").toString());
391 _pppSigPLineEdit = new QLineEdit(settings.value("pppSigmaPhase").toString());
392 _pppSigCrd0 = new QLineEdit(settings.value("pppSigCrd0").toString());
393 _pppSigCrdP = new QLineEdit(settings.value("pppSigCrdP").toString());
394 _pppSigTrp0 = new QLineEdit(settings.value("pppSigTrp0").toString());
395 _pppSigTrpP = new QLineEdit(settings.value("pppSigTrpP").toString());
396 _pppAverageLineEdit = new QLineEdit(settings.value("pppAverage").toString());
397 _pppQuickStartLineEdit = new QLineEdit(settings.value("pppQuickStart").toString());
398 _pppMaxSolGapLineEdit = new QLineEdit(settings.value("pppMaxSolGap").toString());
399 _pppAudioResponseLineEdit = new QLineEdit(settings.value("pppAudioResponse").toString());
400 _pppRefCrdXLineEdit = new QLineEdit(settings.value("pppRefCrdX").toString());
401 _pppRefCrdYLineEdit = new QLineEdit(settings.value("pppRefCrdY").toString());
402 _pppRefCrdZLineEdit = new QLineEdit(settings.value("pppRefCrdZ").toString());
403 _pppRefdNLineEdit = new QLineEdit(settings.value("pppRefdN").toString());
404 _pppRefdELineEdit = new QLineEdit(settings.value("pppRefdE").toString());
405 _pppRefdULineEdit = new QLineEdit(settings.value("pppRefdU").toString());
406 _pppSync = new QLineEdit(settings.value("pppSync").toString());
407 _pppAntexFileChooser = new qtFileChooser;
408 _pppAntexFileChooser->setMinimumWidth(12*ww);
409 _pppAntennaLineEdit = new QLineEdit(settings.value("pppAntenna").toString());
410 _pppAntexFileChooser->setFileName(settings.value("pppAntex").toString());
411
412 _pppSPPComboBox = new QComboBox();
413 _pppSPPComboBox->setEditable(false);
414 _pppSPPComboBox->addItems(QString(",Realtime-PPP,Realtime-SPP,Post-Processing").split(","));
415 int ik = _pppSPPComboBox->findText(settings.value("pppSPP").toString());
416 if (ik != -1) {
417 _pppSPPComboBox->setCurrentIndex(ik);
418 }
419 _pppUsePhaseCheckBox = new QCheckBox();
420 _pppUsePhaseCheckBox->setCheckState(Qt::CheckState(
421 settings.value("pppUsePhase").toInt()));
422 _pppEstTropoCheckBox = new QCheckBox();
423 _pppEstTropoCheckBox->setCheckState(Qt::CheckState(
424 settings.value("pppEstTropo").toInt()));
425 _pppGLONASSCheckBox = new QCheckBox();
426 _pppGLONASSCheckBox->setCheckState(Qt::CheckState(
427 settings.value("pppGLONASS").toInt()));
428 _pppGalileoCheckBox = new QCheckBox();
429 _pppGalileoCheckBox->setCheckState(Qt::CheckState(
430 settings.value("pppGalileo").toInt()));
431
432 connect(_pppMountLineEdit, SIGNAL(textChanged(const QString &)),
433 this, SLOT(slotBncTextChanged()));
434
435 connect(_pppCorrMountLineEdit, SIGNAL(textChanged(const QString &)),
436 this, SLOT(slotBncTextChanged()));
437
438 connect(_pppUsePhaseCheckBox, SIGNAL(stateChanged(int)),
439 this, SLOT(slotBncTextChanged()));
440
441 connect(_pppRefCrdXLineEdit, SIGNAL(textChanged(const QString &)),
442 this, SLOT(slotBncTextChanged()));
443 connect(_pppRefCrdYLineEdit, SIGNAL(textChanged(const QString &)),
444 this, SLOT(slotBncTextChanged()));
445 connect(_pppRefCrdZLineEdit, SIGNAL(textChanged(const QString &)),
446 this, SLOT(slotBncTextChanged()));
447 connect(_pppRefdNLineEdit, SIGNAL(textChanged(const QString &)),
448 this, SLOT(slotBncTextChanged()));
449 connect(_pppRefdELineEdit, SIGNAL(textChanged(const QString &)),
450 this, SLOT(slotBncTextChanged()));
451 connect(_pppRefdULineEdit, SIGNAL(textChanged(const QString &)),
452 this, SLOT(slotBncTextChanged()));
453
454 connect(_pppEstTropoCheckBox, SIGNAL(stateChanged(int)),
455 this, SLOT(slotBncTextChanged()));
456
457 connect(_pppSync, SIGNAL(textChanged(const QString &)),
458 this, SLOT(slotBncTextChanged()));
459
460 connect(_pppSPPComboBox, SIGNAL(currentIndexChanged(const QString &)),
461 this, SLOT(slotBncTextChanged()));
462
463 connect(_pppAntexFileChooser, SIGNAL(fileNameChanged(const QString &)),
464 this, SLOT(slotBncTextChanged()));
465
466 connect(_pppQuickStartLineEdit, SIGNAL(textChanged(const QString &)),
467 this, SLOT(slotBncTextChanged()));
468
469 // Streams
470 // -------
471 _mountPointsTable = new QTableWidget(0,8);
472
473 _mountPointsTable->horizontalHeader()->resizeSection(1,34*ww);
474 _mountPointsTable->horizontalHeader()->resizeSection(2,9*ww);
475 _mountPointsTable->horizontalHeader()->resizeSection(3,7*ww);
476 _mountPointsTable->horizontalHeader()->resizeSection(4,7*ww);
477 _mountPointsTable->horizontalHeader()->resizeSection(5,5*ww);
478 _mountPointsTable->horizontalHeader()->resizeSection(6,5*ww);
479 _mountPointsTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
480 _mountPointsTable->horizontalHeader()->setStretchLastSection(true);
481 _mountPointsTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
482_mountPointsTable->setHorizontalHeaderLabels(labels);
483 _mountPointsTable->setGridStyle(Qt::NoPen);
484 _mountPointsTable->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
485 _mountPointsTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
486 _mountPointsTable->setSelectionBehavior(QAbstractItemView::SelectRows);
487 _mountPointsTable->hideColumn(0);
488 connect(_mountPointsTable, SIGNAL(itemSelectionChanged()),
489 SLOT(slotSelectionChanged()));
490 populateMountPointsTable();
491
492 _log = new QTextBrowser();
493 _log->setReadOnly(true);
494
495 // Combine Corrections
496 // -------------------
497 _cmbTable = new QTableWidget(0,3);
498 _cmbTable->setHorizontalHeaderLabels(QString("Mountpoint, AC Name, Weight").split(","));
499 _cmbTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
500 _cmbTable->setSelectionBehavior(QAbstractItemView::SelectRows);
501 _cmbTable->setMaximumWidth(30*ww);
502 _cmbTable->horizontalHeader()->resizeSection(0,10*ww);
503 _cmbTable->horizontalHeader()->resizeSection(1,8*ww);
504 _cmbTable->horizontalHeader()->resizeSection(2,8*ww);
505 _cmbTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
506 _cmbTable->horizontalHeader()->setStretchLastSection(true);
507 _cmbTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
508
509 _cmbMaxresLineEdit = new QLineEdit(settings.value("cmbMaxres").toString());
510
511 _cmbSamplSpinBox = new QSpinBox;
512 _cmbSamplSpinBox->setMinimum(10);
513 _cmbSamplSpinBox->setMaximum(60);
514 _cmbSamplSpinBox->setSingleStep(10);
515 _cmbSamplSpinBox->setMaximumWidth(9*ww);
516 _cmbSamplSpinBox->setValue(settings.value("cmbSampl").toInt());
517 _cmbSamplSpinBox->setSuffix(" sec");
518
519 QPushButton* addCmbRowButton = new QPushButton("Add Row");
520 QPushButton* delCmbRowButton = new QPushButton("Delete");
521
522 connect(_cmbTable, SIGNAL(itemSelectionChanged()),
523 SLOT(slotBncTextChanged()));
524
525 _cmbMethodComboBox = new QComboBox();
526 _cmbMethodComboBox->setEditable(false);
527 _cmbMethodComboBox->addItems(QString("Filter,Single-Epoch").split(","));
528 int im = _cmbMethodComboBox->findText(settings.value("cmbMethod").toString());
529 if (im != -1) {
530 _cmbMethodComboBox->setCurrentIndex(im);
531 }
532
533 int iRow = _cmbTable->rowCount();
534 if (iRow > 0) {
535 enableWidget(true, _cmbMethodComboBox);
536 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
537 _cmbMaxresLineEdit->setEnabled(true);
538 _cmbSamplSpinBox->setEnabled(true);
539 }
540 else {
541 enableWidget(false, _cmbMethodComboBox);
542 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
543 _cmbMaxresLineEdit->setEnabled(false);
544 _cmbSamplSpinBox->setEnabled(false);
545 }
546
547 // Upload Results
548 // -------------
549 _uploadTable = new QTableWidget(0,12);
550 _uploadTable->setHorizontalHeaderLabels(QString("Host, Port, Mount, Password, System, CoM, SP3 File, RNX File, PID, SID, IOD, bytes").split(","));
551 _uploadTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
552 _uploadTable->setSelectionBehavior(QAbstractItemView::SelectRows);
553 _uploadTable->horizontalHeader()->resizeSection( 0,13*ww);
554 _uploadTable->horizontalHeader()->resizeSection( 1, 5*ww);
555 _uploadTable->horizontalHeader()->resizeSection( 2, 6*ww);
556 _uploadTable->horizontalHeader()->resizeSection( 3, 8*ww);
557 _uploadTable->horizontalHeader()->resizeSection( 4,11*ww);
558 _uploadTable->horizontalHeader()->resizeSection( 5, 4*ww);
559 _uploadTable->horizontalHeader()->resizeSection( 6,15*ww);
560 _uploadTable->horizontalHeader()->resizeSection( 7,15*ww);
561 _uploadTable->horizontalHeader()->resizeSection( 8, 4*ww);
562 _uploadTable->horizontalHeader()->resizeSection( 9, 4*ww);
563 _uploadTable->horizontalHeader()->resizeSection(10, 4*ww);
564 _uploadTable->horizontalHeader()->resizeSection(11,12*ww);
565 _uploadTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
566 _uploadTable->horizontalHeader()->setStretchLastSection(true);
567 _uploadTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
568
569 connect(_uploadTable, SIGNAL(itemSelectionChanged()),
570 SLOT(slotBncTextChanged()));
571
572 QPushButton* addUploadRowButton = new QPushButton("Add Row");
573 QPushButton* delUploadRowButton = new QPushButton("Del Row");
574 QPushButton* setUploadTrafoButton = new QPushButton("Custom Trafo");
575 _uploadIntrComboBox = new QComboBox;
576 _uploadIntrComboBox->setEditable(false);
577 _uploadIntrComboBox->addItems(QString("1 day,1 hour, 30 min,15 min,10 min,5 min,2 min,1 min").split(","));
578 ii = _uploadIntrComboBox->findText(settings.value("uploadIntr").toString());
579 if (ii != -1) {
580 _uploadIntrComboBox->setCurrentIndex(ii);
581 }
582
583 _uploadSamplRtcmEphCorrSpinBox = new QSpinBox;
584 _uploadSamplRtcmEphCorrSpinBox->setMinimum(0);
585 _uploadSamplRtcmEphCorrSpinBox->setMaximum(60);
586 _uploadSamplRtcmEphCorrSpinBox->setSingleStep(5);
587 _uploadSamplRtcmEphCorrSpinBox->setMaximumWidth(9*ww);
588 _uploadSamplRtcmEphCorrSpinBox->setValue(settings.value("uploadSamplRtcmEphCorr").toInt());
589 _uploadSamplRtcmEphCorrSpinBox->setSuffix(" sec");
590
591 _uploadSamplSp3SpinBox = new QSpinBox;
592 _uploadSamplSp3SpinBox->setMinimum(0);
593 _uploadSamplSp3SpinBox->setMaximum(15);
594 _uploadSamplSp3SpinBox->setSingleStep(1);
595 _uploadSamplSp3SpinBox->setMaximumWidth(9*ww);
596 _uploadSamplSp3SpinBox->setValue(settings.value("uploadSamplSp3").toInt());
597 _uploadSamplSp3SpinBox->setSuffix(" min");
598
599 _uploadSamplClkRnxSpinBox = new QSpinBox;
600 _uploadSamplClkRnxSpinBox->setMinimum(0);
601 _uploadSamplClkRnxSpinBox->setMaximum(60);
602 _uploadSamplClkRnxSpinBox->setSingleStep(5);
603 _uploadSamplClkRnxSpinBox->setMaximumWidth(9*ww);
604 _uploadSamplClkRnxSpinBox->setValue(settings.value("uploadSamplClkRnx").toInt());
605 _uploadSamplClkRnxSpinBox->setSuffix(" sec");
606
607 int iRowT = _uploadTable->rowCount();
608 if (iRowT > 0) {
609 enableWidget(true, _uploadIntrComboBox);
610 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
611 enableWidget(true, _uploadSamplSp3SpinBox);
612 enableWidget(true, _uploadSamplClkRnxSpinBox);
613 }
614 else {
615 enableWidget(false, _uploadIntrComboBox);
616 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
617 enableWidget(false, _uploadSamplSp3SpinBox);
618 enableWidget(false, _uploadSamplClkRnxSpinBox);
619 }
620
621 // Upload RTCM3 Ephemeris
622 // ----------------------
623 _uploadEphHostLineEdit = new QLineEdit(settings.value("uploadEphHost").toString());
624 _uploadEphPortLineEdit = new QLineEdit(settings.value("uploadEphPort").toString());
625 _uploadEphPasswordLineEdit = new QLineEdit(settings.value("uploadEphPassword").toString());
626 _uploadEphPasswordLineEdit->setEchoMode(QLineEdit::PasswordEchoOnEdit);
627 _uploadEphMountpointLineEdit = new QLineEdit(settings.value("uploadEphMountpoint").toString());
628 _uploadEphSampleSpinBox = new QSpinBox;
629 _uploadEphSampleSpinBox->setMinimum(5);
630 _uploadEphSampleSpinBox->setMaximum(60);
631 _uploadEphSampleSpinBox->setSingleStep(5);
632 _uploadEphSampleSpinBox->setMaximumWidth(9*ww);
633 _uploadEphSampleSpinBox->setValue(settings.value("uploadEphSample").toInt());
634 _uploadEphSampleSpinBox->setSuffix(" sec");
635 _uploadEphBytesCounter = new bncBytesCounter;
636
637 // Canvas with Editable Fields
638 // ---------------------------
639 _canvas = new QWidget;
640 setCentralWidget(_canvas);
641
642 _aogroup = new QTabWidget();
643 QWidget* pgroup = new QWidget();
644 QWidget* ggroup = new QWidget();
645 QWidget* sgroup = new QWidget();
646 QWidget* egroup = new QWidget();
647 QWidget* agroup = new QWidget();
648 QWidget* cgroup = new QWidget();
649 QWidget* ogroup = new QWidget();
650 QWidget* rgroup = new QWidget();
651 QWidget* sergroup = new QWidget();
652 QWidget* pppgroup = new QWidget();
653 QWidget* ppp2group = new QWidget();
654 QWidget* ppp3group = new QWidget();
655 QWidget* reqcgroup = new QWidget();
656 QWidget* cmbgroup = new QWidget();
657 QWidget* uploadgroup = new QWidget();
658 QWidget* uploadEphgroup = new QWidget();
659 _aogroup->addTab(pgroup,tr("Network"));
660 _aogroup->addTab(ggroup,tr("General"));
661 _aogroup->addTab(ogroup,tr("RINEX Observations"));
662 _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
663 _aogroup->addTab(reqcgroup,tr("RINEX Editing && QC"));
664 _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
665 _aogroup->addTab(sgroup,tr("Feed Engine"));
666 _aogroup->addTab(sergroup,tr("Serial Output"));
667 _aogroup->addTab(agroup,tr("Outages"));
668 _aogroup->addTab(rgroup,tr("Miscellaneous"));
669 _aogroup->addTab(pppgroup,tr("PPP (1)"));
670 _aogroup->addTab(ppp2group,tr("PPP (2)"));
671 _aogroup->addTab(ppp3group,tr("PPP (3)"));
672#ifdef USE_COMBINATION
673 _aogroup->addTab(cmbgroup,tr("Combine Corrections"));
674#endif
675 _aogroup->addTab(uploadgroup,tr("Upload Corrections"));
676 _aogroup->addTab(uploadEphgroup,tr("Upload Ephemeris"));
677
678 // Log Tab
679 // -------
680 _loggroup = new QTabWidget();
681 _loggroup->addTab(_log,tr("Log"));
682 _loggroup->addTab(_bncFigure,tr("Throughput"));
683 _loggroup->addTab(_bncFigureLate,tr("Latency"));
684 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
685
686 // Netowork (Proxy and SSL) Tab
687 // ----------------------------
688 QGridLayout* pLayout = new QGridLayout;
689 pLayout->setColumnMinimumWidth(0,13*ww);
690 _proxyPortLineEdit->setMaximumWidth(9*ww);
691
692 pLayout->addWidget(new QLabel("Settings for proxy in protected networks and for SSL authorization, leave boxes blank if none."),0, 0, 1, 50);
693 pLayout->addWidget(new QLabel("Proxy host"), 1, 0);
694 pLayout->addWidget(_proxyHostLineEdit, 1, 1, 1,10);
695 pLayout->addWidget(new QLabel("Proxy port"), 2, 0);
696 pLayout->addWidget(_proxyPortLineEdit, 2, 1);
697 pLayout->addWidget(new QLabel("Path to SSL Certificates"), 3, 0);
698 pLayout->addWidget(_sslCaCertPathLineEdit, 3, 1, 1,10);
699 pLayout->addWidget(new QLabel("Default: " + bncSslConfig::defaultPath()), 3,11, 1,20);
700 pLayout->addWidget(new QLabel("Ignore SSL Authorization Errors"), 4, 0);
701 pLayout->addWidget(_ignoreSslErrorsCheckBox, 4, 1, 1,10);
702 pLayout->addWidget(new QLabel(" "), 4, 0);
703 pLayout->addWidget(new QLabel(" "), 5, 0);
704 pLayout->addWidget(new QLabel(" "), 6, 0);
705 pgroup->setLayout(pLayout);
706
707 // General Tab
708 // -----------
709 QGridLayout* gLayout = new QGridLayout;
710 gLayout->setColumnMinimumWidth(0,14*ww);
711 _onTheFlyComboBox->setMaximumWidth(9*ww);
712
713 gLayout->addWidget(new QLabel("General settings for logfile, file handling, configuration on-the-fly, and auto-start."),0, 0, 1, 50);
714 gLayout->addWidget(new QLabel("Logfile (full path)"), 1, 0);
715 gLayout->addWidget(_logFileLineEdit, 1, 1, 1,30);
716 gLayout->addWidget(new QLabel("Append files"), 2, 0);
717 gLayout->addWidget(_rnxAppendCheckBox, 2, 1);
718 gLayout->addWidget(new QLabel("Reread configuration"), 3, 0);
719 gLayout->addWidget(_onTheFlyComboBox, 3, 1);
720 gLayout->addWidget(new QLabel("Auto start"), 4, 0);
721 gLayout->addWidget(_autoStartCheckBox, 4, 1);
722 gLayout->addWidget(new QLabel("Raw output file (full path)"), 5, 0);
723 gLayout->addWidget(_rawOutFileLineEdit, 5, 1, 1,30);
724 gLayout->addWidget(new QLabel(" "), 6, 0);
725 ggroup->setLayout(gLayout);
726
727 // RINEX Observations
728 // ------------------
729 QGridLayout* oLayout = new QGridLayout;
730 oLayout->setColumnMinimumWidth(0,14*ww);
731 _rnxIntrComboBox->setMaximumWidth(9*ww);
732 _rnxSamplSpinBox->setMaximumWidth(9*ww);
733
734 oLayout->addWidget(new QLabel("Saving RINEX observation files."),0, 0, 1,50);
735 oLayout->addWidget(new QLabel("Directory"), 1, 0);
736 oLayout->addWidget(_rnxPathLineEdit, 1, 1, 1,24);
737 oLayout->addWidget(new QLabel("Interval"), 2, 0);
738 oLayout->addWidget(_rnxIntrComboBox, 2, 1);
739 oLayout->addWidget(new QLabel(" Sampling"), 2, 2, Qt::AlignRight);
740 oLayout->addWidget(_rnxSamplSpinBox, 2, 3, Qt::AlignLeft);
741 oLayout->addWidget(new QLabel("Skeleton extension"), 3, 0);
742 oLayout->addWidget(_rnxSkelLineEdit, 3, 1, 1, 1, Qt::AlignLeft);
743 oLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
744 oLayout->addWidget(_rnxScrpLineEdit, 4, 1, 1,24);
745 oLayout->addWidget(new QLabel("Version 3"), 5, 0);
746 oLayout->addWidget(_rnxV3CheckBox, 5, 1);
747 oLayout->addWidget(new QLabel(" "), 6, 0);
748 ogroup->setLayout(oLayout);
749
750 // RINEX Ephemeris
751 // ---------------
752 QGridLayout* eLayout = new QGridLayout;
753 eLayout->setColumnMinimumWidth(0,14*ww);
754 _ephIntrComboBox->setMaximumWidth(9*ww);
755 _outEphPortLineEdit->setMaximumWidth(9*ww);
756
757 eLayout->addWidget(new QLabel("Saving RINEX ephemeris files and ephemeris output through IP port."),0,0,1,50);
758 eLayout->addWidget(new QLabel("Directory"), 1, 0);
759 eLayout->addWidget(_ephPathLineEdit, 1, 1, 1,30);
760 eLayout->addWidget(new QLabel("Interval"), 2, 0);
761 eLayout->addWidget(_ephIntrComboBox, 2, 1);
762 eLayout->addWidget(new QLabel("Port"), 3, 0);
763 eLayout->addWidget(_outEphPortLineEdit, 3, 1);
764 eLayout->addWidget(new QLabel("Version 3"), 4, 0);
765 eLayout->addWidget(_ephV3CheckBox, 4, 1);
766 eLayout->addWidget(new QLabel(" "), 5, 0);
767 eLayout->addWidget(new QLabel(" "), 6, 0);
768 egroup->setLayout(eLayout);
769
770
771 // Broadcast Corrections
772 // ---------------------
773 QGridLayout* cLayout = new QGridLayout;
774 cLayout->setColumnMinimumWidth(0,14*ww);
775 _corrIntrComboBox->setMaximumWidth(9*ww);
776 _corrPortLineEdit->setMaximumWidth(9*ww);
777 _corrTimeSpinBox->setMaximumWidth(9*ww);
778
779 cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port."),0,0,1,50);
780 cLayout->addWidget(new QLabel("Directory, ASCII"), 1, 0);
781 cLayout->addWidget(_corrPathLineEdit, 1, 1, 1,20);
782 cLayout->addWidget(new QLabel("Interval"), 2, 0);
783 cLayout->addWidget(_corrIntrComboBox, 2, 1);
784 cLayout->addWidget(new QLabel("Port"), 3, 0);
785 cLayout->addWidget(_corrPortLineEdit, 3, 1);
786 cLayout->addWidget(new QLabel(" Wait for full corr epoch"), 3, 2, Qt::AlignRight);
787 cLayout->addWidget(_corrTimeSpinBox, 3, 3, Qt::AlignLeft);
788 cLayout->addWidget(new QLabel(" "), 4, 0);
789 cLayout->addWidget(new QLabel(" "), 5, 0);
790 cLayout->addWidget(new QLabel(" "), 6, 0);
791 cgroup->setLayout(cLayout);
792
793 // Feed Engine
794 // -----------
795 QGridLayout* sLayout = new QGridLayout;
796 sLayout->setColumnMinimumWidth(0,14*ww);
797 _outPortLineEdit->setMaximumWidth(9*ww);
798 _waitTimeSpinBox->setMaximumWidth(9*ww);
799 _binSamplSpinBox->setMaximumWidth(9*ww);
800 _outUPortLineEdit->setMaximumWidth(9*ww);
801
802 sLayout->addWidget(new QLabel("Output decoded observations in ASCII format to feed a real-time GNSS network engine."),0,0,1,50);
803 sLayout->addWidget(new QLabel("Port"), 1, 0);
804 sLayout->addWidget(_outPortLineEdit, 1, 1);
805 sLayout->addWidget(new QLabel("Wait for full obs epoch"), 1, 2, Qt::AlignRight);
806 sLayout->addWidget(_waitTimeSpinBox, 1, 3, Qt::AlignLeft);
807 sLayout->addWidget(new QLabel("Sampling"), 2, 0);
808 sLayout->addWidget(_binSamplSpinBox, 2, 1, Qt::AlignLeft);
809 sLayout->addWidget(new QLabel("File (full path)"), 3, 0);
810 sLayout->addWidget(_outFileLineEdit, 3, 1, 1, 20);
811 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 4, 0);
812 sLayout->addWidget(_outUPortLineEdit, 4, 1);
813 sLayout->addWidget(new QLabel(" "), 5, 0);
814 sLayout->addWidget(new QLabel(" "), 6, 0);
815 sgroup->setLayout(sLayout);
816
817 // Serial Output
818 // -------------
819 QGridLayout* serLayout = new QGridLayout;
820 serLayout->setColumnMinimumWidth(0,14*ww);
821 _serialBaudRateComboBox->setMaximumWidth(9*ww);
822 _serialFlowControlComboBox->setMaximumWidth(11*ww);
823 _serialDataBitsComboBox->setMaximumWidth(5*ww);
824 _serialParityComboBox->setMaximumWidth(9*ww);
825 _serialStopBitsComboBox->setMaximumWidth(5*ww);
826 _serialAutoNMEAComboBox->setMaximumWidth(9*ww);
827 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
828
829 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver."),0,0,1,30);
830 serLayout->addWidget(new QLabel("Mountpoint"), 1, 0, Qt::AlignLeft);
831 serLayout->addWidget(_serialMountPointLineEdit, 1, 1, 1, 2);
832 serLayout->addWidget(new QLabel("Port name"), 2, 0, Qt::AlignLeft);
833 serLayout->addWidget(_serialPortNameLineEdit, 2, 1, 1, 2);
834 serLayout->addWidget(new QLabel("Baud rate"), 3, 0, Qt::AlignLeft);
835 serLayout->addWidget(_serialBaudRateComboBox, 3, 1);
836 serLayout->addWidget(new QLabel("Flow control"), 3, 2, Qt::AlignRight);
837 serLayout->addWidget(_serialFlowControlComboBox, 3, 3);
838 serLayout->addWidget(new QLabel("Data bits"), 4, 0, Qt::AlignLeft);
839 serLayout->addWidget(_serialDataBitsComboBox, 4, 1);
840 serLayout->addWidget(new QLabel("Parity"), 4, 2, Qt::AlignRight);
841 serLayout->addWidget(_serialParityComboBox, 4, 3);
842 serLayout->addWidget(new QLabel(" Stop bits"), 4, 4, Qt::AlignRight);
843 serLayout->addWidget(_serialStopBitsComboBox, 4, 5);
844 serLayout->addWidget(new QLabel("NMEA"), 5, 0);
845 serLayout->addWidget(_serialAutoNMEAComboBox, 5, 1);
846 serLayout->addWidget(new QLabel(" File (full path)"), 5, 2, Qt::AlignRight);
847 serLayout->addWidget(_serialFileNMEALineEdit, 5, 3, 1,15);
848 serLayout->addWidget(new QLabel("Height"), 5,20, Qt::AlignRight);
849 serLayout->addWidget(_serialHeightNMEALineEdit, 5,21, 1,11);
850 serLayout->addWidget(new QLabel(" "), 6, 0);
851
852 sergroup->setLayout(serLayout);
853
854 // Outages
855 // -------
856 QGridLayout* aLayout = new QGridLayout;
857 aLayout->setColumnMinimumWidth(0,14*ww);
858 _obsRateComboBox->setMaximumWidth(9*ww);
859 _adviseFailSpinBox->setMaximumWidth(9*ww);
860 _adviseRecoSpinBox->setMaximumWidth(9*ww);
861
862 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes."),0,0,1,50,Qt::AlignLeft);
863 aLayout->addWidget(new QLabel("Observation rate"), 1, 0);
864 aLayout->addWidget(_obsRateComboBox, 1, 1);
865 aLayout->addWidget(new QLabel("Failure threshold"), 2, 0);
866 aLayout->addWidget(_adviseFailSpinBox, 2, 1);
867 aLayout->addWidget(new QLabel("Recovery threshold"), 3, 0);
868 aLayout->addWidget(_adviseRecoSpinBox, 3, 1);
869 aLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
870 aLayout->addWidget(_adviseScriptLineEdit, 4, 1, 1,30);
871 aLayout->addWidget(new QLabel(" "), 5, 0);
872 aLayout->addWidget(new QLabel(" "), 6, 0);
873 agroup->setLayout(aLayout);
874
875 // Miscellaneous
876 // -------------
877 QGridLayout* rLayout = new QGridLayout;
878 rLayout->setColumnMinimumWidth(0,14*ww);
879 _perfIntrComboBox->setMaximumWidth(9*ww);
880
881 rLayout->addWidget(new QLabel("Log latencies or scan RTCM streams for numbers of message types and antenna information."),0, 0,1,30);
882 rLayout->addWidget(new QLabel("Mountpoint"), 1, 0);
883 rLayout->addWidget(_miscMountLineEdit, 1, 1, 1,7);
884 rLayout->addWidget(new QLabel("Log latency"), 2, 0);
885 rLayout->addWidget(_perfIntrComboBox, 2, 1);
886 rLayout->addWidget(new QLabel("Scan RTCM"), 3, 0);
887 rLayout->addWidget(_scanRTCMCheckBox, 3, 1);
888 rLayout->addWidget(new QLabel(" "), 4, 0);
889 rLayout->addWidget(new QLabel(" "), 5, 0);
890 rLayout->addWidget(new QLabel(" "), 6, 0);
891 rgroup->setLayout(rLayout);
892
893 // PPP Client
894 // ----------
895 QGridLayout* pppLayout = new QGridLayout;
896 pppLayout->setColumnMinimumWidth(0,14*ww);
897 _pppSigCLineEdit->setMaximumWidth(6*ww);
898 _pppSigPLineEdit->setMaximumWidth(6*ww);
899 _pppSigCrd0->setMaximumWidth(6*ww);
900 _pppSigCrdP->setMaximumWidth(6*ww);
901 _pppSigTrp0->setMaximumWidth(6*ww);
902 _pppSigTrpP->setMaximumWidth(6*ww);
903 _pppAverageLineEdit->setMaximumWidth(6*ww);
904 _pppQuickStartLineEdit->setMaximumWidth(6*ww);
905 _pppMaxSolGapLineEdit->setMaximumWidth(6*ww);
906 _pppAudioResponseLineEdit->setMaximumWidth(6*ww);
907 _pppRefCrdXLineEdit->setMaximumWidth(10*ww);
908 _pppRefCrdYLineEdit->setMaximumWidth(10*ww);
909 _pppRefCrdZLineEdit->setMaximumWidth(10*ww);
910 _pppRefdNLineEdit->setMaximumWidth(6*ww);
911 _pppRefdELineEdit->setMaximumWidth(6*ww);
912 _pppRefdULineEdit->setMaximumWidth(6*ww);
913 _pppSync->setMaximumWidth(6*ww);
914 _pppSPPComboBox->setMinimumWidth(15*ww);
915
916 _postObsFileChooser = new qtFileChooser;
917 _postObsFileChooser->setFileName(settings.value("postObsFile").toString());
918 _postObsFileChooser->setMinimumWidth(15*ww);
919 _postNavFileChooser = new qtFileChooser;
920 _postNavFileChooser->setFileName(settings.value("postNavFile").toString());
921 _postNavFileChooser->setMinimumWidth(15*ww);
922 _postCorrFileChooser = new qtFileChooser;
923 _postCorrFileChooser->setFileName(settings.value("postCorrFile").toString());
924 _postCorrFileChooser->setMinimumWidth(15*ww);
925 _postOutLineEdit = new QLineEdit(settings.value("postOutFile").toString());
926 _postOutLineEdit->setMinimumWidth(15*ww);
927
928 int ir = 0;
929 pppLayout->addWidget(new QLabel("Precise Point Positioning, Panel 1."), ir, 0, 1, 2, Qt::AlignLeft);
930 ++ir;
931 pppLayout->addWidget(new QLabel("Mode & mountpoints"),ir, 0, Qt::AlignLeft);
932 pppLayout->addWidget(_pppSPPComboBox, ir, 1, Qt::AlignRight);
933 pppLayout->addWidget(_pppMountLineEdit, ir, 3, Qt::AlignRight);
934 pppLayout->addWidget(new QLabel("Obs."), ir, 4, Qt::AlignLeft);
935 pppLayout->addWidget(_pppCorrMountLineEdit, ir, 5, Qt::AlignRight);
936 pppLayout->addWidget(new QLabel("Corr."), ir, 6, Qt::AlignLeft);
937 ++ir;
938 pppLayout->addWidget(new QLabel("Marker coordinates"), ir, 0, Qt::AlignLeft);
939 pppLayout->addWidget(_pppRefCrdXLineEdit, ir, 1, Qt::AlignRight);
940 pppLayout->addWidget(new QLabel("X "), ir, 2, Qt::AlignLeft);
941 pppLayout->addWidget(_pppRefCrdYLineEdit, ir, 3, Qt::AlignRight);
942 pppLayout->addWidget(new QLabel("Y"), ir, 4, Qt::AlignLeft);
943 pppLayout->addWidget(_pppRefCrdZLineEdit, ir, 5, Qt::AlignRight);
944 pppLayout->addWidget(new QLabel("Z"), ir, 6, Qt::AlignLeft);
945 ++ir;
946 pppLayout->addWidget(new QLabel("Antenna excentricity"), ir, 0, Qt::AlignLeft);
947 pppLayout->addWidget(_pppRefdNLineEdit, ir, 1, Qt::AlignRight);
948 pppLayout->addWidget(new QLabel("dN"), ir, 2, Qt::AlignLeft);
949 pppLayout->addWidget(_pppRefdELineEdit, ir, 3, Qt::AlignRight);
950 pppLayout->addWidget(new QLabel("dE"), ir, 4, Qt::AlignLeft);
951 pppLayout->addWidget(_pppRefdULineEdit, ir, 5, Qt::AlignRight);
952 pppLayout->addWidget(new QLabel("dU"), ir, 6, Qt::AlignLeft);
953 ++ir;
954 pppLayout->addWidget(new QLabel("NMEA & plot output"),ir, 0, Qt::AlignLeft);
955 pppLayout->addWidget(_pppNMEALineEdit, ir, 1, Qt::AlignRight);
956 pppLayout->addWidget(new QLabel("NMEA File"), ir, 2, Qt::AlignLeft);
957 pppLayout->addWidget(_pppNMEAPortLineEdit, ir, 3, Qt::AlignRight);
958 pppLayout->addWidget(new QLabel("NMEA Port"), ir, 4, Qt::AlignLeft);
959 ++ir;
960 pppLayout->addWidget(new QLabel("Post-processing"), ir, 0, Qt::AlignLeft);
961 pppLayout->addWidget(_postObsFileChooser, ir, 1, Qt::AlignRight);
962 pppLayout->addWidget(new QLabel("Obs "), ir, 2, Qt::AlignLeft);
963 pppLayout->addWidget(_postNavFileChooser, ir, 3, Qt::AlignRight);
964 pppLayout->addWidget(new QLabel("Nav "), ir, 4, Qt::AlignLeft);
965 ++ir;
966 pppLayout->addWidget(_postCorrFileChooser, ir, 1, Qt::AlignRight);
967 pppLayout->addWidget(new QLabel("Corr"), ir, 2, Qt::AlignLeft);
968 pppLayout->addWidget(_postOutLineEdit, ir, 3, Qt::AlignRight);
969 pppLayout->addWidget(new QLabel("Log (full path)"), ir, 4, Qt::AlignLeft);
970
971 pppgroup->setLayout(pppLayout);
972
973 // PPP Client (second panel)
974 // -------------------------
975 QGridLayout* ppp2Layout = new QGridLayout;
976 ppp2Layout->setColumnMinimumWidth(0,14*ww);
977 ir = 0;
978 ppp2Layout->addWidget(new QLabel("Precise Point Positioning, Panel 2."), ir, 0, 1, 10);
979 ++ir;
980 ppp2Layout->addWidget(new QLabel("Antennas"), ir, 0);
981 ppp2Layout->addWidget(_pppAntexFileChooser, ir, 1,1,3);
982 ppp2Layout->addWidget(new QLabel("ANTEX File"), ir, 4);
983 ppp2Layout->addWidget(_pppAntennaLineEdit, ir, 5,1,3);
984 ppp2Layout->addWidget(new QLabel("Antenna Name"), ir, 8);
985 ++ir;
986 ppp2Layout->addWidget(new QLabel("Basics"), ir, 0, 1, 5);
987 ppp2Layout->addWidget(_pppUsePhaseCheckBox, ir, 1, Qt::AlignRight);
988 ppp2Layout->addWidget(new QLabel("Use phase obs"), ir, 2);
989 ppp2Layout->addWidget(_pppEstTropoCheckBox, ir, 3, Qt::AlignRight);
990 ppp2Layout->addWidget(new QLabel("Estimate tropo"), ir, 4);
991 ppp2Layout->addWidget(_pppGLONASSCheckBox, ir, 5, Qt::AlignRight);
992 ppp2Layout->addWidget(new QLabel("Use GLONASS"), ir, 6);
993 ppp2Layout->addWidget(_pppGalileoCheckBox, ir, 7, Qt::AlignRight);
994 ppp2Layout->addWidget(new QLabel("Use Galileo "), ir, 8);
995 ++ir;
996 ppp2Layout->addWidget(new QLabel("Basics cont'd"), ir, 0);
997 ppp2Layout->addWidget(_pppSync, ir, 1);
998 ppp2Layout->addWidget(new QLabel("Sync Corr (sec) "), ir, 2);
999 ppp2Layout->addWidget(_pppAverageLineEdit, ir, 3, Qt::AlignRight);
1000 ppp2Layout->addWidget(new QLabel("Averaging (min)") , ir, 4);
1001 ppp2Layout->addWidget(_pppQuickStartLineEdit, ir, 5, Qt::AlignRight);
1002 ppp2Layout->addWidget(new QLabel("Quick-Start (sec) "), ir, 6);
1003 ppp2Layout->addWidget(_pppMaxSolGapLineEdit, ir, 7, Qt::AlignRight);
1004 ppp2Layout->addWidget(new QLabel("Max Sol. Gap (sec)"), ir, 8);
1005 ++ir;
1006 ppp2Layout->addWidget(new QLabel("Basics cont'd"), ir, 0);
1007 ppp2Layout->addWidget(_pppAudioResponseLineEdit, ir, 1, Qt::AlignRight);
1008 ppp2Layout->addWidget(new QLabel("Audio response (m)"), ir, 2);
1009 ++ir;
1010 ppp2Layout->addWidget(new QLabel("Sigmas"), ir, 0);
1011 ppp2Layout->addWidget(_pppSigCLineEdit, ir, 1, Qt::AlignRight);
1012 ppp2Layout->addWidget(new QLabel("Code"), ir, 2);
1013 ppp2Layout->addWidget(_pppSigPLineEdit, ir, 3);
1014 ppp2Layout->addWidget(new QLabel("Phase"), ir, 4);
1015 ++ir;
1016 ppp2Layout->addWidget(new QLabel("Sigmas cont'd"), ir, 0);
1017 ppp2Layout->addWidget(_pppSigCrd0, ir, 1, Qt::AlignRight);
1018 ppp2Layout->addWidget(new QLabel("XYZ Init "), ir, 2);
1019 ppp2Layout->addWidget(_pppSigCrdP, ir, 3, Qt::AlignRight);
1020 ppp2Layout->addWidget(new QLabel("XYZ White Noise "), ir, 4);
1021 ppp2Layout->addWidget(_pppSigTrp0, ir, 5, Qt::AlignRight);
1022 ppp2Layout->addWidget(new QLabel("Tropo Init "), ir, 6);
1023 ppp2Layout->addWidget(_pppSigTrpP, ir, 7);
1024 ppp2Layout->addWidget(new QLabel("Tropo White Noise"), ir, 8);
1025 ++ir;
1026 ppp2Layout->addWidget(new QLabel(""), ir, 0);
1027
1028 ppp2group->setLayout(ppp2Layout);
1029
1030 // PPP Client (third panel)
1031 // ------------------------
1032 QVBoxLayout* ppp3Layout = new QVBoxLayout;
1033 ppp3Layout->addWidget(new QLabel("Precise Point Positioning, Panel 3."));
1034 ppp3Layout->addSpacing(ww);
1035
1036 QHBoxLayout* ppp3LayoutHlp1 = new QHBoxLayout;
1037 _pppPlotCoordinates = new QCheckBox();
1038 _pppPlotCoordinates->setCheckState(Qt::CheckState(settings.value("pppPlotCoordinates").toInt()));
1039 ppp3LayoutHlp1->addWidget(new QLabel("PPP Plot "));
1040 ppp3LayoutHlp1->addWidget(_pppPlotCoordinates);
1041 ppp3LayoutHlp1->addWidget(new QLabel("Nort-East-Up Time Series"));
1042 ppp3LayoutHlp1->addStretch();
1043 ppp3Layout->addLayout(ppp3LayoutHlp1);
1044 ppp3Layout->addSpacing(ww);
1045
1046 QHBoxLayout* ppp3LayoutHlp2 = new QHBoxLayout;
1047 ppp3LayoutHlp2->addWidget(new QLabel("Track Plot "));
1048 _mapWinButton = new QPushButton;
1049 _mapWinButton->setText("Open Map");
1050 connect(_mapWinButton, SIGNAL(clicked()), SLOT(slotMapPPP()));
1051 ppp3LayoutHlp2->addWidget(_mapWinButton);
1052
1053 ppp3LayoutHlp2->addSpacing(1*ww);
1054
1055 _gmRadioButton = new QRadioButton;
1056 _gmRadioButton->setChecked(!settings.value("useOsmMap").toBool());
1057 ppp3LayoutHlp2->addWidget(new QLabel("Google"));
1058 ppp3LayoutHlp2->addWidget(_gmRadioButton);
1059
1060 _osmRadioButton = new QRadioButton;
1061 _osmRadioButton->setChecked(settings.value("useOsmMap").toBool());
1062 ppp3LayoutHlp2->addWidget(new QLabel("OSM"));
1063 ppp3LayoutHlp2->addWidget(_osmRadioButton);
1064
1065 ppp3LayoutHlp2->addSpacing(3*ww);
1066
1067 _mapWinDotSizeLineEdit = new QLineEdit(settings.value("mapWinDotSize").toString());
1068 ppp3LayoutHlp2->addWidget(new QLabel("Dot Size"));
1069 _mapWinDotSizeLineEdit->setMaximumWidth(5*ww);
1070 ppp3LayoutHlp2->addWidget(_mapWinDotSizeLineEdit);
1071
1072 ppp3LayoutHlp2->addSpacing(3*ww);
1073
1074 _mapWinDotColorComboBox = new QComboBox();
1075 ppp3LayoutHlp2->addWidget(new QLabel("Dot Color"));
1076 _mapWinDotColorComboBox->setEditable(false);
1077 _mapWinDotColorComboBox->addItems(QString("red,yellow").split(","));
1078 ii = _mapWinDotColorComboBox->findText(settings.value("mapWinDotColor").toString());
1079 if (ii != -1) {
1080 _mapWinDotColorComboBox->setCurrentIndex(ii);
1081 }
1082 ppp3LayoutHlp2->addWidget(_mapWinDotColorComboBox);
1083
1084 ppp3LayoutHlp2->addSpacing(3*ww);
1085
1086 _mapSpeedSlider = new QSlider;
1087 _mapSpeedSlider->setOrientation(Qt::Horizontal);
1088 _mapSpeedSlider->setRange(1, 100);
1089 _mapSpeedSlider->setTickPosition(QSlider::TicksBelow);
1090 _mapSpeedSlider->setTickInterval(10);
1091 int speed = settings.value("mapSpeed").toInt();
1092 if (speed == 0) speed = _mapSpeedSlider->maximum();
1093 _mapSpeedSlider->setSliderPosition(speed);
1094 ppp3LayoutHlp2->addWidget(new QLabel("Speed"));
1095 ppp3LayoutHlp2->addWidget(_mapSpeedSlider);
1096
1097 ppp3LayoutHlp2->addStretch();
1098 ppp3Layout->addLayout(ppp3LayoutHlp2);
1099
1100 ppp3Layout->addStretch();
1101 ppp3group->setLayout(ppp3Layout);
1102
1103 // Reqc Processing
1104 // ---------------
1105 _reqcActionComboBox = new QComboBox();
1106 _reqcActionComboBox->setEditable(false);
1107 _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
1108 ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
1109 if (ik != -1) {
1110 _reqcActionComboBox->setCurrentIndex(ik);
1111 }
1112 connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
1113 this, SLOT(slotBncTextChanged()));
1114
1115 QGridLayout* reqcLayout = new QGridLayout;
1116 _reqcActionComboBox->setMinimumWidth(15*ww);
1117 _reqcActionComboBox->setMaximumWidth(15*ww);
1118
1119 _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1120 _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
1121 _reqcObsFileChooser->setWhatsThis(tr("Specify the full path to an observation file in RINEX v2 or v3 format."));
1122 _reqcObsFileChooser->setMinimumWidth(15*ww);
1123 _reqcObsFileChooser->setMaximumWidth(15*ww);
1124
1125 _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1126 _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
1127 _reqcNavFileChooser->setWhatsThis(tr("Specify the full path to a RINEX v2 or v3 navigation file."));
1128 _reqcNavFileChooser->setMinimumWidth(15*ww);
1129 _reqcNavFileChooser->setMaximumWidth(15*ww);
1130
1131 _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
1132 _reqcOutObsLineEdit->setWhatsThis(tr("Specify the full path to a RINEX observation output file."));
1133 _reqcOutObsLineEdit->setMinimumWidth(15*ww);
1134 _reqcOutObsLineEdit->setMaximumWidth(15*ww);
1135
1136 _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
1137 _reqcOutNavLineEdit->setWhatsThis(tr("Specify the full path to a RINEX navigation output file."));
1138 _reqcOutNavLineEdit->setMinimumWidth(15*ww);
1139 _reqcOutNavLineEdit->setMaximumWidth(15*ww);
1140
1141 _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
1142 _reqcOutLogLineEdit->setWhatsThis(tr("Specify the full path to a logfile."));
1143 _reqcOutLogLineEdit->setMinimumWidth(15*ww);
1144 _reqcOutLogLineEdit->setMaximumWidth(15*ww);
1145
1146 _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
1147 _reqcPlotDirLineEdit->setWhatsThis(tr("Specify the directory name for saving plots."));
1148 _reqcPlotDirLineEdit->setMinimumWidth(15*ww);
1149 _reqcPlotDirLineEdit->setMaximumWidth(15*ww);
1150
1151 _reqcSkyPlotSystems = new QComboBox();
1152 _reqcSkyPlotSystems->setEditable(false);
1153 _reqcSkyPlotSystems->addItems(QString("ALL,GPS,GLONASS,Galileo").split(","));
1154 ik = _reqcSkyPlotSystems->findText(settings.value("reqcSkyPlotSystems").toString());
1155 if (ik != -1) {
1156 _reqcSkyPlotSystems->setCurrentIndex(ik);
1157 }
1158
1159 ir = 0;
1160 reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check."),ir, 0, 1, 20);
1161 ++ir;
1162 reqcLayout->addWidget(new QLabel("Action"), ir, 0, Qt::AlignLeft);
1163 reqcLayout->addWidget(_reqcActionComboBox, ir, 1, Qt::AlignLeft);
1164 _reqcEditOptionButton = new QPushButton("Set Edit Options");
1165 reqcLayout->addWidget(_reqcEditOptionButton, ir, 3, Qt::AlignRight);
1166 ++ir;
1167 reqcLayout->addWidget(new QLabel("Input files (full path)"), ir, 0, Qt::AlignLeft);
1168 reqcLayout->addWidget(_reqcObsFileChooser, ir, 1, Qt::AlignRight);
1169 reqcLayout->addWidget(new QLabel("Obs"), ir, 2, Qt::AlignLeft);
1170 reqcLayout->addWidget(_reqcNavFileChooser, ir, 3, Qt::AlignRight);
1171 reqcLayout->addWidget(new QLabel("Nav"), ir, 4, Qt::AlignLeft);
1172 ++ir;
1173 reqcLayout->addWidget(new QLabel("Output files (full path)"), ir, 0, Qt::AlignLeft);
1174 reqcLayout->addWidget(_reqcOutObsLineEdit, ir, 1, Qt::AlignRight);
1175 reqcLayout->addWidget(new QLabel("Obs"), ir, 2, Qt::AlignLeft);
1176 reqcLayout->addWidget(_reqcOutNavLineEdit, ir, 3, Qt::AlignRight);
1177 reqcLayout->addWidget(new QLabel("Nav"), ir, 4, Qt::AlignLeft);
1178 ++ir;
1179 reqcLayout->addWidget(_reqcOutLogLineEdit, ir, 1, Qt::AlignRight);
1180 reqcLayout->addWidget(new QLabel("Log"), ir, 2, Qt::AlignLeft);
1181 ++ir;
1182 reqcLayout->addWidget(new QLabel("Directory for plots"), ir, 0, Qt::AlignLeft);
1183 reqcLayout->addWidget(_reqcPlotDirLineEdit, ir, 1, Qt::AlignRight);
1184 ++ir;
1185 reqcLayout->addWidget(new QLabel("Sky plots for"), ir, 0, Qt::AlignLeft);
1186 reqcLayout->addWidget(_reqcSkyPlotSystems, ir, 1, Qt::AlignRight);
1187 ++ir;
1188 reqcLayout->addWidget(new QLabel(""), ir, 1);
1189 reqcLayout->setRowStretch(ir, 999);
1190
1191 reqcLayout->setColumnMinimumWidth(2, 8*ww);
1192 reqcLayout->setColumnMinimumWidth(4, 8*ww);
1193
1194 reqcgroup->setLayout(reqcLayout);
1195
1196 connect(_reqcEditOptionButton, SIGNAL(clicked()),
1197 this, SLOT(slotReqcEditOption()));
1198
1199 // Combine Corrections
1200 // -------------------
1201 QGridLayout* cmbLayout = new QGridLayout;
1202
1203 populateCmbTable();
1204 cmbLayout->addWidget(_cmbTable, 0, 0, 6, 3);
1205 cmbLayout->addWidget(new QLabel(" "), 0, 5);
1206 cmbLayout->addWidget(new QLabel("Combine Broadcast Correction streams."), 0, 6, 1, 50);
1207 cmbLayout->addWidget(new QLabel(" "), 1, 5);
1208 cmbLayout->addWidget(addCmbRowButton, 1, 6);
1209 cmbLayout->addWidget(delCmbRowButton, 1, 7);
1210 cmbLayout->addWidget(new QLabel(" "), 2, 5);
1211 cmbLayout->addWidget(new QLabel("Method"), 2, 6, Qt::AlignRight);
1212 cmbLayout->addWidget(_cmbMethodComboBox, 2, 7, Qt::AlignRight);
1213 cmbLayout->addWidget(new QLabel(" "), 3, 5);
1214 cmbLayout->addWidget(new QLabel("Maximal Residuum"), 3, 6, Qt::AlignRight);
1215 cmbLayout->addWidget(_cmbMaxresLineEdit, 3, 7, Qt::AlignRight);
1216 cmbLayout->addWidget(new QLabel(" "), 4, 5);
1217 cmbLayout->addWidget(new QLabel("Sampling"), 4, 6, Qt::AlignRight);
1218 cmbLayout->addWidget(_cmbSamplSpinBox, 4, 7, Qt::AlignRight);
1219 cmbLayout->addWidget(new QLabel(" "), 5, 0);
1220
1221 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1222 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
1223
1224 cmbgroup->setLayout(cmbLayout);
1225
1226 // Upload Layout (Clocks)
1227 // ----------------------
1228 QGridLayout* uploadHlpLayout = new QGridLayout();
1229
1230 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1231 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1232 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
1233
1234 uploadHlpLayout->addWidget(addUploadRowButton, 0, 0);
1235 uploadHlpLayout->addWidget(delUploadRowButton, 0, 1);
1236 uploadHlpLayout->addWidget(new QLabel("Interval"), 0, 2, Qt::AlignRight);
1237 uploadHlpLayout->addWidget(_uploadIntrComboBox, 0, 3);
1238 uploadHlpLayout->addWidget(new QLabel(" Sampling: Orb"), 0, 4, Qt::AlignRight);
1239 uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox, 0, 5);
1240 uploadHlpLayout->addWidget(new QLabel("SP3"), 0, 6, Qt::AlignRight);
1241 uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox, 0, 7);
1242 uploadHlpLayout->addWidget(new QLabel("RNX"), 0, 8, Qt::AlignRight);
1243 uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox, 0, 9);
1244 uploadHlpLayout->addWidget(setUploadTrafoButton, 0,10);
1245
1246 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1247 populateUploadTable();
1248
1249 uploadLayout->addWidget(new QLabel("Upload RTCMv3 Broadcast Corrections to caster."));
1250 uploadLayout->addWidget(_uploadTable);
1251 uploadLayout->addLayout(uploadHlpLayout);
1252
1253 uploadgroup->setLayout(uploadLayout);
1254
1255 // Upload Layout (Ephemeris)
1256 // -------------------------
1257 QGridLayout* uploadLayoutEph = new QGridLayout;
1258
1259 uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1260 _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1261 _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1262 _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1263
1264 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster."), 0, 0, 1, 50);
1265 uploadLayoutEph->addWidget(new QLabel("Host"), 1, 0);
1266 uploadLayoutEph->addWidget(_uploadEphHostLineEdit, 1, 1, 1, 3);
1267 uploadLayoutEph->addWidget(new QLabel(" Port"), 1, 4, Qt::AlignRight);
1268 uploadLayoutEph->addWidget(_uploadEphPortLineEdit, 1, 5, 1, 1);
1269 uploadLayoutEph->addWidget(new QLabel("Mountpoint "), 2, 0);
1270 uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit, 2, 1);
1271 uploadLayoutEph->addWidget(new QLabel(" Password"), 2, 2, Qt::AlignRight);
1272 uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit, 2, 3);
1273 uploadLayoutEph->addWidget(new QLabel("Sampling"), 3, 0);
1274 uploadLayoutEph->addWidget(_uploadEphSampleSpinBox, 3, 1);
1275 uploadLayoutEph->addWidget(new QLabel("Uploaded"), 4, 0);
1276 uploadLayoutEph->addWidget(_uploadEphBytesCounter, 4, 1);
1277 uploadLayoutEph->addWidget(new QLabel(" "), 5, 0);
1278 uploadLayoutEph->addWidget(new QLabel(" "), 6, 0);
1279
1280 uploadEphgroup->setLayout(uploadLayoutEph);
1281
1282 connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1283 this, SLOT(slotBncTextChanged()));
1284
1285#ifdef RTROVER_INTERFACE
1286 QWidget* rtroverGroup = new QWidget();
1287 _aogroup->addTab(rtroverGroup,tr("RTRover"));
1288 QGridLayout* rtroverLayout = new QGridLayout();
1289
1290 _rtroverModeComboBox = new QComboBox();
1291
1292 _rtroverModeComboBox->setEditable(false);
1293 _rtroverModeComboBox->addItems(QString(",PPP_DF,SPP_DF,PPP_SF,SPP_SF,PPP_AR,RTK,PPP_FTTF").split(","));
1294 ik = _rtroverModeComboBox->findText(settings.value("rtroverMode").toString());
1295 if (ik != -1) {
1296 _rtroverModeComboBox->setCurrentIndex(ik);
1297 }
1298 _rtroverModeComboBox->setMinimumWidth(10*ww);
1299
1300 _rtroverRoverMountLineEdit = new QLineEdit(settings.value("rtroverRoverMount").toString());
1301 _rtroverRoverMountLineEdit->setMaximumWidth(8*ww);
1302 _rtroverCorrMountLineEdit = new QLineEdit(settings.value("rtroverCorrMount").toString());
1303 _rtroverCorrMountLineEdit->setMaximumWidth(8*ww);
1304 _rtroverBaseMountLineEdit = new QLineEdit(settings.value("rtroverBaseMount").toString());
1305 _rtroverBaseMountLineEdit->setMaximumWidth(8*ww);
1306 _rtroverRoverRefCrdXLineEdit = new QLineEdit(settings.value("rtroverRoverRefCrdX").toString());
1307 _rtroverRoverRefCrdYLineEdit = new QLineEdit(settings.value("rtroverRoverRefCrdY").toString());
1308 _rtroverRoverRefCrdZLineEdit = new QLineEdit(settings.value("rtroverRoverRefCrdZ").toString());
1309 _rtroverBaseRefCrdXLineEdit = new QLineEdit(settings.value("rtroverBaseRefCrdX").toString());
1310 _rtroverBaseRefCrdYLineEdit = new QLineEdit(settings.value("rtroverBaseRefCrdY").toString());
1311 _rtroverBaseCrdZLineEdit = new QLineEdit(settings.value("rtroverBaseRefCrdZ").toString());
1312 _rtroverRoverDNLineEdit = new QLineEdit(settings.value("rtroverRoverDN").toString());
1313 _rtroverRoverDNLineEdit->setMaximumWidth(6*ww);
1314 _rtroverRoverDELineEdit = new QLineEdit(settings.value("rtroverRoverDE").toString());
1315 _rtroverRoverDELineEdit->setMaximumWidth(6*ww);
1316 _rtroverRoverDULineEdit = new QLineEdit(settings.value("rtroverRoverDU").toString());
1317 _rtroverRoverDULineEdit->setMaximumWidth(6*ww);
1318 _rtroverBaseDNLineEdit = new QLineEdit(settings.value("rtroverBaseDN").toString());
1319 _rtroverBaseDNLineEdit->setMaximumWidth(6*ww);
1320 _rtroverBaseDELineEdit = new QLineEdit(settings.value("rtroverBaseDE").toString());
1321 _rtroverBaseDELineEdit->setMaximumWidth(6*ww);
1322 _rtroverBaseDULineEdit = new QLineEdit(settings.value("rtroverBaseDU").toString());
1323 _rtroverBaseDULineEdit->setMaximumWidth(6*ww);
1324 _rtroverRoverAntennaLineEdit = new QLineEdit(settings.value("rtroverRoverAntenna").toString());
1325 _rtroverBaseAntennaLineEdit = new QLineEdit(settings.value("rtroverBaseAntenna").toString());
1326 _rtroverAntexFileChooser = new qtFileChooser;
1327 _rtroverAntexFileChooser->setMinimumWidth(12*ww);
1328 _rtroverAntexFileChooser->setFileName(settings.value("rtroverAntex").toString());
1329 _rtroverOutputLineEdit = new QLineEdit(settings.value("rtroverOutput").toString());
1330 _rtroverOutputLineEdit->setMinimumWidth(15*ww);
1331
1332 ir = 0;
1333 rtroverLayout->addWidget(new QLabel("Real-Time Rover"), ir, 0, 1, 2, Qt::AlignLeft);
1334 ++ir;
1335 rtroverLayout->addWidget(new QLabel("Mode & mountpoints"),ir, 0, Qt::AlignLeft);
1336 rtroverLayout->addWidget(_rtroverModeComboBox, ir, 1, Qt::AlignRight);
1337 rtroverLayout->addWidget(_rtroverRoverMountLineEdit, ir, 3, Qt::AlignRight);
1338 rtroverLayout->addWidget(new QLabel("Rover"), ir, 4, Qt::AlignLeft);
1339 rtroverLayout->addWidget(_rtroverCorrMountLineEdit, ir, 5, Qt::AlignRight);
1340 rtroverLayout->addWidget(new QLabel("Corr."), ir, 6, Qt::AlignLeft);
1341 rtroverLayout->addWidget(_rtroverBaseMountLineEdit, ir, 7, Qt::AlignRight);
1342 rtroverLayout->addWidget(new QLabel("Base"), ir, 8, Qt::AlignLeft);
1343 ++ir;
1344 rtroverLayout->addWidget(new QLabel("Rover coordinates"), ir, 0, Qt::AlignLeft);
1345 rtroverLayout->addWidget(_rtroverRoverRefCrdXLineEdit, ir, 1, Qt::AlignRight);
1346 rtroverLayout->addWidget(new QLabel("X "), ir, 2, Qt::AlignLeft);
1347 rtroverLayout->addWidget(_rtroverRoverRefCrdYLineEdit, ir, 3, Qt::AlignRight);
1348 rtroverLayout->addWidget(new QLabel("Y"), ir, 4, Qt::AlignLeft);
1349 rtroverLayout->addWidget(_rtroverRoverRefCrdZLineEdit, ir, 5, Qt::AlignRight);
1350 rtroverLayout->addWidget(new QLabel("Z"), ir, 6, Qt::AlignLeft);
1351 ++ir;
1352 rtroverLayout->addWidget(_rtroverRoverDNLineEdit, ir, 1, Qt::AlignRight);
1353 rtroverLayout->addWidget(new QLabel("dN"), ir, 2, Qt::AlignLeft);
1354 rtroverLayout->addWidget(_rtroverRoverDELineEdit, ir, 3, Qt::AlignRight);
1355 rtroverLayout->addWidget(new QLabel("dE"), ir, 4, Qt::AlignLeft);
1356 rtroverLayout->addWidget(_rtroverRoverDULineEdit, ir, 5, Qt::AlignRight);
1357 rtroverLayout->addWidget(new QLabel("dU"), ir, 6, Qt::AlignLeft);
1358 ++ir;
1359 rtroverLayout->addWidget(new QLabel("Base coordinates"), ir, 0, Qt::AlignLeft);
1360 rtroverLayout->addWidget(_rtroverBaseRefCrdXLineEdit, ir, 1, Qt::AlignRight);
1361 rtroverLayout->addWidget(new QLabel("X "), ir, 2, Qt::AlignLeft);
1362 rtroverLayout->addWidget(_rtroverBaseRefCrdYLineEdit, ir, 3, Qt::AlignRight);
1363 rtroverLayout->addWidget(new QLabel("Y"), ir, 4, Qt::AlignLeft);
1364 rtroverLayout->addWidget(_rtroverBaseCrdZLineEdit, ir, 5, Qt::AlignRight);
1365 rtroverLayout->addWidget(new QLabel("Z"), ir, 6, Qt::AlignLeft);
1366 ++ir;
1367 rtroverLayout->addWidget(_rtroverBaseDNLineEdit, ir, 1, Qt::AlignRight);
1368 rtroverLayout->addWidget(new QLabel("dN"), ir, 2, Qt::AlignLeft);
1369 rtroverLayout->addWidget(_rtroverBaseDELineEdit, ir, 3, Qt::AlignRight);
1370 rtroverLayout->addWidget(new QLabel("dE"), ir, 4, Qt::AlignLeft);
1371 rtroverLayout->addWidget(_rtroverBaseDULineEdit, ir, 5, Qt::AlignRight);
1372 rtroverLayout->addWidget(new QLabel("dU"), ir, 6, Qt::AlignLeft);
1373 ++ir;
1374 rtroverLayout->addWidget(new QLabel("ANTEX"), ir, 0, Qt::AlignLeft);
1375 rtroverLayout->addWidget(_rtroverAntexFileChooser, ir, 1, Qt::AlignRight);
1376 rtroverLayout->addWidget(new QLabel("file"), ir, 2, Qt::AlignLeft);
1377 rtroverLayout->addWidget(_rtroverBaseAntennaLineEdit, ir, 3, Qt::AlignRight);
1378 rtroverLayout->addWidget(new QLabel("Ant. Rover"), ir, 4, Qt::AlignLeft);
1379 rtroverLayout->addWidget(_rtroverRoverAntennaLineEdit, ir, 5, Qt::AlignRight);
1380 rtroverLayout->addWidget(new QLabel("Ant. Base"), ir, 6, Qt::AlignLeft);
1381 ++ir;
1382 rtroverLayout->addWidget(new QLabel("Output"), ir, 0, Qt::AlignLeft);
1383 rtroverLayout->addWidget(_rtroverOutputLineEdit, ir, 1, Qt::AlignRight);
1384
1385 rtroverGroup->setLayout(rtroverLayout);
1386#endif
1387
1388 // Main Layout
1389 // -----------
1390 QGridLayout* mLayout = new QGridLayout;
1391 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
1392 mLayout->addWidget(_aogroup, 0,0);
1393 mLayout->addWidget(_mountPointsTable, 1,0);
1394 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
1395 mLayout->addWidget(_loggroup, 2,0);
1396
1397 _canvas->setLayout(mLayout);
1398
1399 // WhatsThis
1400 // ---------
1401 _proxyHostLineEdit->setWhatsThis(tr("<p>If you are running BNC within a protected Local Area Network (LAN), you might need to use a proxy server to access the Internet. Enter your proxy server IP and port number in case one is operated in front of BNC. If you do not know the IP and port of your proxy server, check the proxy server settings in your Internet browser or ask your network administrator.</p><p>Note that IP streaming is sometimes not allowed in a LAN. In this case you need to ask your network administrator for an appropriate modification of the local security policy or for the installation of a TCP relay to the NTRIP broadcasters. If these are not possible, you might need to run BNC outside your LAN on a network that has unobstructed connection to the Internet.</p>"));
1402 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1403 _sslCaCertPathLineEdit->setWhatsThis(tr("<p>Communication with an NTRIP broadcaster over SSL requires the exchange of client and/or server certificates. Specify the path to a directory where you save certificates on your system. Don't try communication via SSL if you are not sure wheter this is supported by the involved NTRIP broadcaster. Note that SSL communication is usually done over port 443.</p>"));
1404 _ignoreSslErrorsCheckBox->setWhatsThis(tr("<p>SSL communication may involve queries coming from the NTRIP broadcaster. Tick 'Ignore SSL authorization erros' if you don't want to be bothered with this.</p>"));
1405 _waitTimeSpinBox->setWhatsThis(tr("<p>When feeding a real-time GNSS network engine waiting for synchronized input epoch by epoch, BNC drops whatever is received later than 'Wait for full obs epoch' seconds. A value of 3 to 5 seconds is recommended, depending on the latency of the incoming streams and the delay acceptable to your real-time GNSS network engine or products.</p>"));
1406 _outFileLineEdit->setWhatsThis(tr("Specify the full path to a file where synchronized observations are saved in plain ASCII format. Beware that the size of this file can rapidly increase depending on the number of incoming streams."));
1407 _outPortLineEdit->setWhatsThis(tr("BNC can produce synchronized observations in a plain ASCII format on your local host through an IP port. Specify a port number here to activate this function."));
1408 _outUPortLineEdit->setWhatsThis(tr("BNC can produce unsynchronized observations in a plain ASCII format on your local host through an IP port. Specify a port number here to activate this function."));
1409 _outEphPortLineEdit->setWhatsThis(tr("BNC can produce ephemeris data in RINEX ASCII format on your local host through an IP port. Specify a port number here to activate this function."));
1410 _corrPortLineEdit->setWhatsThis(tr("BNC can produce Broadcast Ephemeris Corrections on your local host through an IP port. Specify a port number here to activate this function."));
1411 _corrTimeSpinBox->setWhatsThis(tr("<p>Concerning output through IP port, BNC drops Broadcast Ephemeris Corrections received later than 'Wait for full corr epoch' seconds. A value of 2 to 5 seconds is recommended, depending on the latency of the incoming correction stream(s) and the delay acceptable to your real-time application.</p><p>Specifying a value of '0' means that BNC immediately outputs all incoming Broadcast Epemeris Corrections and does not drop any of them for latency reasons.</p>"));
1412 _rnxPathLineEdit->setWhatsThis(tr("Here you specify the path to where the RINEX Observation files will be stored. If the specified directory does not exist, BNC will not create RINEX Observation files."));
1413 _ephPathLineEdit->setWhatsThis(tr("Specify the path for saving Broadcast Ephemeris data as RINEX Navigation files. If the specified directory does not exist, BNC will not create RINEX Navigation files."));
1414 _corrPathLineEdit->setWhatsThis(tr("Specify a directory for saving Broadcast Ephemeris Correction files. If the specified directory does not exist, BNC will not create the files."));
1415 _rnxScrpLineEdit->setWhatsThis(tr("<p>Whenever a RINEX Observation file is saved, you might want to compress, copy or upload it immediately via FTP. BNC allows you to execute a script/batch file to carry out these operations. To do that specify the full path of the script/batch file here. BNC will pass the full RINEX Observation file path to the script as a command line parameter (%1 on Windows systems, $1 onUnix/Linux systems).</p>"));
1416 _rnxSkelLineEdit->setWhatsThis(tr("<p>BNC allows using personal skeleton files that contain the header records you would like to include. You can derive a personal RINEX header skeleton file from the information given in an up to date sitelog.</p><p>A file in the RINEX Observations 'Directory' with a 'Skeleton extension' suffix is interpreted by BNC as a personal RINEX header skeleton file for the corresponding stream.</p>"));
1417 _rnxAppendCheckBox->setWhatsThis(tr("<p>When BNC is started, new files are created by default and any existing files with the same name will be overwritten. However, users might want to append already existing files following a restart of BNC, a system crash or when BNC crashed. Tick 'Append files' to continue with existing files and keep what has been recorded so far.</p>"));
1418 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1419 _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p>"));
1420
1421 _onTheFlyComboBox->setWhatsThis(tr("<p>When operating BNC online in 'no window' mode, some configuration parameters can be changed on-the-fly without interrupting the running process. For that BNC rereads parts of its configuration in pre-defined intervals.<p></p>Select '1 min', '5 min', '1 hour', or '1 day' to force BNC to reread its configuration every full minute, hour, or day and let in between edited configuration options become effective on-the-fly without terminating uninvolved threads.</p><p>Note that when operating BNC in window mode, on-the-fly changeable configuration options become effective immediately through 'Save & Reread Configuration'.</p>"));
1422 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1423 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1424 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of the Broadcast Ephemeris Correction files.</p>"));
1425 _rnxSamplSpinBox->setWhatsThis(tr("<p>Select the RINEX Observation sampling interval in seconds. A value of zero '0' tells BNC to store all received epochs into RINEX.</p>"));
1426 _binSamplSpinBox->setWhatsThis(tr("<p>Select the synchronized observation sampling interval in seconds. A value of zero '0' tells BNC to send/store all received epochs.</p>"));
1427 _obsRateComboBox->setWhatsThis(tr("<p>BNC can collect all returns (success or failure) coming from a decoder within a certain short time span to then decide whether a stream has an outage or its content is corrupted. The procedure needs a rough estimate of the expected 'Observation rate' of the incoming streams. When a continuous problem is detected, BNC can inform its operator about this event through an advisory note.</p>"));
1428 _adviseRecoSpinBox->setWhatsThis(tr("<p>Following a stream outage or a longer series of bad observations, an advisory note is generated when valid observations are received again throughout the 'Recovery threshold' time span. A value of about 5min (default) is recommended.</p><p>A value of zero '0' means that for any stream recovery, however short, BNC immediately generates an advisory note.</p>"));
1429 _adviseFailSpinBox->setWhatsThis(tr("<p>An advisory note is generated when no (or only corrupted) observations are seen throughout the 'Failure threshold' time span. A value of 15 min (default) is recommended.</p><p>A value of zero '0' means that for any stream failure, however short, BNC immediately generates an advisory note.</p>"));
1430 _logFileLineEdit->setWhatsThis(tr("<p>Records of BNC's activities are shown in the 'Log' tab on the bottom of this window. They can be saved into a file when a valid path is specified in the 'Logfile (full path)' field.</p><p>The logfile name will automatically be extended by a string '_YYMMDD' carrying the current date."));
1431 _adviseScriptLineEdit->setWhatsThis(tr("<p>Specify the full path to a script or batch file to handle advisory notes generated in the event of corrupted streams or stream outages. The affected mountpoint and one of the comments 'Begin_Outage', 'End_Outage', 'Begin_Corrupted', or 'End_Corrupted' are passed on to the script as command line parameters.</p><p>The script may have the task to send the advisory notes by email to BNC's operator and/or to the affected stream provider. An empty option field (default) or invalid path means that you don't want to use this option.</p>"));
1432 _perfIntrComboBox->setWhatsThis(tr("<p>BNC can average latencies per stream over a certain period of GPS time. The resulting mean latencies are recorded in the 'Log' tab at the end of each 'Log latency' interval together with results of a statistical evaluation (approximate number of covered epochs, data gaps).</p><p>Select a 'Log latency' interval or select the empty option field if you do not want BNC to log latencies and statistical information.</p>"));
1433 _mountPointsTable->setWhatsThis(tr("<p>Streams selected for retrieval are listed in the 'Streams' section. Clicking on 'Add Stream' button will open a window that allows the user to select data streams from an NTRIP broadcaster according to their mountpoints. To remove a stream from the 'Streams' list, highlight it by clicking on it and hit the 'Delete Stream' button. You can also remove multiple streams by highlighting them using +Shift and +Ctrl.</p><p>BNC automatically allocates one of its internal decoders to a stream based on the stream's 'format' as given in the sourcetable. BNC allows users to change this selection by editing the decoder string. Double click on the 'decoder' field, enter your preferred decoder and then hit Enter. The accepted decoder strings are 'RTCM_2.x', 'RTCM_3.x' and 'RTNET'.</p><p>In case you need to log the raw data as is, BNC allows users to by-pass its decoders and directly save the input in daily log files. To do this specify the decoder string as 'ZERO'.</p><p>BNC can also retrieve streams from virtual reference stations (VRS). VRS streams are indicated by a 'yes' in the 'nmea' column. To initiate these streams, the approximate latitude/longitude rover position is sent to the NTRIP broadcaster. The default values can be change according to your requirement. Double click on 'lat' and 'long' fields, enter the values you wish to send and then hit Enter.</p>"));
1434 _log->setWhatsThis(tr("Records of BNC's activities are shown in the 'Log' tab. The message log covers the communication status between BNC and the NTRIP broadcaster as well as any problems that occur in the communication link, stream availability, stream delay, stream conversion etc."));
1435 _bncFigure->setWhatsThis(tr("The bandwidth consumtion per stream is shown in the 'Throughput' tab in bits per second (bps) or kilo bits per second (kbps)."));
1436 _bncFigureLate->setWhatsThis(tr("The individual latency of observations in each incoming stream is shown in the 'Latency' tab. Streams not carrying observations (i.e. those providing only broadcast ephemeris messages) are not considered here. Note that the calculation of correct latencies requires the clock of the host computer to be properly synchronized."));
1437 _ephV3CheckBox->setWhatsThis(tr("The default format for output of RINEX Navigation data containing Broadcast Ephemeris is RINEX Version 2. Select 'Version 3' if you want to output the ephemeris in RINEX Version 3 format."));
1438 _rnxV3CheckBox->setWhatsThis(tr("The default format for RINEX Observation files is RINEX Version 2. Select 'Version 3' if you want to save the observations in RINEX Version 3 format."));
1439 _miscMountLineEdit->setWhatsThis(tr("<p>Specify a mountpoint to apply any of the options shown below. Enter 'ALL' if you want to apply these options to all configured streams.</p><p>An empty option field (default) means that you don't want BNC to apply any of these options.</p>"));
1440 _scanRTCMCheckBox->setWhatsThis(tr("<p>Tick 'Scan RTCM' to log the numbers of incomming message types as well as contained antenna coordinates, antenna heigt, and antenna descriptor.</p><p>In case of RTCM Version 3 MSM streams, BNC will also log contained RINEX Version 3 observation types.</p>."));
1441 _serialMountPointLineEdit->setWhatsThis(tr("<p>Enter a 'Mountpoint' to forward the corresponding stream to a serial connected receiver.</p>"));
1442 _serialPortNameLineEdit->setWhatsThis(tr("<p>Enter the serial 'Port name' selected for communication with your serial connected receiver. Valid port names are</p><pre>Windows: COM1, COM2<br>Linux: /dev/ttyS0, /dev/ttyS1<br>FreeBSD: /dev/ttyd0, /dev/ttyd1<br>Digital Unix: /dev/tty01, /dev/tty02<br>HP-UX: /dev/tty1p0, /dev/tty2p0<br>SGI/IRIX: /dev/ttyf1, /dev/ttyf2<br>SunOS/Solaris: /dev/ttya, /dev/ttyb</pre><p>Note that you must plug a serial cable in the port defined here before you start BNC.</p>"));
1443 _serialBaudRateComboBox->setWhatsThis(tr("<p>Select a 'Baud rate' for the serial output link.</p><p>Note that your selection must equal the baud rate configured to the serial connected receiver. Note further that using a high baud rate is recommended.</p>"));
1444 _serialParityComboBox->setWhatsThis(tr("<p>Select the 'Parity' for the serial output link.</p><p>Note that your selection must equal the parity selection configured to the serial connected receiver. Note further that parity is often set to 'NONE'.</p>"));
1445 _serialDataBitsComboBox->setWhatsThis(tr("<p>Select the number of 'Data bits' for the serial output link.</p><p>Note that your selection must equal the number of data bits configured to the serial connected receiver. Note further that often 8 data bits are used.</p>"));
1446 _serialStopBitsComboBox->setWhatsThis(tr("<p>Select the number of 'Stop bits' for the serial output link.</p><p>Note that your selection must equal the number of stop bits configured to the serial connected receiver. Note further that often 1 stop bit is used.</p>"));
1447 _serialFlowControlComboBox->setWhatsThis(tr("<p>Select a 'Flow control' for the serial output link.</p><p>Note that your selection must equal the flow control configured to the serial connected receiver. Select 'OFF' if you don't know better.</p>"));
1448 _serialAutoNMEAComboBox->setWhatsThis(tr("<p>Select 'Auto' to automatically forward NMEA-GGA messages coming from your serial connected receiver to the NTRIP broadcaster and/or save them in a file.</p><p>Select 'Manual' only when handling a VRS stream and your serial connected receiver doesn't generate NMEA-GGA messages.</p>"));
1449 _serialFileNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where NMEA messages coming from your serial connected receiver are saved.</p>"));
1450 _serialHeightNMEALineEdit->setWhatsThis(tr("<p>Specify an approximate 'Height' above mean sea level in meter for your VRS to simulate an inital NMEA-GGA message.</p><p>The setting of this option is ignored in case of streams coming from physical reference stations.</p>"));
1451 _pppMountLineEdit->setWhatsThis(tr("<p>Specify an observations stream by its mountpoint from the 'Streams' list compiled below if you want BNC to estimate coordinates for the affected receiver position through a PPP solution. Example: 'FFMJ1'</p><p>Note that PPP in BNC requires to also pull a stream carrying RTCM Version 3 satellite orbit and clock corrections to Broadcast Ephemeris referring to the satellites' Antenna Phase Centers (APC). Stream CLK11 on NTRIP broadcaster products.igs-ip.net is an example.</p><p>Pulling in addition a third stream carrying Broadcast Ephemeris messages in high repetition rate is suggested if such messages are comeing from the receiver in low repetition rate or don't come at all from there.</p>"));
1452 _pppCorrMountLineEdit->setWhatsThis(tr("<p>You must specify an orbit/clock Broadcast Ephemeris corrections stream by its mountpoint from the 'Streams' list below. Example: 'CLK10'. Corrections must refer to satellite Antenna Phase Centers (APC).</p><p>Note that BNC can produce an internal PPP solution from combined Broadcast Ephemeris corrections as specified under 'Combine Corrections' if you introduce keyword 'INTERNAL' as the corrections mountpoint.</p>"));
1453 _pppSPPComboBox->setWhatsThis(tr("<p>Choose between plain Single Point Positioning (SPP) and Precise Point Positioning (PPP) in 'Realtime' or 'Post-Processing' mode.</p><p>When in 'Post-Processing mode:<ul><li>Specifying a RINEX Observation, a RINEX Navigation and a Broadcast Correction file leads to a PPP solution.</li><li>Specifying only a RINEX Observation and a RINEX Navigation file and no Broadcast Correction file leads to a SPP solution.</ul></p>"));
1454 _reqcActionComboBox->setWhatsThis(tr("<p>BNC allows to edit or concatenate RINEX v2 or v3 files or to perform a quality check following UNAVCO's famous 'teqc' program.</p>"));
1455 _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX v2 or v3 files.</p>"));
1456 _pppUsePhaseCheckBox->setWhatsThis(tr("<p>By default BNC applies a PPP solution using an ionosphere free P3 linear combination of code observations.</p><p>Tick 'Use phase obs' for an ionosphere free L3 linear combination of phase observations.</p>"));
1457 _pppEstTropoCheckBox->setWhatsThis(tr("<p>By default BNC does not introduce troposphere parameters when estimating coordinates.</p><p>Tick 'Estimate tropo' to introduce troposphere parameters when estimating coordinates.</p>"));
1458 _pppGLONASSCheckBox->setWhatsThis(tr("<p>By default BNC does not use GLONASS observations in PPP mode.</p><p>Tick 'Use GLONASS' for adding GLONASS observations to GPS and Galileo (optional) in a PPP solution.</p>"));
1459 _pppGalileoCheckBox->setWhatsThis(tr("<p>By default BNC does not use Galileo observations in PPP mode.</p><p>Tick 'Use Galileo' for adding Galileo observations to GPS and GLONASS (optional) in a PPP solution.</p>"));
1460 _pppPlotCoordinates->setWhatsThis(tr("<p>BNC will plot PPP results in the 'PPP Plot' tab as North (red), East (green) and Up (blue) displacements when this option is selected. Values will be either referred to an XYZ reference coordinate (if specified) or referred to the first estimated coordinate. The sliding PPP time series window will cover the period of the latest 5 minutes.</p><p>Note that a PPP time series makes only sense for a stationary operated receiver."));
1461 _mapWinButton->setWhatsThis(tr("<p>You make like to track your rover position using Google Maps or Open Street Map as a background map. Track plots can be produced with BNC in 'Realtime-PPP', 'Realtime-SPP' and 'Post-Processing' mode.</p><p>The 'Open Map' button opens a windows showing a map according to specified options.</p><p>When in 'Post-Processing' mode you should not forget to specify a proxy under the 'Network' tab if that is operated in front of BNC."));
1462 _gmRadioButton->setWhatsThis(tr("<p>Specify Google Maps as the background for your rover positions."));
1463 _osmRadioButton->setWhatsThis(tr("<p>Specify Open Street Map as the background for your rover positions."));
1464 _mapWinDotSizeLineEdit->setWhatsThis(tr("<p>Specify the size of dots showing the rover positions.</p><p>A dot size of '3' may be appropriate. The maximum possible dot size is '10'. An empty option field or a size of '0' would mean that you don't want BNC to show the rover's track on the map.</p>"));
1465 _mapWinDotColorComboBox->setWhatsThis(tr("<p>Specify the color of dots showing the rover track.</p>"));
1466 _mapSpeedSlider->setWhatsThis(tr("<p>With BNC in PPP post-processing mode you can specify the speed of computations as appropriate for visualization. Note that you can adjust 'Speed' on-the-fly while BNC is already processing your observations."));
1467 _pppNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where PPP results are saved as NMEA messages.</p>"));
1468 _pppNMEAPortLineEdit->setWhatsThis(tr("<p>Specify an IP port number to output PPP results as NMEA messages through an IP port.</p>"));
1469 _pppSigCLineEdit->setWhatsThis(tr("<p>Enter a sigma for your code observations in meters.</p><p>The higher the sigma you enter, the less the contribution of code observations to a PPP solution based on a combination of code and phase data. 5.0 (default) is likely to be an appropriate choice.</p>"));
1470 _pppQuickStartLineEdit->setWhatsThis(tr("<p>Enter the lenght of a startup period in seconds for which you want to fix the PPP solution to a known XYZ coordinate as introduced above and adjust a sigma 'XYZ Ini' according to the coordinate's precision. Fixing the coordinate is done in BNC through setting the 'Sigma XYZ Noise' you define below temporarily to zero.</p><p>This so-called Quick-Start option allows the PPP solution to rapidly converge. It requires that the antenna remains unmoved on the know position throughout the startup period.</p><p>A value of 120 is likely to be an appropriate choice for 'Quick-Start'. Default is an empty option field, meaning that you don't want BNC to operate in Quick-Start mode.</p>"));
1471 _pppMaxSolGapLineEdit->setWhatsThis(tr("<p>Specify a 'Maximum Solution Gap' in seconds. Should the time span between two consecutive solutions exceed this limit, the algorithm returns into Quick-Start mode and fixes the introduced reference coordinate for the specified period. A value of '60' seconds could be an appropriate choice.</p><p>This option makes only sense for a stationary operated receiver where solution convergence can be enforced because a good approximation for the rover position is known. Default is an empty option field, meaning that you don't want BNC to return into the Quick-Start mode after failures caused i.e. by longer lasting outages.</p>"));
1472 _pppAudioResponseLineEdit->setWhatsThis(tr("<p>Specify an 'Audio response' threshold in meters. A beep is produced by BNC whenever a horizontal PPP coordinate component differs by more than the threshold value from the marker coordinate.</p><p>Default is an empty option field, meaning that you don't want BNC to produce alarm signals.</p>"));
1473 _pppSigPLineEdit->setWhatsThis(tr("<p>Enter a sigma for your phase observations in meters.</p><p>The higher the sigma you enter, the less the contribution of phase observations to a PPP solutions based on a combination of code and phase data. 0.02 (default) is likely to be an appropriate choice.</p>"));
1474 _pppAverageLineEdit->setWhatsThis(tr("<p>Enter the length of a sliding time window in minutes. BNC will continuously output moving average positions computed from those individual positions obtained most recently throughout this period.</p><p>An empty option field (default) means that you don't want BNC to output moving average positions.</p>"));
1475 _pppSigCrd0->setWhatsThis(tr("<p>Enter a sigma in meters for the initial XYZ coordinate componentes. A value of 100.0 (default) may be an appropriate choice. However, this value may be significantly smaller (i.e. 0.01) when starting for example from a station with known XZY position in Quick-Start mode."));
1476 _pppSigCrdP->setWhatsThis(tr("<p>Enter a sigma in meters for the white noise of estimated XYZ coordinate components. A value of 100.0 (default) may be appropriate considering the potential movement of a rover position.</p>"));
1477 _pppSigTrp0->setWhatsThis(tr("<p>Enter a sigma in meters for the a-priory model based tropospheric delay estimation. A value of 0.1 (default) may be an appropriate choice.</p>"));
1478 _pppSigTrpP->setWhatsThis(tr("<p>Enter a sigma in meters per second to describe the expected variation of the tropospheric effect.</p><p>Supposing 1Hz observation data, a value of 3e-6 (default) would mean that the tropospheric effect may vary for 3600 * 3e-6 = 0.01 meters per hour.</p>"));
1479 _pppRefCrdXLineEdit->setWhatsThis(tr("<p>Enter reference coordinate X of the receiver's position.</p><p>This option only makes sense in static observation conditions.</p>"));
1480 _pppRefCrdYLineEdit->setWhatsThis(tr("<p>Enter reference coordinate Y of the receiver's position.</p><p>This option only makes sens in static observation conditions.</p>"));
1481 _pppRefCrdZLineEdit->setWhatsThis(tr("<p>Enter reference coordinate Z of the receiver's position.</p><p>This option only makes sens in static observation conditions.</p>"));
1482 _pppRefdNLineEdit->setWhatsThis(tr("<p>Enter north antenna excentricity.</p>"));
1483 _pppRefdELineEdit->setWhatsThis(tr("<p>Enter east antenna excentricity.</p>"));
1484 _pppRefdULineEdit->setWhatsThis(tr("<p>Enter up antenna excentricity.</p>"));
1485 _bncFigurePPP->setWhatsThis(tr("PPP time series of North (red), East (green) and Up (blue) coordinate components are shown in the 'PPP Plot' tab when the corresponting option is selected above. Values are either referred to an XYZ reference coordinate (if specified) or referred to the first estimated set of coordinate compoments. The sliding PPP time series window covers the period of the latest 5 minutes."));
1486 _pppSync->setWhatsThis(tr(
1487 "<p> Zero value (or empty field, default) means that BNC processes each epoch of data "
1488 "immediately after its arrival using satellite clock corrections available at "
1489 "that time.</p><p> Non-zero value 'Sync Corr' (i.e. 5) means that the epochs of data "
1490 "are buffered and the processing of each epoch is postponed till the satellite clock "
1491 "corrections not older than 'Sync Corr' seconds are available.<p>"));
1492 _pppAntexFileChooser->setWhatsThis(tr("<p>IGS provides a file containing absolute phase center corrections for GNSS satellite and receiver antennas in ANTEX format. Entering the full path to such an ANTEX file is required for correcting observations for antenna phase center offsets and variations. It allows you to specify the name of your receiver's antenna (as contained in the ANTEX file) to apply such corrections.</p><p>Default is an empty option field meaning that you don't want to correct observations for antenna phase center offsets and variations.</p>"));
1493 _pppAntennaLineEdit->setWhatsThis(tr("<p>Specify the receiver's antenna name as defined in your ANTEX file. Observations will be corrected for the antenna phase center's offset which may result in a reduction of a few centimeters at max. Corrections for phase center variations are not yet applied by BNC. The specified name must consist of 20 characters. Add trailing blanks if the antenna name has less then 20 characters.</p><p>Default is an empty option field meaning that you don't want to correct observations for antenna phase center offsets.</p>"));
1494 _cmbTable->setWhatsThis(tr("<p>BNC allows to process several orbit and clock corrections streams in real-time to produce, encode, upload and save a combination of correctors coming from various providers. Hit the 'Add Row' button, double click on the 'Mountpoint' field to enter a Broadcast Ephemeris corrections mountpoint from the 'Streams' section below and hit Enter. Then double click on the 'AC Name' field to enter your choice of an abbreviation for the Analysis Center (AC) providing the stream. Finally, double click on the 'Weight' field to enter the weight to be applied for this stream in the combination.<ul><li>Note that an appropriate 'Wait for full corr epoch' value needs to be specified for the combination under the 'Broadcast Corrections' tab. A value of 15 seconds would make sense there if the update rate of incoming clock corrections is i.e. 10 seconds.</li><li>Note also that you need to tick 'Use GLONASS' which is part ot the 'PPP (2)' panel in case you want to produce an GPS plus GLONASS combination.</li></ul></p><p>Note further that the orbit information in the final combination stream is just copied from one of the incoming streams. The stream used for providing the orbits may vary over time: if the orbit providing stream has an outage then BNC switches to the next remaining stream for getting hold of the orbit information.</p><p>The combination process requires Broadcast Ephemeris. Besides the orbit and clock corrections stream(s) BNC should therefore pull a stream carrying Broadcast Ephemeris in the form of RTCM Version 3 messages.</p><p>It is possible to specify only one Broadcast Ephemeris corrections stream in the combination table. Instead of combining corrections BNC will then merge them with Broadcast Ephemeris to save results in SP3 and/or Clock RINEX format."));
1495 _cmbMaxresLineEdit->setWhatsThis(tr("<p>BNC combines all incoming clocks according to specified weights. Individual clock estimates that differ by more than 'Maximal Residuum' meters from the average of all clocks will be ignored.<p></p>It is suggested to specify a value of about 0.2 m for the Kalman filter combination approach and a value of about 3.0 meters for the Single-Epoch combination approach.</p><p>Default is a value of '999.0'.</p>"));
1496 _cmbSamplSpinBox->setWhatsThis(tr("<p>Specify a combination sampling interval. Clock and orbit corrections will be produced following that interval. A value of 10 sec may be an appropriate choice.</p>"));
1497 _cmbMethodComboBox->setWhatsThis(tr("<p>Select a clock combination approach. Options are 'Single-Epoch' and Kalman 'Filter'. It is suggested to use the Kalman filter approach for the purpose of Precise Point Positioning.</p>"));
1498 _uploadTable->setWhatsThis(tr("<p>BNC can upload clock and orbit corrections to broadcast ephemeris (Broadcast Corrections) in RTCM Version 3 SSR format. You may have a situation where clocks and orbits come from an external Real-time Network Engine (1) or a situation where clock and orbit corrections are combined within BNC (2).</p><p>(1) BNC identifies a stream as coming from a Real-time Network Engine if its format is specified as 'RTNET' and hence its decoder string in the 'Streams' canvas is 'RTNET'. It encodes and uploads that stream to the specified NTRIP broadcaster</p><p>(2) BNC understands that it is expected to encode and upload combined Broadcast Ephemeris corrections if you specify correction streams in the 'Combine Corrections' stream table.</p><p>Hit the 'Add Row' button, double click on the 'Host' field to enter the IP or URL of an NTRIP broadcaster and hit Enter. Then double click on the 'Port', 'Mount' and 'Password' fields to enter the NTRIP broadcaster IP port (default is 80), the mountpoint and the stream upload password. An empty 'Host' option field means that you don't want to upload corrections.</p><p>Select a target coordinate reference system (e.g. IGS08) for outgoing clock and orbit corrections.</p><p>By default orbit and clock corrections refer to Antenna Phase Center (APC). Tick 'CoM' to refer uploaded corrections to Center of Mass instead of APC.</p><p>Specify a path for saving the generated Broadcast Corrections plus Broadcast Ephemeris as SP3 orbit files. If the specified directory does not exist, BNC will not create SP3 orbit files. The following is a path example for a Linux system:<br>/home/user/BNC${GPSWD}.sp3<br>Note that '${GPSWD}' produces the GPS Week and Day number in the file name.</p><ul><li>As an SP3 file contents should be referred to the satellites Center of Mass (CoM) while correctors are referred to the satellites Antenna Phase Center (APC), an offset has to be applied which is available from an IGS ANTEX file. You should therefore specify the 'ANTEX File' path under tab 'PPP (2)' if you want to save the stream contents in SP3 format. If you don't specify an 'ANTEX File' path there, the SP3 file contents will be referred to the satellites APCs.</li></ul></p><p>Specify a path for saving the generated Broadcast Correction clocks plus Broadcast Ephemeris clocks as Clock RINEX files. If the specified directory does not exist, BNC will not create Clock RINEX files. The following is a path example for a Linux system:<br>/home/user/BNC${GPSWD}.clk<br>Note that '${GPSWD}' produces the GPS Week and Day number in the file name.</p><p>Specify finally an SSR Provider ID number, an SSR Solution ID number and an Issue of Data SSR number.</p><p>In case the 'Combine Corrections' table contains only one Broadcast Corrections stream, BNC will merge that stream with Broadcast Ephemeris to save results in files specified here through SP3 and/or Clock RINEX file path. In such a case you should define only the SP3 and Clock RINEX file path and no further options in the 'Upload Corrections' table.</p>"));
1499 _postObsFileChooser->setWhatsThis(tr("Full path to RINEX v2/v3 Observation file."));
1500 _postNavFileChooser->setWhatsThis(tr("Full path to RINEX v2/v3 Navigation file."));
1501 _postCorrFileChooser->setWhatsThis(tr("Full path to Broadcast Corrections file as previously saved with BNC in plain ASCII format."));
1502 _postOutLineEdit->setWhatsThis(tr("Full path to file with post processing PPP results. "));
1503 addCmbRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the mountpoints table."));
1504 delCmbRowButton->setWhatsThis(tr("Hit 'Delete' button to delete the highlighted line from the mountpoints table."));
1505 addUploadRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the stream upload table."));
1506 delUploadRowButton->setWhatsThis(tr("Hit 'Del Row' button to delete the highlighted line from the stream upload table."));
1507 _uploadIntrComboBox->setWhatsThis(tr("Select the length of the SP3 and Clock RINEX files."));
1508 _uploadSamplRtcmEphCorrSpinBox->setWhatsThis(tr("Select the stream's orbit correction sampling interval in seconds. A value of zero '0' tells BNC to upload all available orbit and clock correction samples together in combined messages."));
1509 _uploadSamplClkRnxSpinBox->setWhatsThis(tr("Select the Clock RINEX file sampling interval in seconds. A value of zero '0' tells BNC to store all available samples into Clock RINEX files."));
1510 _uploadSamplSp3SpinBox->setWhatsThis(tr("Select the SP3 orbit file sampling interval in minutes. A value of zero '0' tells BNC to store all available samples into SP3 orbit files."));
1511 setUploadTrafoButton->setWhatsThis(tr("Hit 'Custom Trafo' to specify your own 14 parameter Helmert Transformation instead of selecting a predefined transformation through 'System' button."));
1512
1513 _uploadEphHostLineEdit->setWhatsThis(tr("BNC can upload a Broadcast Ephemeris stream in RTCM Version 3 format. Specify the host IP of an NTRIP Broadcaster to upload the stream. An empty option field means that you don't want to upload Broadcast Ephemeris."));
1514 _uploadEphPortLineEdit->setWhatsThis(tr("Specify the IP port of an NTRIP Broadcaster to upload the stream. Default is port 80."));
1515 _uploadEphMountpointLineEdit->setWhatsThis(tr("Specify the mounpoint for stream upload to an NTRIP Broadcaster."));
1516 _uploadEphPasswordLineEdit->setWhatsThis(tr("Specify the stream upload password protecting the mounpoint on an NTRIP Broadcaster."));
1517 _uploadEphSampleSpinBox->setWhatsThis(tr("Select the Broadcast Ephemeris sampling interval in seconds. Defaut is '5' meaning that a complete set of Broadcast Ephemeris is uploaded every 5 seconds."));
1518 _uploadEphBytesCounter->setWhatsThis(tr("BNC shows the amount of data uploaded through this stream."));
1519
1520 _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1521 _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
1522 _actMapMountPoints->setWhatsThis(tr("<p> Draw distribution map of stream selection presented in the 'Streams' canvas. Use the mouse to zoom in or out.</p><p>Left button: Draw rectangle to zoom in.<br>Right button: Zoom out.<br>Middle button: Zoom back.</p>"));
1523
1524 _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1525 _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1526// Weber
1527
1528 // Enable/Disable all Widgets
1529 // --------------------------
1530 slotBncTextChanged();
1531 enableStartStop();
1532
1533 // Auto start
1534 // ----------
1535 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1536 slotStart();
1537 }
1538}
1539
1540// Destructor
1541////////////////////////////////////////////////////////////////////////////
1542bncWindow::~bncWindow() {
1543 delete _caster;
1544 delete _casterEph;
1545}
1546
1547//
1548////////////////////////////////////////////////////////////////////////////
1549void bncWindow::populateMountPointsTable() {
1550
1551 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1552 _mountPointsTable->removeRow(iRow);
1553 }
1554
1555 bncSettings settings;
1556
1557 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1558 int iRow = 0;
1559 while (it.hasNext()) {
1560 QStringList hlp = it.next().split(" ");
1561 if (hlp.size() < 5) continue;
1562 _mountPointsTable->insertRow(iRow);
1563
1564 QUrl url(hlp[0]);
1565
1566 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1567 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1568 QString nmea(hlp[4]);
1569 if (hlp[5] == "S") {
1570 fullPath = hlp[0].replace(0,2,"");
1571 }
1572 QString ntripVersion = "2";
1573 if (hlp.size() >= 6) {
1574 ntripVersion = (hlp[5]);
1575 }
1576
1577 QTableWidgetItem* it;
1578 it = new QTableWidgetItem(url.userInfo());
1579 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1580 _mountPointsTable->setItem(iRow, 0, it);
1581
1582 it = new QTableWidgetItem(fullPath);
1583 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1584 _mountPointsTable->setItem(iRow, 1, it);
1585
1586 it = new QTableWidgetItem(format);
1587 _mountPointsTable->setItem(iRow, 2, it);
1588
1589 if (nmea == "yes") {
1590 it = new QTableWidgetItem(latitude);
1591 _mountPointsTable->setItem(iRow, 3, it);
1592 it = new QTableWidgetItem(longitude);
1593 _mountPointsTable->setItem(iRow, 4, it);
1594 } else {
1595 it = new QTableWidgetItem(latitude);
1596 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1597 _mountPointsTable->setItem(iRow, 3, it);
1598 it = new QTableWidgetItem(longitude);
1599 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1600 _mountPointsTable->setItem(iRow, 4, it);
1601 }
1602
1603 it = new QTableWidgetItem(nmea);
1604 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1605 _mountPointsTable->setItem(iRow, 5, it);
1606
1607 it = new QTableWidgetItem(ntripVersion);
1608 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1609 _mountPointsTable->setItem(iRow, 6, it);
1610
1611 bncTableItem* bncIt = new bncTableItem();
1612 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1613 _mountPointsTable->setItem(iRow, 7, bncIt);
1614
1615 iRow++;
1616 }
1617
1618 _mountPointsTable->sortItems(1);
1619
1620 enableStartStop();
1621}
1622
1623// Retrieve Table
1624////////////////////////////////////////////////////////////////////////////
1625void bncWindow::slotAddMountPoints() {
1626
1627 bncSettings settings;
1628 QString proxyHost = settings.value("proxyHost").toString();
1629 int proxyPort = settings.value("proxyPort").toInt();
1630 if (proxyHost != _proxyHostLineEdit->text() ||
1631 proxyPort != _proxyPortLineEdit->text().toInt()) {
1632 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1633 "changed. Use the new ones?",
1634 QMessageBox::Yes, QMessageBox::No,
1635 QMessageBox::NoButton);
1636 if (iRet == QMessageBox::Yes) {
1637 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1638 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1639 }
1640 }
1641
1642 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1643 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1644
1645 QMessageBox msgBox;
1646 msgBox.setIcon(QMessageBox::Question);
1647 msgBox.setWindowTitle("Add Stream");
1648 msgBox.setText("Add stream(s) coming from:");
1649
1650 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1651 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1652 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1653 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1654 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1655
1656 msgBox.exec();
1657
1658 if (msgBox.clickedButton() == buttonNtrip) {
1659 bncTableDlg* dlg = new bncTableDlg(this);
1660 dlg->move(this->pos().x()+50, this->pos().y()+50);
1661 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1662 this, SLOT(slotNewMountPoints(QStringList*)));
1663 dlg->exec();
1664 delete dlg;
1665 } else if (msgBox.clickedButton() == buttonIP) {
1666 bncIpPort* ipp = new bncIpPort(this);
1667 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1668 this, SLOT(slotNewMountPoints(QStringList*)));
1669 ipp->exec();
1670 delete ipp;
1671 } else if (msgBox.clickedButton() == buttonUDP) {
1672 bncUdpPort* udp = new bncUdpPort(this);
1673 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1674 this, SLOT(slotNewMountPoints(QStringList*)));
1675 udp->exec();
1676 delete udp;
1677 } else if (msgBox.clickedButton() == buttonSerial) {
1678 bncSerialPort* sep = new bncSerialPort(this);
1679 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1680 this, SLOT(slotNewMountPoints(QStringList*)));
1681 sep->exec();
1682 delete sep;
1683 } else if (msgBox.clickedButton() == buttonCancel) {
1684 // Cancel
1685 }
1686
1687 enableStartStop();
1688}
1689
1690// Delete Selected Mount Points
1691////////////////////////////////////////////////////////////////////////////
1692void bncWindow::slotDeleteMountPoints() {
1693
1694 int nRows = _mountPointsTable->rowCount();
1695 bool flg[nRows];
1696 for (int iRow = 0; iRow < nRows; iRow++) {
1697 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1698 flg[iRow] = true;
1699 }
1700 else {
1701 flg[iRow] = false;
1702 }
1703 }
1704 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1705 if (flg[iRow]) {
1706 _mountPointsTable->removeRow(iRow);
1707 }
1708 }
1709 _actDeleteMountPoints->setEnabled(false);
1710
1711 enableStartStop();
1712}
1713
1714// New Mount Points Selected
1715////////////////////////////////////////////////////////////////////////////
1716void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1717 int iRow = 0;
1718 QListIterator<QString> it(*mountPoints);
1719 while (it.hasNext()) {
1720 QStringList hlp = it.next().split(" ");
1721 QUrl url(hlp[0]);
1722 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1723 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1724 QString nmea(hlp[4]);
1725 if (hlp[5] == "S") {
1726 fullPath = hlp[0].replace(0,2,"");
1727 }
1728 QString ntripVersion = "2";
1729 if (hlp.size() >= 6) {
1730 ntripVersion = (hlp[5]);
1731 }
1732
1733 _mountPointsTable->insertRow(iRow);
1734
1735 QTableWidgetItem* it;
1736 it = new QTableWidgetItem(url.userInfo());
1737 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1738 _mountPointsTable->setItem(iRow, 0, it);
1739
1740 it = new QTableWidgetItem(fullPath);
1741 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1742 _mountPointsTable->setItem(iRow, 1, it);
1743
1744 it = new QTableWidgetItem(format);
1745 _mountPointsTable->setItem(iRow, 2, it);
1746
1747 if (nmea == "yes") {
1748 it = new QTableWidgetItem(latitude);
1749 _mountPointsTable->setItem(iRow, 3, it);
1750 it = new QTableWidgetItem(longitude);
1751 _mountPointsTable->setItem(iRow, 4, it);
1752 } else {
1753 it = new QTableWidgetItem(latitude);
1754 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1755 _mountPointsTable->setItem(iRow, 3, it);
1756 it = new QTableWidgetItem(longitude);
1757 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1758 _mountPointsTable->setItem(iRow, 4, it);
1759 }
1760
1761 it = new QTableWidgetItem(nmea);
1762 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1763 _mountPointsTable->setItem(iRow, 5, it);
1764
1765 it = new QTableWidgetItem(ntripVersion);
1766 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1767 _mountPointsTable->setItem(iRow, 6, it);
1768
1769 bncTableItem* bncIt = new bncTableItem();
1770 _mountPointsTable->setItem(iRow, 7, bncIt);
1771
1772 iRow++;
1773 }
1774 _mountPointsTable->hideColumn(0);
1775 _mountPointsTable->sortItems(1);
1776 delete mountPoints;
1777
1778 enableStartStop();
1779}
1780
1781// Save Options (serialize)
1782////////////////////////////////////////////////////////////////////////////
1783void bncWindow::slotSaveOptions() {
1784 saveOptions();
1785 bncSettings settings;
1786 settings.sync();
1787}
1788
1789// Save Options (memory only)
1790////////////////////////////////////////////////////////////////////////////
1791void bncWindow::saveOptions() {
1792
1793 QStringList mountPoints;
1794 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1795
1796 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1797 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1798 "@" + _mountPointsTable->item(iRow, 1)->text() );
1799
1800 mountPoints.append(url.toString() + " " +
1801 _mountPointsTable->item(iRow, 2)->text()
1802 + " " + _mountPointsTable->item(iRow, 3)->text()
1803 + " " + _mountPointsTable->item(iRow, 4)->text()
1804 + " " + _mountPointsTable->item(iRow, 5)->text()
1805 + " " + _mountPointsTable->item(iRow, 6)->text());
1806 } else {
1807 mountPoints.append(
1808 "//" + _mountPointsTable->item(iRow, 1)->text()
1809 + " " + _mountPointsTable->item(iRow, 2)->text()
1810 + " " + _mountPointsTable->item(iRow, 3)->text()
1811 + " " + _mountPointsTable->item(iRow, 4)->text()
1812 + " " + _mountPointsTable->item(iRow, 5)->text()
1813 + " " + _mountPointsTable->item(iRow, 6)->text());
1814 }
1815 }
1816
1817 QStringList combineStreams;
1818 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1819 QString hlp;
1820 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1821 if (_cmbTable->item(iRow, iCol)) {
1822 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1823 }
1824 }
1825 if (!hlp.isEmpty()) {
1826 combineStreams << hlp;
1827 }
1828 }
1829
1830 QStringList uploadMountpointsOut;
1831 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1832 QString hlp;
1833 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1834 if (_uploadTable->cellWidget(iRow, iCol) &&
1835 (iCol == 3 || iCol == 4 || iCol == 5)) {
1836 if (iCol == 3) {
1837 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1838 hlp += passwd->text() + ",";
1839 }
1840 else if (iCol == 4) {
1841 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1842 hlp += system->currentText() + ",";
1843 }
1844 else if (iCol == 5) {
1845 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1846 QString state; state.setNum(com->checkState());
1847 hlp += state + ",";
1848 }
1849 }
1850 else if (_uploadTable->item(iRow, iCol)) {
1851 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1852 }
1853 }
1854 if (!hlp.isEmpty()) {
1855 uploadMountpointsOut << hlp;
1856 }
1857 }
1858
1859 bncSettings settings;
1860
1861 settings.setValue("startTab", _aogroup->currentIndex());
1862 settings.setValue("statusTab", _loggroup->currentIndex());
1863 settings.setValue("mountPoints", mountPoints);
1864// Network
1865 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1866 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1867 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1868 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1869// General
1870 settings.setValue("logFile", _logFileLineEdit->text());
1871 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1872 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1873 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1874 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1875// RINEX Observations
1876 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1877 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1878 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1879 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1880 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1881 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1882// RINEX Ephemeris
1883 settings.setValue("ephPath", _ephPathLineEdit->text());
1884 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1885 settings.setValue("outEphPort", _outEphPortLineEdit->text());
1886 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1887// Broadcast Corrections
1888 settings.setValue("corrPath", _corrPathLineEdit->text());
1889 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1890 settings.setValue("corrPort", _corrPortLineEdit->text());
1891 settings.setValue("corrTime", _corrTimeSpinBox->value());
1892// Feed Engine
1893 settings.setValue("outPort", _outPortLineEdit->text());
1894 settings.setValue("waitTime", _waitTimeSpinBox->value());
1895 settings.setValue("binSampl", _binSamplSpinBox->value());
1896 settings.setValue("outFile", _outFileLineEdit->text());
1897 settings.setValue("outUPort", _outUPortLineEdit->text());
1898// Serial Output
1899 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1900 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1901 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1902 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1903 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1904 settings.setValue("serialParity", _serialParityComboBox->currentText());
1905 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1906 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1907 settings.setValue("serialFileNMEA",_serialFileNMEALineEdit->text());
1908 settings.setValue("serialHeightNMEA",_serialHeightNMEALineEdit->text());
1909// Outages
1910 settings.setValue("obsRate", _obsRateComboBox->currentText());
1911 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1912 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1913 settings.setValue("adviseScript",_adviseScriptLineEdit->text());
1914// Miscellaneous
1915 settings.setValue("miscMount", _miscMountLineEdit->text());
1916 settings.setValue("perfIntr", _perfIntrComboBox->currentText());
1917 settings.setValue("scanRTCM", _scanRTCMCheckBox->checkState());
1918// PPPP
1919 settings.setValue("pppSPP", _pppSPPComboBox->currentText());
1920 settings.setValue("pppMount", _pppMountLineEdit->text());
1921 settings.setValue("pppCorrMount",_pppCorrMountLineEdit->text());
1922 settings.setValue("pppRefCrdX", _pppRefCrdXLineEdit->text());
1923 settings.setValue("pppRefCrdY", _pppRefCrdYLineEdit->text());
1924 settings.setValue("pppRefCrdZ", _pppRefCrdZLineEdit->text());
1925 settings.setValue("pppRefdN", _pppRefdNLineEdit->text());
1926 settings.setValue("pppRefdE", _pppRefdELineEdit->text());
1927 settings.setValue("pppRefdU", _pppRefdULineEdit->text());
1928 settings.setValue("nmeaFile", _pppNMEALineEdit->text());
1929 settings.setValue("nmeaPort", _pppNMEAPortLineEdit->text());
1930 settings.setValue("pppPlotCoordinates", _pppPlotCoordinates->checkState());
1931 settings.setValue("useOsmMap", _osmRadioButton->isChecked());
1932 settings.setValue("mapWinDotSize", _mapWinDotSizeLineEdit->text());
1933 settings.setValue("mapWinDotColor", _mapWinDotColorComboBox->currentText());
1934 settings.setValue("mapSpeed", _mapSpeedSlider->value());
1935 settings.setValue("postObsFile", _postObsFileChooser->fileName());
1936 settings.setValue("postNavFile", _postNavFileChooser->fileName());
1937 settings.setValue("postCorrFile", _postCorrFileChooser->fileName());
1938 settings.setValue("postOutFile", _postOutLineEdit->text());
1939 settings.setValue("pppAntenna", _pppAntennaLineEdit->text());
1940 settings.setValue("pppAntex", _pppAntexFileChooser->fileName());
1941 settings.setValue("pppUsePhase", _pppUsePhaseCheckBox->checkState());
1942 settings.setValue("pppEstTropo", _pppEstTropoCheckBox->checkState());
1943 settings.setValue("pppGLONASS", _pppGLONASSCheckBox->checkState());
1944 settings.setValue("pppGalileo", _pppGalileoCheckBox->checkState());
1945 settings.setValue("pppSync", _pppSync->text());
1946 settings.setValue("pppAverage", _pppAverageLineEdit->text());
1947 settings.setValue("pppQuickStart", _pppQuickStartLineEdit->text());
1948 settings.setValue("pppMaxSolGap", _pppMaxSolGapLineEdit->text());
1949 settings.setValue("pppAudioResponse", _pppAudioResponseLineEdit->text());
1950 settings.setValue("pppSigmaCode",_pppSigCLineEdit->text());
1951 settings.setValue("pppSigmaPhase",_pppSigPLineEdit->text());
1952 settings.setValue("pppSigCrd0",_pppSigCrd0->text());
1953 settings.setValue("pppSigCrdP",_pppSigCrdP->text());
1954 settings.setValue("pppSigTrp0",_pppSigTrp0->text());
1955 settings.setValue("pppSigTrpP",_pppSigTrpP->text());
1956// Reqc
1957 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1958 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1959 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1960 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1961 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1962 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
1963 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
1964 settings.setValue("reqcSkyPlotSystems", _reqcSkyPlotSystems->currentText());
1965// Combine Corrections
1966 if (!combineStreams.isEmpty()) {
1967 settings.setValue("combineStreams", combineStreams);
1968 }
1969 else {
1970 settings.setValue("combineStreams", "");
1971 }
1972 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1973 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1974 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1975// Upload Corrections
1976 if (!uploadMountpointsOut.isEmpty()) {
1977 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1978 }
1979 else {
1980 settings.setValue("uploadMountpointsOut", "");
1981 }
1982 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1983 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1984 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1985 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
1986// Upload Ephemeris
1987 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1988 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
1989 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
1990 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1991 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
1992
1993#ifdef RTROVER_INTERFACE
1994 settings.setValue("rtroverMode", _rtroverModeComboBox->currentText());
1995 settings.setValue("rtroverRoverMount", _rtroverRoverMountLineEdit->text());
1996 settings.setValue("rtroverCorrMount", _rtroverCorrMountLineEdit->text());
1997 settings.setValue("rtroverBaseMount", _rtroverBaseMountLineEdit->text());
1998 settings.setValue("rtroverRoverRefCrdX", _rtroverRoverRefCrdXLineEdit->text());
1999 settings.setValue("rtroverRoverRefCrdY", _rtroverRoverRefCrdYLineEdit->text());
2000 settings.setValue("rtroverRoverRefCrdZ", _rtroverRoverRefCrdZLineEdit->text());
2001 settings.setValue("rtroverBaseRefCrdX", _rtroverBaseRefCrdXLineEdit->text());
2002 settings.setValue("rtroverBaseRefCrdY", _rtroverBaseRefCrdYLineEdit->text());
2003 settings.setValue("rtroverBaseRefCrdZ", _rtroverBaseCrdZLineEdit->text());
2004 settings.setValue("rtroverRoverDN", _rtroverRoverDNLineEdit->text());
2005 settings.setValue("rtroverRoverDE", _rtroverRoverDELineEdit->text());
2006 settings.setValue("rtroverRoverDU", _rtroverRoverDULineEdit->text());
2007 settings.setValue("rtroverBaseDN", _rtroverBaseDNLineEdit->text());
2008 settings.setValue("rtroverBaseDE", _rtroverBaseDELineEdit->text());
2009 settings.setValue("rtroverBaseDU", _rtroverBaseDULineEdit->text());
2010 settings.setValue("rtroverRoverAntenna", _rtroverRoverAntennaLineEdit->text());
2011 settings.setValue("rtroverBaseAntenna", _rtroverBaseAntennaLineEdit->text());
2012 settings.setValue("rtroverAntex", _rtroverAntexFileChooser->fileName());
2013 settings.setValue("rtroverOutput", _rtroverOutputLineEdit->text());
2014#endif
2015
2016 if (_caster) {
2017 _caster->readMountPoints();
2018 }
2019}
2020
2021// All get slots terminated
2022////////////////////////////////////////////////////////////////////////////
2023void bncWindow::slotGetThreadsFinished() {
2024 BNC_CORE->slotMessage("All Get Threads Terminated", true);
2025 delete _caster; _caster = 0;
2026 delete _casterEph; _casterEph = 0;
2027 _runningRealTime = false;
2028}
2029
2030// Start It!
2031////////////////////////////////////////////////////////////////////////////
2032void bncWindow::slotStart() {
2033 saveOptions();
2034 if ( _pppSPPComboBox->currentText() == "Post-Processing" ) {
2035 startPostProcessingPPP();
2036 }
2037 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
2038 startPostProcessingReqc();
2039 }
2040 else {
2041 startRealTime();
2042 }
2043}
2044
2045// Start Real-Time (Retrieve Data etc.)
2046////////////////////////////////////////////////////////////////////////////
2047void bncWindow::startRealTime() {
2048
2049 _runningRealTime = true;
2050
2051 _bncFigurePPP->reset();
2052
2053 _actDeleteMountPoints->setEnabled(false);
2054
2055 enableStartStop();
2056
2057 _caster = new bncCaster(_outFileLineEdit->text(),
2058 _outPortLineEdit->text().toInt());
2059
2060 BNC_CORE->setPort(_outEphPortLineEdit->text().toInt());
2061 BNC_CORE->setPortCorr(_corrPortLineEdit->text().toInt());
2062 BNC_CORE->initCombination();
2063
2064 connect(_caster, SIGNAL(getThreadsFinished()),
2065 this, SLOT(slotGetThreadsFinished()));
2066
2067 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
2068 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
2069
2070 BNC_CORE->slotMessage("========== Start BNC v" BNCVERSION " =========", true);
2071
2072 bncSettings settings;
2073
2074 QDir rnxdir(settings.value("rnxPath").toString());
2075 if (!rnxdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations directory", true);
2076
2077 QString rnx_file = settings.value("rnxScript").toString();
2078 if ( !rnx_file.isEmpty() ) {
2079 QFile rnxfile(settings.value("rnxScript").toString());
2080 if (!rnxfile.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations script", true);
2081 }
2082
2083 QDir ephdir(settings.value("ephPath").toString());
2084 if (!ephdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Ephemeris directory", true);
2085
2086 QDir corrdir(settings.value("corrPath").toString());
2087 if (!corrdir.exists()) BNC_CORE->slotMessage("Cannot find Broadcast Corrections directory", true);
2088
2089 QString advise_file = settings.value("adviseScript").toString();
2090 if ( !advise_file.isEmpty() ) {
2091 QFile advisefile(settings.value("adviseScript").toString());
2092 if (!advisefile.exists()) BNC_CORE->slotMessage("Cannot find Outages script", true);
2093 }
2094
2095 QString ant_file = settings.value("pppAntex").toString();
2096 if ( !ant_file.isEmpty() ) {
2097 QFile anxfile(settings.value("pppAntex").toString());
2098 if (!anxfile.exists()) BNC_CORE->slotMessage("Cannot find IGS ANTEX file", true);
2099 }
2100
2101 _caster->readMountPoints();
2102
2103 _casterEph = new bncEphUploadCaster();
2104 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
2105 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
2106}
2107
2108// Retrieve Data
2109////////////////////////////////////////////////////////////////////////////
2110void bncWindow::slotStop() {
2111 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving data?",
2112 QMessageBox::Yes, QMessageBox::No,
2113 QMessageBox::NoButton);
2114 if (iRet == QMessageBox::Yes) {
2115 BNC_CORE->stopCombination();
2116 delete _caster; _caster = 0;
2117 delete _casterEph; _casterEph = 0;
2118 _runningRealTime = false;
2119 enableStartStop();
2120 }
2121}
2122
2123// Close Application gracefully
2124////////////////////////////////////////////////////////////////////////////
2125void bncWindow::closeEvent(QCloseEvent* event) {
2126
2127 int iRet = QMessageBox::question(this, "Close", "Save Options?",
2128 QMessageBox::Yes, QMessageBox::No,
2129 QMessageBox::Cancel);
2130
2131 if (iRet == QMessageBox::Cancel) {
2132 event->ignore();
2133 return;
2134 }
2135 else if (iRet == QMessageBox::Yes) {
2136 slotSaveOptions();
2137 }
2138
2139 if (_postProcessing) {
2140 _postProcessing->terminate();
2141 }
2142
2143 QMainWindow::closeEvent(event);
2144}
2145
2146// User changed the selection of mountPoints
2147////////////////////////////////////////////////////////////////////////////
2148void bncWindow::slotSelectionChanged() {
2149 if (_mountPointsTable->selectedItems().isEmpty()) {
2150 _actDeleteMountPoints->setEnabled(false);
2151 }
2152 else {
2153 _actDeleteMountPoints->setEnabled(true);
2154 }
2155}
2156
2157// Display Program Messages
2158////////////////////////////////////////////////////////////////////////////
2159void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
2160
2161#ifdef DEBUG_RTCM2_2021
2162 const int maxBufferSize = 1000;
2163#else
2164 const int maxBufferSize = 10000;
2165#endif
2166
2167 if (! showOnScreen ) {
2168 return;
2169 }
2170
2171 QString txt = _log->toPlainText() + "\n" +
2172 QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg;
2173 _log->clear();
2174 _log->append(txt.right(maxBufferSize));
2175}
2176
2177// About Message
2178////////////////////////////////////////////////////////////////////////////
2179void bncWindow::slotAbout() {
2180 new bncAboutDlg(0);
2181}
2182
2183//Flowchart
2184////////////////////////////////////////////////////////////////////////////
2185void bncWindow::slotFlowchart() {
2186 new bncFlowchartDlg(0);
2187}
2188
2189// Help Window
2190////////////////////////////////////////////////////////////////////////////
2191void bncWindow::slotHelp() {
2192 QUrl url;
2193 url.setPath(":bnchelp.html");
2194 new bncHlpDlg(0, url);
2195}
2196
2197// Select Fonts
2198////////////////////////////////////////////////////////////////////////////
2199void bncWindow::slotFontSel() {
2200 bool ok;
2201 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
2202 if (ok) {
2203 bncSettings settings;
2204 settings.setValue("font", newFont.toString());
2205 QApplication::setFont(newFont);
2206 int ww = QFontMetrics(newFont).width('w');
2207 setMinimumSize(60*ww, 80*ww);
2208 resize(60*ww, 80*ww);
2209 }
2210}
2211
2212// Whats This Help
2213void bncWindow::slotWhatsThis() {
2214 QWhatsThis::enterWhatsThisMode();
2215}
2216
2217//
2218////////////////////////////////////////////////////////////////////////////
2219void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
2220 _threads = threads;
2221
2222 _bncFigure->updateMountPoints();
2223 _bncFigureLate->updateMountPoints();
2224
2225 populateMountPointsTable();
2226 bncSettings settings;
2227 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
2228 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
2229 QListIterator<bncGetThread*> iTh(threads);
2230 while (iTh.hasNext()) {
2231 bncGetThread* thread = iTh.next();
2232 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
2233 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
2234 "@" + _mountPointsTable->item(iRow, 1)->text() );
2235 if (url == thread->mountPoint() &&
2236 _mountPointsTable->item(iRow, 3)->text() == thread->latitude() &&
2237 _mountPointsTable->item(iRow, 4)->text() == thread->longitude() ) {
2238 ((bncTableItem*) _mountPointsTable->item(iRow, 7))->setGetThread(thread);
2239 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
2240 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2241 connect(thread, SIGNAL(newBytes(QByteArray, double)),
2242 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2243 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
2244 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2245 connect(thread, SIGNAL(newLatency(QByteArray, double)),
2246 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2247 if ( Qt::CheckState(settings.value("pppPlotCoordinates").toInt()) == Qt::Checked) {
2248 disconnect(thread,
2249 SIGNAL(newPosition(bncTime, double, double, double)),
2250 _bncFigurePPP,
2251 SLOT(slotNewPosition(bncTime, double, double, double)));
2252 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2253 _bncFigurePPP,
2254 SLOT(slotNewPosition(bncTime, double, double, double)));
2255 }
2256#ifdef QT_WEBKIT
2257 if (_mapWin) {
2258 disconnect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2259 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2260 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2261 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2262 }
2263#endif
2264 break;
2265 }
2266 }
2267 }
2268}
2269
2270//
2271////////////////////////////////////////////////////////////////////////////
2272void bncWindow::CreateMenu() {
2273 // Create Menus
2274 // ------------
2275 _menuFile = menuBar()->addMenu(tr("&File"));
2276 _menuFile->addAction(_actFontSel);
2277 _menuFile->addSeparator();
2278 _menuFile->addAction(_actSaveOpt);
2279 _menuFile->addSeparator();
2280 _menuFile->addAction(_actQuit);
2281
2282 _menuHlp = menuBar()->addMenu(tr("&Help"));
2283 _menuHlp->addAction(_actHelp);
2284 _menuHlp->addAction(_actFlowchart);
2285 _menuHlp->addAction(_actAbout);
2286}
2287
2288// Toolbar
2289////////////////////////////////////////////////////////////////////////////
2290void bncWindow::AddToolbar() {
2291 QToolBar* toolBar = new QToolBar;
2292 addToolBar(Qt::BottomToolBarArea, toolBar);
2293 toolBar->setMovable(false);
2294 toolBar->addAction(_actAddMountPoints);
2295 toolBar->addAction(_actDeleteMountPoints);
2296 toolBar->addAction(_actMapMountPoints);
2297 toolBar->addAction(_actStart);
2298 toolBar->addAction(_actStop);
2299 toolBar->addWidget(new QLabel(" "));
2300 toolBar->addAction(_actwhatsthis);
2301}
2302
2303// About
2304////////////////////////////////////////////////////////////////////////////
2305bncAboutDlg::bncAboutDlg(QWidget* parent) :
2306 QDialog(parent) {
2307
2308 QTextBrowser* tb = new QTextBrowser;
2309 QUrl url; url.setPath(":bncabout.html");
2310 tb->setSource(url);
2311 tb->setReadOnly(true);
2312
2313 int ww = QFontMetrics(font()).width('w');
2314 QPushButton* _closeButton = new QPushButton("Close");
2315 _closeButton->setMaximumWidth(10*ww);
2316 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2317
2318 QGridLayout* dlgLayout = new QGridLayout();
2319 QLabel* img = new QLabel();
2320 img->setPixmap(QPixmap(":ntrip-logo.png"));
2321 dlgLayout->addWidget(img, 0,0);
2322 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
2323 dlgLayout->addWidget(tb,1,0,1,2);
2324 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2325
2326 setLayout(dlgLayout);
2327 resize(60*ww, 60*ww);
2328 setWindowTitle("About BNC");
2329 show();
2330}
2331
2332//
2333////////////////////////////////////////////////////////////////////////////
2334bncAboutDlg::~bncAboutDlg() {
2335};
2336
2337// Flowchart
2338////////////////////////////////////////////////////////////////////////////
2339bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2340 QDialog(parent) {
2341
2342 int ww = QFontMetrics(font()).width('w');
2343 QPushButton* _closeButton = new QPushButton("Close");
2344 _closeButton->setMaximumWidth(10*ww);
2345 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2346
2347 QGridLayout* dlgLayout = new QGridLayout();
2348 QLabel* img = new QLabel();
2349 img->setPixmap(QPixmap(":bncflowchart.png"));
2350 dlgLayout->addWidget(img, 0,0);
2351 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2352
2353 setLayout(dlgLayout);
2354 setWindowTitle("Flow Chart");
2355 show();
2356}
2357
2358//
2359////////////////////////////////////////////////////////////////////////////
2360bncFlowchartDlg::~bncFlowchartDlg() {
2361};
2362
2363// Enable/Disable Widget (and change its color)
2364////////////////////////////////////////////////////////////////////////////
2365void bncWindow::enableWidget(bool enable, QWidget* widget) {
2366 const static QPalette paletteWhite(QColor(255, 255, 255));
2367 const static QPalette paletteGray(QColor(230, 230, 230));
2368
2369 widget->setEnabled(enable);
2370 if (enable) {
2371 widget->setPalette(paletteWhite);
2372 }
2373 else {
2374 widget->setPalette(paletteGray);
2375 }
2376}
2377
2378// Bnc Text
2379////////////////////////////////////////////////////////////////////////////
2380void bncWindow::slotBncTextChanged(){
2381
2382 bool enable = true;
2383
2384 // Proxy
2385 //------
2386 if (sender() == 0 || sender() == _proxyHostLineEdit) {
2387 enable = !_proxyHostLineEdit->text().isEmpty();
2388 enableWidget(enable, _proxyPortLineEdit);
2389 }
2390
2391 // RINEX Observations
2392 // ------------------
2393 if (sender() == 0 || sender() == _rnxPathLineEdit) {
2394 enable = !_rnxPathLineEdit->text().isEmpty();
2395 enableWidget(enable, _rnxSamplSpinBox);
2396 enableWidget(enable, _rnxSkelLineEdit);
2397 enableWidget(enable, _rnxScrpLineEdit);
2398 enableWidget(enable, _rnxV3CheckBox);
2399 enableWidget(enable, _rnxIntrComboBox);
2400 }
2401
2402 // RINEX Ephemeris
2403 // ---------------
2404 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _outEphPortLineEdit) {
2405 enable = !_ephPathLineEdit->text().isEmpty() || !_outEphPortLineEdit->text().isEmpty();
2406 enableWidget(enable, _ephIntrComboBox);
2407 enableWidget(enable, _ephV3CheckBox);
2408 }
2409
2410 // Broadcast Corrections
2411 // ---------------------
2412 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2413 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2414 enableWidget(enable, _corrIntrComboBox);
2415 }
2416
2417 // Feed Engine
2418 // -----------
2419 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2420 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2421 enableWidget(enable, _waitTimeSpinBox);
2422 enableWidget(enable, _binSamplSpinBox);
2423 }
2424
2425 // Serial Output
2426 // -------------
2427 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
2428 sender() == _serialAutoNMEAComboBox) {
2429 enable = !_serialMountPointLineEdit->text().isEmpty();
2430 enableWidget(enable, _serialPortNameLineEdit);
2431 enableWidget(enable, _serialBaudRateComboBox);
2432 enableWidget(enable, _serialParityComboBox);
2433 enableWidget(enable, _serialDataBitsComboBox);
2434 enableWidget(enable, _serialStopBitsComboBox);
2435 enableWidget(enable, _serialFlowControlComboBox);
2436 enableWidget(enable, _serialAutoNMEAComboBox);
2437
2438 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() != "Auto";
2439 enableWidget(enable2, _serialFileNMEALineEdit);
2440 }
2441
2442 // Outages
2443 // -------
2444 if (sender() == 0 || sender() == _obsRateComboBox) {
2445 enable = !_obsRateComboBox->currentText().isEmpty();
2446 enableWidget(enable, _adviseFailSpinBox);
2447 enableWidget(enable, _adviseRecoSpinBox);
2448 enableWidget(enable, _adviseScriptLineEdit);
2449 }
2450
2451 // Miscellaneous
2452 // -------------
2453 if (sender() == 0 || sender() == _miscMountLineEdit) {
2454 enable = !_miscMountLineEdit->text().isEmpty();
2455 enableWidget(enable, _perfIntrComboBox);
2456 enableWidget(enable, _scanRTCMCheckBox);
2457 }
2458
2459 // Enable/disable Broadcast Ephemerides
2460 // ------------------------------------
2461 if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2462 if (!_uploadEphHostLineEdit->text().isEmpty()) {
2463 _uploadEphPortLineEdit->setStyleSheet("background-color: white");
2464 _uploadEphMountpointLineEdit->setStyleSheet("background-color: white");
2465 _uploadEphPasswordLineEdit->setStyleSheet("background-color: white");
2466 _uploadEphSampleSpinBox->setStyleSheet("background-color: white");
2467 _uploadEphPortLineEdit->setEnabled(true);
2468 _uploadEphMountpointLineEdit->setEnabled(true);
2469 _uploadEphPasswordLineEdit->setEnabled(true);
2470 _uploadEphSampleSpinBox->setEnabled(true);
2471 }
2472 else {
2473 _uploadEphPortLineEdit->setStyleSheet("background-color: lightGray");
2474 _uploadEphMountpointLineEdit->setStyleSheet("background-color: lightGray");
2475 _uploadEphPasswordLineEdit->setStyleSheet("background-color: lightGray");
2476 _uploadEphSampleSpinBox->setStyleSheet("background-color: lightGray");
2477 _uploadEphPortLineEdit->setEnabled(false);
2478 _uploadEphMountpointLineEdit->setEnabled(false);
2479 _uploadEphPasswordLineEdit->setEnabled(false);
2480 _uploadEphSampleSpinBox->setEnabled(false);
2481 }
2482 }
2483
2484 // Combine Corrections
2485 // -------------------
2486 if (sender() == 0 || sender() == _cmbTable) {
2487 int iRow = _cmbTable->rowCount();
2488 if (iRow > 0) {
2489 enableWidget(true, _cmbMethodComboBox);
2490 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
2491 _cmbMaxresLineEdit->setEnabled(true);
2492 _cmbSamplSpinBox->setEnabled(true);
2493 }
2494 else {
2495 enableWidget(false, _cmbMethodComboBox);
2496 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2497 _cmbMaxresLineEdit->setEnabled(false);
2498 _cmbSamplSpinBox->setEnabled(false);
2499 }
2500 }
2501
2502 // Upload(clk)
2503 // -----------
2504 int iRow = _uploadTable->rowCount();
2505 if (iRow > 0) {
2506 enableWidget(true, _uploadIntrComboBox);
2507 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2508 enableWidget(true, _uploadSamplClkRnxSpinBox);
2509 enableWidget(true, _uploadSamplSp3SpinBox);
2510 }
2511 else {
2512 enableWidget(false, _uploadIntrComboBox);
2513 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2514 enableWidget(false, _uploadSamplClkRnxSpinBox);
2515 enableWidget(false, _uploadSamplSp3SpinBox);
2516 }
2517
2518 // PPP Client
2519 // ----------
2520 if (sender() == 0
2521 || sender() == _pppMountLineEdit
2522 || sender() == _pppCorrMountLineEdit
2523 || sender() == _pppRefCrdXLineEdit
2524 || sender() == _pppRefCrdYLineEdit
2525 || sender() == _pppRefCrdZLineEdit
2526 || sender() == _pppRefdNLineEdit
2527 || sender() == _pppRefdELineEdit
2528 || sender() == _pppRefdULineEdit
2529 || sender() == _pppSync
2530 || sender() == _pppSPPComboBox
2531 || sender() == _pppQuickStartLineEdit
2532 || sender() == _pppEstTropoCheckBox
2533 || sender() == _pppUsePhaseCheckBox
2534 || sender() == _pppAntexFileChooser
2535#ifdef QT_WEBKIT
2536 || sender() == _mapWin
2537#endif
2538 ) {
2539
2540
2541 enable = !_pppSPPComboBox->currentText().isEmpty();
2542 if (enable) {
2543 enable = (!_pppMountLineEdit->text().isEmpty() && !_pppCorrMountLineEdit->text().isEmpty()) ||
2544 (!_pppMountLineEdit->text().isEmpty() && _pppSPPComboBox->currentText() == "Realtime-SPP") ||
2545 (_pppSPPComboBox->currentText() == "Post-Processing");
2546 }
2547
2548 enableWidget(enable, _pppNMEALineEdit);
2549 enableWidget(enable, _pppNMEAPortLineEdit);
2550 enableWidget(enable, _pppRefCrdXLineEdit);
2551 enableWidget(enable, _pppRefCrdYLineEdit);
2552 enableWidget(enable, _pppRefCrdZLineEdit);
2553 enableWidget(enable, _pppRefdNLineEdit);
2554 enableWidget(enable, _pppRefdELineEdit);
2555 enableWidget(enable, _pppRefdULineEdit);
2556 enableWidget(enable, _pppUsePhaseCheckBox);
2557 enableWidget(enable, _pppPlotCoordinates);
2558 enableWidget(enable, _mapWinButton);
2559 enableWidget(enable, _mapWinDotSizeLineEdit);
2560 enableWidget(enable, _mapWinDotColorComboBox);
2561 enableWidget(enable, _gmRadioButton);
2562 enableWidget(enable, _osmRadioButton);
2563 enableWidget(enable, _pppEstTropoCheckBox);
2564// enableWidget(enable, _pppGLONASSCheckBox);
2565 enableWidget(enable, _pppGalileoCheckBox);
2566// enableWidget(enable, _pppAntexFileChooser);
2567 enableWidget(enable, _pppSigCLineEdit);
2568 enableWidget(enable, _pppSigCrd0);
2569 enableWidget(enable, _pppSigCrdP);
2570
2571 bool enable2 = enable && !_pppRefCrdXLineEdit->text().isEmpty() &&
2572 !_pppRefCrdYLineEdit->text().isEmpty() &&
2573 !_pppRefCrdZLineEdit->text().isEmpty();
2574
2575 enableWidget(enable2, _pppAverageLineEdit);
2576 enableWidget(enable2, _pppQuickStartLineEdit);
2577
2578 bool enable3 = enable2 && !_pppQuickStartLineEdit->text().isEmpty();
2579 enableWidget(enable3, _pppMaxSolGapLineEdit);
2580 enableWidget(enable3, _pppAudioResponseLineEdit);
2581
2582 bool enable4 = enable && !_pppAntexFileChooser->fileName().isEmpty();
2583 enableWidget(enable4, _pppAntennaLineEdit);
2584
2585 bool enable5 = enable && _pppEstTropoCheckBox->isChecked();
2586 enableWidget(enable5, _pppSigTrp0);
2587 enableWidget(enable5, _pppSigTrpP);
2588
2589 bool enable6 = enable && _pppUsePhaseCheckBox->isChecked();
2590 enableWidget(enable6, _pppSigPLineEdit);
2591
2592 bool enable7 = enable && _pppSPPComboBox->currentText() == "Realtime-PPP";
2593 enableWidget(enable7, _pppSync);
2594
2595 bool enable8 = _pppSPPComboBox->currentText() == "Realtime-PPP";
2596 enableWidget(enable8, _pppCorrMountLineEdit);
2597
2598 bool enable9 = _pppSPPComboBox->currentText() == "Post-Processing";
2599 enableWidget(enable9, _postObsFileChooser);
2600 enableWidget(enable9, _postNavFileChooser);
2601 enableWidget(enable9, _postCorrFileChooser);
2602 enableWidget(enable9, _postOutLineEdit);
2603 enableWidget(enable9, _mapSpeedSlider);
2604
2605 bool enable10 = !_pppSPPComboBox->currentText().isEmpty() && !enable9;
2606 enableWidget(enable10, _pppMountLineEdit);
2607 }
2608
2609 if (sender() == 0 || sender() == _reqcActionComboBox) {
2610 enable = !_reqcActionComboBox->currentText().isEmpty();
2611 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2612 enableWidget(enable && enable10, _reqcEditOptionButton);
2613 enableWidget(enable, _reqcObsFileChooser);
2614 enableWidget(enable, _reqcNavFileChooser);
2615 enableWidget(enable && enable10, _reqcOutObsLineEdit);
2616 enableWidget(enable && enable10, _reqcOutNavLineEdit);
2617 enableWidget(enable, _reqcOutLogLineEdit);
2618 enableWidget(enable && !enable10, _reqcPlotDirLineEdit);
2619 enableWidget(enable && !enable10, _reqcSkyPlotSystems);
2620 }
2621
2622 enableStartStop();
2623}
2624
2625//
2626////////////////////////////////////////////////////////////////////////////
2627void bncWindow::slotAddCmbRow() {
2628 int iRow = _cmbTable->rowCount();
2629 _cmbTable->insertRow(iRow);
2630 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2631 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2632 }
2633}
2634
2635//
2636////////////////////////////////////////////////////////////////////////////
2637void bncWindow::slotDelCmbRow() {
2638 int nRows = _cmbTable->rowCount();
2639 bool flg[nRows];
2640 for (int iRow = 0; iRow < nRows; iRow++) {
2641 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2642 flg[iRow] = true;
2643 }
2644 else {
2645 flg[iRow] = false;
2646 }
2647 }
2648 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2649 if (flg[iRow]) {
2650 _cmbTable->removeRow(iRow);
2651 }
2652 }
2653 nRows = _cmbTable->rowCount();
2654 if (nRows < 1) {
2655 enableWidget(false, _cmbMethodComboBox);
2656 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2657 _cmbMaxresLineEdit->setEnabled(false);
2658 _cmbSamplSpinBox->setEnabled(false);
2659 }
2660}
2661
2662//
2663////////////////////////////////////////////////////////////////////////////
2664void bncWindow::populateCmbTable() {
2665
2666 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2667 _cmbTable->removeRow(iRow);
2668 }
2669
2670 bncSettings settings;
2671
2672 int iRow = -1;
2673 QListIterator<QString> it(settings.value("combineStreams").toStringList());
2674 while (it.hasNext()) {
2675 QStringList hlp = it.next().split(" ");
2676 if (hlp.size() > 2) {
2677 ++iRow;
2678 _cmbTable->insertRow(iRow);
2679 }
2680 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2681 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2682 }
2683 }
2684}
2685
2686//
2687////////////////////////////////////////////////////////////////////////////
2688void bncWindow::slotAddUploadRow() {
2689 int iRow = _uploadTable->rowCount();
2690 _uploadTable->insertRow(iRow);
2691 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2692 if (iCol == 3) {
2693 QLineEdit* passwd = new QLineEdit();
2694 passwd->setFrame(false);
2695 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2696 _uploadTable->setCellWidget(iRow, iCol, passwd);
2697 }
2698 else if (iCol == 4) {
2699 QComboBox* system = new QComboBox();
2700 system->setEditable(false);
2701 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2702 system->setFrame(false);
2703 _uploadTable->setCellWidget(iRow, iCol, system);
2704 }
2705 else if (iCol == 5) {
2706 QCheckBox* com = new QCheckBox();
2707 _uploadTable->setCellWidget(iRow, iCol, com);
2708 }
2709 else if (iCol == 11) {
2710 bncTableItem* bncIt = new bncTableItem();
2711 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2712 _uploadTable->setItem(iRow, iCol, bncIt);
2713 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2714 }
2715 else {
2716 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2717 }
2718 }
2719}
2720
2721//
2722////////////////////////////////////////////////////////////////////////////
2723void bncWindow::slotDelUploadRow() {
2724 BNC_CORE->_uploadTableItems.clear();
2725 int nRows = _uploadTable->rowCount();
2726 bool flg[nRows];
2727 for (int iRow = 0; iRow < nRows; iRow++) {
2728 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2729 flg[iRow] = true;
2730 }
2731 else {
2732 flg[iRow] = false;
2733 }
2734 }
2735 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2736 if (flg[iRow]) {
2737 _uploadTable->removeRow(iRow);
2738 }
2739 }
2740 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2741 BNC_CORE->_uploadTableItems[iRow] =
2742 (bncTableItem*) _uploadTable->item(iRow, 11);
2743 }
2744 nRows = _uploadTable->rowCount();
2745 if (nRows < 1) {
2746 enableWidget(false, _uploadIntrComboBox);
2747 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2748 enableWidget(false, _uploadSamplSp3SpinBox);
2749 enableWidget(false, _uploadSamplClkRnxSpinBox);
2750 }
2751}
2752
2753//
2754////////////////////////////////////////////////////////////////////////////
2755void bncWindow::populateUploadTable() {
2756 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2757 _uploadTable->removeRow(iRow);
2758 }
2759
2760 bncSettings settings;
2761
2762 int iRow = -1;
2763 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2764 while (it.hasNext()) {
2765 QStringList hlp = it.next().split(",");
2766 if (hlp.size() > 6) {
2767 ++iRow;
2768 _uploadTable->insertRow(iRow);
2769 }
2770 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2771 if (iCol == 3) {
2772 QLineEdit* passwd = new QLineEdit();
2773 passwd->setFrame(false);
2774 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2775 passwd->setText(hlp[iCol]);
2776 _uploadTable->setCellWidget(iRow, iCol, passwd);
2777 }
2778 else if (iCol == 4) {
2779 QComboBox* system = new QComboBox();
2780 system->setEditable(false);
2781 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2782 system->setFrame(false);
2783 system->setCurrentIndex(system->findText(hlp[iCol]));
2784 _uploadTable->setCellWidget(iRow, iCol, system);
2785 }
2786 else if (iCol == 5) {
2787 QCheckBox* com = new QCheckBox();
2788 if (hlp[iCol].toInt() == Qt::Checked) {
2789 com->setCheckState(Qt::Checked);
2790 }
2791 _uploadTable->setCellWidget(iRow, iCol, com);
2792 }
2793 else if (iCol == 11) {
2794 bncTableItem* bncIt = new bncTableItem();
2795 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2796 _uploadTable->setItem(iRow, iCol, bncIt);
2797 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2798 }
2799 else {
2800 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2801 }
2802 }
2803 }
2804}
2805
2806//
2807////////////////////////////////////////////////////////////////////////////
2808void bncWindow::slotSetUploadTrafo() {
2809 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2810 dlg->exec();
2811 delete dlg;
2812}
2813
2814// Start Post-Processing PPP
2815////////////////////////////////////////////////////////////////////////////
2816void bncWindow::startPostProcessingPPP() {
2817#ifdef USE_POSTPROCESSING
2818 _runningPostProcessingPPP = true;
2819 _actStart->setText("0 Epochs");
2820 enableStartStop();
2821
2822 _postProcessing = new t_postProcessing(this, _mapSpeedSlider->maximum(), _mapSpeedSlider->value());
2823 connect(_postProcessing, SIGNAL(finished()), this, SLOT(slotFinishedPostProcessingPPP()));
2824 connect(_postProcessing, SIGNAL(progress(int)), this, SLOT(slotPostProgress(int)));
2825 connect(_mapSpeedSlider, SIGNAL(valueChanged(int)), _postProcessing, SLOT(slotSetSpeed(int)));
2826 bncSettings settings;
2827 if ( Qt::CheckState(settings.value("pppPlotCoordinates").toInt()) == Qt::Checked) {
2828 _bncFigurePPP->reset();
2829 connect(_postProcessing, SIGNAL(newPosition(bncTime, double, double, double)),
2830 _bncFigurePPP, SLOT(slotNewPosition(bncTime, double, double, double)));
2831 }
2832#ifdef QT_WEBKIT
2833 if (_mapWin) {
2834 connect(_postProcessing, SIGNAL(newPosition(bncTime, double, double, double)),
2835 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2836 }
2837#endif
2838
2839 _postProcessing->start();
2840#else
2841 QMessageBox::information(this, "Information",
2842 "Post-Processing Not Permitted");
2843#endif
2844}
2845
2846// Post-Processing PPP Finished
2847////////////////////////////////////////////////////////////////////////////
2848void bncWindow::slotFinishedPostProcessingPPP() {
2849#ifdef QT_WEBKIT
2850 if (_mapWin) {
2851 _postProcessing->disconnect(_mapWin);
2852 }
2853#endif
2854 _runningPostProcessingPPP = false;
2855 delete _postProcessing;
2856 _postProcessing = 0;
2857 QMessageBox::information(this, "Information",
2858 "Post-Processing Thread Finished");
2859 _actStart->setText("Start");
2860 enableStartStop();
2861}
2862
2863// Progress Bar Change
2864////////////////////////////////////////////////////////////////////////////
2865void bncWindow::slotPostProgress(int nEpo) {
2866 if (_actStart) {
2867 _actStart->setText(QString("%1 Epochs").arg(nEpo));
2868 }
2869}
2870
2871// Start Post-Processing Reqc
2872////////////////////////////////////////////////////////////////////////////
2873void bncWindow::startPostProcessingReqc() {
2874#ifdef USE_POSTPROCESSING
2875 _runningPostProcessingReqc = true;
2876 enableStartStop();
2877 if (_reqcActionComboBox->currentText() == "Analyze") {
2878 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
2879 connect(reqcAnalyze, SIGNAL(finished()),
2880 this, SLOT(slotFinishedPostProcessingReqc()));
2881 reqcAnalyze->start();
2882 }
2883 else {
2884 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
2885 connect(reqcEdit, SIGNAL(finished()),
2886 this, SLOT(slotFinishedPostProcessingReqc()));
2887 reqcEdit->start();
2888 }
2889#else
2890 QMessageBox::information(this, "Information",
2891 "Post-Processing Not Permitted");
2892#endif
2893}
2894
2895// Post-Processing Reqc Finished
2896////////////////////////////////////////////////////////////////////////////
2897void bncWindow::slotFinishedPostProcessingReqc() {
2898 _runningPostProcessingReqc = false;
2899 if (_reqcActionComboBox->currentText() != "Analyze") {
2900 QMessageBox::information(this, "Information",
2901 "RINEX Processing Thread Finished");
2902 }
2903 enableStartStop();
2904}
2905
2906// Edit teqc-like editing options
2907////////////////////////////////////////////////////////////////////////////
2908void bncWindow::slotReqcEditOption() {
2909 reqcDlg* dlg = new reqcDlg(this);
2910 dlg->move(this->pos().x()+50, this->pos().y()+50);
2911 dlg->exec();
2912 delete dlg;
2913}
2914
2915// Enable/Disable Start and Stop Buttons
2916////////////////////////////////////////////////////////////////////////////
2917void bncWindow::enableStartStop() {
2918
2919 if ( _pppSPPComboBox && _pppSPPComboBox->currentText() == "Post-Processing" ) {
2920 if (_runningPostProcessingPPP) {
2921 _actStart->setEnabled(false);
2922 }
2923 else {
2924 _actStart->setEnabled(true);
2925 }
2926 _actStop->setEnabled(false);
2927 }
2928 else if ( _reqcActionComboBox && !_reqcActionComboBox->currentText().isEmpty() ) {
2929 if (_runningPostProcessingReqc) {
2930 _actStart->setEnabled(false);
2931 }
2932 else {
2933 _actStart->setEnabled(true);
2934 }
2935 _actStop->setEnabled(false);
2936 }
2937 else {
2938 if (_runningRealTime) {
2939 _actStart->setEnabled(false);
2940 _actStop->setEnabled(true);
2941 }
2942 else {
2943 _actStop->setEnabled(false);
2944 if (_mountPointsTable->rowCount() == 0) {
2945 _actStart->setEnabled(false);
2946 }
2947 else {
2948 _actStart->setEnabled(true);
2949 }
2950 }
2951 }
2952}
2953
2954// Show Map
2955////////////////////////////////////////////////////////////////////////////
2956void bncWindow::slotMapMountPoints() {
2957 saveOptions();
2958 t_bncMap* bncMap = new t_bncMap(this);
2959 bncMap->setMinimumSize(800, 600);
2960 bncMap->setWindowTitle("Selected Mountpoints");
2961
2962 bncSettings settings;
2963 QListIterator<QString> it(settings.value("mountPoints").toStringList());
2964 while (it.hasNext()) {
2965 QStringList hlp = it.next().split(" ");
2966 if (hlp.size() < 5) continue;
2967 QUrl url(hlp[0]);
2968 double latDeg = hlp[2].toDouble();
2969 double lonDeg = hlp[3].toDouble();
2970 bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
2971 }
2972
2973 bncMap->show();
2974}
2975
2976// Show Map
2977////////////////////////////////////////////////////////////////////////////
2978void bncWindow::slotMapPPP() {
2979#ifdef QT_WEBKIT
2980 saveOptions();
2981 enableWidget(false, _mapWinButton);
2982 enableWidget(false, _gmRadioButton);
2983 enableWidget(false, _osmRadioButton);
2984 enableWidget(false, _mapWinDotSizeLineEdit);
2985 enableWidget(false, _mapWinDotColorComboBox);
2986
2987 if (!_mapWin) {
2988 _mapWin = new bncMapWin(this);
2989 connect(_mapWin, SIGNAL(mapClosed()), this, SLOT(slotMapPPPClosed()));
2990 QListIterator<bncGetThread*> it(_threads);
2991 while (it.hasNext()) {
2992 bncGetThread* thread = it.next();
2993 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2994 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2995 }
2996 if (_postProcessing) {
2997 connect(_postProcessing, SIGNAL(newPosition(bncTime, double, double, double)),
2998 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2999 }
3000 }
3001 _mapWin->show();
3002#else
3003 QMessageBox::information(this, "Information",
3004 "Qt Library compiled without QtWebKit");
3005#endif
3006}
3007
3008// Show Map
3009////////////////////////////////////////////////////////////////////////////
3010void bncWindow::slotMapPPPClosed() {
3011#ifdef QT_WEBKIT
3012 slotBncTextChanged();
3013 if (_mapWin) {
3014 QListIterator<bncGetThread*> it(_threads);
3015 while (it.hasNext()) {
3016 bncGetThread* thread = it.next();
3017 thread->disconnect(_mapWin);
3018 }
3019 if (_postProcessing) {
3020 _postProcessing->disconnect(_mapWin);
3021 }
3022 _mapWin->deleteLater();
3023 _mapWin = 0;
3024 }
3025#endif
3026}
Note: See TracBrowser for help on using the repository browser.