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

Last change on this file since 5680 was 5680, checked in by mervart, 8 years ago
File size: 148.4 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("&Reread && Save 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("&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 _miscPortLineEdit = new QLineEdit(settings.value("miscPort").toString());
364 _perfIntrComboBox = new QComboBox();
365 _perfIntrComboBox->setEditable(false);
366 _perfIntrComboBox->addItems(QString(",2 sec, 10 sec,1 min,5 min,15 min,1 hour,6 hours,1 day").split(","));
367 int ll = _perfIntrComboBox->findText(settings.value("perfIntr").toString());
368 if (ll != -1) {
369 _perfIntrComboBox->setCurrentIndex(ll);
370 }
371 _scanRTCMCheckBox = new QCheckBox();
372 _scanRTCMCheckBox->setCheckState(Qt::CheckState(
373 settings.value("scanRTCM").toInt()));
374
375 connect(_miscMountLineEdit, SIGNAL(textChanged(const QString &)),
376 this, SLOT(slotBncTextChanged()));
377
378 // PPP Options
379 // -----------
380 _pppMountLineEdit = new QLineEdit(settings.value("pppMount").toString());
381 _pppMountLineEdit->setMaximumWidth(8*ww);
382 _pppCorrMountLineEdit = new QLineEdit(settings.value("pppCorrMount").toString());
383 _pppMountLineEdit->setMinimumWidth(8*ww);
384 _pppCorrMountLineEdit->setMinimumWidth(8*ww);
385 _pppCorrMountLineEdit->setMaximumWidth(8*ww);
386 _pppNMEALineEdit = new QLineEdit(settings.value("nmeaFile").toString());
387 _pppNMEALineEdit->setMinimumWidth(15*ww);
388 _pppNMEAPortLineEdit = new QLineEdit(settings.value("nmeaPort").toString());
389 _pppNMEAPortLineEdit->setMaximumWidth(8*ww);
390 _pppNMEAPortLineEdit->setMinimumWidth(8*ww);
391 _pppSigCLineEdit = new QLineEdit(settings.value("pppSigmaCode").toString());
392 _pppSigPLineEdit = new QLineEdit(settings.value("pppSigmaPhase").toString());
393 _pppSigCrd0 = new QLineEdit(settings.value("pppSigCrd0").toString());
394 _pppSigCrdP = new QLineEdit(settings.value("pppSigCrdP").toString());
395 _pppSigTrp0 = new QLineEdit(settings.value("pppSigTrp0").toString());
396 _pppSigTrpP = new QLineEdit(settings.value("pppSigTrpP").toString());
397 _pppAverageLineEdit = new QLineEdit(settings.value("pppAverage").toString());
398 _pppQuickStartLineEdit = new QLineEdit(settings.value("pppQuickStart").toString());
399 _pppMaxSolGapLineEdit = new QLineEdit(settings.value("pppMaxSolGap").toString());
400 _pppAudioResponseLineEdit = new QLineEdit(settings.value("pppAudioResponse").toString());
401 _pppRefCrdXLineEdit = new QLineEdit(settings.value("pppRefCrdX").toString());
402 _pppRefCrdYLineEdit = new QLineEdit(settings.value("pppRefCrdY").toString());
403 _pppRefCrdZLineEdit = new QLineEdit(settings.value("pppRefCrdZ").toString());
404 _pppRefdNLineEdit = new QLineEdit(settings.value("pppRefdN").toString());
405 _pppRefdELineEdit = new QLineEdit(settings.value("pppRefdE").toString());
406 _pppRefdULineEdit = new QLineEdit(settings.value("pppRefdU").toString());
407 _pppSync = new QLineEdit(settings.value("pppSync").toString());
408 _pppAntexFileChooser = new qtFileChooser;
409 _pppAntexFileChooser->setMinimumWidth(12*ww);
410 _pppAntennaLineEdit = new QLineEdit(settings.value("pppAntenna").toString());
411 _pppAntexFileChooser->setFileName(settings.value("pppAntex").toString());
412
413 _pppSPPComboBox = new QComboBox();
414 _pppSPPComboBox->setEditable(false);
415 _pppSPPComboBox->addItems(QString(",Realtime-PPP,Realtime-SPP,Post-Processing").split(","));
416 int ik = _pppSPPComboBox->findText(settings.value("pppSPP").toString());
417 if (ik != -1) {
418 _pppSPPComboBox->setCurrentIndex(ik);
419 }
420 _pppUsePhaseCheckBox = new QCheckBox();
421 _pppUsePhaseCheckBox->setCheckState(Qt::CheckState(
422 settings.value("pppUsePhase").toInt()));
423 _pppEstTropoCheckBox = new QCheckBox();
424 _pppEstTropoCheckBox->setCheckState(Qt::CheckState(
425 settings.value("pppEstTropo").toInt()));
426 _pppGLONASSCheckBox = new QCheckBox();
427 _pppGLONASSCheckBox->setCheckState(Qt::CheckState(
428 settings.value("pppGLONASS").toInt()));
429 _pppGalileoCheckBox = new QCheckBox();
430 _pppGalileoCheckBox->setCheckState(Qt::CheckState(
431 settings.value("pppGalileo").toInt()));
432
433 connect(_pppMountLineEdit, SIGNAL(textChanged(const QString &)),
434 this, SLOT(slotBncTextChanged()));
435
436 connect(_pppCorrMountLineEdit, SIGNAL(textChanged(const QString &)),
437 this, SLOT(slotBncTextChanged()));
438
439 connect(_pppUsePhaseCheckBox, SIGNAL(stateChanged(int)),
440 this, SLOT(slotBncTextChanged()));
441
442 connect(_pppRefCrdXLineEdit, SIGNAL(textChanged(const QString &)),
443 this, SLOT(slotBncTextChanged()));
444 connect(_pppRefCrdYLineEdit, SIGNAL(textChanged(const QString &)),
445 this, SLOT(slotBncTextChanged()));
446 connect(_pppRefCrdZLineEdit, SIGNAL(textChanged(const QString &)),
447 this, SLOT(slotBncTextChanged()));
448 connect(_pppRefdNLineEdit, SIGNAL(textChanged(const QString &)),
449 this, SLOT(slotBncTextChanged()));
450 connect(_pppRefdELineEdit, SIGNAL(textChanged(const QString &)),
451 this, SLOT(slotBncTextChanged()));
452 connect(_pppRefdULineEdit, SIGNAL(textChanged(const QString &)),
453 this, SLOT(slotBncTextChanged()));
454
455 connect(_pppEstTropoCheckBox, SIGNAL(stateChanged(int)),
456 this, SLOT(slotBncTextChanged()));
457
458 connect(_pppSync, SIGNAL(textChanged(const QString &)),
459 this, SLOT(slotBncTextChanged()));
460
461 connect(_pppSPPComboBox, SIGNAL(currentIndexChanged(const QString &)),
462 this, SLOT(slotBncTextChanged()));
463
464 connect(_pppAntexFileChooser, SIGNAL(fileNameChanged(const QString &)),
465 this, SLOT(slotBncTextChanged()));
466
467 connect(_pppQuickStartLineEdit, SIGNAL(textChanged(const QString &)),
468 this, SLOT(slotBncTextChanged()));
469
470 // Streams
471 // -------
472 _mountPointsTable = new QTableWidget(0,8);
473
474 _mountPointsTable->horizontalHeader()->resizeSection(1,34*ww);
475 _mountPointsTable->horizontalHeader()->resizeSection(2,9*ww);
476 _mountPointsTable->horizontalHeader()->resizeSection(3,7*ww);
477 _mountPointsTable->horizontalHeader()->resizeSection(4,7*ww);
478 _mountPointsTable->horizontalHeader()->resizeSection(5,5*ww);
479 _mountPointsTable->horizontalHeader()->resizeSection(6,5*ww);
480 _mountPointsTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
481 _mountPointsTable->horizontalHeader()->setStretchLastSection(true);
482 _mountPointsTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
483_mountPointsTable->setHorizontalHeaderLabels(labels);
484 _mountPointsTable->setGridStyle(Qt::NoPen);
485 _mountPointsTable->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
486 _mountPointsTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
487 _mountPointsTable->setSelectionBehavior(QAbstractItemView::SelectRows);
488 _mountPointsTable->hideColumn(0);
489 connect(_mountPointsTable, SIGNAL(itemSelectionChanged()),
490 SLOT(slotSelectionChanged()));
491 populateMountPointsTable();
492
493 _log = new QTextBrowser();
494 _log->setReadOnly(true);
495
496 // Combine Corrections
497 // -------------------
498 _cmbTable = new QTableWidget(0,3);
499 _cmbTable->setHorizontalHeaderLabels(QString("Mountpoint, AC Name, Weight").split(","));
500 _cmbTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
501 _cmbTable->setSelectionBehavior(QAbstractItemView::SelectRows);
502 _cmbTable->setMaximumWidth(30*ww);
503 _cmbTable->horizontalHeader()->resizeSection(0,10*ww);
504 _cmbTable->horizontalHeader()->resizeSection(1,8*ww);
505 _cmbTable->horizontalHeader()->resizeSection(2,8*ww);
506 _cmbTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
507 _cmbTable->horizontalHeader()->setStretchLastSection(true);
508 _cmbTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
509
510 _cmbMaxresLineEdit = new QLineEdit(settings.value("cmbMaxres").toString());
511
512 _cmbSamplSpinBox = new QSpinBox;
513 _cmbSamplSpinBox->setMinimum(10);
514 _cmbSamplSpinBox->setMaximum(60);
515 _cmbSamplSpinBox->setSingleStep(10);
516 _cmbSamplSpinBox->setMaximumWidth(9*ww);
517 _cmbSamplSpinBox->setValue(settings.value("cmbSampl").toInt());
518 _cmbSamplSpinBox->setSuffix(" sec");
519
520 QPushButton* addCmbRowButton = new QPushButton("Add Row");
521 QPushButton* delCmbRowButton = new QPushButton("Delete");
522
523 connect(_cmbTable, SIGNAL(itemSelectionChanged()),
524 SLOT(slotBncTextChanged()));
525
526 _cmbMethodComboBox = new QComboBox();
527 _cmbMethodComboBox->setEditable(false);
528 _cmbMethodComboBox->addItems(QString("Filter,Single-Epoch").split(","));
529 int im = _cmbMethodComboBox->findText(settings.value("cmbMethod").toString());
530 if (im != -1) {
531 _cmbMethodComboBox->setCurrentIndex(im);
532 }
533
534 int iRow = _cmbTable->rowCount();
535 if (iRow > 0) {
536 enableWidget(true, _cmbMethodComboBox);
537 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
538 _cmbMaxresLineEdit->setEnabled(true);
539 _cmbSamplSpinBox->setEnabled(true);
540 }
541 else {
542 enableWidget(false, _cmbMethodComboBox);
543 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
544 _cmbMaxresLineEdit->setEnabled(false);
545 _cmbSamplSpinBox->setEnabled(false);
546 }
547
548 // Upload Results
549 // -------------
550 _uploadTable = new QTableWidget(0,12);
551 _uploadTable->setHorizontalHeaderLabels(QString("Host, Port, Mount, Password, System, CoM, SP3 File, RNX File, PID, SID, IOD, bytes").split(","));
552 _uploadTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
553 _uploadTable->setSelectionBehavior(QAbstractItemView::SelectRows);
554 _uploadTable->horizontalHeader()->resizeSection( 0,13*ww);
555 _uploadTable->horizontalHeader()->resizeSection( 1, 5*ww);
556 _uploadTable->horizontalHeader()->resizeSection( 2, 6*ww);
557 _uploadTable->horizontalHeader()->resizeSection( 3, 8*ww);
558 _uploadTable->horizontalHeader()->resizeSection( 4,11*ww);
559 _uploadTable->horizontalHeader()->resizeSection( 5, 4*ww);
560 _uploadTable->horizontalHeader()->resizeSection( 6,15*ww);
561 _uploadTable->horizontalHeader()->resizeSection( 7,15*ww);
562 _uploadTable->horizontalHeader()->resizeSection( 8, 4*ww);
563 _uploadTable->horizontalHeader()->resizeSection( 9, 4*ww);
564 _uploadTable->horizontalHeader()->resizeSection(10, 4*ww);
565 _uploadTable->horizontalHeader()->resizeSection(11,12*ww);
566 _uploadTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
567 _uploadTable->horizontalHeader()->setStretchLastSection(true);
568 _uploadTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
569
570 connect(_uploadTable, SIGNAL(itemSelectionChanged()),
571 SLOT(slotBncTextChanged()));
572
573 QPushButton* addUploadRowButton = new QPushButton("Add Row");
574 QPushButton* delUploadRowButton = new QPushButton("Del Row");
575 QPushButton* setUploadTrafoButton = new QPushButton("Custom Trafo");
576 _uploadIntrComboBox = new QComboBox;
577 _uploadIntrComboBox->setEditable(false);
578 _uploadIntrComboBox->addItems(QString("1 day,1 hour, 30 min,15 min,10 min,5 min,2 min,1 min").split(","));
579 ii = _uploadIntrComboBox->findText(settings.value("uploadIntr").toString());
580 if (ii != -1) {
581 _uploadIntrComboBox->setCurrentIndex(ii);
582 }
583
584 _uploadSamplRtcmEphCorrSpinBox = new QSpinBox;
585 _uploadSamplRtcmEphCorrSpinBox->setMinimum(0);
586 _uploadSamplRtcmEphCorrSpinBox->setMaximum(60);
587 _uploadSamplRtcmEphCorrSpinBox->setSingleStep(5);
588 _uploadSamplRtcmEphCorrSpinBox->setMaximumWidth(9*ww);
589 _uploadSamplRtcmEphCorrSpinBox->setValue(settings.value("uploadSamplRtcmEphCorr").toInt());
590 _uploadSamplRtcmEphCorrSpinBox->setSuffix(" sec");
591
592 _uploadSamplSp3SpinBox = new QSpinBox;
593 _uploadSamplSp3SpinBox->setMinimum(0);
594 _uploadSamplSp3SpinBox->setMaximum(15);
595 _uploadSamplSp3SpinBox->setSingleStep(1);
596 _uploadSamplSp3SpinBox->setMaximumWidth(9*ww);
597 _uploadSamplSp3SpinBox->setValue(settings.value("uploadSamplSp3").toInt());
598 _uploadSamplSp3SpinBox->setSuffix(" min");
599
600 _uploadSamplClkRnxSpinBox = new QSpinBox;
601 _uploadSamplClkRnxSpinBox->setMinimum(0);
602 _uploadSamplClkRnxSpinBox->setMaximum(60);
603 _uploadSamplClkRnxSpinBox->setSingleStep(5);
604 _uploadSamplClkRnxSpinBox->setMaximumWidth(9*ww);
605 _uploadSamplClkRnxSpinBox->setValue(settings.value("uploadSamplClkRnx").toInt());
606 _uploadSamplClkRnxSpinBox->setSuffix(" sec");
607
608 int iRowT = _uploadTable->rowCount();
609 if (iRowT > 0) {
610 enableWidget(true, _uploadIntrComboBox);
611 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
612 enableWidget(true, _uploadSamplSp3SpinBox);
613 enableWidget(true, _uploadSamplClkRnxSpinBox);
614 }
615 else {
616 enableWidget(false, _uploadIntrComboBox);
617 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
618 enableWidget(false, _uploadSamplSp3SpinBox);
619 enableWidget(false, _uploadSamplClkRnxSpinBox);
620 }
621
622 // Upload RTCM3 Ephemeris
623 // ----------------------
624 _uploadEphHostLineEdit = new QLineEdit(settings.value("uploadEphHost").toString());
625 _uploadEphPortLineEdit = new QLineEdit(settings.value("uploadEphPort").toString());
626 _uploadEphPasswordLineEdit = new QLineEdit(settings.value("uploadEphPassword").toString());
627 _uploadEphPasswordLineEdit->setEchoMode(QLineEdit::PasswordEchoOnEdit);
628 _uploadEphMountpointLineEdit = new QLineEdit(settings.value("uploadEphMountpoint").toString());
629 _uploadEphSampleSpinBox = new QSpinBox;
630 _uploadEphSampleSpinBox->setMinimum(5);
631 _uploadEphSampleSpinBox->setMaximum(60);
632 _uploadEphSampleSpinBox->setSingleStep(5);
633 _uploadEphSampleSpinBox->setMaximumWidth(9*ww);
634 _uploadEphSampleSpinBox->setValue(settings.value("uploadEphSample").toInt());
635 _uploadEphSampleSpinBox->setSuffix(" sec");
636 _uploadEphBytesCounter = new bncBytesCounter;
637
638 // Canvas with Editable Fields
639 // ---------------------------
640 _canvas = new QWidget;
641 setCentralWidget(_canvas);
642
643 _aogroup = new QTabWidget();
644 QWidget* pgroup = new QWidget();
645 QWidget* ggroup = new QWidget();
646 QWidget* sgroup = new QWidget();
647 QWidget* egroup = new QWidget();
648 QWidget* agroup = new QWidget();
649 QWidget* cgroup = new QWidget();
650 QWidget* ogroup = new QWidget();
651 QWidget* rgroup = new QWidget();
652 QWidget* sergroup = new QWidget();
653 QWidget* pppgroup = new QWidget();
654 QWidget* ppp2group = new QWidget();
655 QWidget* ppp3group = new QWidget();
656 QWidget* reqcgroup = new QWidget();
657 QWidget* cmbgroup = new QWidget();
658 QWidget* uploadgroup = new QWidget();
659 QWidget* uploadEphgroup = new QWidget();
660 _aogroup->addTab(pgroup,tr("Network"));
661 _aogroup->addTab(ggroup,tr("General"));
662 _aogroup->addTab(ogroup,tr("RINEX Observations"));
663 _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
664 _aogroup->addTab(reqcgroup,tr("RINEX Editing && QC"));
665 _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
666 _aogroup->addTab(sgroup,tr("Feed Engine"));
667 _aogroup->addTab(sergroup,tr("Serial Output"));
668 _aogroup->addTab(agroup,tr("Outages"));
669 _aogroup->addTab(rgroup,tr("Miscellaneous"));
670 _aogroup->addTab(pppgroup,tr("PPP (1)"));
671 _aogroup->addTab(ppp2group,tr("PPP (2)"));
672 _aogroup->addTab(ppp3group,tr("PPP (3)"));
673#ifdef USE_COMBINATION
674 _aogroup->addTab(cmbgroup,tr("Combine Corrections"));
675#endif
676 _aogroup->addTab(uploadgroup,tr("Upload Corrections"));
677 _aogroup->addTab(uploadEphgroup,tr("Upload Ephemeris"));
678
679 // Log Tab
680 // -------
681 _loggroup = new QTabWidget();
682 _loggroup->addTab(_log,tr("Log"));
683 _loggroup->addTab(_bncFigure,tr("Throughput"));
684 _loggroup->addTab(_bncFigureLate,tr("Latency"));
685 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
686
687 // Netowork (Proxy and SSL) Tab
688 // ----------------------------
689 QGridLayout* pLayout = new QGridLayout;
690 pLayout->setColumnMinimumWidth(0,13*ww);
691 _proxyPortLineEdit->setMaximumWidth(9*ww);
692
693 pLayout->addWidget(new QLabel("Settings for proxy in protected networks and for SSL authorization, leave boxes blank if none."),0, 0, 1, 50);
694 pLayout->addWidget(new QLabel("Proxy host"), 1, 0);
695 pLayout->addWidget(_proxyHostLineEdit, 1, 1, 1,10);
696 pLayout->addWidget(new QLabel("Proxy port"), 2, 0);
697 pLayout->addWidget(_proxyPortLineEdit, 2, 1);
698 pLayout->addWidget(new QLabel("Path to SSL Certificates"), 3, 0);
699 pLayout->addWidget(_sslCaCertPathLineEdit, 3, 1, 1,10);
700 pLayout->addWidget(new QLabel("Default: " + bncSslConfig::defaultPath()), 3,11, 1,20);
701 pLayout->addWidget(new QLabel("Ignore SSL Authorization Errors"), 4, 0);
702 pLayout->addWidget(_ignoreSslErrorsCheckBox, 4, 1, 1,10);
703 pLayout->addWidget(new QLabel(" "), 4, 0);
704 pLayout->addWidget(new QLabel(" "), 5, 0);
705 pLayout->addWidget(new QLabel(" "), 6, 0);
706 pgroup->setLayout(pLayout);
707
708 // General Tab
709 // -----------
710 QGridLayout* gLayout = new QGridLayout;
711 gLayout->setColumnMinimumWidth(0,14*ww);
712 _onTheFlyComboBox->setMaximumWidth(9*ww);
713
714 gLayout->addWidget(new QLabel("General settings for logfile, file handling, configuration on-the-fly, and auto-start."),0, 0, 1, 50);
715 gLayout->addWidget(new QLabel("Logfile (full path)"), 1, 0);
716 gLayout->addWidget(_logFileLineEdit, 1, 1, 1,30);
717 gLayout->addWidget(new QLabel("Append files"), 2, 0);
718 gLayout->addWidget(_rnxAppendCheckBox, 2, 1);
719 gLayout->addWidget(new QLabel("Reread configuration"), 3, 0);
720 gLayout->addWidget(_onTheFlyComboBox, 3, 1);
721 gLayout->addWidget(new QLabel("Auto start"), 4, 0);
722 gLayout->addWidget(_autoStartCheckBox, 4, 1);
723 gLayout->addWidget(new QLabel("Raw output file (full path)"), 5, 0);
724 gLayout->addWidget(_rawOutFileLineEdit, 5, 1, 1,30);
725 gLayout->addWidget(new QLabel(" "), 6, 0);
726 ggroup->setLayout(gLayout);
727
728 // RINEX Observations
729 // ------------------
730 QGridLayout* oLayout = new QGridLayout;
731 oLayout->setColumnMinimumWidth(0,14*ww);
732 _rnxIntrComboBox->setMaximumWidth(9*ww);
733 _rnxSamplSpinBox->setMaximumWidth(9*ww);
734
735 oLayout->addWidget(new QLabel("Saving RINEX observation files."),0, 0, 1,50);
736 oLayout->addWidget(new QLabel("Directory"), 1, 0);
737 oLayout->addWidget(_rnxPathLineEdit, 1, 1, 1,24);
738 oLayout->addWidget(new QLabel("Interval"), 2, 0);
739 oLayout->addWidget(_rnxIntrComboBox, 2, 1);
740 oLayout->addWidget(new QLabel(" Sampling"), 2, 2, Qt::AlignRight);
741 oLayout->addWidget(_rnxSamplSpinBox, 2, 3, Qt::AlignLeft);
742 oLayout->addWidget(new QLabel("Skeleton extension"), 3, 0);
743 oLayout->addWidget(_rnxSkelLineEdit, 3, 1, 1, 1, Qt::AlignLeft);
744 oLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
745 oLayout->addWidget(_rnxScrpLineEdit, 4, 1, 1,24);
746 oLayout->addWidget(new QLabel("Version 3"), 5, 0);
747 oLayout->addWidget(_rnxV3CheckBox, 5, 1);
748 oLayout->addWidget(new QLabel(" "), 6, 0);
749 ogroup->setLayout(oLayout);
750
751 // RINEX Ephemeris
752 // ---------------
753 QGridLayout* eLayout = new QGridLayout;
754 eLayout->setColumnMinimumWidth(0,14*ww);
755 _ephIntrComboBox->setMaximumWidth(9*ww);
756 _outEphPortLineEdit->setMaximumWidth(9*ww);
757
758 eLayout->addWidget(new QLabel("Saving RINEX ephemeris files and ephemeris output through IP port."),0,0,1,50);
759 eLayout->addWidget(new QLabel("Directory"), 1, 0);
760 eLayout->addWidget(_ephPathLineEdit, 1, 1, 1,30);
761 eLayout->addWidget(new QLabel("Interval"), 2, 0);
762 eLayout->addWidget(_ephIntrComboBox, 2, 1);
763 eLayout->addWidget(new QLabel("Port"), 3, 0);
764 eLayout->addWidget(_outEphPortLineEdit, 3, 1);
765 eLayout->addWidget(new QLabel("Version 3"), 4, 0);
766 eLayout->addWidget(_ephV3CheckBox, 4, 1);
767 eLayout->addWidget(new QLabel(" "), 5, 0);
768 eLayout->addWidget(new QLabel(" "), 6, 0);
769 egroup->setLayout(eLayout);
770
771
772 // Broadcast Corrections
773 // ---------------------
774 QGridLayout* cLayout = new QGridLayout;
775 cLayout->setColumnMinimumWidth(0,14*ww);
776 _corrIntrComboBox->setMaximumWidth(9*ww);
777 _corrPortLineEdit->setMaximumWidth(9*ww);
778 _corrTimeSpinBox->setMaximumWidth(9*ww);
779
780 cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port."),0,0,1,50);
781 cLayout->addWidget(new QLabel("Directory, ASCII"), 1, 0);
782 cLayout->addWidget(_corrPathLineEdit, 1, 1, 1,20);
783 cLayout->addWidget(new QLabel("Interval"), 2, 0);
784 cLayout->addWidget(_corrIntrComboBox, 2, 1);
785 cLayout->addWidget(new QLabel("Port"), 3, 0);
786 cLayout->addWidget(_corrPortLineEdit, 3, 1);
787 cLayout->addWidget(new QLabel(" Wait for full corr epoch"), 3, 2, Qt::AlignRight);
788 cLayout->addWidget(_corrTimeSpinBox, 3, 3, Qt::AlignLeft);
789 cLayout->addWidget(new QLabel(" "), 4, 0);
790 cLayout->addWidget(new QLabel(" "), 5, 0);
791 cLayout->addWidget(new QLabel(" "), 6, 0);
792 cgroup->setLayout(cLayout);
793
794 // Feed Engine
795 // -----------
796 QGridLayout* sLayout = new QGridLayout;
797 sLayout->setColumnMinimumWidth(0,14*ww);
798 _outPortLineEdit->setMaximumWidth(9*ww);
799 _waitTimeSpinBox->setMaximumWidth(9*ww);
800 _binSamplSpinBox->setMaximumWidth(9*ww);
801 _outUPortLineEdit->setMaximumWidth(9*ww);
802
803 sLayout->addWidget(new QLabel("Output decoded observations in ASCII format to feed a real-time GNSS network engine."),0,0,1,50);
804 sLayout->addWidget(new QLabel("Port"), 1, 0);
805 sLayout->addWidget(_outPortLineEdit, 1, 1);
806 sLayout->addWidget(new QLabel("Wait for full obs epoch"), 1, 2, Qt::AlignRight);
807 sLayout->addWidget(_waitTimeSpinBox, 1, 3, Qt::AlignLeft);
808 sLayout->addWidget(new QLabel("Sampling"), 2, 0);
809 sLayout->addWidget(_binSamplSpinBox, 2, 1, Qt::AlignLeft);
810 sLayout->addWidget(new QLabel("File (full path)"), 3, 0);
811 sLayout->addWidget(_outFileLineEdit, 3, 1, 1, 20);
812 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 4, 0);
813 sLayout->addWidget(_outUPortLineEdit, 4, 1);
814 sLayout->addWidget(new QLabel(" "), 5, 0);
815 sLayout->addWidget(new QLabel(" "), 6, 0);
816 sgroup->setLayout(sLayout);
817
818 // Serial Output
819 // -------------
820 QGridLayout* serLayout = new QGridLayout;
821 serLayout->setColumnMinimumWidth(0,14*ww);
822 _serialBaudRateComboBox->setMaximumWidth(9*ww);
823 _serialFlowControlComboBox->setMaximumWidth(11*ww);
824 _serialDataBitsComboBox->setMaximumWidth(5*ww);
825 _serialParityComboBox->setMaximumWidth(9*ww);
826 _serialStopBitsComboBox->setMaximumWidth(5*ww);
827 _serialAutoNMEAComboBox->setMaximumWidth(9*ww);
828 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
829
830 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver."),0,0,1,30);
831 serLayout->addWidget(new QLabel("Mountpoint"), 1, 0, Qt::AlignLeft);
832 serLayout->addWidget(_serialMountPointLineEdit, 1, 1, 1, 2);
833 serLayout->addWidget(new QLabel("Port name"), 2, 0, Qt::AlignLeft);
834 serLayout->addWidget(_serialPortNameLineEdit, 2, 1, 1, 2);
835 serLayout->addWidget(new QLabel("Baud rate"), 3, 0, Qt::AlignLeft);
836 serLayout->addWidget(_serialBaudRateComboBox, 3, 1);
837 serLayout->addWidget(new QLabel("Flow control"), 3, 2, Qt::AlignRight);
838 serLayout->addWidget(_serialFlowControlComboBox, 3, 3);
839 serLayout->addWidget(new QLabel("Data bits"), 4, 0, Qt::AlignLeft);
840 serLayout->addWidget(_serialDataBitsComboBox, 4, 1);
841 serLayout->addWidget(new QLabel("Parity"), 4, 2, Qt::AlignRight);
842 serLayout->addWidget(_serialParityComboBox, 4, 3);
843 serLayout->addWidget(new QLabel(" Stop bits"), 4, 4, Qt::AlignRight);
844 serLayout->addWidget(_serialStopBitsComboBox, 4, 5);
845 serLayout->addWidget(new QLabel("NMEA"), 5, 0);
846 serLayout->addWidget(_serialAutoNMEAComboBox, 5, 1);
847 serLayout->addWidget(new QLabel(" File (full path)"), 5, 2, Qt::AlignRight);
848 serLayout->addWidget(_serialFileNMEALineEdit, 5, 3, 1,15);
849 serLayout->addWidget(new QLabel("Height"), 5,20, Qt::AlignRight);
850 serLayout->addWidget(_serialHeightNMEALineEdit, 5,21, 1,11);
851 serLayout->addWidget(new QLabel(" "), 6, 0);
852
853 sergroup->setLayout(serLayout);
854
855 // Outages
856 // -------
857 QGridLayout* aLayout = new QGridLayout;
858 aLayout->setColumnMinimumWidth(0,14*ww);
859 _obsRateComboBox->setMaximumWidth(9*ww);
860 _adviseFailSpinBox->setMaximumWidth(9*ww);
861 _adviseRecoSpinBox->setMaximumWidth(9*ww);
862
863 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes."),0,0,1,50,Qt::AlignLeft);
864 aLayout->addWidget(new QLabel("Observation rate"), 1, 0);
865 aLayout->addWidget(_obsRateComboBox, 1, 1);
866 aLayout->addWidget(new QLabel("Failure threshold"), 2, 0);
867 aLayout->addWidget(_adviseFailSpinBox, 2, 1);
868 aLayout->addWidget(new QLabel("Recovery threshold"), 3, 0);
869 aLayout->addWidget(_adviseRecoSpinBox, 3, 1);
870 aLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
871 aLayout->addWidget(_adviseScriptLineEdit, 4, 1, 1,30);
872 aLayout->addWidget(new QLabel(" "), 5, 0);
873 aLayout->addWidget(new QLabel(" "), 6, 0);
874 agroup->setLayout(aLayout);
875
876 // Miscellaneous
877 // -------------
878 QGridLayout* rLayout = new QGridLayout;
879 rLayout->setColumnMinimumWidth(0,14*ww);
880 _perfIntrComboBox->setMaximumWidth(9*ww);
881 _miscPortLineEdit->setMaximumWidth(9*ww);
882
883 rLayout->addWidget(new QLabel("Log latencies or scan RTCM streams for message types and antenna information or output raw data through TCP/IP port."),0, 0,1,30);
884 rLayout->addWidget(new QLabel("Mountpoint"), 1, 0);
885 rLayout->addWidget(_miscMountLineEdit, 1, 1, 1,7);
886 rLayout->addWidget(new QLabel("Log latency"), 2, 0);
887 rLayout->addWidget(_perfIntrComboBox, 2, 1);
888 rLayout->addWidget(new QLabel("Scan RTCM"), 3, 0);
889 rLayout->addWidget(_scanRTCMCheckBox, 3, 1);
890 rLayout->addWidget(new QLabel("Port"), 4, 0);
891 rLayout->addWidget(_miscPortLineEdit, 4, 1);
892 rLayout->addWidget(new QLabel(" "), 5, 0);
893 rLayout->addWidget(new QLabel(" "), 6, 0);
894 rgroup->setLayout(rLayout);
895
896 // PPP Client
897 // ----------
898 QGridLayout* pppLayout = new QGridLayout;
899 pppLayout->setColumnMinimumWidth(0,14*ww);
900 _pppSigCLineEdit->setMaximumWidth(6*ww);
901 _pppSigPLineEdit->setMaximumWidth(6*ww);
902 _pppSigCrd0->setMaximumWidth(6*ww);
903 _pppSigCrdP->setMaximumWidth(6*ww);
904 _pppSigTrp0->setMaximumWidth(6*ww);
905 _pppSigTrpP->setMaximumWidth(6*ww);
906 _pppAverageLineEdit->setMaximumWidth(6*ww);
907 _pppQuickStartLineEdit->setMaximumWidth(6*ww);
908 _pppMaxSolGapLineEdit->setMaximumWidth(6*ww);
909 _pppAudioResponseLineEdit->setMaximumWidth(6*ww);
910 _pppRefCrdXLineEdit->setMaximumWidth(10*ww);
911 _pppRefCrdYLineEdit->setMaximumWidth(10*ww);
912 _pppRefCrdZLineEdit->setMaximumWidth(10*ww);
913 _pppRefdNLineEdit->setMaximumWidth(6*ww);
914 _pppRefdELineEdit->setMaximumWidth(6*ww);
915 _pppRefdULineEdit->setMaximumWidth(6*ww);
916 _pppSync->setMaximumWidth(6*ww);
917 _pppSPPComboBox->setMinimumWidth(15*ww);
918
919 _postObsFileChooser = new qtFileChooser;
920 _postObsFileChooser->setFileName(settings.value("postObsFile").toString());
921 _postObsFileChooser->setMinimumWidth(15*ww);
922 _postNavFileChooser = new qtFileChooser;
923 _postNavFileChooser->setFileName(settings.value("postNavFile").toString());
924 _postNavFileChooser->setMinimumWidth(15*ww);
925 _postCorrFileChooser = new qtFileChooser;
926 _postCorrFileChooser->setFileName(settings.value("postCorrFile").toString());
927 _postCorrFileChooser->setMinimumWidth(15*ww);
928 _postOutLineEdit = new QLineEdit(settings.value("postOutFile").toString());
929 _postOutLineEdit->setMinimumWidth(15*ww);
930
931 int ir = 0;
932 pppLayout->addWidget(new QLabel("Precise Point Positioning, Panel 1."), ir, 0, 1, 2, Qt::AlignLeft);
933 ++ir;
934 pppLayout->addWidget(new QLabel("Mode & mountpoints"),ir, 0, Qt::AlignLeft);
935 pppLayout->addWidget(_pppSPPComboBox, ir, 1, Qt::AlignRight);
936 pppLayout->addWidget(_pppMountLineEdit, ir, 3, Qt::AlignRight);
937 pppLayout->addWidget(new QLabel("Obs."), ir, 4, Qt::AlignLeft);
938 pppLayout->addWidget(_pppCorrMountLineEdit, ir, 5, Qt::AlignRight);
939 pppLayout->addWidget(new QLabel("Corr."), ir, 6, Qt::AlignLeft);
940 ++ir;
941 pppLayout->addWidget(new QLabel("Marker coordinates"), ir, 0, Qt::AlignLeft);
942 pppLayout->addWidget(_pppRefCrdXLineEdit, ir, 1, Qt::AlignRight);
943 pppLayout->addWidget(new QLabel("X "), ir, 2, Qt::AlignLeft);
944 pppLayout->addWidget(_pppRefCrdYLineEdit, ir, 3, Qt::AlignRight);
945 pppLayout->addWidget(new QLabel("Y"), ir, 4, Qt::AlignLeft);
946 pppLayout->addWidget(_pppRefCrdZLineEdit, ir, 5, Qt::AlignRight);
947 pppLayout->addWidget(new QLabel("Z"), ir, 6, Qt::AlignLeft);
948 ++ir;
949 pppLayout->addWidget(new QLabel("Antenna excentricity"), ir, 0, Qt::AlignLeft);
950 pppLayout->addWidget(_pppRefdNLineEdit, ir, 1, Qt::AlignRight);
951 pppLayout->addWidget(new QLabel("dN"), ir, 2, Qt::AlignLeft);
952 pppLayout->addWidget(_pppRefdELineEdit, ir, 3, Qt::AlignRight);
953 pppLayout->addWidget(new QLabel("dE"), ir, 4, Qt::AlignLeft);
954 pppLayout->addWidget(_pppRefdULineEdit, ir, 5, Qt::AlignRight);
955 pppLayout->addWidget(new QLabel("dU"), ir, 6, Qt::AlignLeft);
956 ++ir;
957 pppLayout->addWidget(new QLabel("NMEA output"), ir, 0, Qt::AlignLeft);
958 pppLayout->addWidget(_pppNMEALineEdit, ir, 1, Qt::AlignRight);
959 pppLayout->addWidget(new QLabel("NMEA File"), ir, 2, Qt::AlignLeft);
960 pppLayout->addWidget(_pppNMEAPortLineEdit, ir, 3, Qt::AlignRight);
961 pppLayout->addWidget(new QLabel("NMEA Port"), ir, 4, Qt::AlignLeft);
962 ++ir;
963 pppLayout->addWidget(new QLabel("Post-processing"), ir, 0, Qt::AlignLeft);
964 pppLayout->addWidget(_postObsFileChooser, ir, 1, Qt::AlignRight);
965 pppLayout->addWidget(new QLabel("Obs "), ir, 2, Qt::AlignLeft);
966 pppLayout->addWidget(_postNavFileChooser, ir, 3, Qt::AlignRight);
967 pppLayout->addWidget(new QLabel("Nav "), ir, 4, Qt::AlignLeft);
968 ++ir;
969 pppLayout->addWidget(_postCorrFileChooser, ir, 1, Qt::AlignRight);
970 pppLayout->addWidget(new QLabel("Corr"), ir, 2, Qt::AlignLeft);
971 pppLayout->addWidget(_postOutLineEdit, ir, 3, Qt::AlignRight);
972 pppLayout->addWidget(new QLabel("Log (full path)"), ir, 4, Qt::AlignLeft);
973
974 pppgroup->setLayout(pppLayout);
975
976 // PPP Client (second panel)
977 // -------------------------
978 QGridLayout* ppp2Layout = new QGridLayout;
979 ppp2Layout->setColumnMinimumWidth(0,14*ww);
980 ir = 0;
981 ppp2Layout->addWidget(new QLabel("Precise Point Positioning, Panel 2."), ir, 0, 1, 10);
982 ++ir;
983 ppp2Layout->addWidget(new QLabel("Antennas"), ir, 0);
984 ppp2Layout->addWidget(_pppAntexFileChooser, ir, 1,1,3);
985 ppp2Layout->addWidget(new QLabel("ANTEX File"), ir, 4);
986 ppp2Layout->addWidget(_pppAntennaLineEdit, ir, 5,1,3);
987 ppp2Layout->addWidget(new QLabel("Antenna Name"), ir, 8);
988 ++ir;
989 ppp2Layout->addWidget(new QLabel("Basics"), ir, 0, 1, 5);
990 ppp2Layout->addWidget(_pppUsePhaseCheckBox, ir, 1, Qt::AlignRight);
991 ppp2Layout->addWidget(new QLabel("Use phase obs"), ir, 2);
992 ppp2Layout->addWidget(_pppEstTropoCheckBox, ir, 3, Qt::AlignRight);
993 ppp2Layout->addWidget(new QLabel("Estimate tropo"), ir, 4);
994 ppp2Layout->addWidget(_pppGLONASSCheckBox, ir, 5, Qt::AlignRight);
995 ppp2Layout->addWidget(new QLabel("Use GLONASS"), ir, 6);
996 ppp2Layout->addWidget(_pppGalileoCheckBox, ir, 7, Qt::AlignRight);
997 ppp2Layout->addWidget(new QLabel("Use Galileo "), ir, 8);
998 ++ir;
999 ppp2Layout->addWidget(new QLabel("Basics cont'd"), ir, 0);
1000 ppp2Layout->addWidget(_pppSync, ir, 1);
1001 ppp2Layout->addWidget(new QLabel("Sync Corr (sec) "), ir, 2);
1002 ppp2Layout->addWidget(_pppAverageLineEdit, ir, 3, Qt::AlignRight);
1003 ppp2Layout->addWidget(new QLabel("Averaging (min)") , ir, 4);
1004 ppp2Layout->addWidget(_pppQuickStartLineEdit, ir, 5, Qt::AlignRight);
1005 ppp2Layout->addWidget(new QLabel("Quick-Start (sec) "), ir, 6);
1006 ppp2Layout->addWidget(_pppMaxSolGapLineEdit, ir, 7, Qt::AlignRight);
1007 ppp2Layout->addWidget(new QLabel("Max Sol. Gap (sec)"), ir, 8);
1008 ++ir;
1009 ppp2Layout->addWidget(new QLabel("Basics cont'd"), ir, 0);
1010 ppp2Layout->addWidget(_pppAudioResponseLineEdit, ir, 1, Qt::AlignRight);
1011 ppp2Layout->addWidget(new QLabel("Audio response (m)"), ir, 2);
1012 ++ir;
1013 ppp2Layout->addWidget(new QLabel("Sigmas"), ir, 0);
1014 ppp2Layout->addWidget(_pppSigCLineEdit, ir, 1, Qt::AlignRight);
1015 ppp2Layout->addWidget(new QLabel("Code"), ir, 2);
1016 ppp2Layout->addWidget(_pppSigPLineEdit, ir, 3);
1017 ppp2Layout->addWidget(new QLabel("Phase"), ir, 4);
1018 ++ir;
1019 ppp2Layout->addWidget(new QLabel("Sigmas cont'd"), ir, 0);
1020 ppp2Layout->addWidget(_pppSigCrd0, ir, 1, Qt::AlignRight);
1021 ppp2Layout->addWidget(new QLabel("XYZ Init "), ir, 2);
1022 ppp2Layout->addWidget(_pppSigCrdP, ir, 3, Qt::AlignRight);
1023 ppp2Layout->addWidget(new QLabel("XYZ White Noise "), ir, 4);
1024 ppp2Layout->addWidget(_pppSigTrp0, ir, 5, Qt::AlignRight);
1025 ppp2Layout->addWidget(new QLabel("Tropo Init "), ir, 6);
1026 ppp2Layout->addWidget(_pppSigTrpP, ir, 7);
1027 ppp2Layout->addWidget(new QLabel("Tropo White Noise"), ir, 8);
1028 ++ir;
1029 ppp2Layout->addWidget(new QLabel(""), ir, 0);
1030
1031 ppp2group->setLayout(ppp2Layout);
1032
1033 // PPP Client (third panel)
1034 // ------------------------
1035 QVBoxLayout* ppp3Layout = new QVBoxLayout;
1036 ppp3Layout->addWidget(new QLabel("Precise Point Positioning, Panel 3."));
1037 ppp3Layout->addSpacing(ww);
1038
1039 QHBoxLayout* ppp3LayoutHlp1 = new QHBoxLayout;
1040 _pppPlotCoordinates = new QCheckBox();
1041 _pppPlotCoordinates->setCheckState(Qt::CheckState(settings.value("pppPlotCoordinates").toInt()));
1042 ppp3LayoutHlp1->addWidget(new QLabel("PPP Plot "));
1043 ppp3LayoutHlp1->addWidget(_pppPlotCoordinates);
1044 ppp3LayoutHlp1->addWidget(new QLabel("Nort-East-Up Time Series"));
1045 ppp3LayoutHlp1->addStretch();
1046 ppp3Layout->addLayout(ppp3LayoutHlp1);
1047 ppp3Layout->addSpacing(ww);
1048
1049 QHBoxLayout* ppp3LayoutHlp2 = new QHBoxLayout;
1050 ppp3LayoutHlp2->addWidget(new QLabel("Track Plot "));
1051 _mapWinButton = new QPushButton;
1052 _mapWinButton->setText("Open Map");
1053 connect(_mapWinButton, SIGNAL(clicked()), SLOT(slotMapPPP()));
1054 ppp3LayoutHlp2->addWidget(_mapWinButton);
1055
1056 ppp3LayoutHlp2->addSpacing(1*ww);
1057
1058 _gmRadioButton = new QRadioButton;
1059 _gmRadioButton->setChecked(!settings.value("useOsmMap").toBool());
1060 ppp3LayoutHlp2->addWidget(new QLabel("Google"));
1061 ppp3LayoutHlp2->addWidget(_gmRadioButton);
1062
1063 _osmRadioButton = new QRadioButton;
1064 _osmRadioButton->setChecked(settings.value("useOsmMap").toBool());
1065 ppp3LayoutHlp2->addWidget(new QLabel("OSM"));
1066 ppp3LayoutHlp2->addWidget(_osmRadioButton);
1067
1068 ppp3LayoutHlp2->addSpacing(3*ww);
1069
1070 _mapWinDotSizeLineEdit = new QLineEdit(settings.value("mapWinDotSize").toString());
1071 ppp3LayoutHlp2->addWidget(new QLabel("Dot Size"));
1072 _mapWinDotSizeLineEdit->setMaximumWidth(5*ww);
1073 ppp3LayoutHlp2->addWidget(_mapWinDotSizeLineEdit);
1074
1075 ppp3LayoutHlp2->addSpacing(3*ww);
1076
1077 _mapWinDotColorComboBox = new QComboBox();
1078 ppp3LayoutHlp2->addWidget(new QLabel("Dot Color"));
1079 _mapWinDotColorComboBox->setEditable(false);
1080 _mapWinDotColorComboBox->addItems(QString("red,yellow").split(","));
1081 ii = _mapWinDotColorComboBox->findText(settings.value("mapWinDotColor").toString());
1082 if (ii != -1) {
1083 _mapWinDotColorComboBox->setCurrentIndex(ii);
1084 }
1085 ppp3LayoutHlp2->addWidget(_mapWinDotColorComboBox);
1086
1087 ppp3LayoutHlp2->addSpacing(3*ww);
1088
1089 _mapSpeedSlider = new QSlider;
1090 _mapSpeedSlider->setOrientation(Qt::Horizontal);
1091 _mapSpeedSlider->setRange(1, 100);
1092 _mapSpeedSlider->setTickPosition(QSlider::TicksBelow);
1093 _mapSpeedSlider->setTickInterval(10);
1094 int speed = settings.value("mapSpeed").toInt();
1095 if (speed == 0) speed = _mapSpeedSlider->maximum();
1096 _mapSpeedSlider->setSliderPosition(speed);
1097 ppp3LayoutHlp2->addWidget(new QLabel("Speed"));
1098 ppp3LayoutHlp2->addWidget(_mapSpeedSlider);
1099
1100 ppp3LayoutHlp2->addStretch();
1101 ppp3Layout->addLayout(ppp3LayoutHlp2);
1102
1103 ppp3Layout->addStretch();
1104 ppp3group->setLayout(ppp3Layout);
1105
1106 // Reqc Processing
1107 // ---------------
1108 _reqcActionComboBox = new QComboBox();
1109 _reqcActionComboBox->setEditable(false);
1110 _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
1111 ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
1112 if (ik != -1) {
1113 _reqcActionComboBox->setCurrentIndex(ik);
1114 }
1115 connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
1116 this, SLOT(slotBncTextChanged()));
1117
1118 QGridLayout* reqcLayout = new QGridLayout;
1119 _reqcActionComboBox->setMinimumWidth(15*ww);
1120 _reqcActionComboBox->setMaximumWidth(15*ww);
1121
1122 _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1123 _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
1124 _reqcObsFileChooser->setWhatsThis(tr("Specify the full path to an observation file in RINEX v2 or v3 format."));
1125 _reqcObsFileChooser->setMinimumWidth(15*ww);
1126 _reqcObsFileChooser->setMaximumWidth(15*ww);
1127
1128 _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1129 _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
1130 _reqcNavFileChooser->setWhatsThis(tr("Specify the full path to a RINEX v2 or v3 navigation file."));
1131 _reqcNavFileChooser->setMinimumWidth(15*ww);
1132 _reqcNavFileChooser->setMaximumWidth(15*ww);
1133
1134 _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
1135 _reqcOutObsLineEdit->setWhatsThis(tr("Specify the full path to a RINEX observation output file."));
1136 _reqcOutObsLineEdit->setMinimumWidth(15*ww);
1137 _reqcOutObsLineEdit->setMaximumWidth(15*ww);
1138
1139 _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
1140 _reqcOutNavLineEdit->setWhatsThis(tr("Specify the full path to a RINEX navigation output file."));
1141 _reqcOutNavLineEdit->setMinimumWidth(15*ww);
1142 _reqcOutNavLineEdit->setMaximumWidth(15*ww);
1143
1144 _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
1145 _reqcOutLogLineEdit->setWhatsThis(tr("Specify the full path to a logfile."));
1146 _reqcOutLogLineEdit->setMinimumWidth(15*ww);
1147 _reqcOutLogLineEdit->setMaximumWidth(15*ww);
1148
1149 _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
1150 _reqcPlotDirLineEdit->setWhatsThis(tr("Specify the directory name for saving plots."));
1151 _reqcPlotDirLineEdit->setMinimumWidth(15*ww);
1152 _reqcPlotDirLineEdit->setMaximumWidth(15*ww);
1153
1154 _reqcSkyPlotSystems = new QComboBox();
1155 _reqcSkyPlotSystems->setEditable(false);
1156 _reqcSkyPlotSystems->addItems(QString("ALL,GPS,GLONASS,Galileo").split(","));
1157 ik = _reqcSkyPlotSystems->findText(settings.value("reqcSkyPlotSystems").toString());
1158 if (ik != -1) {
1159 _reqcSkyPlotSystems->setCurrentIndex(ik);
1160 }
1161
1162 ir = 0;
1163 reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check."),ir, 0, 1, 20);
1164 ++ir;
1165 reqcLayout->addWidget(new QLabel("Action"), ir, 0, Qt::AlignLeft);
1166 reqcLayout->addWidget(_reqcActionComboBox, ir, 1, Qt::AlignLeft);
1167 _reqcEditOptionButton = new QPushButton("Set Edit Options");
1168 reqcLayout->addWidget(_reqcEditOptionButton, ir, 3, Qt::AlignRight);
1169 ++ir;
1170 reqcLayout->addWidget(new QLabel("Input files (full path)"), ir, 0, Qt::AlignLeft);
1171 reqcLayout->addWidget(_reqcObsFileChooser, ir, 1, Qt::AlignRight);
1172 reqcLayout->addWidget(new QLabel("Obs"), ir, 2, Qt::AlignLeft);
1173 reqcLayout->addWidget(_reqcNavFileChooser, ir, 3, Qt::AlignRight);
1174 reqcLayout->addWidget(new QLabel("Nav"), ir, 4, Qt::AlignLeft);
1175 ++ir;
1176 reqcLayout->addWidget(new QLabel("Output files (full path)"), ir, 0, Qt::AlignLeft);
1177 reqcLayout->addWidget(_reqcOutObsLineEdit, ir, 1, Qt::AlignRight);
1178 reqcLayout->addWidget(new QLabel("Obs"), ir, 2, Qt::AlignLeft);
1179 reqcLayout->addWidget(_reqcOutNavLineEdit, ir, 3, Qt::AlignRight);
1180 reqcLayout->addWidget(new QLabel("Nav"), ir, 4, Qt::AlignLeft);
1181 ++ir;
1182 reqcLayout->addWidget(_reqcOutLogLineEdit, ir, 1, Qt::AlignRight);
1183 reqcLayout->addWidget(new QLabel("Log"), ir, 2, Qt::AlignLeft);
1184 ++ir;
1185 reqcLayout->addWidget(new QLabel("Directory for plots"), ir, 0, Qt::AlignLeft);
1186 reqcLayout->addWidget(_reqcPlotDirLineEdit, ir, 1, Qt::AlignRight);
1187 ++ir;
1188 reqcLayout->addWidget(new QLabel("Sky plots for"), ir, 0, Qt::AlignLeft);
1189 reqcLayout->addWidget(_reqcSkyPlotSystems, ir, 1, Qt::AlignRight);
1190 ++ir;
1191 reqcLayout->addWidget(new QLabel(""), ir, 1);
1192 reqcLayout->setRowStretch(ir, 999);
1193
1194 reqcLayout->setColumnMinimumWidth(2, 8*ww);
1195 reqcLayout->setColumnMinimumWidth(4, 8*ww);
1196
1197 reqcgroup->setLayout(reqcLayout);
1198
1199 connect(_reqcEditOptionButton, SIGNAL(clicked()),
1200 this, SLOT(slotReqcEditOption()));
1201
1202 // Combine Corrections
1203 // -------------------
1204 QGridLayout* cmbLayout = new QGridLayout;
1205
1206 populateCmbTable();
1207 cmbLayout->addWidget(_cmbTable, 0, 0, 6, 3);
1208 cmbLayout->addWidget(new QLabel(" "), 0, 5);
1209 cmbLayout->addWidget(new QLabel("Combine Broadcast Correction streams."), 0, 6, 1, 50);
1210 cmbLayout->addWidget(new QLabel(" "), 1, 5);
1211 cmbLayout->addWidget(addCmbRowButton, 1, 6);
1212 cmbLayout->addWidget(delCmbRowButton, 1, 7);
1213 cmbLayout->addWidget(new QLabel(" "), 2, 5);
1214 cmbLayout->addWidget(new QLabel("Method"), 2, 6, Qt::AlignRight);
1215 cmbLayout->addWidget(_cmbMethodComboBox, 2, 7, Qt::AlignRight);
1216 cmbLayout->addWidget(new QLabel(" "), 3, 5);
1217 cmbLayout->addWidget(new QLabel("Maximal Residuum"), 3, 6, Qt::AlignRight);
1218 cmbLayout->addWidget(_cmbMaxresLineEdit, 3, 7, Qt::AlignRight);
1219 cmbLayout->addWidget(new QLabel(" "), 4, 5);
1220 cmbLayout->addWidget(new QLabel("Sampling"), 4, 6, Qt::AlignRight);
1221 cmbLayout->addWidget(_cmbSamplSpinBox, 4, 7, Qt::AlignRight);
1222 cmbLayout->addWidget(new QLabel(" "), 5, 0);
1223
1224 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1225 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
1226
1227 cmbgroup->setLayout(cmbLayout);
1228
1229 // Upload Layout (Clocks)
1230 // ----------------------
1231 QGridLayout* uploadHlpLayout = new QGridLayout();
1232
1233 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1234 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1235 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
1236
1237 uploadHlpLayout->addWidget(addUploadRowButton, 0, 0);
1238 uploadHlpLayout->addWidget(delUploadRowButton, 0, 1);
1239 uploadHlpLayout->addWidget(new QLabel("Interval"), 0, 2, Qt::AlignRight);
1240 uploadHlpLayout->addWidget(_uploadIntrComboBox, 0, 3);
1241 uploadHlpLayout->addWidget(new QLabel(" Sampling: Orb"), 0, 4, Qt::AlignRight);
1242 uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox, 0, 5);
1243 uploadHlpLayout->addWidget(new QLabel("SP3"), 0, 6, Qt::AlignRight);
1244 uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox, 0, 7);
1245 uploadHlpLayout->addWidget(new QLabel("RNX"), 0, 8, Qt::AlignRight);
1246 uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox, 0, 9);
1247 uploadHlpLayout->addWidget(setUploadTrafoButton, 0,10);
1248
1249 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1250 populateUploadTable();
1251
1252 uploadLayout->addWidget(new QLabel("Upload RTCMv3 Broadcast Corrections to caster."));
1253 uploadLayout->addWidget(_uploadTable);
1254 uploadLayout->addLayout(uploadHlpLayout);
1255
1256 uploadgroup->setLayout(uploadLayout);
1257
1258 // Upload Layout (Ephemeris)
1259 // -------------------------
1260 QGridLayout* uploadLayoutEph = new QGridLayout;
1261
1262 uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1263 _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1264 _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1265 _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1266
1267 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster."), 0, 0, 1, 50);
1268 uploadLayoutEph->addWidget(new QLabel("Host"), 1, 0);
1269 uploadLayoutEph->addWidget(_uploadEphHostLineEdit, 1, 1, 1, 3);
1270 uploadLayoutEph->addWidget(new QLabel(" Port"), 1, 4, Qt::AlignRight);
1271 uploadLayoutEph->addWidget(_uploadEphPortLineEdit, 1, 5, 1, 1);
1272 uploadLayoutEph->addWidget(new QLabel("Mountpoint "), 2, 0);
1273 uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit, 2, 1);
1274 uploadLayoutEph->addWidget(new QLabel(" Password"), 2, 2, Qt::AlignRight);
1275 uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit, 2, 3);
1276 uploadLayoutEph->addWidget(new QLabel("Sampling"), 3, 0);
1277 uploadLayoutEph->addWidget(_uploadEphSampleSpinBox, 3, 1);
1278 uploadLayoutEph->addWidget(new QLabel("Uploaded"), 4, 0);
1279 uploadLayoutEph->addWidget(_uploadEphBytesCounter, 4, 1);
1280 uploadLayoutEph->addWidget(new QLabel(" "), 5, 0);
1281 uploadLayoutEph->addWidget(new QLabel(" "), 6, 0);
1282
1283 uploadEphgroup->setLayout(uploadLayoutEph);
1284
1285 connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1286 this, SLOT(slotBncTextChanged()));
1287
1288 // Main Layout
1289 // -----------
1290 QGridLayout* mLayout = new QGridLayout;
1291 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
1292 mLayout->addWidget(_aogroup, 0,0);
1293 mLayout->addWidget(_mountPointsTable, 1,0);
1294 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
1295 mLayout->addWidget(_loggroup, 2,0);
1296
1297 _canvas->setLayout(mLayout);
1298
1299 // WhatsThis
1300 // ---------
1301 _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>"));
1302 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1303 _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>"));
1304 _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>"));
1305 _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>"));
1306 _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."));
1307 _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."));
1308 _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."));
1309 _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."));
1310 _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."));
1311 _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>"));
1312 _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."));
1313 _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."));
1314 _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."));
1315 _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>"));
1316 _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>"));
1317 _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>"));
1318 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1319 _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p>"));
1320
1321 _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>"));
1322 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1323 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1324 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of the Broadcast Ephemeris Correction files.</p>"));
1325 _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>"));
1326 _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>"));
1327 _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>"));
1328 _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>"));
1329 _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>"));
1330 _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."));
1331 _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>"));
1332 _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>"));
1333 _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>"));
1334 _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."));
1335 _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)."));
1336 _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."));
1337 _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."));
1338 _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."));
1339 _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>"));
1340 _miscPortLineEdit->setWhatsThis(tr("BNC can output an incoming stream through a TCP/IP port of your local host. Specify a port number here to activate this function."));
1341 _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>."));
1342 _serialMountPointLineEdit->setWhatsThis(tr("<p>Enter a 'Mountpoint' to forward the corresponding stream to a serial connected receiver.</p>"));
1343 _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>"));
1344 _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>"));
1345 _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>"));
1346 _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>"));
1347 _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>"));
1348 _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>"));
1349 _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>"));
1350 _serialFileNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where NMEA messages coming from your serial connected receiver are saved.</p>"));
1351 _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>"));
1352 _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>"));
1353 _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>"));
1354 _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>"));
1355 _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>"));
1356 _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX v2 or v3 files.</p>"));
1357 _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>"));
1358 _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>"));
1359 _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>"));
1360 _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>"));
1361 _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."));
1362 _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."));
1363 _gmRadioButton->setWhatsThis(tr("<p>Specify Google Maps as the background for your rover positions."));
1364 _osmRadioButton->setWhatsThis(tr("<p>Specify Open Street Map as the background for your rover positions."));
1365 _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>"));
1366 _mapWinDotColorComboBox->setWhatsThis(tr("<p>Specify the color of dots showing the rover track.</p>"));
1367 _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."));
1368 _pppNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where PPP results are saved as NMEA messages.</p>"));
1369 _pppNMEAPortLineEdit->setWhatsThis(tr("<p>Specify an IP port number to output PPP results as NMEA messages through an IP port.</p>"));
1370 _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>"));
1371 _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>"));
1372 _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>"));
1373 _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>"));
1374 _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>"));
1375 _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>"));
1376 _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."));
1377 _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>"));
1378 _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>"));
1379 _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>"));
1380 _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>"));
1381 _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>"));
1382 _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>"));
1383 _pppRefdNLineEdit->setWhatsThis(tr("<p>Enter north antenna excentricity.</p>"));
1384 _pppRefdELineEdit->setWhatsThis(tr("<p>Enter east antenna excentricity.</p>"));
1385 _pppRefdULineEdit->setWhatsThis(tr("<p>Enter up antenna excentricity.</p>"));
1386 _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."));
1387 _pppSync->setWhatsThis(tr(
1388 "<p> Zero value (or empty field, default) means that BNC processes each epoch of data "
1389 "immediately after its arrival using satellite clock corrections available at "
1390 "that time.</p><p> Non-zero value 'Sync Corr' (i.e. 5) means that the epochs of data "
1391 "are buffered and the processing of each epoch is postponed till the satellite clock "
1392 "corrections not older than 'Sync Corr' seconds are available.<p>"));
1393 _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>"));
1394 _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>"));
1395 _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."));
1396 _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>"));
1397 _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>"));
1398 _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>"));
1399 _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>"));
1400 _postObsFileChooser->setWhatsThis(tr("Full path to RINEX v2/v3 Observation file."));
1401 _postNavFileChooser->setWhatsThis(tr("Full path to RINEX v2/v3 Navigation file."));
1402 _postCorrFileChooser->setWhatsThis(tr("Full path to Broadcast Corrections file as previously saved with BNC in plain ASCII format."));
1403 _postOutLineEdit->setWhatsThis(tr("Full path to file with post processing PPP results. "));
1404 addCmbRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the mountpoints table."));
1405 delCmbRowButton->setWhatsThis(tr("Hit 'Delete' button to delete the highlighted line from the mountpoints table."));
1406 addUploadRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the stream upload table."));
1407 delUploadRowButton->setWhatsThis(tr("Hit 'Del Row' button to delete the highlighted line from the stream upload table."));
1408 _uploadIntrComboBox->setWhatsThis(tr("Select the length of the SP3 and Clock RINEX files."));
1409 _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."));
1410 _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."));
1411 _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."));
1412 setUploadTrafoButton->setWhatsThis(tr("Hit 'Custom Trafo' to specify your own 14 parameter Helmert Transformation instead of selecting a predefined transformation through 'System' button."));
1413
1414 _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."));
1415 _uploadEphPortLineEdit->setWhatsThis(tr("Specify the IP port of an NTRIP Broadcaster to upload the stream. Default is port 80."));
1416 _uploadEphMountpointLineEdit->setWhatsThis(tr("Specify the mounpoint for stream upload to an NTRIP Broadcaster."));
1417 _uploadEphPasswordLineEdit->setWhatsThis(tr("Specify the stream upload password protecting the mounpoint on an NTRIP Broadcaster."));
1418 _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."));
1419 _uploadEphBytesCounter->setWhatsThis(tr("BNC shows the amount of data uploaded through this stream."));
1420
1421 _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1422 _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
1423 _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>"));
1424
1425 _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1426 _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1427// Weber
1428
1429 // Enable/Disable all Widgets
1430 // --------------------------
1431 slotBncTextChanged();
1432 enableStartStop();
1433
1434 // Auto start
1435 // ----------
1436 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1437 slotStart();
1438 }
1439}
1440
1441// Destructor
1442////////////////////////////////////////////////////////////////////////////
1443bncWindow::~bncWindow() {
1444 delete _caster;
1445 delete _casterEph;
1446}
1447
1448//
1449////////////////////////////////////////////////////////////////////////////
1450void bncWindow::populateMountPointsTable() {
1451
1452 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1453 _mountPointsTable->removeRow(iRow);
1454 }
1455
1456 bncSettings settings;
1457
1458 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1459 int iRow = 0;
1460 while (it.hasNext()) {
1461 QStringList hlp = it.next().split(" ");
1462 if (hlp.size() < 5) continue;
1463 _mountPointsTable->insertRow(iRow);
1464
1465 QUrl url(hlp[0]);
1466
1467 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1468 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1469 QString nmea(hlp[4]);
1470 if (hlp[5] == "S") {
1471 fullPath = hlp[0].replace(0,2,"");
1472 }
1473 QString ntripVersion = "2";
1474 if (hlp.size() >= 6) {
1475 ntripVersion = (hlp[5]);
1476 }
1477
1478 QTableWidgetItem* it;
1479 it = new QTableWidgetItem(url.userInfo());
1480 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1481 _mountPointsTable->setItem(iRow, 0, it);
1482
1483 it = new QTableWidgetItem(fullPath);
1484 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1485 _mountPointsTable->setItem(iRow, 1, it);
1486
1487 it = new QTableWidgetItem(format);
1488 _mountPointsTable->setItem(iRow, 2, it);
1489
1490 if (nmea == "yes") {
1491 it = new QTableWidgetItem(latitude);
1492 _mountPointsTable->setItem(iRow, 3, it);
1493 it = new QTableWidgetItem(longitude);
1494 _mountPointsTable->setItem(iRow, 4, it);
1495 } else {
1496 it = new QTableWidgetItem(latitude);
1497 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1498 _mountPointsTable->setItem(iRow, 3, it);
1499 it = new QTableWidgetItem(longitude);
1500 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1501 _mountPointsTable->setItem(iRow, 4, it);
1502 }
1503
1504 it = new QTableWidgetItem(nmea);
1505 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1506 _mountPointsTable->setItem(iRow, 5, it);
1507
1508 it = new QTableWidgetItem(ntripVersion);
1509 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1510 _mountPointsTable->setItem(iRow, 6, it);
1511
1512 bncTableItem* bncIt = new bncTableItem();
1513 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1514 _mountPointsTable->setItem(iRow, 7, bncIt);
1515
1516 iRow++;
1517 }
1518
1519 _mountPointsTable->sortItems(1);
1520
1521 enableStartStop();
1522}
1523
1524// Retrieve Table
1525////////////////////////////////////////////////////////////////////////////
1526void bncWindow::slotAddMountPoints() {
1527
1528 bncSettings settings;
1529 QString proxyHost = settings.value("proxyHost").toString();
1530 int proxyPort = settings.value("proxyPort").toInt();
1531 if (proxyHost != _proxyHostLineEdit->text() ||
1532 proxyPort != _proxyPortLineEdit->text().toInt()) {
1533 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1534 "changed. Use the new ones?",
1535 QMessageBox::Yes, QMessageBox::No,
1536 QMessageBox::NoButton);
1537 if (iRet == QMessageBox::Yes) {
1538 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1539 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1540 }
1541 }
1542
1543 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1544 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1545
1546 QMessageBox msgBox;
1547 msgBox.setIcon(QMessageBox::Question);
1548 msgBox.setWindowTitle("Add Stream");
1549 msgBox.setText("Add stream(s) coming from:");
1550
1551 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1552 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1553 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1554 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1555 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1556
1557 msgBox.exec();
1558
1559 if (msgBox.clickedButton() == buttonNtrip) {
1560 bncTableDlg* dlg = new bncTableDlg(this);
1561 dlg->move(this->pos().x()+50, this->pos().y()+50);
1562 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1563 this, SLOT(slotNewMountPoints(QStringList*)));
1564 dlg->exec();
1565 delete dlg;
1566 } else if (msgBox.clickedButton() == buttonIP) {
1567 bncIpPort* ipp = new bncIpPort(this);
1568 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1569 this, SLOT(slotNewMountPoints(QStringList*)));
1570 ipp->exec();
1571 delete ipp;
1572 } else if (msgBox.clickedButton() == buttonUDP) {
1573 bncUdpPort* udp = new bncUdpPort(this);
1574 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1575 this, SLOT(slotNewMountPoints(QStringList*)));
1576 udp->exec();
1577 delete udp;
1578 } else if (msgBox.clickedButton() == buttonSerial) {
1579 bncSerialPort* sep = new bncSerialPort(this);
1580 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1581 this, SLOT(slotNewMountPoints(QStringList*)));
1582 sep->exec();
1583 delete sep;
1584 } else if (msgBox.clickedButton() == buttonCancel) {
1585 // Cancel
1586 }
1587
1588 enableStartStop();
1589}
1590
1591// Delete Selected Mount Points
1592////////////////////////////////////////////////////////////////////////////
1593void bncWindow::slotDeleteMountPoints() {
1594
1595 int nRows = _mountPointsTable->rowCount();
1596 bool flg[nRows];
1597 for (int iRow = 0; iRow < nRows; iRow++) {
1598 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1599 flg[iRow] = true;
1600 }
1601 else {
1602 flg[iRow] = false;
1603 }
1604 }
1605 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1606 if (flg[iRow]) {
1607 _mountPointsTable->removeRow(iRow);
1608 }
1609 }
1610 _actDeleteMountPoints->setEnabled(false);
1611
1612 enableStartStop();
1613}
1614
1615// New Mount Points Selected
1616////////////////////////////////////////////////////////////////////////////
1617void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1618 int iRow = 0;
1619 QListIterator<QString> it(*mountPoints);
1620 while (it.hasNext()) {
1621 QStringList hlp = it.next().split(" ");
1622 QUrl url(hlp[0]);
1623 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1624 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1625 QString nmea(hlp[4]);
1626 if (hlp[5] == "S") {
1627 fullPath = hlp[0].replace(0,2,"");
1628 }
1629 QString ntripVersion = "2";
1630 if (hlp.size() >= 6) {
1631 ntripVersion = (hlp[5]);
1632 }
1633
1634 _mountPointsTable->insertRow(iRow);
1635
1636 QTableWidgetItem* it;
1637 it = new QTableWidgetItem(url.userInfo());
1638 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1639 _mountPointsTable->setItem(iRow, 0, it);
1640
1641 it = new QTableWidgetItem(fullPath);
1642 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1643 _mountPointsTable->setItem(iRow, 1, it);
1644
1645 it = new QTableWidgetItem(format);
1646 _mountPointsTable->setItem(iRow, 2, it);
1647
1648 if (nmea == "yes") {
1649 it = new QTableWidgetItem(latitude);
1650 _mountPointsTable->setItem(iRow, 3, it);
1651 it = new QTableWidgetItem(longitude);
1652 _mountPointsTable->setItem(iRow, 4, it);
1653 } else {
1654 it = new QTableWidgetItem(latitude);
1655 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1656 _mountPointsTable->setItem(iRow, 3, it);
1657 it = new QTableWidgetItem(longitude);
1658 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1659 _mountPointsTable->setItem(iRow, 4, it);
1660 }
1661
1662 it = new QTableWidgetItem(nmea);
1663 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1664 _mountPointsTable->setItem(iRow, 5, it);
1665
1666 it = new QTableWidgetItem(ntripVersion);
1667 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1668 _mountPointsTable->setItem(iRow, 6, it);
1669
1670 bncTableItem* bncIt = new bncTableItem();
1671 _mountPointsTable->setItem(iRow, 7, bncIt);
1672
1673 iRow++;
1674 }
1675 _mountPointsTable->hideColumn(0);
1676 _mountPointsTable->sortItems(1);
1677 delete mountPoints;
1678
1679 enableStartStop();
1680}
1681
1682// Save Options (serialize)
1683////////////////////////////////////////////////////////////////////////////
1684void bncWindow::slotSaveOptions() {
1685 saveOptions();
1686 bncSettings settings;
1687 settings.sync();
1688}
1689
1690// Save Options (memory only)
1691////////////////////////////////////////////////////////////////////////////
1692void bncWindow::saveOptions() {
1693
1694 QStringList mountPoints;
1695 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1696
1697 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1698 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1699 "@" + _mountPointsTable->item(iRow, 1)->text() );
1700
1701 mountPoints.append(url.toString() + " " +
1702 _mountPointsTable->item(iRow, 2)->text()
1703 + " " + _mountPointsTable->item(iRow, 3)->text()
1704 + " " + _mountPointsTable->item(iRow, 4)->text()
1705 + " " + _mountPointsTable->item(iRow, 5)->text()
1706 + " " + _mountPointsTable->item(iRow, 6)->text());
1707 } else {
1708 mountPoints.append(
1709 "//" + _mountPointsTable->item(iRow, 1)->text()
1710 + " " + _mountPointsTable->item(iRow, 2)->text()
1711 + " " + _mountPointsTable->item(iRow, 3)->text()
1712 + " " + _mountPointsTable->item(iRow, 4)->text()
1713 + " " + _mountPointsTable->item(iRow, 5)->text()
1714 + " " + _mountPointsTable->item(iRow, 6)->text());
1715 }
1716 }
1717
1718 QStringList combineStreams;
1719 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1720 QString hlp;
1721 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1722 if (_cmbTable->item(iRow, iCol)) {
1723 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1724 }
1725 }
1726 if (!hlp.isEmpty()) {
1727 combineStreams << hlp;
1728 }
1729 }
1730
1731 QStringList uploadMountpointsOut;
1732 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1733 QString hlp;
1734 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1735 if (_uploadTable->cellWidget(iRow, iCol) &&
1736 (iCol == 3 || iCol == 4 || iCol == 5)) {
1737 if (iCol == 3) {
1738 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1739 hlp += passwd->text() + ",";
1740 }
1741 else if (iCol == 4) {
1742 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1743 hlp += system->currentText() + ",";
1744 }
1745 else if (iCol == 5) {
1746 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1747 QString state; state.setNum(com->checkState());
1748 hlp += state + ",";
1749 }
1750 }
1751 else if (_uploadTable->item(iRow, iCol)) {
1752 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1753 }
1754 }
1755 if (!hlp.isEmpty()) {
1756 uploadMountpointsOut << hlp;
1757 }
1758 }
1759
1760 bncSettings settings;
1761
1762 settings.setValue("startTab", _aogroup->currentIndex());
1763 settings.setValue("statusTab", _loggroup->currentIndex());
1764 settings.setValue("mountPoints", mountPoints);
1765// Network
1766 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1767 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1768 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1769 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1770// General
1771 settings.setValue("logFile", _logFileLineEdit->text());
1772 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1773 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1774 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1775 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1776// RINEX Observations
1777 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1778 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1779 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1780 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1781 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1782 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1783// RINEX Ephemeris
1784 settings.setValue("ephPath", _ephPathLineEdit->text());
1785 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1786 settings.setValue("outEphPort", _outEphPortLineEdit->text());
1787 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1788// Broadcast Corrections
1789 settings.setValue("corrPath", _corrPathLineEdit->text());
1790 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1791 settings.setValue("corrPort", _corrPortLineEdit->text());
1792 settings.setValue("corrTime", _corrTimeSpinBox->value());
1793// Feed Engine
1794 settings.setValue("outPort", _outPortLineEdit->text());
1795 settings.setValue("waitTime", _waitTimeSpinBox->value());
1796 settings.setValue("binSampl", _binSamplSpinBox->value());
1797 settings.setValue("outFile", _outFileLineEdit->text());
1798 settings.setValue("outUPort", _outUPortLineEdit->text());
1799// Serial Output
1800 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1801 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1802 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1803 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1804 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1805 settings.setValue("serialParity", _serialParityComboBox->currentText());
1806 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1807 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1808 settings.setValue("serialFileNMEA",_serialFileNMEALineEdit->text());
1809 settings.setValue("serialHeightNMEA",_serialHeightNMEALineEdit->text());
1810// Outages
1811 settings.setValue("obsRate", _obsRateComboBox->currentText());
1812 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1813 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1814 settings.setValue("adviseScript",_adviseScriptLineEdit->text());
1815// Miscellaneous
1816 settings.setValue("miscMount", _miscMountLineEdit->text());
1817 settings.setValue("miscPort", _miscPortLineEdit->text());
1818 settings.setValue("perfIntr", _perfIntrComboBox->currentText());
1819 settings.setValue("scanRTCM", _scanRTCMCheckBox->checkState());
1820// PPPP
1821 settings.setValue("pppSPP", _pppSPPComboBox->currentText());
1822 settings.setValue("pppMount", _pppMountLineEdit->text());
1823 settings.setValue("pppCorrMount",_pppCorrMountLineEdit->text());
1824 settings.setValue("pppRefCrdX", _pppRefCrdXLineEdit->text());
1825 settings.setValue("pppRefCrdY", _pppRefCrdYLineEdit->text());
1826 settings.setValue("pppRefCrdZ", _pppRefCrdZLineEdit->text());
1827 settings.setValue("pppRefdN", _pppRefdNLineEdit->text());
1828 settings.setValue("pppRefdE", _pppRefdELineEdit->text());
1829 settings.setValue("pppRefdU", _pppRefdULineEdit->text());
1830 settings.setValue("nmeaFile", _pppNMEALineEdit->text());
1831 settings.setValue("nmeaPort", _pppNMEAPortLineEdit->text());
1832 settings.setValue("pppPlotCoordinates", _pppPlotCoordinates->checkState());
1833 settings.setValue("useOsmMap", _osmRadioButton->isChecked());
1834 settings.setValue("mapWinDotSize", _mapWinDotSizeLineEdit->text());
1835 settings.setValue("mapWinDotColor", _mapWinDotColorComboBox->currentText());
1836 settings.setValue("mapSpeed", _mapSpeedSlider->value());
1837 settings.setValue("postObsFile", _postObsFileChooser->fileName());
1838 settings.setValue("postNavFile", _postNavFileChooser->fileName());
1839 settings.setValue("postCorrFile", _postCorrFileChooser->fileName());
1840 settings.setValue("postOutFile", _postOutLineEdit->text());
1841 settings.setValue("pppAntenna", _pppAntennaLineEdit->text());
1842 settings.setValue("pppAntex", _pppAntexFileChooser->fileName());
1843 settings.setValue("pppUsePhase", _pppUsePhaseCheckBox->checkState());
1844 settings.setValue("pppEstTropo", _pppEstTropoCheckBox->checkState());
1845 settings.setValue("pppGLONASS", _pppGLONASSCheckBox->checkState());
1846 settings.setValue("pppGalileo", _pppGalileoCheckBox->checkState());
1847 settings.setValue("pppSync", _pppSync->text());
1848 settings.setValue("pppAverage", _pppAverageLineEdit->text());
1849 settings.setValue("pppQuickStart", _pppQuickStartLineEdit->text());
1850 settings.setValue("pppMaxSolGap", _pppMaxSolGapLineEdit->text());
1851 settings.setValue("pppAudioResponse", _pppAudioResponseLineEdit->text());
1852 settings.setValue("pppSigmaCode",_pppSigCLineEdit->text());
1853 settings.setValue("pppSigmaPhase",_pppSigPLineEdit->text());
1854 settings.setValue("pppSigCrd0",_pppSigCrd0->text());
1855 settings.setValue("pppSigCrdP",_pppSigCrdP->text());
1856 settings.setValue("pppSigTrp0",_pppSigTrp0->text());
1857 settings.setValue("pppSigTrpP",_pppSigTrpP->text());
1858// Reqc
1859 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1860 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1861 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1862 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1863 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1864 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
1865 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
1866 settings.setValue("reqcSkyPlotSystems", _reqcSkyPlotSystems->currentText());
1867// Combine Corrections
1868 if (!combineStreams.isEmpty()) {
1869 settings.setValue("combineStreams", combineStreams);
1870 }
1871 else {
1872 settings.setValue("combineStreams", "");
1873 }
1874 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1875 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1876 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1877// Upload Corrections
1878 if (!uploadMountpointsOut.isEmpty()) {
1879 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1880 }
1881 else {
1882 settings.setValue("uploadMountpointsOut", "");
1883 }
1884 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1885 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1886 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1887 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
1888// Upload Ephemeris
1889 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1890 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
1891 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
1892 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1893 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
1894
1895 if (_caster) {
1896 _caster->readMountPoints();
1897 }
1898}
1899
1900// All get slots terminated
1901////////////////////////////////////////////////////////////////////////////
1902void bncWindow::slotGetThreadsFinished() {
1903 BNC_CORE->slotMessage("All Get Threads Terminated", true);
1904 delete _caster; _caster = 0;
1905 delete _casterEph; _casterEph = 0;
1906 _runningRealTime = false;
1907}
1908
1909// Start It!
1910////////////////////////////////////////////////////////////////////////////
1911void bncWindow::slotStart() {
1912 saveOptions();
1913 if ( _pppSPPComboBox->currentText() == "Post-Processing" ) {
1914 startPostProcessingPPP();
1915 }
1916 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
1917 startPostProcessingReqc();
1918 }
1919 else {
1920 startRealTime();
1921 }
1922}
1923
1924// Start Real-Time (Retrieve Data etc.)
1925////////////////////////////////////////////////////////////////////////////
1926void bncWindow::startRealTime() {
1927
1928 _runningRealTime = true;
1929
1930 _bncFigurePPP->reset();
1931
1932 _actDeleteMountPoints->setEnabled(false);
1933
1934 enableStartStop();
1935
1936 _caster = new bncCaster();
1937
1938 BNC_CORE->setPort(_outEphPortLineEdit->text().toInt());
1939 BNC_CORE->setPortCorr(_corrPortLineEdit->text().toInt());
1940 BNC_CORE->initCombination();
1941
1942 connect(_caster, SIGNAL(getThreadsFinished()),
1943 this, SLOT(slotGetThreadsFinished()));
1944
1945 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
1946 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
1947
1948 BNC_CORE->slotMessage("========== Start BNC v" BNCVERSION " =========", true);
1949
1950 bncSettings settings;
1951
1952 QDir rnxdir(settings.value("rnxPath").toString());
1953 if (!rnxdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations directory", true);
1954
1955 QString rnx_file = settings.value("rnxScript").toString();
1956 if ( !rnx_file.isEmpty() ) {
1957 QFile rnxfile(settings.value("rnxScript").toString());
1958 if (!rnxfile.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations script", true);
1959 }
1960
1961 QDir ephdir(settings.value("ephPath").toString());
1962 if (!ephdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Ephemeris directory", true);
1963
1964 QDir corrdir(settings.value("corrPath").toString());
1965 if (!corrdir.exists()) BNC_CORE->slotMessage("Cannot find Broadcast Corrections directory", true);
1966
1967 QString advise_file = settings.value("adviseScript").toString();
1968 if ( !advise_file.isEmpty() ) {
1969 QFile advisefile(settings.value("adviseScript").toString());
1970 if (!advisefile.exists()) BNC_CORE->slotMessage("Cannot find Outages script", true);
1971 }
1972
1973 QString ant_file = settings.value("pppAntex").toString();
1974 if ( !ant_file.isEmpty() ) {
1975 QFile anxfile(settings.value("pppAntex").toString());
1976 if (!anxfile.exists()) BNC_CORE->slotMessage("Cannot find IGS ANTEX file", true);
1977 }
1978
1979 _caster->readMountPoints();
1980
1981 _casterEph = new bncEphUploadCaster();
1982 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
1983 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
1984}
1985
1986// Retrieve Data
1987////////////////////////////////////////////////////////////////////////////
1988void bncWindow::slotStop() {
1989 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving data?",
1990 QMessageBox::Yes, QMessageBox::No,
1991 QMessageBox::NoButton);
1992 if (iRet == QMessageBox::Yes) {
1993 BNC_CORE->stopCombination();
1994 delete _caster; _caster = 0;
1995 delete _casterEph; _casterEph = 0;
1996 _runningRealTime = false;
1997 enableStartStop();
1998 }
1999}
2000
2001// Close Application gracefully
2002////////////////////////////////////////////////////////////////////////////
2003void bncWindow::closeEvent(QCloseEvent* event) {
2004
2005 int iRet = QMessageBox::question(this, "Close", "Save Options?",
2006 QMessageBox::Yes, QMessageBox::No,
2007 QMessageBox::Cancel);
2008
2009 if (iRet == QMessageBox::Cancel) {
2010 event->ignore();
2011 return;
2012 }
2013 else if (iRet == QMessageBox::Yes) {
2014 slotSaveOptions();
2015 }
2016
2017 if (_postProcessing) {
2018 _postProcessing->terminate();
2019 }
2020
2021 QMainWindow::closeEvent(event);
2022}
2023
2024// User changed the selection of mountPoints
2025////////////////////////////////////////////////////////////////////////////
2026void bncWindow::slotSelectionChanged() {
2027 if (_mountPointsTable->selectedItems().isEmpty()) {
2028 _actDeleteMountPoints->setEnabled(false);
2029 }
2030 else {
2031 _actDeleteMountPoints->setEnabled(true);
2032 }
2033}
2034
2035// Display Program Messages
2036////////////////////////////////////////////////////////////////////////////
2037void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
2038
2039#ifdef DEBUG_RTCM2_2021
2040 const int maxBufferSize = 1000;
2041#else
2042 const int maxBufferSize = 10000;
2043#endif
2044
2045 if (! showOnScreen ) {
2046 return;
2047 }
2048
2049 QString txt = _log->toPlainText() + "\n" +
2050 QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg;
2051 _log->clear();
2052 _log->append(txt.right(maxBufferSize));
2053}
2054
2055// About Message
2056////////////////////////////////////////////////////////////////////////////
2057void bncWindow::slotAbout() {
2058 new bncAboutDlg(0);
2059}
2060
2061//Flowchart
2062////////////////////////////////////////////////////////////////////////////
2063void bncWindow::slotFlowchart() {
2064 new bncFlowchartDlg(0);
2065}
2066
2067// Help Window
2068////////////////////////////////////////////////////////////////////////////
2069void bncWindow::slotHelp() {
2070 QUrl url;
2071 url.setPath(":bnchelp.html");
2072 new bncHlpDlg(0, url);
2073}
2074
2075// Select Fonts
2076////////////////////////////////////////////////////////////////////////////
2077void bncWindow::slotFontSel() {
2078 bool ok;
2079 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
2080 if (ok) {
2081 bncSettings settings;
2082 settings.setValue("font", newFont.toString());
2083 QApplication::setFont(newFont);
2084 int ww = QFontMetrics(newFont).width('w');
2085 setMinimumSize(60*ww, 80*ww);
2086 resize(60*ww, 80*ww);
2087 }
2088}
2089
2090// Whats This Help
2091void bncWindow::slotWhatsThis() {
2092 QWhatsThis::enterWhatsThisMode();
2093}
2094
2095//
2096////////////////////////////////////////////////////////////////////////////
2097void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
2098 _threads = threads;
2099
2100 _bncFigure->updateMountPoints();
2101 _bncFigureLate->updateMountPoints();
2102
2103 populateMountPointsTable();
2104 bncSettings settings;
2105 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
2106 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
2107 QListIterator<bncGetThread*> iTh(threads);
2108 while (iTh.hasNext()) {
2109 bncGetThread* thread = iTh.next();
2110 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
2111 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
2112 "@" + _mountPointsTable->item(iRow, 1)->text() );
2113 if (url == thread->mountPoint() &&
2114 _mountPointsTable->item(iRow, 3)->text() == thread->latitude() &&
2115 _mountPointsTable->item(iRow, 4)->text() == thread->longitude() ) {
2116 ((bncTableItem*) _mountPointsTable->item(iRow, 7))->setGetThread(thread);
2117 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
2118 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2119 connect(thread, SIGNAL(newBytes(QByteArray, double)),
2120 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2121 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
2122 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2123 connect(thread, SIGNAL(newLatency(QByteArray, double)),
2124 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2125 if ( Qt::CheckState(settings.value("pppPlotCoordinates").toInt()) == Qt::Checked) {
2126 disconnect(thread,
2127 SIGNAL(newPosition(bncTime, double, double, double)),
2128 _bncFigurePPP,
2129 SLOT(slotNewPosition(bncTime, double, double, double)));
2130 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2131 _bncFigurePPP,
2132 SLOT(slotNewPosition(bncTime, double, double, double)));
2133 }
2134#ifdef QT_WEBKIT
2135 if (_mapWin) {
2136 disconnect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2137 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2138 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2139 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2140 }
2141#endif
2142 break;
2143 }
2144 }
2145 }
2146}
2147
2148//
2149////////////////////////////////////////////////////////////////////////////
2150void bncWindow::CreateMenu() {
2151 // Create Menus
2152 // ------------
2153 _menuFile = menuBar()->addMenu(tr("&File"));
2154 _menuFile->addAction(_actFontSel);
2155 _menuFile->addSeparator();
2156 _menuFile->addAction(_actSaveOpt);
2157 _menuFile->addSeparator();
2158 _menuFile->addAction(_actQuit);
2159
2160 _menuHlp = menuBar()->addMenu(tr("&Help"));
2161 _menuHlp->addAction(_actHelp);
2162 _menuHlp->addAction(_actFlowchart);
2163 _menuHlp->addAction(_actAbout);
2164}
2165
2166// Toolbar
2167////////////////////////////////////////////////////////////////////////////
2168void bncWindow::AddToolbar() {
2169 QToolBar* toolBar = new QToolBar;
2170 addToolBar(Qt::BottomToolBarArea, toolBar);
2171 toolBar->setMovable(false);
2172 toolBar->addAction(_actAddMountPoints);
2173 toolBar->addAction(_actDeleteMountPoints);
2174 toolBar->addAction(_actMapMountPoints);
2175 toolBar->addAction(_actStart);
2176 toolBar->addAction(_actStop);
2177 toolBar->addWidget(new QLabel(" "));
2178 toolBar->addAction(_actwhatsthis);
2179}
2180
2181// About
2182////////////////////////////////////////////////////////////////////////////
2183bncAboutDlg::bncAboutDlg(QWidget* parent) :
2184 QDialog(parent) {
2185
2186 QTextBrowser* tb = new QTextBrowser;
2187 QUrl url; url.setPath(":bncabout.html");
2188 tb->setSource(url);
2189 tb->setReadOnly(true);
2190
2191 int ww = QFontMetrics(font()).width('w');
2192 QPushButton* _closeButton = new QPushButton("Close");
2193 _closeButton->setMaximumWidth(10*ww);
2194 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2195
2196 QGridLayout* dlgLayout = new QGridLayout();
2197 QLabel* img = new QLabel();
2198 img->setPixmap(QPixmap(":ntrip-logo.png"));
2199 dlgLayout->addWidget(img, 0,0);
2200 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
2201 dlgLayout->addWidget(tb,1,0,1,2);
2202 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2203
2204 setLayout(dlgLayout);
2205 resize(60*ww, 60*ww);
2206 setWindowTitle("About BNC");
2207 show();
2208}
2209
2210//
2211////////////////////////////////////////////////////////////////////////////
2212bncAboutDlg::~bncAboutDlg() {
2213};
2214
2215// Flowchart
2216////////////////////////////////////////////////////////////////////////////
2217bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2218 QDialog(parent) {
2219
2220 int ww = QFontMetrics(font()).width('w');
2221 QPushButton* _closeButton = new QPushButton("Close");
2222 _closeButton->setMaximumWidth(10*ww);
2223 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2224
2225 QGridLayout* dlgLayout = new QGridLayout();
2226 QLabel* img = new QLabel();
2227 img->setPixmap(QPixmap(":bncflowchart.png"));
2228 dlgLayout->addWidget(img, 0,0);
2229 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2230
2231 setLayout(dlgLayout);
2232 setWindowTitle("Flow Chart");
2233 show();
2234}
2235
2236//
2237////////////////////////////////////////////////////////////////////////////
2238bncFlowchartDlg::~bncFlowchartDlg() {
2239};
2240
2241// Enable/Disable Widget (and change its color)
2242////////////////////////////////////////////////////////////////////////////
2243void bncWindow::enableWidget(bool enable, QWidget* widget) {
2244 const static QPalette paletteWhite(QColor(255, 255, 255));
2245 const static QPalette paletteGray(QColor(230, 230, 230));
2246
2247 widget->setEnabled(enable);
2248 if (enable) {
2249 widget->setPalette(paletteWhite);
2250 }
2251 else {
2252 widget->setPalette(paletteGray);
2253 }
2254}
2255
2256// Bnc Text
2257////////////////////////////////////////////////////////////////////////////
2258void bncWindow::slotBncTextChanged(){
2259
2260 bool enable = true;
2261
2262 // Proxy
2263 //------
2264 if (sender() == 0 || sender() == _proxyHostLineEdit) {
2265 enable = !_proxyHostLineEdit->text().isEmpty();
2266 enableWidget(enable, _proxyPortLineEdit);
2267 }
2268
2269 // RINEX Observations
2270 // ------------------
2271 if (sender() == 0 || sender() == _rnxPathLineEdit) {
2272 enable = !_rnxPathLineEdit->text().isEmpty();
2273 enableWidget(enable, _rnxSamplSpinBox);
2274 enableWidget(enable, _rnxSkelLineEdit);
2275 enableWidget(enable, _rnxScrpLineEdit);
2276 enableWidget(enable, _rnxV3CheckBox);
2277 enableWidget(enable, _rnxIntrComboBox);
2278 }
2279
2280 // RINEX Ephemeris
2281 // ---------------
2282 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _outEphPortLineEdit) {
2283 enable = !_ephPathLineEdit->text().isEmpty() || !_outEphPortLineEdit->text().isEmpty();
2284 enableWidget(enable, _ephIntrComboBox);
2285 enableWidget(enable, _ephV3CheckBox);
2286 }
2287
2288 // Broadcast Corrections
2289 // ---------------------
2290 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2291 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2292 enableWidget(enable, _corrIntrComboBox);
2293 }
2294
2295 // Feed Engine
2296 // -----------
2297 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2298 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2299 enableWidget(enable, _waitTimeSpinBox);
2300 enableWidget(enable, _binSamplSpinBox);
2301 }
2302
2303 // Serial Output
2304 // -------------
2305 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
2306 sender() == _serialAutoNMEAComboBox) {
2307 enable = !_serialMountPointLineEdit->text().isEmpty();
2308 enableWidget(enable, _serialPortNameLineEdit);
2309 enableWidget(enable, _serialBaudRateComboBox);
2310 enableWidget(enable, _serialParityComboBox);
2311 enableWidget(enable, _serialDataBitsComboBox);
2312 enableWidget(enable, _serialStopBitsComboBox);
2313 enableWidget(enable, _serialFlowControlComboBox);
2314 enableWidget(enable, _serialAutoNMEAComboBox);
2315
2316 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() != "Auto";
2317 enableWidget(enable2, _serialFileNMEALineEdit);
2318 }
2319
2320 // Outages
2321 // -------
2322 if (sender() == 0 || sender() == _obsRateComboBox) {
2323 enable = !_obsRateComboBox->currentText().isEmpty();
2324 enableWidget(enable, _adviseFailSpinBox);
2325 enableWidget(enable, _adviseRecoSpinBox);
2326 enableWidget(enable, _adviseScriptLineEdit);
2327 }
2328
2329 // Miscellaneous
2330 // -------------
2331 if (sender() == 0 || sender() == _miscMountLineEdit) {
2332 enable = !_miscMountLineEdit->text().isEmpty();
2333 enableWidget(enable, _perfIntrComboBox);
2334 enableWidget(enable, _scanRTCMCheckBox);
2335 enableWidget(enable, _miscPortLineEdit);
2336 }
2337
2338 // Enable/disable Broadcast Ephemerides
2339 // ------------------------------------
2340 if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2341 if (!_uploadEphHostLineEdit->text().isEmpty()) {
2342 _uploadEphPortLineEdit->setStyleSheet("background-color: white");
2343 _uploadEphMountpointLineEdit->setStyleSheet("background-color: white");
2344 _uploadEphPasswordLineEdit->setStyleSheet("background-color: white");
2345 _uploadEphSampleSpinBox->setStyleSheet("background-color: white");
2346 _uploadEphPortLineEdit->setEnabled(true);
2347 _uploadEphMountpointLineEdit->setEnabled(true);
2348 _uploadEphPasswordLineEdit->setEnabled(true);
2349 _uploadEphSampleSpinBox->setEnabled(true);
2350 }
2351 else {
2352 _uploadEphPortLineEdit->setStyleSheet("background-color: lightGray");
2353 _uploadEphMountpointLineEdit->setStyleSheet("background-color: lightGray");
2354 _uploadEphPasswordLineEdit->setStyleSheet("background-color: lightGray");
2355 _uploadEphSampleSpinBox->setStyleSheet("background-color: lightGray");
2356 _uploadEphPortLineEdit->setEnabled(false);
2357 _uploadEphMountpointLineEdit->setEnabled(false);
2358 _uploadEphPasswordLineEdit->setEnabled(false);
2359 _uploadEphSampleSpinBox->setEnabled(false);
2360 }
2361 }
2362
2363 // Combine Corrections
2364 // -------------------
2365 if (sender() == 0 || sender() == _cmbTable) {
2366 int iRow = _cmbTable->rowCount();
2367 if (iRow > 0) {
2368 enableWidget(true, _cmbMethodComboBox);
2369 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
2370 _cmbMaxresLineEdit->setEnabled(true);
2371 _cmbSamplSpinBox->setEnabled(true);
2372 }
2373 else {
2374 enableWidget(false, _cmbMethodComboBox);
2375 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2376 _cmbMaxresLineEdit->setEnabled(false);
2377 _cmbSamplSpinBox->setEnabled(false);
2378 }
2379 }
2380
2381 // Upload(clk)
2382 // -----------
2383 int iRow = _uploadTable->rowCount();
2384 if (iRow > 0) {
2385 enableWidget(true, _uploadIntrComboBox);
2386 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2387 enableWidget(true, _uploadSamplClkRnxSpinBox);
2388 enableWidget(true, _uploadSamplSp3SpinBox);
2389 }
2390 else {
2391 enableWidget(false, _uploadIntrComboBox);
2392 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2393 enableWidget(false, _uploadSamplClkRnxSpinBox);
2394 enableWidget(false, _uploadSamplSp3SpinBox);
2395 }
2396
2397 // PPP Client
2398 // ----------
2399 if (sender() == 0
2400 || sender() == _pppMountLineEdit
2401 || sender() == _pppCorrMountLineEdit
2402 || sender() == _pppRefCrdXLineEdit
2403 || sender() == _pppRefCrdYLineEdit
2404 || sender() == _pppRefCrdZLineEdit
2405 || sender() == _pppRefdNLineEdit
2406 || sender() == _pppRefdELineEdit
2407 || sender() == _pppRefdULineEdit
2408 || sender() == _pppSync
2409 || sender() == _pppSPPComboBox
2410 || sender() == _pppQuickStartLineEdit
2411 || sender() == _pppEstTropoCheckBox
2412 || sender() == _pppUsePhaseCheckBox
2413 || sender() == _pppAntexFileChooser
2414#ifdef QT_WEBKIT
2415 || sender() == _mapWin
2416#endif
2417 ) {
2418
2419
2420 enable = !_pppSPPComboBox->currentText().isEmpty();
2421 if (enable) {
2422 enable = (!_pppMountLineEdit->text().isEmpty() && !_pppCorrMountLineEdit->text().isEmpty()) ||
2423 (!_pppMountLineEdit->text().isEmpty() && _pppSPPComboBox->currentText() == "Realtime-SPP") ||
2424 (_pppSPPComboBox->currentText() == "Post-Processing");
2425 }
2426
2427 enableWidget(enable, _pppNMEALineEdit);
2428 enableWidget(enable, _pppNMEAPortLineEdit);
2429 enableWidget(enable, _pppRefCrdXLineEdit);
2430 enableWidget(enable, _pppRefCrdYLineEdit);
2431 enableWidget(enable, _pppRefCrdZLineEdit);
2432 enableWidget(enable, _pppRefdNLineEdit);
2433 enableWidget(enable, _pppRefdELineEdit);
2434 enableWidget(enable, _pppRefdULineEdit);
2435 enableWidget(enable, _pppUsePhaseCheckBox);
2436 enableWidget(enable, _pppPlotCoordinates);
2437 enableWidget(enable, _mapWinButton);
2438 enableWidget(enable, _mapWinDotSizeLineEdit);
2439 enableWidget(enable, _mapWinDotColorComboBox);
2440 enableWidget(enable, _gmRadioButton);
2441 enableWidget(enable, _osmRadioButton);
2442 enableWidget(enable, _pppEstTropoCheckBox);
2443// enableWidget(enable, _pppGLONASSCheckBox);
2444 enableWidget(enable, _pppGalileoCheckBox);
2445// enableWidget(enable, _pppAntexFileChooser);
2446 enableWidget(enable, _pppSigCLineEdit);
2447 enableWidget(enable, _pppSigCrd0);
2448 enableWidget(enable, _pppSigCrdP);
2449
2450 bool enable2 = enable && !_pppRefCrdXLineEdit->text().isEmpty() &&
2451 !_pppRefCrdYLineEdit->text().isEmpty() &&
2452 !_pppRefCrdZLineEdit->text().isEmpty();
2453
2454 enableWidget(enable2, _pppAverageLineEdit);
2455 enableWidget(enable2, _pppQuickStartLineEdit);
2456
2457 bool enable3 = enable2 && !_pppQuickStartLineEdit->text().isEmpty();
2458 enableWidget(enable3, _pppMaxSolGapLineEdit);
2459 enableWidget(enable3, _pppAudioResponseLineEdit);
2460
2461 bool enable4 = enable && !_pppAntexFileChooser->fileName().isEmpty();
2462 enableWidget(enable4, _pppAntennaLineEdit);
2463
2464 bool enable5 = enable && _pppEstTropoCheckBox->isChecked();
2465 enableWidget(enable5, _pppSigTrp0);
2466 enableWidget(enable5, _pppSigTrpP);
2467
2468 bool enable6 = enable && _pppUsePhaseCheckBox->isChecked();
2469 enableWidget(enable6, _pppSigPLineEdit);
2470
2471 bool enable7 = enable && _pppSPPComboBox->currentText() == "Realtime-PPP";
2472 enableWidget(enable7, _pppSync);
2473
2474 bool enable8 = _pppSPPComboBox->currentText() == "Realtime-PPP";
2475 enableWidget(enable8, _pppCorrMountLineEdit);
2476
2477 bool enable9 = _pppSPPComboBox->currentText() == "Post-Processing";
2478 enableWidget(enable9, _postObsFileChooser);
2479 enableWidget(enable9, _postNavFileChooser);
2480 enableWidget(enable9, _postCorrFileChooser);
2481 enableWidget(enable9, _postOutLineEdit);
2482 enableWidget(enable9, _mapSpeedSlider);
2483
2484 bool enable10 = !_pppSPPComboBox->currentText().isEmpty() && !enable9;
2485 enableWidget(enable10, _pppMountLineEdit);
2486 }
2487
2488 if (sender() == 0 || sender() == _reqcActionComboBox) {
2489 enable = !_reqcActionComboBox->currentText().isEmpty();
2490 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2491 enableWidget(enable && enable10, _reqcEditOptionButton);
2492 enableWidget(enable, _reqcObsFileChooser);
2493 enableWidget(enable, _reqcNavFileChooser);
2494 enableWidget(enable && enable10, _reqcOutObsLineEdit);
2495 enableWidget(enable && enable10, _reqcOutNavLineEdit);
2496 enableWidget(enable, _reqcOutLogLineEdit);
2497 enableWidget(enable && !enable10, _reqcPlotDirLineEdit);
2498 enableWidget(enable && !enable10, _reqcSkyPlotSystems);
2499 }
2500
2501 enableStartStop();
2502}
2503
2504//
2505////////////////////////////////////////////////////////////////////////////
2506void bncWindow::slotAddCmbRow() {
2507 int iRow = _cmbTable->rowCount();
2508 _cmbTable->insertRow(iRow);
2509 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2510 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2511 }
2512}
2513
2514//
2515////////////////////////////////////////////////////////////////////////////
2516void bncWindow::slotDelCmbRow() {
2517 int nRows = _cmbTable->rowCount();
2518 bool flg[nRows];
2519 for (int iRow = 0; iRow < nRows; iRow++) {
2520 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2521 flg[iRow] = true;
2522 }
2523 else {
2524 flg[iRow] = false;
2525 }
2526 }
2527 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2528 if (flg[iRow]) {
2529 _cmbTable->removeRow(iRow);
2530 }
2531 }
2532 nRows = _cmbTable->rowCount();
2533 if (nRows < 1) {
2534 enableWidget(false, _cmbMethodComboBox);
2535 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2536 _cmbMaxresLineEdit->setEnabled(false);
2537 _cmbSamplSpinBox->setEnabled(false);
2538 }
2539}
2540
2541//
2542////////////////////////////////////////////////////////////////////////////
2543void bncWindow::populateCmbTable() {
2544
2545 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2546 _cmbTable->removeRow(iRow);
2547 }
2548
2549 bncSettings settings;
2550
2551 int iRow = -1;
2552 QListIterator<QString> it(settings.value("combineStreams").toStringList());
2553 while (it.hasNext()) {
2554 QStringList hlp = it.next().split(" ");
2555 if (hlp.size() > 2) {
2556 ++iRow;
2557 _cmbTable->insertRow(iRow);
2558 }
2559 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2560 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2561 }
2562 }
2563}
2564
2565//
2566////////////////////////////////////////////////////////////////////////////
2567void bncWindow::slotAddUploadRow() {
2568 int iRow = _uploadTable->rowCount();
2569 _uploadTable->insertRow(iRow);
2570 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2571 if (iCol == 3) {
2572 QLineEdit* passwd = new QLineEdit();
2573 passwd->setFrame(false);
2574 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2575 _uploadTable->setCellWidget(iRow, iCol, passwd);
2576 }
2577 else if (iCol == 4) {
2578 QComboBox* system = new QComboBox();
2579 system->setEditable(false);
2580 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2581 system->setFrame(false);
2582 _uploadTable->setCellWidget(iRow, iCol, system);
2583 }
2584 else if (iCol == 5) {
2585 QCheckBox* com = new QCheckBox();
2586 _uploadTable->setCellWidget(iRow, iCol, com);
2587 }
2588 else if (iCol == 11) {
2589 bncTableItem* bncIt = new bncTableItem();
2590 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2591 _uploadTable->setItem(iRow, iCol, bncIt);
2592 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2593 }
2594 else {
2595 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2596 }
2597 }
2598}
2599
2600//
2601////////////////////////////////////////////////////////////////////////////
2602void bncWindow::slotDelUploadRow() {
2603 BNC_CORE->_uploadTableItems.clear();
2604 int nRows = _uploadTable->rowCount();
2605 bool flg[nRows];
2606 for (int iRow = 0; iRow < nRows; iRow++) {
2607 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2608 flg[iRow] = true;
2609 }
2610 else {
2611 flg[iRow] = false;
2612 }
2613 }
2614 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2615 if (flg[iRow]) {
2616 _uploadTable->removeRow(iRow);
2617 }
2618 }
2619 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2620 BNC_CORE->_uploadTableItems[iRow] =
2621 (bncTableItem*) _uploadTable->item(iRow, 11);
2622 }
2623 nRows = _uploadTable->rowCount();
2624 if (nRows < 1) {
2625 enableWidget(false, _uploadIntrComboBox);
2626 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2627 enableWidget(false, _uploadSamplSp3SpinBox);
2628 enableWidget(false, _uploadSamplClkRnxSpinBox);
2629 }
2630}
2631
2632//
2633////////////////////////////////////////////////////////////////////////////
2634void bncWindow::populateUploadTable() {
2635 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2636 _uploadTable->removeRow(iRow);
2637 }
2638
2639 bncSettings settings;
2640
2641 int iRow = -1;
2642 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2643 while (it.hasNext()) {
2644 QStringList hlp = it.next().split(",");
2645 if (hlp.size() > 6) {
2646 ++iRow;
2647 _uploadTable->insertRow(iRow);
2648 }
2649 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2650 if (iCol == 3) {
2651 QLineEdit* passwd = new QLineEdit();
2652 passwd->setFrame(false);
2653 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2654 passwd->setText(hlp[iCol]);
2655 _uploadTable->setCellWidget(iRow, iCol, passwd);
2656 }
2657 else if (iCol == 4) {
2658 QComboBox* system = new QComboBox();
2659 system->setEditable(false);
2660 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2661 system->setFrame(false);
2662 system->setCurrentIndex(system->findText(hlp[iCol]));
2663 _uploadTable->setCellWidget(iRow, iCol, system);
2664 }
2665 else if (iCol == 5) {
2666 QCheckBox* com = new QCheckBox();
2667 if (hlp[iCol].toInt() == Qt::Checked) {
2668 com->setCheckState(Qt::Checked);
2669 }
2670 _uploadTable->setCellWidget(iRow, iCol, com);
2671 }
2672 else if (iCol == 11) {
2673 bncTableItem* bncIt = new bncTableItem();
2674 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2675 _uploadTable->setItem(iRow, iCol, bncIt);
2676 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2677 }
2678 else {
2679 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2680 }
2681 }
2682 }
2683}
2684
2685//
2686////////////////////////////////////////////////////////////////////////////
2687void bncWindow::slotSetUploadTrafo() {
2688 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2689 dlg->exec();
2690 delete dlg;
2691}
2692
2693// Start Post-Processing PPP
2694////////////////////////////////////////////////////////////////////////////
2695void bncWindow::startPostProcessingPPP() {
2696#ifdef USE_POSTPROCESSING
2697 _runningPostProcessingPPP = true;
2698 _actStart->setText("0 Epochs");
2699 enableStartStop();
2700
2701 _postProcessing = new t_postProcessing(this, _mapSpeedSlider->maximum(), _mapSpeedSlider->value());
2702 connect(_postProcessing, SIGNAL(finished()), this, SLOT(slotFinishedPostProcessingPPP()));
2703 connect(_postProcessing, SIGNAL(progress(int)), this, SLOT(slotPostProgress(int)));
2704 connect(_mapSpeedSlider, SIGNAL(valueChanged(int)), _postProcessing, SLOT(slotSetSpeed(int)));
2705 bncSettings settings;
2706 if ( Qt::CheckState(settings.value("pppPlotCoordinates").toInt()) == Qt::Checked) {
2707 _bncFigurePPP->reset();
2708 connect(_postProcessing, SIGNAL(newPosition(bncTime, double, double, double)),
2709 _bncFigurePPP, SLOT(slotNewPosition(bncTime, double, double, double)));
2710 }
2711#ifdef QT_WEBKIT
2712 if (_mapWin) {
2713 connect(_postProcessing, SIGNAL(newPosition(bncTime, double, double, double)),
2714 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2715 }
2716#endif
2717
2718 _postProcessing->start();
2719#else
2720 QMessageBox::information(this, "Information",
2721 "Post-Processing Not Permitted");
2722#endif
2723}
2724
2725// Post-Processing PPP Finished
2726////////////////////////////////////////////////////////////////////////////
2727void bncWindow::slotFinishedPostProcessingPPP() {
2728#ifdef QT_WEBKIT
2729 if (_mapWin) {
2730 _postProcessing->disconnect(_mapWin);
2731 }
2732#endif
2733 _runningPostProcessingPPP = false;
2734 delete _postProcessing;
2735 _postProcessing = 0;
2736 QMessageBox::information(this, "Information",
2737 "Post-Processing Thread Finished");
2738 _actStart->setText("Start");
2739 enableStartStop();
2740}
2741
2742// Progress Bar Change
2743////////////////////////////////////////////////////////////////////////////
2744void bncWindow::slotPostProgress(int nEpo) {
2745 if (_actStart) {
2746 _actStart->setText(QString("%1 Epochs").arg(nEpo));
2747 }
2748}
2749
2750// Start Post-Processing Reqc
2751////////////////////////////////////////////////////////////////////////////
2752void bncWindow::startPostProcessingReqc() {
2753#ifdef USE_POSTPROCESSING
2754 _runningPostProcessingReqc = true;
2755 enableStartStop();
2756 if (_reqcActionComboBox->currentText() == "Analyze") {
2757 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
2758 connect(reqcAnalyze, SIGNAL(finished()),
2759 this, SLOT(slotFinishedPostProcessingReqc()));
2760 reqcAnalyze->start();
2761 }
2762 else {
2763 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
2764 connect(reqcEdit, SIGNAL(finished()),
2765 this, SLOT(slotFinishedPostProcessingReqc()));
2766 reqcEdit->start();
2767 }
2768#else
2769 QMessageBox::information(this, "Information",
2770 "Post-Processing Not Permitted");
2771#endif
2772}
2773
2774// Post-Processing Reqc Finished
2775////////////////////////////////////////////////////////////////////////////
2776void bncWindow::slotFinishedPostProcessingReqc() {
2777 _runningPostProcessingReqc = false;
2778 if (_reqcActionComboBox->currentText() != "Analyze") {
2779 QMessageBox::information(this, "Information",
2780 "RINEX Processing Thread Finished");
2781 }
2782 enableStartStop();
2783}
2784
2785// Edit teqc-like editing options
2786////////////////////////////////////////////////////////////////////////////
2787void bncWindow::slotReqcEditOption() {
2788 reqcDlg* dlg = new reqcDlg(this);
2789 dlg->move(this->pos().x()+50, this->pos().y()+50);
2790 dlg->exec();
2791 delete dlg;
2792}
2793
2794// Enable/Disable Start and Stop Buttons
2795////////////////////////////////////////////////////////////////////////////
2796void bncWindow::enableStartStop() {
2797
2798 if ( _pppSPPComboBox && _pppSPPComboBox->currentText() == "Post-Processing" ) {
2799 if (_runningPostProcessingPPP) {
2800 _actStart->setEnabled(false);
2801 }
2802 else {
2803 _actStart->setEnabled(true);
2804 }
2805 _actStop->setEnabled(false);
2806 }
2807 else if ( _reqcActionComboBox && !_reqcActionComboBox->currentText().isEmpty() ) {
2808 if (_runningPostProcessingReqc) {
2809 _actStart->setEnabled(false);
2810 }
2811 else {
2812 _actStart->setEnabled(true);
2813 }
2814 _actStop->setEnabled(false);
2815 }
2816 else {
2817 if (_runningRealTime) {
2818 _actStart->setEnabled(false);
2819 _actStop->setEnabled(true);
2820 }
2821 else {
2822 _actStop->setEnabled(false);
2823 if (_mountPointsTable->rowCount() == 0) {
2824 _actStart->setEnabled(false);
2825 }
2826 else {
2827 _actStart->setEnabled(true);
2828 }
2829 }
2830 }
2831}
2832
2833// Show Map
2834////////////////////////////////////////////////////////////////////////////
2835void bncWindow::slotMapMountPoints() {
2836 saveOptions();
2837 t_bncMap* bncMap = new t_bncMap(this);
2838 bncMap->setMinimumSize(800, 600);
2839 bncMap->setWindowTitle("Selected Mountpoints");
2840
2841 bncSettings settings;
2842 QListIterator<QString> it(settings.value("mountPoints").toStringList());
2843 while (it.hasNext()) {
2844 QStringList hlp = it.next().split(" ");
2845 if (hlp.size() < 5) continue;
2846 QUrl url(hlp[0]);
2847 double latDeg = hlp[2].toDouble();
2848 double lonDeg = hlp[3].toDouble();
2849 bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
2850 }
2851
2852 bncMap->show();
2853}
2854
2855// Show Map
2856////////////////////////////////////////////////////////////////////////////
2857void bncWindow::slotMapPPP() {
2858#ifdef QT_WEBKIT
2859 saveOptions();
2860 enableWidget(false, _mapWinButton);
2861 enableWidget(false, _gmRadioButton);
2862 enableWidget(false, _osmRadioButton);
2863 enableWidget(false, _mapWinDotSizeLineEdit);
2864 enableWidget(false, _mapWinDotColorComboBox);
2865
2866 if (!_mapWin) {
2867 _mapWin = new bncMapWin(this);
2868 connect(_mapWin, SIGNAL(mapClosed()), this, SLOT(slotMapPPPClosed()));
2869 QListIterator<bncGetThread*> it(_threads);
2870 while (it.hasNext()) {
2871 bncGetThread* thread = it.next();
2872 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2873 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2874 }
2875 if (_postProcessing) {
2876 connect(_postProcessing, SIGNAL(newPosition(bncTime, double, double, double)),
2877 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2878 }
2879 }
2880 _mapWin->show();
2881#else
2882 QMessageBox::information(this, "Information",
2883 "Qt Library compiled without QtWebKit");
2884#endif
2885}
2886
2887// Show Map
2888////////////////////////////////////////////////////////////////////////////
2889void bncWindow::slotMapPPPClosed() {
2890#ifdef QT_WEBKIT
2891 slotBncTextChanged();
2892 if (_mapWin) {
2893 QListIterator<bncGetThread*> it(_threads);
2894 while (it.hasNext()) {
2895 bncGetThread* thread = it.next();
2896 thread->disconnect(_mapWin);
2897 }
2898 if (_postProcessing) {
2899 _postProcessing->disconnect(_mapWin);
2900 }
2901 _mapWin->deleteLater();
2902 _mapWin = 0;
2903 }
2904#endif
2905}
Note: See TracBrowser for help on using the repository browser.