source: ntrip/branches/BNC_2.12/src/bncwindow.cpp@ 9043

Last change on this file since 9043 was 9036, checked in by stuerze, 4 years ago

some modification to allow encoding and decoding of SSR corrections in RTCM-SSR and IGS-SSR formats

File size: 149.8 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#include "rinex/reqcedit.h"
67#include "rinex/reqcanalyze.h"
68#include "orbComp/sp3Comp.h"
69#ifdef QT_WEBKIT
70# include "map/bncmapwin.h"
71#endif
72
73using namespace std;
74
75#ifdef GNSSCENTER_PLUGIN
76Q_EXPORT_PLUGIN2(gnsscenter_bnc, t_bncFactory)
77#endif
78
79// Constructor
80////////////////////////////////////////////////////////////////////////////
81bncWindow::bncWindow() {
82
83 const static QPalette paletteWhite(QColor(255, 255, 255));
84 const static QPalette paletteGray(QColor(230, 230, 230));
85
86#ifdef GNSSCENTER_PLUGIN
87 BNC_CORE->setConfFileName("");
88#endif
89
90 _caster = 0;
91 _casterEph = 0;
92
93 _bncFigure = new bncFigure(this);
94 _bncFigureLate = new bncFigureLate(this);
95 _bncFigurePPP = new bncFigurePPP(this);
96
97 connect(BNC_CORE, SIGNAL(newPosition(QByteArray, bncTime, QVector<double>)),
98 _bncFigurePPP, SLOT(slotNewPosition(QByteArray, bncTime, QVector<double>)));
99
100 connect(BNC_CORE, SIGNAL(progressRnxPPP(int)), this, SLOT(slotPostProcessingProgress(int)));
101 connect(BNC_CORE, SIGNAL(finishedRnxPPP()), this, SLOT(slotPostProcessingFinished()));
102
103 _runningRealTime = false;
104 _runningPPP = false;
105 _runningEdit = false;
106 _runningQC = false;
107 _runningSp3Comp = false;
108 _reqcActionComboBox = 0; // necessary for enableStartStop()
109
110 _mapWin = 0;
111
112 int ww = QFontMetrics(this->font()).width('w');
113
114 static const QStringList labels = QString("account, Streams: resource loader / mountpoint, decoder, country, lat, long, nmea, ntrip, bytes").split(",");
115
116 setMinimumSize(100*ww, 70*ww);
117
118 setWindowTitle(tr("BKG Ntrip Client (BNC) Version " BNCVERSION));
119
120 connect(BNC_CORE, SIGNAL(newMessage(QByteArray,bool)),
121 this, SLOT(slotWindowMessage(QByteArray,bool)));
122
123 // Create Actions
124 // --------------
125 _actHelp = new QAction(tr("&Help Contents"),this);
126 connect(_actHelp, SIGNAL(triggered()), SLOT(slotHelp()));
127
128 _actAbout = new QAction(tr("&About BNC"),this);
129 connect(_actAbout, SIGNAL(triggered()), SLOT(slotAbout()));
130
131 _actFlowchart = new QAction(tr("&Flow Chart"),this);
132 connect(_actFlowchart, SIGNAL(triggered()), SLOT(slotFlowchart()));
133
134 _actFontSel = new QAction(tr("Select &Font"),this);
135 connect(_actFontSel, SIGNAL(triggered()), SLOT(slotFontSel()));
136
137 _actSaveOpt = new QAction(tr("&Reread && Save Configuration"),this);
138 connect(_actSaveOpt, SIGNAL(triggered()), SLOT(slotSaveOptions()));
139
140 _actQuit = new QAction(tr("&Quit"),this);
141 connect(_actQuit, SIGNAL(triggered()), SLOT(close()));
142
143 _actAddMountPoints = new QAction(tr("Add &Stream"),this);
144 connect(_actAddMountPoints, SIGNAL(triggered()), SLOT(slotAddMountPoints()));
145
146 _actDeleteMountPoints = new QAction(tr("&Delete Stream"),this);
147 connect(_actDeleteMountPoints, SIGNAL(triggered()), SLOT(slotDeleteMountPoints()));
148 _actDeleteMountPoints->setEnabled(false);
149
150 _actMapMountPoints = new QAction(tr("&Map"),this);
151 connect(_actMapMountPoints, SIGNAL(triggered()), SLOT(slotMapMountPoints()));
152
153 _actStart = new QAction(tr("Sta&rt"),this);
154 connect(_actStart, SIGNAL(triggered()), SLOT(slotStart()));
155
156 _actStop = new QAction(tr("Sto&p"),this);
157 connect(_actStop, SIGNAL(triggered()), SLOT(slotStop()));
158
159 _actwhatsthis= new QAction(tr("Help?=Shift+F1"),this);
160 connect(_actwhatsthis, SIGNAL(triggered()), SLOT(slotWhatsThis()));
161
162 CreateMenu();
163 AddToolbar();
164
165 bncSettings settings;
166
167 // Network Options
168 // ---------------
169 _proxyHostLineEdit = new QLineEdit(settings.value("proxyHost").toString());
170 _proxyPortLineEdit = new QLineEdit(settings.value("proxyPort").toString());
171
172 connect(_proxyHostLineEdit, SIGNAL(textChanged(const QString &)),
173 this, SLOT(slotBncTextChanged()));
174
175 _sslCaCertPathLineEdit = new QLineEdit(settings.value("sslCaCertPath").toString());
176 _sslIgnoreErrorsCheckBox = new QCheckBox();
177 _sslIgnoreErrorsCheckBox->setCheckState(Qt::CheckState(
178 settings.value("sslIgnoreErrors").toInt()));
179
180 // General Options
181 // ---------------
182 _logFileLineEdit = new QLineEdit(settings.value("logFile").toString());
183 _rawOutFileLineEdit = new QLineEdit(settings.value("rawOutFile").toString());
184 _rnxAppendCheckBox = new QCheckBox();
185 _rnxAppendCheckBox->setCheckState(Qt::CheckState(
186 settings.value("rnxAppend").toInt()));
187 _onTheFlyComboBox = new QComboBox();
188 _onTheFlyComboBox->setEditable(false);
189 _onTheFlyComboBox->addItems(QString("no, 1 day,1 hour,5 min,1 min").split(","));
190 int ii = _onTheFlyComboBox->findText(settings.value("onTheFlyInterval").toString());
191 if (ii != -1) {
192 _onTheFlyComboBox->setCurrentIndex(ii);
193 }
194 _autoStartCheckBox = new QCheckBox();
195 _autoStartCheckBox->setCheckState(Qt::CheckState(
196 settings.value("autoStart").toInt()));
197
198 // RINEX Observations Options
199 // --------------------------
200 _rnxPathLineEdit = new QLineEdit(settings.value("rnxPath").toString());
201 _rnxIntrComboBox = new QComboBox();
202 _rnxIntrComboBox->setEditable(false);
203 _rnxIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
204 ii = _rnxIntrComboBox->findText(settings.value("rnxIntr").toString());
205 if (ii != -1) {
206 _rnxIntrComboBox->setCurrentIndex(ii);
207 }
208 _rnxSamplComboBox = new QComboBox();
209 _rnxSamplComboBox->setEditable(false);
210 _rnxSamplComboBox->addItems(QString("0.1 sec,1 sec,5 sec,10 sec,15 sec,30 sec,60 sec").split(","));
211 int ij = _rnxSamplComboBox->findText(settings.value("rnxSampl").toString());
212 if (ij != -1) {
213 _rnxSamplComboBox->setCurrentIndex(ij);
214 }
215 _rnxFileCheckBox = new QCheckBox();
216 _rnxFileCheckBox->setCheckState(Qt::CheckState(settings.value("rnxOnlyWithSKL").toInt()));
217 _rnxSkelLineEdit = new QLineEdit(settings.value("rnxSkel").toString());
218 _rnxSkelLineEdit->setMaximumWidth(5*ww);
219 _rnxScrpLineEdit = new QLineEdit(settings.value("rnxScript").toString());
220 _rnxV3CheckBox = new QCheckBox();
221 _rnxV3CheckBox->setCheckState(Qt::CheckState(settings.value("rnxV3").toInt()));
222 QString hlp = settings.value("rnxV2Priority").toString();
223 if (hlp.isEmpty()) {
224 hlp = "G:12&PWCSLX G:5&IQX R:12&PC R:3&IQX R:46&ABX E:16&BCXZ E:578&IQX J:1&SLXCZ J:26&SLX J:5&IQX C:267&IQX C:128&DPX C:7&DPZ I:ABCX S:1&C S:5&IQX";
225 }
226 _rnxV2Priority = new QLineEdit(hlp);
227
228 connect(_rnxPathLineEdit, SIGNAL(textChanged(const QString &)),
229 this, SLOT(slotBncTextChanged()));
230 connect(_rnxV3CheckBox, SIGNAL(stateChanged(int)),
231 this, SLOT(slotBncTextChanged()));
232
233 // RINEX Ephemeris Options
234 // -----------------------
235 _ephPathLineEdit = new QLineEdit(settings.value("ephPath").toString());
236 _ephIntrComboBox = new QComboBox();
237 _ephIntrComboBox->setEditable(false);
238 _ephIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
239 int jj = _ephIntrComboBox->findText(settings.value("ephIntr").toString());
240 if (jj != -1) {
241 _ephIntrComboBox->setCurrentIndex(jj);
242 }
243 _ephOutPortLineEdit = new QLineEdit(settings.value("ephOutPort").toString());
244 _ephV3CheckBox = new QCheckBox();
245 _ephV3CheckBox->setCheckState(Qt::CheckState(settings.value("ephV3").toInt()));
246
247 connect(_ephOutPortLineEdit, SIGNAL(textChanged(const QString &)),
248 this, SLOT(slotBncTextChanged()));
249
250 connect(_ephPathLineEdit, SIGNAL(textChanged(const QString &)),
251 this, SLOT(slotBncTextChanged()));
252
253 // Broadcast Corrections Options
254 // -----------------------------
255 _corrPathLineEdit = new QLineEdit(settings.value("corrPath").toString());
256 _corrIntrComboBox = new QComboBox();
257 _corrIntrComboBox->setEditable(false);
258 _corrIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
259 int mm = _corrIntrComboBox->findText(settings.value("corrIntr").toString());
260 if (mm != -1) {
261 _corrIntrComboBox->setCurrentIndex(mm);
262 }
263 _corrPortLineEdit = new QLineEdit(settings.value("corrPort").toString());
264
265 connect(_corrPathLineEdit, SIGNAL(textChanged(const QString &)),
266 this, SLOT(slotBncTextChanged()));
267
268 connect(_corrPortLineEdit, SIGNAL(textChanged(const QString &)),
269 this, SLOT(slotBncTextChanged()));
270
271 // Feed Engine Options
272 // -------------------
273 _outPortLineEdit = new QLineEdit(settings.value("outPort").toString());
274 _outWaitSpinBox = new QSpinBox();
275 _outWaitSpinBox->setMinimum(1);
276 _outWaitSpinBox->setMaximum(30);
277 _outWaitSpinBox->setSingleStep(1);
278 _outWaitSpinBox->setSuffix(" sec");
279 _outWaitSpinBox->setValue(settings.value("outWait").toInt());
280 _outSamplComboBox = new QComboBox();
281 _outSamplComboBox->addItems(QString("0.1 sec,1 sec,5 sec,10 sec,15 sec,30 sec,60 sec").split(","));
282 int nn = _outSamplComboBox->findText(settings.value("outSampl").toString());
283 if (nn != -1) {
284 _outSamplComboBox->setCurrentIndex(nn);
285 }
286 _outFileLineEdit = new QLineEdit(settings.value("outFile").toString());
287 _outUPortLineEdit = new QLineEdit(settings.value("outUPort").toString());
288 _outLockTimeCheckBox = new QCheckBox();
289 _outLockTimeCheckBox->setCheckState(Qt::CheckState(settings.value("outLockTime").toInt()));
290
291 connect(_outPortLineEdit, SIGNAL(textChanged(const QString &)),
292 this, SLOT(slotBncTextChanged()));
293
294 connect(_outFileLineEdit, SIGNAL(textChanged(const QString &)),
295 this, SLOT(slotBncTextChanged()));
296
297 connect(_outLockTimeCheckBox, SIGNAL(stateChanged(int)),
298 this, SLOT(slotBncTextChanged()));
299
300 // Serial Output Options
301 // ---------------------
302 _serialMountPointLineEdit = new QLineEdit(settings.value("serialMountPoint").toString());
303 _serialPortNameLineEdit = new QLineEdit(settings.value("serialPortName").toString());
304 _serialBaudRateComboBox = new QComboBox();
305 _serialBaudRateComboBox->addItems(QString("110,300,600,"
306 "1200,2400,4800,9600,19200,38400,57600,115200").split(","));
307 int kk = _serialBaudRateComboBox->findText(settings.value("serialBaudRate").toString());
308 if (kk != -1) {
309 _serialBaudRateComboBox->setCurrentIndex(kk);
310 }
311 _serialFlowControlComboBox = new QComboBox();
312 _serialFlowControlComboBox->addItems(QString("OFF,XONXOFF,HARDWARE").split(","));
313 kk = _serialFlowControlComboBox->findText(settings.value("serialFlowControl").toString());
314 if (kk != -1) {
315 _serialFlowControlComboBox->setCurrentIndex(kk);
316 }
317 _serialDataBitsComboBox = new QComboBox();
318 _serialDataBitsComboBox->addItems(QString("5,6,7,8").split(","));
319 kk = _serialDataBitsComboBox->findText(settings.value("serialDataBits").toString());
320 if (kk != -1) {
321 _serialDataBitsComboBox->setCurrentIndex(kk);
322 }
323 _serialParityComboBox = new QComboBox();
324 _serialParityComboBox->addItems(QString("NONE,ODD,EVEN,SPACE").split(","));
325 kk = _serialParityComboBox->findText(settings.value("serialParity").toString());
326 if (kk != -1) {
327 _serialParityComboBox->setCurrentIndex(kk);
328 }
329 _serialStopBitsComboBox = new QComboBox();
330 _serialStopBitsComboBox->addItems(QString("1,2").split(","));
331 kk = _serialStopBitsComboBox->findText(settings.value("serialStopBits").toString());
332 if (kk != -1) {
333 _serialStopBitsComboBox->setCurrentIndex(kk);
334 }
335 _serialAutoNMEAComboBox = new QComboBox();
336 _serialAutoNMEAComboBox->addItems(QString("no,Auto,Manual GPGGA,Manual GNGGA").split(","));
337 kk = _serialAutoNMEAComboBox->findText(settings.value("serialAutoNMEA").toString());
338 if (kk != -1) {
339 _serialAutoNMEAComboBox->setCurrentIndex(kk);
340 }
341 _serialFileNMEALineEdit = new QLineEdit(settings.value("serialFileNMEA").toString());
342 _serialHeightNMEALineEdit = new QLineEdit(settings.value("serialHeightNMEA").toString());
343
344 _serialManualNMEASamplingSpinBox = new QSpinBox();
345 _serialManualNMEASamplingSpinBox->setMinimum(0);
346 _serialManualNMEASamplingSpinBox->setMaximum(300);
347 _serialManualNMEASamplingSpinBox->setSingleStep(10);
348 _serialManualNMEASamplingSpinBox->setValue(settings.value("serialManualNMEASampling").toInt());
349 _serialManualNMEASamplingSpinBox->setSuffix(" sec");
350
351 connect(_serialMountPointLineEdit, SIGNAL(textChanged(const QString &)),
352 this, SLOT(slotBncTextChanged()));
353
354 connect(_serialAutoNMEAComboBox, SIGNAL(currentIndexChanged(const QString &)),
355 this, SLOT(slotBncTextChanged()));
356
357 // Outages Options
358 // ---------------
359 _adviseObsRateComboBox = new QComboBox();
360 _adviseObsRateComboBox->setEditable(false);
361 _adviseObsRateComboBox->addItems(QString(",0.1 Hz,0.2 Hz,0.5 Hz,1 Hz,5 Hz").split(","));
362 kk = _adviseObsRateComboBox->findText(settings.value("adviseObsRate").toString());
363 if (kk != -1) {
364 _adviseObsRateComboBox->setCurrentIndex(kk);
365 }
366 _adviseFailSpinBox = new QSpinBox();
367 _adviseFailSpinBox->setMinimum(0);
368 _adviseFailSpinBox->setMaximum(60);
369 _adviseFailSpinBox->setSingleStep(1);
370 _adviseFailSpinBox->setSuffix(" min");
371 _adviseFailSpinBox->setValue(settings.value("adviseFail").toInt());
372 _adviseRecoSpinBox = new QSpinBox();
373 _adviseRecoSpinBox->setMinimum(0);
374 _adviseRecoSpinBox->setMaximum(60);
375 _adviseRecoSpinBox->setSingleStep(1);
376 _adviseRecoSpinBox->setSuffix(" min");
377 _adviseRecoSpinBox->setValue(settings.value("adviseReco").toInt());
378 _adviseScriptLineEdit = new QLineEdit(settings.value("adviseScript").toString());
379
380 connect(_adviseObsRateComboBox, SIGNAL(currentIndexChanged(const QString &)),
381 this, SLOT(slotBncTextChanged()));
382
383 // Miscellaneous Options
384 // ---------------------
385 _miscMountLineEdit = new QLineEdit(settings.value("miscMount").toString());
386 _miscPortLineEdit = new QLineEdit(settings.value("miscPort").toString());
387 _miscIntrComboBox = new QComboBox();
388 _miscIntrComboBox->setEditable(false);
389 _miscIntrComboBox->addItems(QString(",2 sec,10 sec,1 min,5 min,15 min,1 hour,6 hours,1 day").split(","));
390 int ll = _miscIntrComboBox->findText(settings.value("miscIntr").toString());
391 if (ll != -1) {
392 _miscIntrComboBox->setCurrentIndex(ll);
393 }
394 _miscScanRTCMCheckBox = new QCheckBox();
395 _miscScanRTCMCheckBox->setCheckState(Qt::CheckState(
396 settings.value("miscScanRTCM").toInt()));
397
398 connect(_miscMountLineEdit, SIGNAL(textChanged(const QString &)),
399 this, SLOT(slotBncTextChanged()));
400
401 // Streams
402 // -------
403 _mountPointsTable = new QTableWidget(0,9);
404
405 _mountPointsTable->horizontalHeader()->resizeSection(1,34*ww);
406 _mountPointsTable->horizontalHeader()->resizeSection(2,9*ww);
407 _mountPointsTable->horizontalHeader()->resizeSection(3,9*ww);
408 _mountPointsTable->horizontalHeader()->resizeSection(4,7*ww);
409 _mountPointsTable->horizontalHeader()->resizeSection(5,7*ww);
410 _mountPointsTable->horizontalHeader()->resizeSection(6,5*ww);
411 _mountPointsTable->horizontalHeader()->resizeSection(7,5*ww);
412 _mountPointsTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
413 _mountPointsTable->horizontalHeader()->setStretchLastSection(true);
414 _mountPointsTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
415 _mountPointsTable->setHorizontalHeaderLabels(labels);
416 _mountPointsTable->setGridStyle(Qt::NoPen);
417 _mountPointsTable->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
418 _mountPointsTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
419 _mountPointsTable->setSelectionBehavior(QAbstractItemView::SelectRows);
420 _mountPointsTable->hideColumn(0);
421 _mountPointsTable->hideColumn(3);
422 connect(_mountPointsTable, SIGNAL(itemSelectionChanged()),
423 SLOT(slotSelectionChanged()));
424 populateMountPointsTable();
425
426 _log = new QTextEdit();
427 _log->setReadOnly(true);
428 QFont msFont(""); msFont.setStyleHint(QFont::TypeWriter); // default monospace font
429 _log->setFont(msFont);
430 _log->document()->setMaximumBlockCount(1000);
431
432 // Combine Corrections
433 // -------------------
434 _cmbTable = new QTableWidget(0,3);
435 _cmbTable->setHorizontalHeaderLabels(QString("Mountpoint, AC Name, Weight").split(","));
436 _cmbTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
437 _cmbTable->setSelectionBehavior(QAbstractItemView::SelectRows);
438 _cmbTable->setMaximumWidth(30*ww);
439 _cmbTable->horizontalHeader()->resizeSection(0,10*ww);
440 _cmbTable->horizontalHeader()->resizeSection(1,8*ww);
441 _cmbTable->horizontalHeader()->resizeSection(2,8*ww);
442 _cmbTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
443 _cmbTable->horizontalHeader()->setStretchLastSection(true);
444 _cmbTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
445
446 _cmbMaxresLineEdit = new QLineEdit(settings.value("cmbMaxres").toString());
447 _cmbUseGlonass = new QCheckBox();
448 _cmbUseGlonass->setCheckState(Qt::CheckState(settings.value("cmbUseGlonass").toInt()));
449
450 _cmbSamplSpinBox = new QSpinBox;
451 _cmbSamplSpinBox->setMinimum(10);
452 _cmbSamplSpinBox->setMaximum(60);
453 _cmbSamplSpinBox->setSingleStep(10);
454 _cmbSamplSpinBox->setMaximumWidth(9*ww);
455 _cmbSamplSpinBox->setValue(settings.value("cmbSampl").toInt());
456 _cmbSamplSpinBox->setSuffix(" sec");
457
458 QPushButton* addCmbRowButton = new QPushButton("Add Row");
459 QPushButton* delCmbRowButton = new QPushButton("Delete");
460
461 connect(_cmbTable, SIGNAL(itemSelectionChanged()),
462 SLOT(slotBncTextChanged()));
463
464 _cmbMethodComboBox = new QComboBox();
465 _cmbMethodComboBox->setEditable(false);
466 _cmbMethodComboBox->addItems(QString("Filter,Single-Epoch").split(","));
467 int im = _cmbMethodComboBox->findText(settings.value("cmbMethod").toString());
468 if (im != -1) {
469 _cmbMethodComboBox->setCurrentIndex(im);
470 }
471
472 int iRow = _cmbTable->rowCount();
473 if (iRow > 0) {
474 enableWidget(true, _cmbMethodComboBox);
475 enableWidget(true, _cmbMaxresLineEdit);
476 enableWidget(true, _cmbSamplSpinBox);
477 enableWidget(true, _cmbUseGlonass);
478 }
479 else {
480 enableWidget(false, _cmbMethodComboBox);
481 enableWidget(false, _cmbMaxresLineEdit);
482 enableWidget(false, _cmbSamplSpinBox);
483 enableWidget(false, _cmbUseGlonass);
484 }
485
486 // Upload Results
487 // -------------
488 _uploadTable = new QTableWidget(0,13);
489 _uploadTable->setHorizontalHeaderLabels(QString("Host, Port, Mount, Password, System, Format, CoM, SP3 File, RNX File, PID, SID, IOD, bytes").split(","));
490 _uploadTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
491 _uploadTable->setSelectionBehavior(QAbstractItemView::SelectRows);
492 _uploadTable->horizontalHeader()->resizeSection( 0,13*ww);
493 _uploadTable->horizontalHeader()->resizeSection( 1, 5*ww);
494 _uploadTable->horizontalHeader()->resizeSection( 2, 6*ww);
495 _uploadTable->horizontalHeader()->resizeSection( 3, 8*ww);
496 _uploadTable->horizontalHeader()->resizeSection( 4,11*ww);
497 _uploadTable->horizontalHeader()->resizeSection( 5,11*ww);
498 _uploadTable->horizontalHeader()->resizeSection( 6, 4*ww);
499 _uploadTable->horizontalHeader()->resizeSection( 7,15*ww);
500 _uploadTable->horizontalHeader()->resizeSection( 8,15*ww);
501 _uploadTable->horizontalHeader()->resizeSection( 9, 4*ww);
502 _uploadTable->horizontalHeader()->resizeSection(10, 4*ww);
503 _uploadTable->horizontalHeader()->resizeSection(11, 4*ww);
504 _uploadTable->horizontalHeader()->resizeSection(12,12*ww);
505 _uploadTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
506 _uploadTable->horizontalHeader()->setStretchLastSection(true);
507 _uploadTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
508
509 connect(_uploadTable, SIGNAL(itemSelectionChanged()),
510 SLOT(slotBncTextChanged()));
511
512 QPushButton* addUploadRowButton = new QPushButton("Add Row");
513 QPushButton* delUploadRowButton = new QPushButton("Del Row");
514 QPushButton* setUploadTrafoButton = new QPushButton("Custom Trafo");
515 _uploadIntrComboBox = new QComboBox;
516 _uploadIntrComboBox->setEditable(false);
517 _uploadIntrComboBox->addItems(QString("1 day,1 hour, 30 min,15 min,10 min,5 min,2 min,1 min").split(","));
518 ii = _uploadIntrComboBox->findText(settings.value("uploadIntr").toString());
519 if (ii != -1) {
520 _uploadIntrComboBox->setCurrentIndex(ii);
521 }
522
523 _uploadAntexFile = new qtFileChooser(0, qtFileChooser::File);
524 _uploadAntexFile->setFileName(settings.value("uploadAntexFile").toString());
525
526 _uploadSamplRtcmEphCorrSpinBox = new QSpinBox;
527 _uploadSamplRtcmEphCorrSpinBox->setMinimum(0);
528 _uploadSamplRtcmEphCorrSpinBox->setMaximum(60);
529 _uploadSamplRtcmEphCorrSpinBox->setSingleStep(5);
530 _uploadSamplRtcmEphCorrSpinBox->setMaximumWidth(9*ww);
531 _uploadSamplRtcmEphCorrSpinBox->setValue(settings.value("uploadSamplRtcmEphCorr").toInt());
532 _uploadSamplRtcmEphCorrSpinBox->setSuffix(" sec");
533
534 _uploadSamplSp3SpinBox = new QSpinBox;
535 _uploadSamplSp3SpinBox->setMinimum(0);
536 _uploadSamplSp3SpinBox->setMaximum(15);
537 _uploadSamplSp3SpinBox->setSingleStep(1);
538 _uploadSamplSp3SpinBox->setMaximumWidth(9*ww);
539 _uploadSamplSp3SpinBox->setValue(settings.value("uploadSamplSp3").toInt());
540 _uploadSamplSp3SpinBox->setSuffix(" min");
541
542 _uploadSamplClkRnxSpinBox = new QSpinBox;
543 _uploadSamplClkRnxSpinBox->setMinimum(0);
544 _uploadSamplClkRnxSpinBox->setMaximum(60);
545 _uploadSamplClkRnxSpinBox->setSingleStep(5);
546 _uploadSamplClkRnxSpinBox->setMaximumWidth(9*ww);
547 _uploadSamplClkRnxSpinBox->setValue(settings.value("uploadSamplClkRnx").toInt());
548 _uploadSamplClkRnxSpinBox->setSuffix(" sec");
549
550 int iRowT = _uploadTable->rowCount();
551 if (iRowT > 0) {
552 enableWidget(true, _uploadIntrComboBox);
553 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
554 enableWidget(true, _uploadSamplSp3SpinBox);
555 enableWidget(true, _uploadSamplClkRnxSpinBox);
556 enableWidget(true, _uploadAntexFile);
557 }
558 else {
559 enableWidget(false, _uploadIntrComboBox);
560 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
561 enableWidget(false, _uploadSamplSp3SpinBox);
562 enableWidget(false, _uploadSamplClkRnxSpinBox);
563 enableWidget(false, _uploadAntexFile);
564 }
565
566 // Upload RTCM3 Ephemeris
567 // ----------------------
568 _uploadEphHostLineEdit = new QLineEdit(settings.value("uploadEphHost").toString());
569 _uploadEphPortLineEdit = new QLineEdit(settings.value("uploadEphPort").toString());
570 _uploadEphPasswordLineEdit = new QLineEdit(settings.value("uploadEphPassword").toString());
571 _uploadEphPasswordLineEdit->setEchoMode(QLineEdit::PasswordEchoOnEdit);
572 _uploadEphMountpointLineEdit = new QLineEdit(settings.value("uploadEphMountpoint").toString());
573 _uploadEphSampleSpinBox = new QSpinBox;
574 _uploadEphSampleSpinBox->setMinimum(5);
575 _uploadEphSampleSpinBox->setMaximum(60);
576 _uploadEphSampleSpinBox->setSingleStep(5);
577 _uploadEphSampleSpinBox->setMaximumWidth(9*ww);
578 _uploadEphSampleSpinBox->setValue(settings.value("uploadEphSample").toInt());
579 _uploadEphSampleSpinBox->setSuffix(" sec");
580 _uploadEphBytesCounter = new bncBytesCounter;
581
582 // Canvas with Editable Fields
583 // ---------------------------
584 _canvas = new QWidget;
585 setCentralWidget(_canvas);
586
587 _aogroup = new QTabWidget();
588 _aogroup->setElideMode(Qt::ElideNone);
589 _aogroup->setUsesScrollButtons(true);
590 QWidget* pgroup = new QWidget();
591 QWidget* ggroup = new QWidget();
592 QWidget* sgroup = new QWidget();
593 QWidget* egroup = new QWidget();
594 QWidget* agroup = new QWidget();
595 QWidget* cgroup = new QWidget();
596 QWidget* ogroup = new QWidget();
597 QWidget* rgroup = new QWidget();
598 QWidget* sergroup = new QWidget();
599 QWidget* pppGroup1 = new QWidget();
600 QWidget* pppGroup2 = new QWidget();
601 QWidget* pppGroup3 = new QWidget();
602 QWidget* pppGroup4 = new QWidget();
603 QWidget* reqcgroup = new QWidget();
604 QWidget* sp3CompGroup = new QWidget();
605 QWidget* cmbgroup = new QWidget();
606 QWidget* uploadgroup = new QWidget();
607 QWidget* uploadEphgroup = new QWidget();
608 _aogroup->addTab(pgroup,tr("Network"));
609 _aogroup->addTab(ggroup,tr("General"));
610 _aogroup->addTab(ogroup,tr("RINEX Observations"));
611 _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
612 _aogroup->addTab(reqcgroup,tr("RINEX Editing && QC"));
613 _aogroup->addTab(sp3CompGroup,tr("SP3 Comparison"));
614 _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
615 _aogroup->addTab(sgroup,tr("Feed Engine"));
616 _aogroup->addTab(sergroup,tr("Serial Output"));
617 _aogroup->addTab(agroup,tr("Outages"));
618 _aogroup->addTab(rgroup,tr("Miscellaneous"));
619 _aogroup->addTab(pppGroup1,tr("PPP (1)"));
620 _aogroup->addTab(pppGroup2,tr("PPP (2)"));
621 _aogroup->addTab(pppGroup3,tr("PPP (3)"));
622 _aogroup->addTab(pppGroup4,tr("PPP (4)"));
623 _aogroup->addTab(cmbgroup,tr("Combine Corrections"));
624 _aogroup->addTab(uploadgroup,tr("Upload Corrections"));
625 _aogroup->addTab(uploadEphgroup,tr("Upload Ephemeris"));
626
627 // Log Tab
628 // -------
629 _loggroup = new QTabWidget();
630 _loggroup->addTab(_log,tr("Log"));
631 _loggroup->addTab(_bncFigure,tr("Throughput"));
632 _loggroup->addTab(_bncFigureLate,tr("Latency"));
633 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
634
635 // Netowork (Proxy and SSL) Tab
636 // ----------------------------
637 QGridLayout* pLayout = new QGridLayout;
638 pLayout->setColumnMinimumWidth(0,13*ww);
639 _proxyPortLineEdit->setMaximumWidth(9*ww);
640
641 pLayout->addWidget(new QLabel("Settings for proxy in protected networks and for SSL authorization, leave boxes blank if none.<br>"),0, 0, 1, 50);
642 pLayout->addWidget(new QLabel("Proxy host"), 1, 0);
643 pLayout->addWidget(_proxyHostLineEdit, 1, 1, 1,10);
644 pLayout->addWidget(new QLabel("Proxy port"), 2, 0);
645 pLayout->addWidget(_proxyPortLineEdit, 2, 1);
646 pLayout->addWidget(new QLabel("Path to SSL certificates"), 3, 0);
647 pLayout->addWidget(_sslCaCertPathLineEdit, 3, 1, 1,10);
648 pLayout->addWidget(new QLabel("Default: " + bncSslConfig::defaultPath()), 3,11, 1,20);
649 pLayout->addWidget(new QLabel("Ignore SSL authorization errors"), 4, 0);
650 pLayout->addWidget(_sslIgnoreErrorsCheckBox, 4, 1, 1,10);
651 pLayout->addWidget(new QLabel(""), 5, 1);
652 pLayout->setRowStretch(6, 999);
653
654 pgroup->setLayout(pLayout);
655
656 // General Tab
657 // -----------
658 QGridLayout* gLayout = new QGridLayout;
659 gLayout->setColumnMinimumWidth(0,14*ww);
660 _onTheFlyComboBox->setMaximumWidth(9*ww);
661
662 gLayout->addWidget(new QLabel("General settings for logfile, file handling, configuration on-the-fly, auto-start, and raw file output.<br>"),0, 0, 1, 50);
663 gLayout->addWidget(new QLabel("Logfile (full path)"), 1, 0);
664 gLayout->addWidget(_logFileLineEdit, 1, 1, 1,20);
665 gLayout->addWidget(new QLabel("Append files"), 2, 0);
666 gLayout->addWidget(_rnxAppendCheckBox, 2, 1);
667 gLayout->addWidget(new QLabel("Reread configuration"), 3, 0);
668 gLayout->addWidget(_onTheFlyComboBox, 3, 1);
669 gLayout->addWidget(new QLabel("Auto start"), 4, 0);
670 gLayout->addWidget(_autoStartCheckBox, 4, 1);
671 gLayout->addWidget(new QLabel("Raw output file (full path)"), 5, 0);
672 gLayout->addWidget(_rawOutFileLineEdit, 5, 1, 1,20);
673 gLayout->addWidget(new QLabel(""), 6, 1);
674 gLayout->setRowStretch(7, 999);
675
676 ggroup->setLayout(gLayout);
677
678 // RINEX Observations
679 // ------------------
680 QGridLayout* oLayout = new QGridLayout;
681 oLayout->setColumnMinimumWidth(0,14*ww);
682 _rnxIntrComboBox->setMaximumWidth(9*ww);
683 _rnxSamplComboBox->setMaximumWidth(9*ww);
684
685 oLayout->addWidget(new QLabel("Saving RINEX observation files.<br>"),0, 0, 1,50);
686 oLayout->addWidget(new QLabel("Directory"), 1, 0);
687 oLayout->addWidget(_rnxPathLineEdit, 1, 1, 1, 15);
688 oLayout->addWidget(new QLabel("Interval"), 2, 0);
689 oLayout->addWidget(_rnxIntrComboBox, 2, 1);
690 oLayout->addWidget(new QLabel(" Sampling"), 2, 2, Qt::AlignRight);
691 oLayout->addWidget(_rnxSamplComboBox, 2, 3, Qt::AlignLeft);
692 oLayout->addWidget(new QLabel("Skeleton extension"), 3, 0);
693 oLayout->addWidget(_rnxSkelLineEdit, 3, 1, Qt::AlignLeft);
694 oLayout->addWidget(new QLabel("Skeleton mandatory"), 3, 2);
695 oLayout->addWidget(_rnxFileCheckBox, 3, 3);
696 oLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
697 oLayout->addWidget(_rnxScrpLineEdit, 4, 1, 1, 15);
698 oLayout->addWidget(new QLabel("Version 2 signal priority"), 5, 0);
699 oLayout->addWidget(_rnxV2Priority, 5, 1, 1, 15);
700 oLayout->addWidget(new QLabel("Version 3"), 6, 0);
701 oLayout->addWidget(_rnxV3CheckBox, 6, 1);
702 oLayout->addWidget(new QLabel(""), 7, 1);
703 oLayout->setRowStretch(8, 999);
704
705 ogroup->setLayout(oLayout);
706
707 // RINEX Ephemeris
708 // ---------------
709 QGridLayout* eLayout = new QGridLayout;
710 eLayout->setColumnMinimumWidth(0,14*ww);
711 _ephIntrComboBox->setMaximumWidth(9*ww);
712 _ephOutPortLineEdit->setMaximumWidth(9*ww);
713
714 eLayout->addWidget(new QLabel("Saving RINEX navigation files and ephemeris output through IP port.<br>"),0,0,1,70);
715 eLayout->addWidget(new QLabel("Directory"), 1, 0);
716 eLayout->addWidget(_ephPathLineEdit, 1, 1, 1,30);
717 eLayout->addWidget(new QLabel("Interval"), 2, 0);
718 eLayout->addWidget(_ephIntrComboBox, 2, 1);
719 eLayout->addWidget(new QLabel("Port"), 3, 0);
720 eLayout->addWidget(_ephOutPortLineEdit, 3, 1);
721 eLayout->addWidget(new QLabel("Version 3"), 4, 0);
722 eLayout->addWidget(_ephV3CheckBox, 4, 1);
723 eLayout->setRowStretch(5, 999);
724
725 egroup->setLayout(eLayout);
726
727
728 // Broadcast Corrections
729 // ---------------------
730 QGridLayout* cLayout = new QGridLayout;
731 cLayout->setColumnMinimumWidth(0,14*ww);
732 _corrIntrComboBox->setMaximumWidth(9*ww);
733 _corrPortLineEdit->setMaximumWidth(9*ww);
734
735 cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port.<br>"),0,0,1,70);
736 cLayout->addWidget(new QLabel("Directory, ASCII"), 1, 0);
737 cLayout->addWidget(_corrPathLineEdit, 1, 1, 1,30);
738 cLayout->addWidget(new QLabel("Interval"), 2, 0);
739 cLayout->addWidget(_corrIntrComboBox, 2, 1);
740 cLayout->addWidget(new QLabel("Port"), 3, 0);
741 cLayout->addWidget(_corrPortLineEdit, 3, 1);
742 cLayout->addWidget(new QLabel(""), 4, 1);
743 cLayout->setRowStretch(7, 999);
744 cgroup->setLayout(cLayout);
745
746 // Feed Engine
747 // -----------
748 QGridLayout* sLayout = new QGridLayout;
749 sLayout->setColumnMinimumWidth(0,14*ww);
750 _outPortLineEdit->setMaximumWidth(9*ww);
751 _outWaitSpinBox->setMaximumWidth(9*ww);
752 _outSamplComboBox->setMaximumWidth(9*ww);
753 _outUPortLineEdit->setMaximumWidth(9*ww);
754
755 sLayout->addWidget(new QLabel("Output decoded observations in ASCII format to feed a real-time GNSS network engine.<br>"),0,0,1,50);
756 sLayout->addWidget(new QLabel("Port"), 1, 0);
757 sLayout->addWidget(_outPortLineEdit, 1, 1);
758 sLayout->addWidget(new QLabel(" Wait for full obs epoch"), 1, 2, Qt::AlignRight);
759 sLayout->addWidget(_outWaitSpinBox, 1, 3, Qt::AlignLeft);
760 sLayout->addWidget(new QLabel("Sampling"), 2, 0);
761 sLayout->addWidget(_outSamplComboBox, 2, 1, Qt::AlignLeft);
762 sLayout->addWidget(new QLabel("File (full path)"), 3, 0);
763 sLayout->addWidget(_outFileLineEdit, 3, 1, 1, 10);
764 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 4, 0);
765 sLayout->addWidget(_outUPortLineEdit, 4, 1);
766 sLayout->addWidget(new QLabel("Print lock time"), 5, 0);
767 sLayout->addWidget(_outLockTimeCheckBox, 5, 1);
768 sLayout->addWidget(new QLabel(""), 6, 1);
769 sLayout->setRowStretch(7, 999);
770
771 sgroup->setLayout(sLayout);
772
773 // Serial Output
774 // -------------
775 QGridLayout* serLayout = new QGridLayout;
776 serLayout->setColumnMinimumWidth(0,12*ww);
777 _serialBaudRateComboBox->setMaximumWidth(9*ww);
778 _serialFlowControlComboBox->setMaximumWidth(11*ww);
779 _serialDataBitsComboBox->setMaximumWidth(5*ww);
780 _serialParityComboBox->setMaximumWidth(9*ww);
781 _serialStopBitsComboBox->setMaximumWidth(5*ww);
782 _serialAutoNMEAComboBox->setMaximumWidth(14*ww);
783 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
784 _serialManualNMEASamplingSpinBox->setMaximumWidth(8*ww);
785
786 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver.<br>"),0,0,1,30);
787 serLayout->addWidget(new QLabel("Mountpoint"), 1, 0, Qt::AlignLeft);
788 serLayout->addWidget(_serialMountPointLineEdit, 1, 1, 1, 2);
789 serLayout->addWidget(new QLabel("Port name"), 2, 0, Qt::AlignLeft);
790 serLayout->addWidget(_serialPortNameLineEdit, 2, 1, 1, 2);
791 serLayout->addWidget(new QLabel("Baud rate"), 3, 0, Qt::AlignLeft);
792 serLayout->addWidget(_serialBaudRateComboBox, 3, 1);
793 serLayout->addWidget(new QLabel("Flow control"), 3, 2, Qt::AlignRight);
794 serLayout->addWidget(_serialFlowControlComboBox, 3, 3);
795 serLayout->addWidget(new QLabel("Data bits"), 4, 0, Qt::AlignLeft);
796 serLayout->addWidget(_serialDataBitsComboBox, 4, 1);
797 serLayout->addWidget(new QLabel("Parity"), 4, 2, Qt::AlignRight);
798 serLayout->addWidget(_serialParityComboBox, 4, 3);
799 serLayout->addWidget(new QLabel(" Stop bits"), 4, 4, Qt::AlignRight);
800 serLayout->addWidget(_serialStopBitsComboBox, 4, 5);
801 serLayout->addWidget(new QLabel("NMEA"), 5, 0);
802 serLayout->addWidget(_serialAutoNMEAComboBox, 5, 1);
803 serLayout->addWidget(new QLabel(" File (full path)"), 5, 2, Qt::AlignRight);
804 serLayout->addWidget(_serialFileNMEALineEdit, 5, 3, 1,10);
805 serLayout->addWidget(new QLabel("Height"), 5,14, Qt::AlignRight);
806 serLayout->addWidget(_serialHeightNMEALineEdit, 5,15, 1,11);
807 serLayout->addWidget(new QLabel("Sampling"), 5,25, Qt::AlignRight);
808 serLayout->addWidget(_serialManualNMEASamplingSpinBox, 5,26, 1,12);
809 serLayout->addWidget(new QLabel(""), 6, 1);
810 serLayout->setRowStretch(7, 999);
811
812 sergroup->setLayout(serLayout);
813
814 // Outages
815 // -------
816 QGridLayout* aLayout = new QGridLayout;
817 aLayout->setColumnMinimumWidth(0,14*ww);
818 _adviseObsRateComboBox->setMaximumWidth(9*ww);
819 _adviseFailSpinBox->setMaximumWidth(9*ww);
820 _adviseRecoSpinBox->setMaximumWidth(9*ww);
821
822 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes.<br>"),0,0,1,50,Qt::AlignLeft);
823 aLayout->addWidget(new QLabel("Observation rate"), 1, 0);
824 aLayout->addWidget(_adviseObsRateComboBox, 1, 1);
825 aLayout->addWidget(new QLabel("Failure threshold"), 2, 0);
826 aLayout->addWidget(_adviseFailSpinBox, 2, 1);
827 aLayout->addWidget(new QLabel("Recovery threshold"), 3, 0);
828 aLayout->addWidget(_adviseRecoSpinBox, 3, 1);
829 aLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
830 aLayout->addWidget(_adviseScriptLineEdit, 4, 1, 1,20);
831 aLayout->addWidget(new QLabel(""), 5, 1);
832 aLayout->setRowStretch(6, 999);
833
834 agroup->setLayout(aLayout);
835
836 // Miscellaneous
837 // -------------
838 QGridLayout* rLayout = new QGridLayout;
839 rLayout->setColumnMinimumWidth(0,14*ww);
840 _miscIntrComboBox->setMaximumWidth(9*ww);
841 _miscPortLineEdit->setMaximumWidth(9*ww);
842
843 rLayout->addWidget(new QLabel("Log latencies or scan RTCM streams for message types and antenna information or output raw data through TCP/IP port.<br>"),0, 0,1,50);
844 rLayout->addWidget(new QLabel("Mountpoint"), 1, 0);
845 rLayout->addWidget(_miscMountLineEdit, 1, 1, 1, 7);
846 rLayout->addWidget(new QLabel("Log latency"), 2, 0);
847 rLayout->addWidget(_miscIntrComboBox, 2, 1);
848 rLayout->addWidget(new QLabel("Scan RTCM"), 3, 0);
849 rLayout->addWidget(_miscScanRTCMCheckBox, 3, 1);
850 rLayout->addWidget(new QLabel("Port"), 4, 0);
851 rLayout->addWidget(_miscPortLineEdit, 4, 1);
852 rLayout->addWidget(new QLabel(""), 5, 1);
853 rLayout->setRowStretch(6, 999);
854
855 rgroup->setLayout(rLayout);
856
857 // PPP
858 // ---
859 _pppWidgets._dataSource->setMaximumWidth(20*ww);
860 _pppWidgets._corrMount->setMaximumWidth(20*ww);
861
862 _pppWidgets._corrFile->setMaximumWidth(35*ww);
863 _pppWidgets._crdFile->setMaximumWidth(35*ww);
864 _pppWidgets._logPath->setMaximumWidth(35*ww);
865 _pppWidgets._snxtroPath->setMaximumWidth(35*ww);
866 _pppWidgets._snxtroIntr->setMaximumWidth(10*ww);
867 _pppWidgets._snxtroAc ->setMaximumWidth(10*ww);
868 _pppWidgets._snxtroSol ->setMaximumWidth(7*ww);
869
870 QGridLayout* pppLayout1 = new QGridLayout();
871 int ir = 0;
872 pppLayout1->addWidget(new QLabel("Precise Point Positioning - Input and Output."), ir, 0, 1, 7, Qt::AlignLeft);
873 ++ir;
874 pppLayout1->addWidget(new QLabel("Data source"), ir, 0);
875 pppLayout1->addWidget(_pppWidgets._dataSource, ir, 1);
876 pppLayout1->addWidget(new QLabel(" RINEX Obs file"), ir, 3);
877 pppLayout1->addWidget(_pppWidgets._rinexObs, ir, 4, 1, 3);
878 ++ir;
879 pppLayout1->addWidget(new QLabel("Corrections stream"), ir, 0);
880 pppLayout1->addWidget(_pppWidgets._corrMount, ir, 1);
881 pppLayout1->addWidget(new QLabel(" RINEX Nav file"), ir, 3);
882 pppLayout1->addWidget(_pppWidgets._rinexNav, ir, 4, 1, 3);
883 ++ir;
884 pppLayout1->addWidget(new QLabel("Corrections file"), ir, 0);
885 pppLayout1->addWidget(_pppWidgets._corrFile, ir, 1);
886 pppLayout1->addWidget(new QLabel(" ANTEX file"), ir, 3);
887 pppLayout1->addWidget(_pppWidgets._antexFile, ir, 4, 1, 3);
888 ++ir;
889 pppLayout1->addWidget(new QLabel("Coordinates file"), ir, 0);
890 pppLayout1->addWidget(_pppWidgets._crdFile, ir, 1);
891 pppLayout1->addWidget(new QLabel(" Version 3 filenames"),ir, 3);
892 pppLayout1->addWidget(_pppWidgets._v3filenames, ir, 4, 1, 3);
893 ++ir;
894 pppLayout1->addWidget(new QLabel("Logfile directory"), ir, 0);
895 pppLayout1->addWidget(_pppWidgets._logPath, ir, 1);
896 pppLayout1->addWidget(new QLabel(" NMEA directory"), ir, 3);
897 pppLayout1->addWidget(_pppWidgets._nmeaPath, ir, 4, 1, 3);
898 ++ir;
899 pppLayout1->addWidget(new QLabel("SNX TRO directory"), ir, 0);
900 pppLayout1->addWidget(_pppWidgets._snxtroPath, ir, 1);
901 pppLayout1->addWidget(new QLabel(" SNX TRO interval"), ir, 3);
902 pppLayout1->addWidget(_pppWidgets._snxtroIntr, ir, 4);
903 pppLayout1->addWidget(new QLabel(" SNX TRO sampling"), ir, 5);
904 pppLayout1->addWidget(_pppWidgets._snxtroSampl, ir, 6, Qt::AlignRight);
905 ++ir;
906 pppLayout1->addWidget(new QLabel(" SNX TRO AC"), ir, 3);
907 pppLayout1->addWidget(_pppWidgets._snxtroAc, ir, 4);
908 pppLayout1->addWidget(new QLabel(" SNX TRO solution") ,ir, 5);
909 pppLayout1->addWidget(_pppWidgets._snxtroSol, ir, 6, Qt::AlignRight);
910 pppLayout1->setRowStretch(ir, 999);
911
912 pppGroup1->setLayout(pppLayout1);
913
914 QVBoxLayout* pppLayout2 = new QVBoxLayout();
915 pppLayout2->addWidget(new QLabel("Precise Point Positioning - Processed Stations.<br>"));
916 pppLayout2->addWidget(_pppWidgets._staTable, 99);
917 QHBoxLayout* pppLayout2sub = new QHBoxLayout();
918 pppLayout2sub->addWidget(_pppWidgets._addStaButton);
919 pppLayout2sub->addWidget(_pppWidgets._delStaButton);
920 pppLayout2sub->addStretch(99);
921
922 pppLayout2->addLayout(pppLayout2sub);
923
924 pppGroup2->setLayout(pppLayout2);
925
926 QGridLayout* pppLayout3 = new QGridLayout();
927 ir = 0;
928 pppLayout3->addWidget(new QLabel("Precise Point Positioning - Options.<br>"), ir, 0, 1, 2, Qt::AlignLeft);
929 ++ir;
930 pppLayout3->addWidget(new QLabel("GPS LCs"), ir, 0, Qt::AlignLeft);
931 pppLayout3->addWidget(_pppWidgets._lcGPS, ir, 1);
932 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 2);
933 pppLayout3->addWidget(new QLabel("Sigma C1"), ir, 3, Qt::AlignLeft);
934 pppLayout3->addWidget(_pppWidgets._sigmaC1, ir, 4); _pppWidgets._sigmaC1->setMaximumWidth(8*ww);
935 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 5);
936 pppLayout3->addWidget(new QLabel("Sigma L1"), ir, 6, Qt::AlignLeft);
937 pppLayout3->addWidget(_pppWidgets._sigmaL1, ir, 7); _pppWidgets._sigmaL1->setMaximumWidth(8*ww);
938 ++ir;
939 pppLayout3->addWidget(new QLabel("GLONASS LCs"), ir, 0, Qt::AlignLeft);
940 pppLayout3->addWidget(_pppWidgets._lcGLONASS, ir, 1);
941 pppLayout3->addWidget(new QLabel("Max Res C1"), ir, 3, Qt::AlignLeft);
942 pppLayout3->addWidget(_pppWidgets._maxResC1, ir, 4); _pppWidgets._maxResC1->setMaximumWidth(8*ww);
943 pppLayout3->addWidget(new QLabel("Max Res L1"), ir, 6, Qt::AlignLeft);
944 pppLayout3->addWidget(_pppWidgets._maxResL1, ir, 7); _pppWidgets._maxResL1->setMaximumWidth(8*ww);
945 ++ir;
946 pppLayout3->addWidget(new QLabel("Galileo LCs"), ir, 0, Qt::AlignLeft);
947 pppLayout3->addWidget(_pppWidgets._lcGalileo, ir, 1);
948 pppLayout3->addWidget(new QLabel("Ele Wgt Code"), ir, 3, Qt::AlignLeft);
949 pppLayout3->addWidget(_pppWidgets._eleWgtCode, ir, 4);
950 pppLayout3->addWidget(new QLabel("Ele Wgt Phase"), ir, 6, Qt::AlignLeft);
951 pppLayout3->addWidget(_pppWidgets._eleWgtPhase, ir, 7);
952 ++ir;
953 pppLayout3->addWidget(new QLabel("BDS LCs"), ir, 0, Qt::AlignLeft);
954 pppLayout3->addWidget(_pppWidgets._lcBDS, ir, 1);
955 pppLayout3->addWidget(new QLabel("Min # of Obs"), ir, 3, Qt::AlignLeft);
956 pppLayout3->addWidget(_pppWidgets._minObs, ir, 4);
957 pppLayout3->addWidget(new QLabel("Min Elevation"), ir, 6, Qt::AlignLeft);
958 pppLayout3->addWidget(_pppWidgets._minEle, ir, 7);
959 ++ir;
960 pppLayout3->addWidget(new QLabel("Wait for clock corr."), ir, 0, Qt::AlignLeft);
961 pppLayout3->addWidget(_pppWidgets._corrWaitTime, ir, 1);
962 pppLayout3->addWidget(new QLabel("Seeding (sec)"), ir, 3, Qt::AlignLeft);
963 pppLayout3->addWidget(_pppWidgets._seedingTime, ir, 4);
964 ++ir;
965 pppLayout3->addWidget(new QLabel(""), ir, 8);
966 pppLayout3->setColumnStretch(8, 999);
967 ++ir;
968 pppLayout3->addWidget(new QLabel(""), ir, 1);
969 pppLayout3->setRowStretch(ir, 999);
970
971 pppGroup3->setLayout(pppLayout3);
972
973 // ------------------------
974 connect(_pppWidgets._mapWinButton, SIGNAL(clicked()), SLOT(slotMapPPP()));
975 _pppWidgets._mapSpeedSlider->setMinimumWidth(33*ww);
976 _pppWidgets._audioResponse->setMaximumWidth(8*ww);
977
978 QGridLayout* pppLayout4 = new QGridLayout();
979 ir = 0;
980 pppLayout4->addWidget(new QLabel("Precise Point Positioning - Plots.<br>"), ir, 0, 1, 50, Qt::AlignLeft);
981 ++ir;
982 pppLayout4->addWidget(new QLabel("PPP Plot"), ir, 0, Qt::AlignLeft);
983 pppLayout4->addWidget(_pppWidgets._plotCoordinates, ir, 1, Qt::AlignLeft);
984 pppLayout4->addWidget(new QLabel("Mountpoint"), ir, 2, 1, 10, Qt::AlignLeft);
985 pppLayout4->addWidget(_pppWidgets._audioResponse, ir, 4, Qt::AlignLeft);
986 pppLayout4->addWidget(new QLabel("Audio response"), ir, 5, Qt::AlignRight);
987
988 ++ir;
989 pppLayout4->addWidget(new QLabel("Track map"), ir, 0, Qt::AlignLeft);
990 pppLayout4->addWidget(_pppWidgets._mapWinButton, ir, 1, Qt::AlignLeft);
991 pppLayout4->addWidget(new QLabel("OSM"), ir, 2, Qt::AlignLeft);
992 pppLayout4->addWidget(_pppWidgets._useOpenStreetMap, ir, 3, Qt::AlignLeft);
993 pppLayout4->addWidget(new QLabel("Google"), ir, 3, Qt::AlignRight);
994 pppLayout4->addWidget(_pppWidgets._useGoogleMap, ir, 4, Qt::AlignLeft);
995 ++ir;
996 pppLayout4->addWidget(new QLabel("Dot-properties"), ir, 0, Qt::AlignLeft);
997 pppLayout4->addWidget(_pppWidgets._mapWinDotSize, ir, 1, Qt::AlignLeft);
998 pppLayout4->addWidget(new QLabel("Size "), ir, 2, Qt::AlignLeft);
999 pppLayout4->addWidget(_pppWidgets._mapWinDotColor, ir, 3, Qt::AlignLeft);
1000 pppLayout4->addWidget(new QLabel("Color"), ir, 4, Qt::AlignLeft);
1001 ++ir;
1002 pppLayout4->addWidget(new QLabel("Post-processing speed"), ir, 0, Qt::AlignLeft);
1003 pppLayout4->addWidget(_pppWidgets._mapSpeedSlider, ir, 1, 1, 20, Qt::AlignLeft);
1004 ++ir;
1005 pppLayout4->addWidget(new QLabel(""), ir, 1);
1006 pppLayout4->setRowStretch(ir, 999);
1007
1008 pppGroup4->setLayout(pppLayout4);
1009
1010 // Reqc Processing
1011 // ---------------
1012 _reqcActionComboBox = new QComboBox();
1013 _reqcActionComboBox->setEditable(false);
1014 _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
1015 int ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
1016 if (ik != -1) {
1017 _reqcActionComboBox->setCurrentIndex(ik);
1018 }
1019 connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
1020 this, SLOT(slotBncTextChanged()));
1021
1022 QGridLayout* reqcLayout = new QGridLayout;
1023 _reqcActionComboBox->setMinimumWidth(15*ww);
1024 _reqcActionComboBox->setMaximumWidth(20*ww);
1025
1026 _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1027 _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
1028
1029 _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1030 _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
1031 _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
1032 _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
1033 _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
1034 _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
1035 _reqcSkyPlotSignals = new QLineEdit(settings.value("reqcSkyPlotSignals").toString());
1036
1037 connect(_reqcSkyPlotSignals, SIGNAL(textChanged(const QString &)),
1038 this, SLOT(slotBncTextChanged()));
1039
1040 _reqcLogSummaryOnly = new QCheckBox();
1041 _reqcLogSummaryOnly->setCheckState(Qt::CheckState(settings.value("reqcLogSummaryOnly").toInt()));
1042
1043 ir = 0;
1044 reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check.<br>"),ir, 0, 1, 8);
1045 ++ir;
1046 reqcLayout->addWidget(new QLabel("Action"), ir, 0);
1047 reqcLayout->addWidget(_reqcActionComboBox, ir, 1);
1048 _reqcEditOptionButton = new QPushButton("Set Edit Options");
1049 _reqcEditOptionButton->setMinimumWidth(15*ww);
1050 _reqcEditOptionButton->setMaximumWidth(20*ww);
1051
1052 reqcLayout->addWidget(_reqcEditOptionButton, ir, 3);
1053 ++ir;
1054 reqcLayout->addWidget(new QLabel("Input files (full path)"), ir, 0);
1055 reqcLayout->addWidget(_reqcObsFileChooser, ir, 1);
1056 _reqcObsFileChooser->setMaximumWidth(40*ww);
1057 reqcLayout->addWidget(new QLabel(" Obs"), ir, 2);
1058 reqcLayout->addWidget(_reqcNavFileChooser, ir, 3);
1059 _reqcNavFileChooser->setMaximumWidth(40*ww);
1060 reqcLayout->addWidget(new QLabel(" Nav"), ir, 4);
1061 ++ir;
1062 reqcLayout->addWidget(new QLabel("Output file (full path)"), ir, 0);
1063 reqcLayout->addWidget(_reqcOutObsLineEdit, ir, 1);
1064 _reqcOutObsLineEdit->setMaximumWidth(40*ww);
1065 reqcLayout->addWidget(new QLabel(" Obs"), ir, 2);
1066 reqcLayout->addWidget(_reqcOutNavLineEdit, ir, 3);
1067 _reqcOutNavLineEdit->setMaximumWidth(40*ww);
1068 reqcLayout->addWidget(new QLabel(" Nav"), ir, 4);
1069 ++ir;
1070 reqcLayout->addWidget(new QLabel("Logfile"), ir, 0);
1071 reqcLayout->addWidget(_reqcOutLogLineEdit, ir, 1);
1072 _reqcOutLogLineEdit->setMaximumWidth(40*ww);
1073 reqcLayout->addWidget(new QLabel(" Summary only"), ir, 2);
1074 reqcLayout->addWidget(_reqcLogSummaryOnly, ir, 3);
1075 ++ir;
1076 reqcLayout->addWidget(new QLabel("Plots for signals"), ir, 0);
1077 reqcLayout->addWidget(_reqcSkyPlotSignals, ir, 1);
1078 _reqcSkyPlotSignals->setMaximumWidth(40*ww);
1079 ++ir;
1080 reqcLayout->addWidget(new QLabel("Directory for plots"), ir, 0);
1081 reqcLayout->addWidget(_reqcPlotDirLineEdit, ir, 1);
1082 _reqcPlotDirLineEdit->setMaximumWidth(40*ww);
1083 ++ir;
1084 reqcLayout->setRowStretch(ir, 999);
1085
1086 reqcLayout->setColumnMinimumWidth(2, 8*ww);
1087 reqcLayout->setColumnMinimumWidth(4, 8*ww);
1088
1089 reqcgroup->setLayout(reqcLayout);
1090
1091 connect(_reqcEditOptionButton, SIGNAL(clicked()),
1092 this, SLOT(slotReqcEditOption()));
1093
1094 QGridLayout* sp3CompLayout = new QGridLayout;
1095
1096 _sp3CompFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1097 _sp3CompFileChooser->setFileName(settings.value("sp3CompFile").toString());
1098 _sp3CompFileChooser->setMinimumWidth(15*ww);
1099 _sp3CompFileChooser->setMaximumWidth(40*ww);
1100
1101 _sp3CompExclude = new QLineEdit(settings.value("sp3CompExclude").toString());
1102 _sp3CompExclude->setMinimumWidth(18*ww);
1103 _sp3CompExclude->setMaximumWidth(18*ww);
1104
1105 _sp3CompLogLineEdit = new QLineEdit(settings.value("sp3CompOutLogFile").toString());
1106 _sp3CompLogLineEdit->setMinimumWidth(18*ww);
1107 _sp3CompLogLineEdit->setMaximumWidth(18*ww);
1108
1109 ir = 0;
1110 sp3CompLayout->addWidget(new QLabel("Orbit and clock comparison.<br>"), ir, 0, 1, 40);
1111 ++ir;
1112 sp3CompLayout->addWidget(new QLabel("Input SP3 files (full path)"), ir, 0, Qt::AlignLeft);
1113 sp3CompLayout->addWidget(_sp3CompFileChooser, ir, 1, 1, 20);
1114 ++ir;
1115 sp3CompLayout->addWidget(new QLabel("Exclude satellites"), ir, 0, Qt::AlignLeft);
1116 sp3CompLayout->addWidget(_sp3CompExclude, ir, 1, Qt::AlignRight);
1117 ++ir;
1118 sp3CompLayout->addWidget(new QLabel("Logfile"), ir, 0, Qt::AlignLeft);
1119 sp3CompLayout->addWidget(_sp3CompLogLineEdit, ir, 1, Qt::AlignRight);
1120 ++ir;
1121 sp3CompLayout->addWidget(new QLabel(""), ir, 1);
1122 ++ir;
1123 sp3CompLayout->setRowStretch(ir, 999);
1124
1125 sp3CompLayout->setColumnMinimumWidth(2, 8*ww);
1126 sp3CompLayout->setColumnMinimumWidth(4, 8*ww);
1127
1128 sp3CompGroup->setLayout(sp3CompLayout);
1129
1130 connect(_sp3CompFileChooser, SIGNAL(fileNameChanged(const QString &)),
1131 this, SLOT(slotBncTextChanged()));
1132
1133 // Combine Corrections
1134 // -------------------
1135 QGridLayout* cmbLayout = new QGridLayout;
1136
1137 populateCmbTable();
1138 cmbLayout->addWidget(_cmbTable, 0, 0, 8, 3);
1139 cmbLayout->addWidget(new QLabel(" Combine Broadcast Correction streams.<br>"), 1, 6, 1, 10);
1140 cmbLayout->addWidget(addCmbRowButton, 2, 6);
1141 cmbLayout->addWidget(delCmbRowButton, 2, 7);
1142 cmbLayout->addWidget(new QLabel("Method"), 3, 6, Qt::AlignRight);
1143 cmbLayout->addWidget(_cmbMethodComboBox, 3, 7);
1144 cmbLayout->addWidget(new QLabel(" Maximal residuum"), 4, 6, Qt::AlignRight);
1145 cmbLayout->addWidget(_cmbMaxresLineEdit, 4, 7, Qt::AlignRight);
1146 cmbLayout->addWidget(new QLabel("Sampling"), 5, 6, Qt::AlignRight);
1147 cmbLayout->addWidget(_cmbSamplSpinBox, 5, 7);
1148 cmbLayout->addWidget(new QLabel(" Use GLONASS"), 6, 6, Qt::AlignRight);
1149 cmbLayout->addWidget(_cmbUseGlonass, 6, 7);
1150 cmbLayout->setRowStretch(7, 999);
1151
1152 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1153 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
1154
1155 cmbgroup->setLayout(cmbLayout);
1156
1157 // Upload Layout (Clocks)
1158 // ----------------------
1159 QGridLayout* uploadHlpLayout = new QGridLayout();
1160
1161 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1162 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1163 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
1164
1165 uploadHlpLayout->addWidget(addUploadRowButton, 0, 0);
1166 uploadHlpLayout->addWidget(delUploadRowButton, 0, 1);
1167 uploadHlpLayout->addWidget(new QLabel("Interval"), 0, 2, Qt::AlignRight);
1168 uploadHlpLayout->addWidget(_uploadIntrComboBox, 0, 3);
1169 uploadHlpLayout->addWidget(new QLabel(" Sampling: Orb"), 0, 4, Qt::AlignRight);
1170 uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox, 0, 5);
1171 uploadHlpLayout->addWidget(new QLabel("SP3"), 0, 6, Qt::AlignRight);
1172 uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox, 0, 7);
1173 uploadHlpLayout->addWidget(new QLabel("RNX"), 0, 8, Qt::AlignRight);
1174 uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox, 0, 9);
1175 uploadHlpLayout->addWidget(setUploadTrafoButton, 0,10);
1176 uploadHlpLayout->addWidget(new QLabel("ANTEX file"), 1, 0, Qt::AlignLeft);
1177 uploadHlpLayout->addWidget(_uploadAntexFile, 1, 1, 1, 4);
1178
1179 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1180 populateUploadTable();
1181
1182 uploadLayout->addWidget(new QLabel("Upload RTCM Version 3 Broadcast Corrections to caster.<br>"));
1183 uploadLayout->addWidget(_uploadTable);
1184 uploadLayout->addLayout(uploadHlpLayout);
1185
1186 uploadgroup->setLayout(uploadLayout);
1187
1188 // Upload Layout (Ephemeris)
1189 // -------------------------
1190 QGridLayout* uploadLayoutEph = new QGridLayout;
1191
1192 uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1193 _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1194 _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1195 _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1196
1197 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster.<br>"), 0, 0, 1, 50);
1198 uploadLayoutEph->addWidget(new QLabel("Host"), 1, 0);
1199 uploadLayoutEph->addWidget(_uploadEphHostLineEdit, 1, 1, 1, 3);
1200 uploadLayoutEph->addWidget(new QLabel(" Port"), 1, 4, Qt::AlignRight);
1201 uploadLayoutEph->addWidget(_uploadEphPortLineEdit, 1, 5, 1, 1);
1202 uploadLayoutEph->addWidget(new QLabel("Mountpoint "), 2, 0);
1203 uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit, 2, 1);
1204 uploadLayoutEph->addWidget(new QLabel(" Password"), 2, 2, Qt::AlignRight);
1205 uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit, 2, 3);
1206 uploadLayoutEph->addWidget(new QLabel("Sampling"), 3, 0);
1207 uploadLayoutEph->addWidget(_uploadEphSampleSpinBox, 3, 1);
1208 uploadLayoutEph->addWidget(new QLabel("Uploaded"), 4, 0);
1209 uploadLayoutEph->addWidget(_uploadEphBytesCounter, 4, 1);
1210 uploadLayoutEph->setRowStretch(5, 999);
1211
1212 uploadEphgroup->setLayout(uploadLayoutEph);
1213
1214 connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1215 this, SLOT(slotBncTextChanged()));
1216
1217 // Main Layout
1218 // -----------
1219 QGridLayout* mLayout = new QGridLayout;
1220 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
1221 mLayout->addWidget(_aogroup, 0,0);
1222 mLayout->addWidget(_mountPointsTable, 1,0);
1223 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
1224 mLayout->addWidget(_loggroup, 2,0);
1225
1226 _canvas->setLayout(mLayout);
1227
1228 // WhatsThis, Network
1229 // ------------------
1230 _proxyHostLineEdit->setWhatsThis(tr("<p>If you are running BNC within a protected Local Area Network (LAN), you may 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 this is not possible, you may need to run BNC outside your LAN on a network that has unobstructed connection to the Internet.</p>"));
1231 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1232 _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 whether this is supported by the involved Ntrip Broadcaster.</p><p>Note that SSL communication is usually done over port 443.</p>"));
1233 _sslIgnoreErrorsCheckBox->setWhatsThis(tr("<p>SSL communication may involve queries coming from the Ntrip Broadcaster. Tick 'Ignore SSL authorization errors' if you don't want to be bothered with this.</p>"));
1234
1235 // WhatsThis, General
1236 // ------------------
1237 _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 for that 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.</p>"));
1238 _rnxAppendCheckBox->setWhatsThis(tr("<p>When BNC is started, new files are created by default and file content already available under the same name will be overwritten. However, users might want to append already existing files following a regular restart or a crash of BNC or its platform.</p><p>Tick 'Append files' to continue with existing files and keep what has been recorded so far.</p>"));
1239 _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, five minutes, 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 via button 'Save & Reread Configuration'.</p>"));
1240 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1241 _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p><p>This option is primarily meant for debugging purposes.</p>"));
1242
1243 // WhatsThis, RINEX Observations
1244 // -----------------------------
1245 _rnxPathLineEdit->setWhatsThis(tr("<p>Here you specify the path to where the RINEX Observation files will be stored.</p><p>If the specified directory does not exist, BNC will not create RINEX Observation files.</p>"));
1246 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1247 _rnxSamplComboBox->setWhatsThis(tr("<p>Select the RINEX Observation sampling interval in seconds. </p>"));
1248 _rnxSkelLineEdit->setWhatsThis(tr("<p>BNC allows using personal RINEX skeleton files that contain the RINEX header records you would like to include. You can derive a skeleton file from information given in an up to date sitelog.</p><p>A file in the RINEX Observations 'Directory' with a 'Skeleton extension' skl or SKL is interpreted by BNC as a personal RINEX header skeleton file for the corresponding stream. In case of 'SKL'/'skl' the 4/9-char ID forming the base name has to be written in upper cases. </p>"));
1249 _rnxFileCheckBox->setWhatsThis(tr("<p>Tick check box 'Skeleton mandatory' in case you want that RINEX files are only produced if skeleton files are available for BNC. If no skeleton file is available for a particular source then no RINEX Observation file will be produced from the affected stream.</p><p>Note that a skeleton file contains RINEX header information such as receiver and antenna types. In case of stream conversion to RINEX Version 3, a skeleton file should also contain information on potentially available observation types. A missing skeleton file will therefore enforce BNC to only save a default set of RINEX 3 observation types.</p>"));
1250 _rnxScrpLineEdit->setWhatsThis(tr("<p>Whenever a RINEX Observation file is finally saved, you may want to compress, copy or upload it immediately, for example via FTP. BNC allows you to execute a script/batch file to carry out such operation.</p><p>Specify the full path of a script or batch file. BNC will pass the full RINEX Observation file path to the script as command line parameter (%1 on Windows systems, $1 on Unix/Linux/Mac systems).</p>"));
1251 _rnxV2Priority->setWhatsThis(tr("<p>Specify a priority list of characters defining signal attributes as defined in RINEX Version 3. Priorities will be used to map observations with RINEX Version 3 attributes from incoming streams to Version 2. The underscore character '_' stands for undefined attributes. A question mark '?' can be used as wildcard which represents any one character.</p><p>Signal priorities can be specified as equal for all systems, as system specific or as system and freq. specific. For example: </li><ul><li>'CWPX_?' (General signal priorities valid for all GNSS) </li><li>'I:ABCX' (System specific signal priorities for IRNSS) </li><li>'G:12&PWCSLX G:5&IQX R:12&PC R:3&IQX' (System and frequency specific signal priorities) </li></ul>Default is the following priority list 'G:12&PWCSLX G:5&IQX R:12&PC R:3&IQX R:46&ABX E:16&BCXZ E:578&IQX J:1&SLXCZ J:26&SLX J:5&IQX C:267&IQX C:128&DPX C:7&DPZ I:ABCX S:1&C S:5&IQX'. <i>[key: rnxV2Priority]</i></p>"));
1252 _rnxV3CheckBox->setWhatsThis(tr("<p>The default format for RINEX Observation files is RINEX Version 2.</p><p>Select 'Version 3' if you want to save observations in RINEX Version 3 format.</p>"));
1253
1254 // WhatsThis, RINEX Ephemeris
1255 // --------------------------
1256 _ephPathLineEdit->setWhatsThis(tr("<p>Specify the path for saving Broadcast Ephemeris data as RINEX Navigation files.</p><p>If the specified directory does not exist, BNC will not create RINEX Navigation files.</p>"));
1257 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1258 _ephOutPortLineEdit->setWhatsThis(tr("<p>BNC can produce ephemeris data in RINEX Navigation ASCII format on your local host through an IP port.</p><p>Specify a port number here to activate this function.</p>"));
1259 _ephV3CheckBox->setWhatsThis(tr("<p>The default format for output of RINEX Navigation data containing Broadcast Ephemeris is RINEX Version 2.</p><p>Select 'Version 3' if you want to output ephemeris in RINEX Version 3 format.</p>"));
1260
1261 // WhatsThis, RINEX Editing & QC
1262 // -----------------------------
1263 _reqcActionComboBox->setWhatsThis(tr("<p>BNC allows to 'Edit or Concatenate' RINEX Version 2 or 3 files or to perform a Quality Check (QC) and 'Analyze' data following UNAVCO's famous 'teqc' program.</p>"));
1264 _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX Version 2 or 3 files.</p>"));
1265 _reqcObsFileChooser->setWhatsThis(tr("<p>Specify the full path to input observation files in RINEX Version 2 or 3 format.</p><p>Note that when in 'Analyze' mode, specifying at least one RINEX observation file is mandatory.</p>"));
1266 _reqcNavFileChooser->setWhatsThis(tr("<p>Specify the full path to input navigation files in RINEX Version 2 or 3 format.</p><p>Note that when in 'Analyze' mode, specifying at least one RINEX navigation file is mandatory.</p>"));
1267 _reqcOutObsLineEdit->setWhatsThis(tr("<p>Specify the full path to a RINEX Observation output file.</p><p>Default is an empty option field, meaning that no RINEX Observation output file will be produced.</p>"));
1268 _reqcOutNavLineEdit->setWhatsThis(tr("<p>Specify the full path to a RINEX Navigation output file.</p><p>Default is an empty option field, meaning that no RINEX Navigation output file will be produced.</p>"));
1269 _reqcOutLogLineEdit->setWhatsThis(tr("<p>Specify the full path to a logfile.</p><p>Default is an empty option field, meaning that no 'RINEX Editing & QC' logfile will be produced.</p>"));
1270 _reqcLogSummaryOnly->setWhatsThis(tr("<p>By default BNC produces a detailed 'Logfile' providing all information resulting from editing or analyzing RINEX data. If that is too much information, you can limit the logfile content to a short summary.</p><p>Tick 'Summary only' to suppress full logfile output and instead produce a logfile containing only summary information.</p>"));
1271 _reqcPlotDirLineEdit->setWhatsThis(tr("<p>Specify a directory for saving plots in PNG format.</p><p>Default is an empty option field, meaning that plots will not be saved on disk.</p>"));
1272 _reqcSkyPlotSignals->setWhatsThis(tr("<p>BNC can produce plots for multipath, signal-to-noise ratio, satellite availability, satellite elevation, and PDOP values. The 'Plots for signals' option lets you exactly specify observation signals to be used for that and also enables the plot generation. You can specify the navigation system, the frequency, and the tracking mode or channel as defined in RINEX Version 3. Specifications for frequency and tracking mode or channel must be separated by ampersand character '&'. Specifications for navigation systems must be separated by blank character ' '.</p><p>Examples for 'Plots for signals' option:<ul><li> G:1&2 R:1&2 J:1&2 E:1&7 C:1&6 S:1<br>(Plots will be based on GPS observations on 1st and 2nd frequency, GLONASS observations on 1st and 2nd frequency, QZSS observations on 1st and 2nd frequency, Galileo observations on 1st and 7th frequency, BeiDou observations on 1st and 6th frequency, SBAS observations on 1st frequency.)</li><li>G:1C&5X<br>(Plots will be based on GPS observations on 1st frequency in C tracking mode and GPS observations on 5th frequency in X tracking mode.)</li><li>C:6I&7I<br>(Plots will be based on BeiDou observations on 6th frequency in I tracking mode and BeiDou observations on 7th frequency in I tracking mode.)<li></ul></p><p>Default is 'C:2&7 E:1&5 G:1&2 J:1&2 R:1&2 S:1&5 I:5&9'. Specifying an empty option string would be overruled by this default.</p>"));
1273
1274 // WhatsThis, SP3 Comparison
1275 // -------------------------
1276 _sp3CompFileChooser->setWhatsThis(tr("<p>BNC can compare two SP3 files containing GNSS satellite orbit and clock information.</p></p>Specify the full path to two files with orbits and clocks in SP3 format, separate them by comma.</p>"));
1277 _sp3CompExclude->setWhatsThis(tr("<p>Specify satellites to exclude them from orbit and clock comparison. Example:<p>G04,G31,R</p><p>This excludes GPS satellites PRN 4 and 31 as well as all GLONASS satellites from the comparison.</p><p>Default is an empty option field, meaning that no satellite is excluded from the comparison.</p>"));
1278 _sp3CompLogLineEdit->setWhatsThis(tr("<p>Specify the full path to a logfile saving comparison results.</p><p>Specifying a logfile is mandatory. Comparing SP3 files and not saving comparison results on disk would be useless.</p>"));
1279
1280 // WhatsThis, Broadcast Corrections
1281 // --------------------------------
1282 _corrPathLineEdit->setWhatsThis(tr("<p>Specify a directory for saving Broadcast Ephemeris Correction files.</p><p>If the specified directory does not exist, BNC will not create the files.</p>"));
1283 _corrPortLineEdit->setWhatsThis(tr("<p>BNC can produce Broadcast Ephemeris Corrections on your local host through an IP port.</p><p>Specify a port number here to activate this function.</p>"));
1284 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of Broadcast Ephemeris Correction files.</p>"));
1285
1286 // WhatsThis, Feed Engine
1287 // ----------------------
1288 _outPortLineEdit->setWhatsThis(tr("<p>BNC can produce synchronized observations in a plain ASCII format on your local host via IP port.</p><p>Specify a port number to activate this function.</p>"));
1289 _outWaitSpinBox->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.</p><p>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 product.</p>"));
1290 _outSamplComboBox->setWhatsThis(tr("<p>Select a synchronized observation sampling interval in seconds. </p>"));
1291 _outFileLineEdit->setWhatsThis(tr("<p>Specify the full path to a file where synchronized observations are saved in plain ASCII format.</p><p>Beware that the size of this file can rapidly increase depending on the number of incoming streams.</p>"));
1292 _outUPortLineEdit->setWhatsThis(tr("<p>BNC can produce unsynchronized observations in a plain ASCII format on your local host via IP port.</p><p>Specify a port number to activate this function.</p>"));
1293 _outLockTimeCheckBox->setWhatsThis(tr("<p>Print the lock time in seconds in the feed engine output.</p>"));
1294
1295 // WhatsThis, Serial Output
1296 // ------------------------
1297 _serialMountPointLineEdit->setWhatsThis(tr("<p>Enter a 'Mountpoint' to forward the corresponding stream to a serial connected receiver.</p><p>Depending on the stream content, the receiver may use it for example for Differential GNSS, Precise Point Positioning or any other purpose supported by its firmware.</p>"));
1298 _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 before you start BNC, you must plug a serial cable in the port defined here.</p>"));
1299 _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. Using a high baud rate is recommended.</p>"));
1300 _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>"));
1301 _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>"));
1302 _serialParityComboBox->setWhatsThis(tr("<p>Select a 'Parity' for the serial output link.</p><p>Note that your selection must equal the parity selection configured to the serial connected receiver. The parity is often set to 'NONE'.</p>"));
1303 _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>"));
1304 _serialAutoNMEAComboBox->setWhatsThis(tr("<p>The 'NMEA' option supports the so-called 'Virtual Reference Station' (VRS) concept which requires the receiver to send approximate position information to the Ntrip Broadcaster. Select 'no' if you don't want BNC to forward or upload any NMEA message to the Ntrip Broadcaster in support of VRS.</p><p>Select 'Auto' to automatically forward NMEA messages of type GGA from your serial connected receiver to the Ntrip Broadcaster and/or save them in a file.</p><p>Select 'Manual GPGGA' or 'Manual GNGGA' if you want BNC to produce and upload GPGGA or GNGGA NMEA messages to the Ntrip Broadcaster because your serial connected receiver doesn't generate these messages. A Talker ID 'GP' preceding the GGA string stands for GPS solutions while a Talker ID 'GN' stands for multi constellation solutions.</p><p>Note that selecting 'Auto' or 'Manual' works only for VRS streams which show up under the 'Streams' canvas on BNC's main window with 'nmea' stream attribute set to 'yes'. This attribute is either extracted from the Ntrip Broadcaster's source-table or introduced by the user via editing the BNC configuration file.</p>"));
1305 _serialFileNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where NMEA messages coming from your serial connected receiver are saved.</p><p>Default is an empty option field, meaning that NMEA messages will not be saved on disk.</p>"));
1306 _serialHeightNMEALineEdit->setWhatsThis(tr("<p>Specify an approximate 'Height' above mean sea level in meters for the reference station introduced by option 'Mountpoint'. Together with the latitude and longitude from the source-table, the height information is used to build GGA messages to be sent to the Ntrip Broadcaster.</p><p>For adjusting latitude and longitude values of a VRS stream given in the 'Streams' canvas, you can double click the latitude/longitude data fields, specify appropriate values and then hit Enter.</p><p>This option is only relevant when option 'NMEA' is set to 'Manual GPGGA' or 'Manual GNGGA' respectively.</p>"));
1307 _serialManualNMEASamplingSpinBox->setWhatsThis(tr("<p>Select a sampling interval in seconds for manual generation and upload of NMEA GGA sentences.</p><p>A sampling rate of '0' means, the a GGA sentence will be send only once to initialize the requested VRS stream. Note that some VRS systems need GGA sentences at regular intervals.</p>"));
1308
1309 // WhatsThis, Outages
1310 // ------------------
1311 _adviseObsRateComboBox->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><p>Default is an empty option field, meaning that you don't want BNC to report on stream failures or recoveries when exceeding a threshold time span.</p>"));
1312 _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>"));
1313 _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>"));
1314 _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 a comment '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.</p><p>An empty option field (default) or invalid path means that you don't want to use this option.</p>"));
1315
1316 // WhatsThis, Miscellaneous
1317 // ------------------------
1318 _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>"));
1319 _miscIntrComboBox->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>"));
1320 _miscScanRTCMCheckBox->setWhatsThis(tr("<p>Tick 'Scan RTCM' to log the numbers of incoming message types as well as contained antenna coordinates, antenna height, and antenna descriptor.</p><p>In case of RTCM Version 3 MSM streams, BNC will also log contained RINEX Version 3 observation types.</p>."));
1321 _miscPortLineEdit->setWhatsThis(tr("<p>BNC can output an incoming stream through an IP port of your local host.</p><p>Specify a port number to activate this function.</p>"));
1322
1323 // WhatsThis, PPP (1)
1324 // ------------------
1325 _pppWidgets._dataSource->setWhatsThis(tr("<p>Select 'Real-time Streams' for real-time PPP from RTCM streams or 'RINEX Files' for post processing PPP from RINEX files.</p><p><ul><li>Real-time PPP requires that you pull a RTCM stream carrying GNSS observations plus a stream providing corrections to Broadcast Ephemeris. If the observations stream does not contain Broadcast Ephemeris then you must in addition pull a Broadcast Ephemeris stream like 'RTCM3EPH' from Ntrip Broadcaster <u>products.igs-ip.net</u>.<br></li><li>Post processing PPP requires RINEX Observation files, RINEX Navigation files and a file with corrections to Broadcast Ephemeris in plain ASCII format as saved beforehand using BNC.</li></ul></p><p>Note that BNC allows to carry out PPP solutions simultaneously for several stations.</p>"));
1326 _pppWidgets._rinexObs->setWhatsThis(tr("<p>Specify the RINEX Observation file.</p>"));
1327 _pppWidgets._rinexNav->setWhatsThis(tr("<p>Specify the RINEX Navigation file.</p>"));
1328 _pppWidgets._corrMount->setWhatsThis(tr("<p>Specify a 'mountpoint' from the 'Streams' canvas below which provides corrections to Broadcast Ephemeris.</p><p>If you don't specify a corrections stream via this option, BNC will fall back to Single Point Positioning (SPP, positioning from observations and Broadcast Ephemeris only) instead of doing PPP.</p>"));
1329 _pppWidgets._corrFile->setWhatsThis(tr("<p>Specify the Broadcast Ephemeris Corrections file as saved beforehand using BNC.</p><p>If you don't specify corrections by this option, BNC will fall back to Single Point Positioning (SPP, positioning from RINEX Obs and RINEX Nav files only) instead of doing PPP.</p>"));
1330 _pppWidgets._antexFile->setWhatsThis(tr("<p>Observations in RTCM streams or RINEX files should be referred to the receiver's and to the satellite's Antenna Phase Center (APC) and therefore be corrected for<ul><li>Receiver APC offsets</li><li>Receiver APC variations</li><li>Satellite APC offsets.</li></ul> Specify the full path to an IGS 'ANTEX file' which contains APC offsets and variations.</p><p>If you don't specify an 'ANTEX file' then observations will not be corrected for APC offsets and variations.</p>"));
1331 _pppWidgets._crdFile->setWhatsThis(tr("<p>Enter the full path to an ASCII file which specifies the streams or files of those stations you want to process. Specifying a 'Coordinates file' is optional. If it exists, it should contain one record per station with the following parameters separated by blank character:<p><ul><li>Specify the station either by<ul><li>the 'Mountpoint' of the station's RTCM stream (when in real-time PPP mode), or</li><li>the 4-charater station ID of the RINEX Observations file (when in post processing PPP mode).</li></ul></li><li>Approximate X,Y,Z coordinate of station's Antenna Reference Point [m] (ARP, specify '0.0 0.0 0.0' if unknown).</li><li>North, East and Up component of antenna eccentricity [m] (specify '0.0 0.0 0.0' if unknown).</li><li>20 Characters describing the antenna type and radome following the IGS 'ANTEX file' standard (leave blank if unknown).</li><li>Receiver type following the naming conventions for IGS equipment.</li></ul></p><p>Records with exclamation mark '!' in the first column or blank records will be interpreted as comment lines and ignored.</p>"));
1332 _pppWidgets._v3filenames->setWhatsThis(tr("<p>Tick 'Version 3 filenames' to let BNC create so-called extended filenames for PPP logfiles, NMEA files and SINEX Troposphere files following the RINEX Version 3 standard.</p><p>Default is an empty check box, meaning to create filenames following the RINEX Version 2 standard. The file content is not affected by this option. It only concerns the filenames.</p>"));
1333 _pppWidgets._logPath->setWhatsThis(tr("<p>Specify a directory for saving daily PPP logfiles. If the specified directory does not exist, BNC will not create such files.</p><p>Default is an empty option field, meaning that no PPP logfiles shall be produced.</p>"));
1334 _pppWidgets._nmeaPath->setWhatsThis(tr("<p>Specify a directory for saving coordinates in daily NMEA files. If the specified directory does not exist, BNC will not create such files.</p><p>Default is an empty option field, meaning that no NMEA file shall be produced.</p>"));
1335 _pppWidgets._snxtroPath->setWhatsThis(tr("<p>Specify a directory for saving SINEX Troposphere files. If the specified directory does not exist, BNC will not create such files.</p><p>Default is an empty option field, meaning that no SINEX Troposphere files shall be produced.</p>"));
1336 _pppWidgets._snxtroIntr->setWhatsThis(tr("<p>Select a length for SINEX Troposphere files.</p><p>Default 'SNX TRO interval' for saving SINEX Troposphere files on disk is '1 hour'.</p>"));
1337 _pppWidgets._snxtroSampl->setWhatsThis(tr("<p>Select a 'Sampling' rate for saving troposphere parameters.</p>"));
1338 _pppWidgets._snxtroAc->setWhatsThis(tr("<p>Specify a 3-character abbreviation describing you as the generating Analysis Center (AC) in your SINEX troposphere files.</p>"));
1339 _pppWidgets._snxtroSol->setWhatsThis(tr("<p>Specify a 4-character solution ID to allow a distingtion between different solutions per AC.</p>"));
1340
1341 // WhatsThis, PPP (3)
1342 // ------------------
1343 _pppWidgets._lcGPS->setWhatsThis(tr("<p>Specify which kind of GPS observations you want to use and on which kind of ionosphere-free linear combination of GPS observations you want to base ambiguity resolutions.</p><p><ul><li>Specifying 'P3' means that you request BNC to use code data and so-called P3 ionosphere-free linear combination of code observations.</li><li>'P3&L3' means that you request BNC to use both, code and phase data and so-called P3 and L3 ionosphere-free linear combination of code and phase observations.</li></ul></p><p>Note that most geodetic receivers support the observation of GPS code and phase data. Hence specifying 'P3&L3' would be a good choice when processing data from such a receiver.</p><p>Specifying 'no' means that you don't want BNC to use GPS data.</p>"));
1344 _pppWidgets._lcGLONASS->setWhatsThis(tr("<p>Specify which kind of GLONASS observations you want to use and on which kind of ionosphere-free linear combination of GLONASS observations you want to base ambiguity resolutions.</p><p><ul><li>Specifying 'P3' means that you request BNC to use code data and so-called P3 ionosphere-free linear combination of code observations.</li><li>'L3' means that you request BNC to use phase data and so-called L3 ionosphere-free linear combination of phase observations.</li> <li>'P3&L3' means that you request BNC to use both, code and phase data and so-called P3 and L3 ionosphere-free linear combination of code and phase observations.</li></ul></p><p>Specifying 'no' means that you don't want BNC to use GLONASS data.</p>"));
1345 _pppWidgets._lcGalileo->setWhatsThis(tr("<p>Specify which kind of Galileo observations you want to use and on which kind of of ionosphere-free linear combination of Galileo observations you want to base ambiguity resolutions.</p><p><ul><li>Specifying 'P3' means that you request BNC to use code data and so-called P3 ionosphere-free linear combination of code observations.</li><li>'L3' means that you request BNC to use phase data and so-called L3 ionosphere-free linear combination of phase observations.</li> <li>'P3&L3' means that you request BNC to use both, code and phase data and so-called P3 and L3 ionosphere-free linear combination of code and phase observations.</li></ul></p><p>Specifying on of these options makes only sense if Galileo data are part of the processed observation stream.</p><p>Specifying 'no' means that you don't want BNC to use Galileo data.</p>"));
1346 _pppWidgets._lcBDS->setWhatsThis(tr("<p>Specify which kind of BDS observations you want to use and on which kind of ionosphere-free linear combination of BDS observations you want to base ambiguity resolutions.</p><p><ul><li>Specifying 'P3' means that you request BNC to use code data and so-called P3 ionosphere-free linear combination of code observations.</li><li>'L3' means that you request BNC to use phase data and so-called L3 ionosphere-free linear combination of phase observations.</li> <li>'P3&L3' means that you request BNC to use both, code and phase data and so-called P3 and L3 ionosphere-free linear combination of code and phase observations.</li></ul></p><p>Specifying on of these options makes only sense if BDS data are part of the processed observation stream.</p><p>Specifying 'no' means that you don't want to use BDS data.</p>"));
1347 _pppWidgets._sigmaC1->setWhatsThis(tr("<p>Enter a Sigma for GNSS C1 code observations in meters.</p><p>The higher the sigma you enter, the less the contribution of C1 code observations to a PPP solution from combined code and phase data. 2.0 is likely to be an appropriate choice.</p><p>Default is an empty option field, meaning<br>'Sigma C1 = 2.0'</p>"));
1348 _pppWidgets._sigmaL1->setWhatsThis(tr("<p>Enter a Sigma for GNSS L1 phase observations in meters.</p><p>The higher the sigma you enter, the less the contribution of L1 phase observations to a PPP solutions from combined code and phase data. 0.01 is likely to be an appropriate choice.</p><p>Default is an empty option field, meaning<br>'Sigma L1 = 0.01'</p>"));
1349 _pppWidgets._maxResC1->setWhatsThis(tr("<p>Specify a maximum for residuals from C1 code observations in a PPP solution. '3.0' meters may be an appropriate choice for that.</p><p>If the maximum is exceeded, contributions from the corresponding observation will be ignored in the PPP solution.</p><p>Default is an empty option field, meaning<br>'Max Rex C1 = 3.0'</p>"));
1350 _pppWidgets._maxResL1->setWhatsThis(tr("<p>Specify a maximum for residuals from L1 code observations in a PPP solution. '0.03' meters may be an appropriate choice for that.</p><p>If the maximum is exceeded, contributions from the corresponding observation will be ignored in the PPP solution.</p><p>Default is an empty option field, meaning<br>'Max Rex L1 = 0.03'</p>"));
1351 _pppWidgets._eleWgtCode->setWhatsThis(tr("<p>Tic 'Ele Wgt Code' to use satellite Elevation depending Weights for Code observations in the PPP solution.</p>"));
1352 _pppWidgets._eleWgtPhase->setWhatsThis(tr("<p>Tic 'Ele Wgt Phase' to use satellite Elevation depending Weights for Phase observations in the PPP solution.</p>"));
1353 _pppWidgets._minObs->setWhatsThis(tr("<p>Select a Minimum Number of Observations per epoch for a PPP solution.</p><p>BNC will only process epochs with observation numbers reaching or exceeding this minimum.</p>"));
1354 _pppWidgets._minEle->setWhatsThis(tr("<p>Select a Minimum satellite Elevation for observations.</p><p>BNC will ignore an observation if the associated satellite Elevation does not reach or exceed this minimum.</p><p>Selecting '10 deg' may be an appropriate choice in order to avoid too noisy observations.</p>"));
1355
1356 // WhatsThis, Combine Corrections
1357 // ------------------------------
1358 _cmbTable->setWhatsThis(tr("<p>BNC allows to process several orbit and clock correction streams in real-time to produce, encode, upload and save a combination of correctors coming from different providers. To add a line to the 'Combine Corrections' table hit the 'Add Row' button, double click on the 'Mountpoint' field to specify a Broadcast Ephemeris Correction 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 a weight to be applied for this stream in the combination.</p><p>Note that the orbit information in the resulting 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 orbit and clock correction streams 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 Correction stream in the 'Combine Corrections' table. Instead of combining corrections BNC will then add the corrections to the Broadcast Ephemeris with the possibility to save final orbit and clock results in SP3 and/or Clock RINEX format.</p>"));
1359 addCmbRowButton->setWhatsThis(tr("<p>Hit 'Add Row' button to add another line to the 'Combine Corrections' table.</p>"));
1360 delCmbRowButton->setWhatsThis(tr("<p>Hit 'Delete' button to delete the highlighted line(s) from the 'Combine Corrections' table.</p>"));
1361 _cmbMethodComboBox->setWhatsThis(tr("<p>Select a clock combination approach. Options are 'Single-Epoch' and Kalman 'Filter'.</p><p>It is suggested to use the Kalman filter approach for the purpose of Precise Point Positioning.</p>"));
1362 _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>"));
1363 _cmbSamplSpinBox->setWhatsThis(tr("<p>Select a combination Sampling interval for the clocks. Clock corrections will be produced following that interval.</p><p>A value of 10 sec may be an appropriate choice.</p>"));
1364 _cmbUseGlonass->setWhatsThis(tr("<p>In case the incoming orbit and clock correction stream(s) support GLONASS, you can tick 'Use GLONASS' to produce a GPS plus GLONASS combination solution.</p><p>Default is a GPS-only combination.</p>"));
1365
1366 // WhatsThis, Upload Corrections
1367 // -----------------------------
1368 _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 Host and Port</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' table.</p><p>To fill the 'Upload Corrections' table, 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. IGS14) 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 generated Broadcast Corrections plus Broadcast Ephemeris as SP3 orbit files. If the specified directory does not exist, BNC will not create such files. The following is a path example for a Linux system: /home/user/BNC${GPSWD}.sp3<br>Note that '${GPSWD}' produces the GPS Week and Day number in the filename.</p><p>Specify a path for saving 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: /home/user/BNC${GPSWD}.clk<br>Note that '${GPSWD}' produces the GPS Week and Day number in the filename.</p><p>Finally, specify a SSR Provider ID (issued by RTCM), SSR Solution ID, and SSR Issue of Data number.</p><p>In case the 'Combine Corrections' table contains only one Broadcast Correction stream, BNC will add that stream content to the Broadcast Ephemeris to save results in files specified via SP3 and/or Clock RINEX file path. You should then define only the SP3 and Clock RINEX file path and no further option in the 'Upload Corrections' table.</p>"));
1369 addUploadRowButton->setWhatsThis(tr("<p>Hit 'Add Row' button to add another line to the 'Upload Corrections' table.</p>"));
1370 delUploadRowButton->setWhatsThis(tr("<p>Hit 'Del Row' button to delete the highlighted line(s) from the Upload Corrections' table.</p>"));
1371 _uploadIntrComboBox->setWhatsThis(tr("<p>Select the length of the SP3 and Clock RINEX files.</p>"));
1372 _uploadSamplRtcmEphCorrSpinBox->setWhatsThis(tr("<p>Select a stream's orbit correction sampling interval in seconds.</p><p>A value of zero '0' tells BNC to upload all available orbit and clock correction samples together in combined messages.</p>"));
1373 _uploadSamplSp3SpinBox->setWhatsThis(tr("<p>Select a SP3 orbit file sampling interval in minutes.</p><p>A value of zero '0' tells BNC to store all available samples into SP3 orbit files.</p>"));
1374 _uploadSamplClkRnxSpinBox->setWhatsThis(tr("<p>Select a Clock RINEX file sampling interval in seconds.</p><p>A value of zero '0' tells BNC to store all available samples into Clock RINEX files.</p>"));
1375 setUploadTrafoButton->setWhatsThis(tr("<p>Hit 'Custom Trafo' to specify your own 14 parameter Helmert Transformation instead of selecting a predefined transformation via option 'System'.</p>"));
1376 _uploadAntexFile->setWhatsThis(tr("<p>When producing SP3 files or referring orbit and clock corrections to the satellite's Center of Mass (CoM) instead Antenna Phase Center (APC), an offset has to be applied which is available from the IGS 'ANTEX file'. You must therefore specify an 'ANTEX file' path if you want to save the stream content in SP3 format and/or refer correctors to CoM.</p><p>If you don't specify an 'ANTEX file' path, the SP3 file content as well as the orbit and clock correctors will be referred to satellite APCs.</p>"));
1377
1378 // WhatsThis, Upload Ephemeris
1379 // ---------------------------
1380 _uploadEphHostLineEdit->setWhatsThis(tr("<p>BNC can upload a Broadcast Ephemeris stream in RTCM Version 3 format. Specify the IP number or URL of an Ntrip Broadcaster to upload the stream.</p><p>An empty option field means that you don't want to upload Broadcast Ephemeris.</p>"));
1381 _uploadEphPortLineEdit->setWhatsThis(tr("<p>Specify the IP port of the Ntrip Broadcaster to upload the Broadcast Ephemeris stream. Default is port 80.</p>"));
1382 _uploadEphMountpointLineEdit->setWhatsThis(tr("<p>Specify a mountpoint for uploading the Broadcast Ephemeris stream.</p>"));
1383 _uploadEphPasswordLineEdit->setWhatsThis(tr("<p>Specify the stream upload password protecting the mounpoint on the Ntrip Broadcaster.</p>"));
1384 _uploadEphSampleSpinBox->setWhatsThis(tr("<p>Select the Broadcast Ephemeris sampling interval in seconds.</p><p>Default is '5', meaning that a complete set of Broadcast Ephemeris is uploaded every 5 seconds.</p>"));
1385 _uploadEphBytesCounter->setWhatsThis(tr("<p>BNC shows the amount of data uploaded via this stream.</p>"));
1386// weber
1387
1388 // WhatsThis, Streams Canvas
1389 // -------------------------
1390 _mountPointsTable->setWhatsThis(tr("<p>Streams selected for retrieval are listed in the 'Streams' section. Clicking on 'Add Stream' button opens 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 source-table. 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. Accepted decoder strings are 'RTCM_2.x', 'RTCM_3.x' and 'RTNET'.</p><p>In case you need to log raw data as is, BNC allows 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 such stream, the approximate latitude/longitude rover position is sent to the Ntrip Broadcaster together with an approximation for the height. Default values for latitude and longitude 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>"));
1391 _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
1392 _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1393 _actMapMountPoints->setWhatsThis(tr("<p> Draw distribution map of stream selection presented in the 'Streams' canvas. Use 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>"));
1394 _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1395 _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1396
1397 // WhatsThis, Log Canvas
1398 // ---------------------
1399 _log->setWhatsThis(tr("<p>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 problems that occur in the communication link, stream availability, stream delay, stream conversion etc.</p>"));
1400 _bncFigure->setWhatsThis(tr("<p>The bandwidth consumption per stream is shown in the 'Throughput' tab in bits per second (bps) or kilobits per second (kbps).</p>"));
1401 _bncFigureLate->setWhatsThis(tr("<p>The individual latency of observations of incoming streams is shown in the 'Latency' tab. Streams not carrying observations (e.g. those providing only Broadcast Ephemeris) remain unconsidered.</p><p>Note that the calculation of correct latencies requires the clock of the host computer to be properly synchronized.</p>"));
1402 _bncFigurePPP->setWhatsThis(tr("<p>PPP time series of North (red), East (green) and Up (blue) displacements are shown in the 'PPP Plot' tab when the corresponding option is selected.</p><p>Values are referred to an XYZ a priori coordinate. The sliding PPP time series window covers the period of the latest 5 minutes.</p>"));
1403
1404
1405 // Enable/Disable all Widgets
1406 // --------------------------
1407 slotBncTextChanged();
1408 enableStartStop();
1409
1410 // Auto start
1411 // ----------
1412 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1413 slotStart();
1414 }
1415}
1416
1417// Destructor
1418////////////////////////////////////////////////////////////////////////////
1419bncWindow::~bncWindow() {
1420 if (_caster) {
1421 delete _caster; BNC_CORE->setCaster(0);
1422 }
1423 if (_casterEph) {
1424 delete _casterEph;
1425 }
1426 delete _bncFigureLate;
1427 delete _bncFigurePPP;
1428 delete _actHelp;
1429 delete _actAbout;
1430 delete _actFlowchart;
1431 delete _actFontSel;
1432 delete _actSaveOpt;
1433 delete _actQuit;
1434 delete _actAddMountPoints;
1435 delete _actDeleteMountPoints;
1436 delete _actMapMountPoints;
1437 delete _actStart;
1438 delete _actStop;
1439 delete _actwhatsthis;
1440 delete _proxyHostLineEdit;
1441 delete _proxyPortLineEdit;
1442 delete _sslCaCertPathLineEdit;
1443 delete _sslIgnoreErrorsCheckBox;
1444 delete _logFileLineEdit;
1445 delete _rawOutFileLineEdit;
1446 delete _rnxAppendCheckBox;
1447 delete _onTheFlyComboBox;
1448 delete _autoStartCheckBox;
1449 delete _rnxPathLineEdit;
1450 delete _rnxIntrComboBox;
1451 delete _rnxSamplComboBox;
1452 delete _rnxFileCheckBox;
1453 delete _rnxSkelLineEdit;
1454 delete _rnxScrpLineEdit;
1455 delete _rnxV3CheckBox;
1456 delete _rnxV2Priority;
1457 delete _ephPathLineEdit;
1458 delete _ephIntrComboBox;
1459 delete _ephOutPortLineEdit;
1460 delete _ephV3CheckBox;
1461 delete _corrPathLineEdit;
1462 delete _corrIntrComboBox;
1463 delete _corrPortLineEdit;
1464 delete _outPortLineEdit;
1465 delete _outWaitSpinBox;
1466 delete _outSamplComboBox;
1467 delete _outFileLineEdit;
1468 delete _outUPortLineEdit;
1469 delete _outLockTimeCheckBox;
1470 delete _serialMountPointLineEdit;
1471 delete _serialPortNameLineEdit;
1472 delete _serialBaudRateComboBox;
1473 delete _serialFlowControlComboBox;
1474 delete _serialDataBitsComboBox;
1475 delete _serialParityComboBox;
1476 delete _serialStopBitsComboBox;
1477 delete _serialAutoNMEAComboBox;
1478 delete _serialFileNMEALineEdit;
1479 delete _serialHeightNMEALineEdit;
1480 delete _serialManualNMEASamplingSpinBox;
1481 delete _adviseObsRateComboBox;
1482 delete _adviseFailSpinBox;
1483 delete _adviseRecoSpinBox;
1484 delete _adviseScriptLineEdit;
1485 delete _miscMountLineEdit;
1486 delete _miscPortLineEdit;
1487 delete _miscIntrComboBox;
1488 delete _miscScanRTCMCheckBox;
1489 _mountPointsTable->deleteLater();
1490 delete _log;
1491 _cmbTable->deleteLater();
1492 delete _cmbMaxresLineEdit;
1493 delete _cmbUseGlonass;
1494 delete _cmbSamplSpinBox;
1495 delete _cmbMethodComboBox;
1496 _uploadTable->deleteLater();
1497 delete _uploadIntrComboBox;
1498 delete _uploadAntexFile;
1499 delete _uploadSamplRtcmEphCorrSpinBox;
1500 delete _uploadSamplSp3SpinBox;
1501 delete _uploadSamplClkRnxSpinBox;
1502 delete _uploadEphHostLineEdit;
1503 delete _uploadEphPortLineEdit;
1504 delete _uploadEphPasswordLineEdit;
1505 delete _uploadEphMountpointLineEdit;
1506 delete _uploadEphSampleSpinBox;
1507 delete _uploadEphBytesCounter;
1508 delete _loggroup;
1509 delete _reqcActionComboBox;
1510 delete _reqcObsFileChooser;
1511 delete _reqcNavFileChooser;
1512 delete _reqcOutObsLineEdit;
1513 delete _reqcOutNavLineEdit;
1514 delete _reqcOutLogLineEdit;
1515 delete _reqcPlotDirLineEdit;
1516 delete _reqcSkyPlotSignals;
1517 delete _reqcLogSummaryOnly;
1518 delete _reqcEditOptionButton;
1519 delete _sp3CompFileChooser;
1520 delete _sp3CompExclude;
1521 delete _sp3CompLogLineEdit;
1522 //delete _canvas;
1523}
1524
1525//
1526////////////////////////////////////////////////////////////////////////////
1527void bncWindow::populateMountPointsTable() {
1528
1529 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1530 _mountPointsTable->removeRow(iRow);
1531 }
1532
1533 bncSettings settings;
1534
1535 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1536 int iRow = 0;
1537 while (it.hasNext()) {
1538 QStringList hlp = it.next().split(" ");
1539 if (hlp.size() < 7) continue;
1540 _mountPointsTable->insertRow(iRow);
1541
1542 QUrl url(hlp[0]);
1543
1544 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1545 QString format(hlp[1]); QString country(hlp[2]); QString latitude(hlp[3]); QString longitude(hlp[4]);
1546 QString nmea(hlp[5]);
1547 if (hlp[6] == "S") {
1548 fullPath = hlp[0].replace(0,2,"");
1549 }
1550 QString ntripVersion = "2";
1551 if (hlp.size() >= 7) {
1552 ntripVersion = (hlp[6]);
1553 }
1554
1555 QTableWidgetItem* it;
1556 it = new QTableWidgetItem(url.userInfo());
1557 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1558 _mountPointsTable->setItem(iRow, 0, it);
1559
1560 it = new QTableWidgetItem(fullPath);
1561 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1562 _mountPointsTable->setItem(iRow, 1, it);
1563
1564 it = new QTableWidgetItem(format);
1565 _mountPointsTable->setItem(iRow, 2, it);
1566
1567 it = new QTableWidgetItem(country);
1568 _mountPointsTable->setItem(iRow, 3, it);
1569
1570 if (nmea == "yes") {
1571 it = new QTableWidgetItem(latitude);
1572 _mountPointsTable->setItem(iRow, 4, it);
1573 it = new QTableWidgetItem(longitude);
1574 _mountPointsTable->setItem(iRow, 5, it);
1575 } else {
1576 it = new QTableWidgetItem(latitude);
1577 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1578 _mountPointsTable->setItem(iRow, 4, it);
1579
1580 it = new QTableWidgetItem(longitude);
1581 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1582 _mountPointsTable->setItem(iRow, 5, it);
1583 }
1584
1585 it = new QTableWidgetItem(nmea);
1586 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1587 _mountPointsTable->setItem(iRow, 6, it);
1588
1589 it = new QTableWidgetItem(ntripVersion);
1590 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1591 _mountPointsTable->setItem(iRow, 7, it);
1592
1593 bncTableItem* bncIt = new bncTableItem();
1594 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1595 _mountPointsTable->setItem(iRow, 8, bncIt);
1596
1597 iRow++;
1598 }
1599
1600 _mountPointsTable->sortItems(1);
1601
1602 enableStartStop();
1603}
1604
1605// Retrieve Table
1606////////////////////////////////////////////////////////////////////////////
1607void bncWindow::slotAddMountPoints() {
1608
1609 bncSettings settings;
1610 QString proxyHost = settings.value("proxyHost").toString();
1611 int proxyPort = settings.value("proxyPort").toInt();
1612 if (proxyHost != _proxyHostLineEdit->text() ||
1613 proxyPort != _proxyPortLineEdit->text().toInt()) {
1614 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1615 "changed. Use the new ones?",
1616 QMessageBox::Yes, QMessageBox::No,
1617 QMessageBox::NoButton);
1618 if (iRet == QMessageBox::Yes) {
1619 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1620 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1621 }
1622 }
1623
1624 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1625 settings.setValue("sslIgnoreErrors", _sslIgnoreErrorsCheckBox->checkState());
1626
1627 QMessageBox msgBox;
1628 msgBox.setIcon(QMessageBox::Question);
1629 msgBox.setWindowTitle("Add Stream");
1630 msgBox.setText("Add stream(s) coming from:");
1631
1632 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1633 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1634 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1635 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1636 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1637
1638 msgBox.exec();
1639
1640 if (msgBox.clickedButton() == buttonNtrip) {
1641 bncTableDlg* dlg = new bncTableDlg(this);
1642 dlg->move(this->pos().x()+50, this->pos().y()+50);
1643 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1644 this, SLOT(slotNewMountPoints(QStringList*)));
1645 dlg->exec();
1646 delete dlg;
1647 } else if (msgBox.clickedButton() == buttonIP) {
1648 bncIpPort* ipp = new bncIpPort(this);
1649 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1650 this, SLOT(slotNewMountPoints(QStringList*)));
1651 ipp->exec();
1652 delete ipp;
1653 } else if (msgBox.clickedButton() == buttonUDP) {
1654 bncUdpPort* udp = new bncUdpPort(this);
1655 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1656 this, SLOT(slotNewMountPoints(QStringList*)));
1657 udp->exec();
1658 delete udp;
1659 } else if (msgBox.clickedButton() == buttonSerial) {
1660 bncSerialPort* sep = new bncSerialPort(this);
1661 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1662 this, SLOT(slotNewMountPoints(QStringList*)));
1663 sep->exec();
1664 delete sep;
1665 } else if (msgBox.clickedButton() == buttonCancel) {
1666 // Cancel
1667 }
1668
1669 enableStartStop();
1670}
1671
1672// Delete Selected Mount Points
1673////////////////////////////////////////////////////////////////////////////
1674void bncWindow::slotDeleteMountPoints() {
1675
1676 int nRows = _mountPointsTable->rowCount();
1677 bool flg[nRows];
1678 for (int iRow = 0; iRow < nRows; iRow++) {
1679 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1680 flg[iRow] = true;
1681 }
1682 else {
1683 flg[iRow] = false;
1684 }
1685 }
1686 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1687 if (flg[iRow]) {
1688 _mountPointsTable->removeRow(iRow);
1689 }
1690 }
1691 _actDeleteMountPoints->setEnabled(false);
1692
1693 enableStartStop();
1694}
1695
1696// New Mount Points Selected
1697////////////////////////////////////////////////////////////////////////////
1698void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1699 int iRow = 0;
1700 QListIterator<QString> it(*mountPoints);
1701 while (it.hasNext()) {
1702 QStringList hlp = it.next().split(" ");
1703 QUrl url(hlp[0]);
1704 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1705 QString format(hlp[1]); QString country(hlp[2]); QString latitude(hlp[3]); QString longitude(hlp[4]);
1706 QString nmea(hlp[5]);
1707 if (hlp[6] == "S") {
1708 fullPath = hlp[0].replace(0,2,"");
1709 }
1710 QString ntripVersion = "2";
1711 if (hlp.size() >= 7) {
1712 ntripVersion = (hlp[6]);
1713 }
1714
1715 _mountPointsTable->insertRow(iRow);
1716
1717 QTableWidgetItem* it;
1718 it = new QTableWidgetItem(url.userInfo());
1719 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1720 _mountPointsTable->setItem(iRow, 0, it);
1721
1722 it = new QTableWidgetItem(fullPath);
1723 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1724 _mountPointsTable->setItem(iRow, 1, it);
1725
1726 it = new QTableWidgetItem(format);
1727 _mountPointsTable->setItem(iRow, 2, it);
1728
1729 it = new QTableWidgetItem(country);
1730 _mountPointsTable->setItem(iRow, 3, it);
1731
1732 if (nmea == "yes") {
1733 it = new QTableWidgetItem(latitude);
1734 _mountPointsTable->setItem(iRow, 4, it);
1735 it = new QTableWidgetItem(longitude);
1736 _mountPointsTable->setItem(iRow, 5, it);
1737 } else {
1738 it = new QTableWidgetItem(latitude);
1739 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1740 _mountPointsTable->setItem(iRow, 4, it);
1741 it = new QTableWidgetItem(longitude);
1742 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1743 _mountPointsTable->setItem(iRow, 5, it);
1744 }
1745
1746 it = new QTableWidgetItem(nmea);
1747 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1748 _mountPointsTable->setItem(iRow, 6, it);
1749
1750 it = new QTableWidgetItem(ntripVersion);
1751 ////it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1752 _mountPointsTable->setItem(iRow, 7, it);
1753
1754 bncTableItem* bncIt = new bncTableItem();
1755 _mountPointsTable->setItem(iRow, 8, bncIt);
1756
1757 iRow++;
1758 }
1759 _mountPointsTable->hideColumn(0);
1760 _mountPointsTable->hideColumn(3);
1761 _mountPointsTable->sortItems(1);
1762 delete mountPoints;
1763
1764 enableStartStop();
1765}
1766
1767// Save Options (serialize)
1768////////////////////////////////////////////////////////////////////////////
1769void bncWindow::slotSaveOptions() {
1770 saveOptions();
1771 bncSettings settings;
1772 settings.sync();
1773}
1774
1775// Save Options (memory only)
1776////////////////////////////////////////////////////////////////////////////
1777void bncWindow::saveOptions() {
1778
1779 QStringList mountPoints;
1780 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1781
1782 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1783 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1784 "@" + _mountPointsTable->item(iRow, 1)->text() );
1785
1786 mountPoints.append(url.toString() + " " +
1787 _mountPointsTable->item(iRow, 2)->text()
1788 + " " + _mountPointsTable->item(iRow, 3)->text()
1789 + " " + _mountPointsTable->item(iRow, 4)->text()
1790 + " " + _mountPointsTable->item(iRow, 5)->text()
1791 + " " + _mountPointsTable->item(iRow, 6)->text()
1792 + " " + _mountPointsTable->item(iRow, 7)->text());
1793 } else {
1794 mountPoints.append(
1795 "//" + _mountPointsTable->item(iRow, 1)->text()
1796 + " " + _mountPointsTable->item(iRow, 2)->text()
1797 + " " + _mountPointsTable->item(iRow, 3)->text()
1798 + " " + _mountPointsTable->item(iRow, 4)->text()
1799 + " " + _mountPointsTable->item(iRow, 5)->text()
1800 + " " + _mountPointsTable->item(iRow, 6)->text()
1801 + " " + _mountPointsTable->item(iRow, 7)->text());
1802 }
1803 }
1804
1805 QStringList cmbStreams;
1806 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1807 QString hlp;
1808 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1809 if (_cmbTable->item(iRow, iCol)) {
1810 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1811 }
1812 }
1813 if (!hlp.isEmpty()) {
1814 cmbStreams << hlp;
1815 }
1816 }
1817
1818 QStringList uploadMountpointsOut;
1819 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1820 QString hlp;
1821 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1822 if (_uploadTable->cellWidget(iRow, iCol) &&
1823 (iCol == 3 || iCol == 4 || iCol == 5 || iCol == 6)) {
1824 if (iCol == 3) {
1825 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1826 hlp += passwd->text() + ",";
1827 }
1828 else if (iCol == 4) {
1829 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1830 hlp += system->currentText() + ",";
1831 }
1832 else if (iCol == 5) {
1833 QComboBox* format = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1834 hlp += format->currentText() + ",";
1835 }
1836 else if (iCol == 6) {
1837 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1838 QString state; state.setNum(com->checkState());
1839 hlp += state + ",";
1840 }
1841 }
1842 else if (_uploadTable->item(iRow, iCol)) {
1843 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1844 }
1845 }
1846 if (!hlp.isEmpty()) {
1847 uploadMountpointsOut << hlp;
1848 }
1849 }
1850
1851 bncSettings settings;
1852
1853 settings.setValue("startTab", _aogroup->currentIndex());
1854 settings.setValue("statusTab", _loggroup->currentIndex());
1855 settings.setValue("mountPoints", mountPoints);
1856// Network
1857 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1858 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1859 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1860 settings.setValue("sslIgnoreErrors", _sslIgnoreErrorsCheckBox->checkState());
1861// General
1862 settings.setValue("logFile", _logFileLineEdit->text());
1863 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1864 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1865 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1866 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1867// RINEX Observations
1868 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1869 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1870 settings.setValue("rnxSampl", _rnxSamplComboBox->currentText());
1871 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1872 settings.setValue("rnxOnlyWithSKL",_rnxFileCheckBox->checkState());
1873 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1874 settings.setValue("rnxV2Priority",_rnxV2Priority->text());
1875 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1876// RINEX Ephemeris
1877 settings.setValue("ephPath", _ephPathLineEdit->text());
1878 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1879 settings.setValue("ephOutPort", _ephOutPortLineEdit->text());
1880 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1881// Broadcast Corrections
1882 settings.setValue("corrPath", _corrPathLineEdit->text());
1883 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1884 settings.setValue("corrPort", _corrPortLineEdit->text());
1885// Feed Engine
1886 settings.setValue("outPort", _outPortLineEdit->text());
1887 settings.setValue("outWait", _outWaitSpinBox->value());
1888 settings.setValue("outSampl", _outSamplComboBox->currentText());
1889 settings.setValue("outFile", _outFileLineEdit->text());
1890 settings.setValue("outUPort", _outUPortLineEdit->text());
1891 settings.setValue("outLockTime",_outLockTimeCheckBox->checkState());
1892// Serial Output
1893 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1894 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1895 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1896 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1897 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1898 settings.setValue("serialParity", _serialParityComboBox->currentText());
1899 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1900 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1901 settings.setValue("serialFileNMEA", _serialFileNMEALineEdit->text());
1902 settings.setValue("serialHeightNMEA", _serialHeightNMEALineEdit->text());
1903 settings.setValue("serialManualNMEASampling", _serialManualNMEASamplingSpinBox->value());
1904// Outages
1905 settings.setValue("adviseObsRate", _adviseObsRateComboBox->currentText());
1906 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1907 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1908 settings.setValue("adviseScript", _adviseScriptLineEdit->text());
1909// Miscellaneous
1910 settings.setValue("miscMount", _miscMountLineEdit->text());
1911 settings.setValue("miscPort", _miscPortLineEdit->text());
1912 settings.setValue("miscIntr", _miscIntrComboBox->currentText());
1913 settings.setValue("miscScanRTCM", _miscScanRTCMCheckBox->checkState());
1914// Reqc
1915 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1916 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1917 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1918 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1919 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1920 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
1921 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
1922 settings.setValue("reqcSkyPlotSignals", _reqcSkyPlotSignals->text());
1923 settings.setValue("reqcLogSummaryOnly", _reqcLogSummaryOnly->checkState());
1924// SP3 Comparison
1925 settings.setValue("sp3CompFile", _sp3CompFileChooser->fileName());
1926 settings.setValue("sp3CompExclude", _sp3CompExclude->text());
1927 settings.setValue("sp3CompOutLogFile", _sp3CompLogLineEdit->text());
1928// Combine Corrections
1929 if (!cmbStreams.isEmpty()) {
1930 settings.setValue("cmbStreams", cmbStreams);
1931 }
1932 else {
1933 settings.setValue("cmbStreams", "");
1934 }
1935 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1936 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1937 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1938 settings.setValue("cmbUseGlonass", _cmbUseGlonass->checkState());
1939// Upload Corrections
1940 if (!uploadMountpointsOut.isEmpty()) {
1941 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1942 }
1943 else {
1944 settings.setValue("uploadMountpointsOut", "");
1945 }
1946 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1947 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1948 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1949 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
1950 settings.setValue("uploadAntexFile", _uploadAntexFile->fileName());
1951// Upload Ephemeris
1952 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1953 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
1954 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
1955 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1956 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
1957
1958 if (_caster) {
1959 _caster->readMountPoints();
1960 }
1961
1962 _pppWidgets.saveOptions();
1963}
1964
1965// All get slots terminated
1966////////////////////////////////////////////////////////////////////////////
1967void bncWindow::slotGetThreadsFinished() {
1968 BNC_CORE->slotMessage("All Get Threads Terminated", true);
1969 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
1970 delete _casterEph; _casterEph = 0;
1971 _runningRealTime = false;
1972}
1973
1974// Start It!
1975////////////////////////////////////////////////////////////////////////////
1976void bncWindow::slotStart() {
1977 saveOptions();
1978 if ( _pppWidgets._dataSource->currentText() == "RINEX Files") {
1979 _runningPPP = true;
1980 enableStartStop();
1981 _caster = new bncCaster(); BNC_CORE->setCaster(_caster);
1982 BNC_CORE->startPPP();
1983 _bncFigurePPP->reset();
1984 }
1985 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
1986 if (_reqcActionComboBox->currentText() == "Analyze") {
1987 _runningQC = true;
1988 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
1989 connect(reqcAnalyze, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1990 reqcAnalyze->start();
1991 }
1992 else {
1993 _runningEdit = true;
1994 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
1995 connect(reqcEdit, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1996 reqcEdit->start();
1997 }
1998 enableStartStop();
1999 }
2000 else if (!_sp3CompFileChooser->fileName().isEmpty()) {
2001 _runningSp3Comp = true;
2002 t_sp3Comp* sp3Comp = new t_sp3Comp(this);
2003 connect(sp3Comp, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
2004 sp3Comp->start();
2005 enableStartStop();
2006 }
2007 else {
2008 startRealTime();
2009 BNC_CORE->startPPP();
2010 }
2011}
2012
2013// Start Real-Time (Retrieve Data etc.)
2014////////////////////////////////////////////////////////////////////////////
2015void bncWindow::startRealTime() {
2016
2017 _runningRealTime = true;
2018
2019 _bncFigurePPP->reset();
2020
2021 _actDeleteMountPoints->setEnabled(false);
2022
2023 enableStartStop();
2024
2025 _caster = new bncCaster();
2026
2027 BNC_CORE->setCaster(_caster);
2028 BNC_CORE->setPortEph(_ephOutPortLineEdit->text().toInt());
2029 BNC_CORE->setPortCorr(_corrPortLineEdit->text().toInt());
2030 BNC_CORE->initCombination();
2031
2032 connect(_caster, SIGNAL(getThreadsFinished()),
2033 this, SLOT(slotGetThreadsFinished()));
2034
2035 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
2036 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
2037
2038 BNC_CORE->slotMessage("========== Start BNC v" BNCVERSION" ("BNC_OS") ==========", true);
2039
2040 bncSettings settings;
2041
2042 // Active panels
2043 // -------------
2044 if (!_rnxPathLineEdit->text().isEmpty())
2045 BNC_CORE->slotMessage("Panel 'RINEX Observations' active", true);
2046 if (!_ephPathLineEdit->text().isEmpty())
2047 BNC_CORE->slotMessage("Panel 'RINEX Ephemeris' active", true);
2048 if (!_corrPathLineEdit->text().isEmpty())
2049 BNC_CORE->slotMessage("Panel 'Broadcast Corrections' active", true);
2050 if (!_outPortLineEdit->text().isEmpty())
2051 BNC_CORE->slotMessage("Panel 'Feed Engine' active", true);
2052 if (!_serialMountPointLineEdit->text().isEmpty())
2053 BNC_CORE->slotMessage("Panel 'Serial Output' active", true);
2054 if (!_adviseObsRateComboBox->currentText().isEmpty())
2055 BNC_CORE->slotMessage("Panel 'Outages' active", true);
2056 if (!_miscMountLineEdit->text().isEmpty())
2057 BNC_CORE->slotMessage("Panel 'Miscellaneous' active", true);
2058 if (_pppWidgets._dataSource->currentText() == "Real-Time Streams")
2059 BNC_CORE->slotMessage("Panel 'PPP' active", true);
2060 if (_cmbTable->rowCount() > 0)
2061 BNC_CORE->slotMessage("Panel 'Combine Corrections' active", true);
2062 if (_uploadTable->rowCount() > 0)
2063 BNC_CORE->slotMessage("Panel 'Upload Corrections' active", true);
2064 if (!_uploadEphHostLineEdit->text().isEmpty())
2065 BNC_CORE->slotMessage("Panel 'UploadEphemeris' active", true);
2066
2067 QDir rnxdir(settings.value("rnxPath").toString());
2068 if (!rnxdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations directory", true);
2069
2070 QString rnx_file = settings.value("rnxScript").toString();
2071 if ( !rnx_file.isEmpty() ) {
2072 QFile rnxfile(settings.value("rnxScript").toString());
2073 if (!rnxfile.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations script", true);
2074 }
2075
2076 QDir ephdir(settings.value("ephPath").toString());
2077 if (!ephdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Ephemeris directory", true);
2078
2079 QDir corrdir(settings.value("corrPath").toString());
2080 if (!corrdir.exists()) BNC_CORE->slotMessage("Cannot find Broadcast Corrections directory", true);
2081
2082 QString advise_file = settings.value("adviseScript").toString();
2083 if ( !advise_file.isEmpty() ) {
2084 QFile advisefile(settings.value("adviseScript").toString());
2085 if (!advisefile.exists()) BNC_CORE->slotMessage("Cannot find Outages script", true);
2086 }
2087
2088 _caster->readMountPoints();
2089
2090 _casterEph = new bncEphUploadCaster();
2091 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
2092 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
2093}
2094
2095// Retrieve Data
2096////////////////////////////////////////////////////////////////////////////
2097void bncWindow::slotStop() {
2098 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving/processing data?",
2099 QMessageBox::Yes, QMessageBox::No,
2100 QMessageBox::NoButton);
2101 if (iRet == QMessageBox::Yes) {
2102 BNC_CORE->stopPPP();
2103 BNC_CORE->stopCombination();
2104 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
2105 delete _casterEph; _casterEph = 0;
2106 _runningRealTime = false;
2107 _runningPPP = false;
2108 enableStartStop();
2109 }
2110}
2111
2112// Close Application gracefully
2113////////////////////////////////////////////////////////////////////////////
2114void bncWindow::closeEvent(QCloseEvent* event) {
2115
2116 int iRet = QMessageBox::question(this, "Close", "Save Options?",
2117 QMessageBox::Yes, QMessageBox::No,
2118 QMessageBox::Cancel);
2119
2120 if (iRet == QMessageBox::Cancel) {
2121 event->ignore();
2122 return;
2123 }
2124 else if (iRet == QMessageBox::Yes) {
2125 slotSaveOptions();
2126 }
2127
2128 BNC_CORE->stopPPP();
2129
2130 QMainWindow::closeEvent(event);
2131}
2132
2133// User changed the selection of mountPoints
2134////////////////////////////////////////////////////////////////////////////
2135void bncWindow::slotSelectionChanged() {
2136 if (_mountPointsTable->selectedItems().isEmpty()) {
2137 _actDeleteMountPoints->setEnabled(false);
2138 }
2139 else {
2140 _actDeleteMountPoints->setEnabled(true);
2141 }
2142}
2143
2144// Display Program Messages
2145////////////////////////////////////////////////////////////////////////////
2146void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
2147 if (showOnScreen ) {
2148 _log->append(QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg);
2149 }
2150}
2151
2152// About Message
2153////////////////////////////////////////////////////////////////////////////
2154void bncWindow::slotAbout() {
2155 new bncAboutDlg(0);
2156}
2157
2158//Flowchart
2159////////////////////////////////////////////////////////////////////////////
2160void bncWindow::slotFlowchart() {
2161 new bncFlowchartDlg(0);
2162}
2163
2164// Help Window
2165////////////////////////////////////////////////////////////////////////////
2166void bncWindow::slotHelp() {
2167 QUrl url;
2168 url.setPath(":bnchelp.html");
2169 new bncHlpDlg(0, url);
2170}
2171
2172// Select Fonts
2173////////////////////////////////////////////////////////////////////////////
2174void bncWindow::slotFontSel() {
2175 bool ok;
2176 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
2177 if (ok) {
2178 bncSettings settings;
2179 settings.setValue("font", newFont.toString());
2180 QApplication::setFont(newFont);
2181 int ww = QFontMetrics(newFont).width('w');
2182 setMinimumSize(60*ww, 80*ww);
2183 resize(60*ww, 80*ww);
2184 }
2185}
2186
2187// Whats This Help
2188void bncWindow::slotWhatsThis() {
2189 QWhatsThis::enterWhatsThisMode();
2190}
2191
2192//
2193////////////////////////////////////////////////////////////////////////////
2194void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
2195 _threads = threads;
2196
2197 _bncFigure->updateMountPoints();
2198 _bncFigureLate->updateMountPoints();
2199
2200 populateMountPointsTable();
2201 bncSettings settings;
2202 _outSamplComboBox->findText(settings.value("outSampl").toString());
2203 _outWaitSpinBox->setValue(settings.value("outWait").toInt());
2204 QListIterator<bncGetThread*> iTh(threads);
2205 while (iTh.hasNext()) {
2206 bncGetThread* thread = iTh.next();
2207 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
2208 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
2209 "@" + _mountPointsTable->item(iRow, 1)->text() );
2210 if (url == thread->mountPoint() &&
2211 _mountPointsTable->item(iRow, 4)->text() == thread->latitude() &&
2212 _mountPointsTable->item(iRow, 5)->text() == thread->longitude() ) {
2213 ((bncTableItem*) _mountPointsTable->item(iRow, 8))->setGetThread(thread);
2214 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
2215 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2216 connect(thread, SIGNAL(newBytes(QByteArray, double)),
2217 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2218 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
2219 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2220 connect(thread, SIGNAL(newLatency(QByteArray, double)),
2221 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2222 break;
2223 }
2224 }
2225 }
2226}
2227
2228//
2229////////////////////////////////////////////////////////////////////////////
2230void bncWindow::CreateMenu() {
2231 // Create Menus
2232 // ------------
2233 _menuFile = menuBar()->addMenu(tr("&File"));
2234 _menuFile->addAction(_actFontSel);
2235 _menuFile->addSeparator();
2236 _menuFile->addAction(_actSaveOpt);
2237 _menuFile->addSeparator();
2238 _menuFile->addAction(_actQuit);
2239
2240 _menuHlp = menuBar()->addMenu(tr("&Help"));
2241 _menuHlp->addAction(_actHelp);
2242 _menuHlp->addAction(_actFlowchart);
2243 _menuHlp->addAction(_actAbout);
2244}
2245
2246// Toolbar
2247////////////////////////////////////////////////////////////////////////////
2248void bncWindow::AddToolbar() {
2249 QToolBar* toolBar = new QToolBar;
2250 addToolBar(Qt::BottomToolBarArea, toolBar);
2251 toolBar->setMovable(false);
2252 toolBar->addAction(_actAddMountPoints);
2253 toolBar->addAction(_actDeleteMountPoints);
2254 toolBar->addAction(_actMapMountPoints);
2255 toolBar->addAction(_actStart);
2256 toolBar->addAction(_actStop);
2257 toolBar->addWidget(new QLabel(" "));
2258 toolBar->addAction(_actwhatsthis);
2259}
2260
2261// About
2262////////////////////////////////////////////////////////////////////////////
2263bncAboutDlg::bncAboutDlg(QWidget* parent) :
2264 QDialog(parent) {
2265
2266 QTextBrowser* tb = new QTextBrowser;
2267 QUrl url; url.setPath(":bncabout.html");
2268 tb->setSource(url);
2269 tb->setReadOnly(true);
2270
2271 int ww = QFontMetrics(font()).width('w');
2272 QPushButton* _closeButton = new QPushButton("Close");
2273 _closeButton->setMaximumWidth(10*ww);
2274 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2275
2276 QGridLayout* dlgLayout = new QGridLayout();
2277 QLabel* img = new QLabel();
2278 img->setPixmap(QPixmap(":ntrip-logo.png"));
2279 dlgLayout->addWidget(img, 0,0);
2280 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
2281 dlgLayout->addWidget(tb,1,0,1,2);
2282 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2283
2284 setLayout(dlgLayout);
2285 resize(60*ww, 60*ww);
2286 setWindowTitle("About BNC");
2287 show();
2288}
2289
2290//
2291////////////////////////////////////////////////////////////////////////////
2292bncAboutDlg::~bncAboutDlg() {
2293
2294};
2295
2296// Flowchart
2297////////////////////////////////////////////////////////////////////////////
2298bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2299 QDialog(parent) {
2300
2301 int ww = QFontMetrics(font()).width('w');
2302 QPushButton* _closeButton = new QPushButton("Close");
2303 _closeButton->setMaximumWidth(10*ww);
2304 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2305
2306 QGridLayout* dlgLayout = new QGridLayout();
2307 QLabel* img = new QLabel();
2308 img->setPixmap(QPixmap(":bncflowchart.png"));
2309 dlgLayout->addWidget(img, 0,0);
2310 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2311
2312 setLayout(dlgLayout);
2313 setWindowTitle("Flow Chart");
2314 show();
2315}
2316
2317//
2318////////////////////////////////////////////////////////////////////////////
2319bncFlowchartDlg::~bncFlowchartDlg() {
2320};
2321
2322// Enable/Disable Widget (and change its color)
2323////////////////////////////////////////////////////////////////////////////
2324void bncWindow::enableWidget(bool enable, QWidget* widget) {
2325
2326 const static QPalette paletteWhite(QColor(255, 255, 255));
2327 const static QPalette paletteGray(QColor(230, 230, 230));
2328
2329 widget->setEnabled(enable);
2330 if (enable) {
2331 widget->setPalette(paletteWhite);
2332 }
2333 else {
2334 widget->setPalette(paletteGray);
2335 }
2336}
2337
2338// Bnc Text
2339////////////////////////////////////////////////////////////////////////////
2340void bncWindow::slotBncTextChanged(){
2341
2342 const static QPalette paletteWhite(QColor(255, 255, 255));
2343 const static QPalette paletteGray(QColor(230, 230, 230));
2344
2345 bool enable = true;
2346
2347 // Proxy
2348 //------
2349 if (sender() == 0 || sender() == _proxyHostLineEdit) {
2350 enable = !_proxyHostLineEdit->text().isEmpty();
2351 enableWidget(enable, _proxyPortLineEdit);
2352 }
2353
2354 // RINEX Observations
2355 // ------------------
2356 if (sender() == 0 || sender() == _rnxPathLineEdit) {
2357 enable = !_rnxPathLineEdit->text().isEmpty();
2358 enableWidget(enable, _rnxIntrComboBox);
2359 enableWidget(enable, _rnxSamplComboBox);
2360 enableWidget(enable, _rnxSkelLineEdit);
2361 enableWidget(enable, _rnxFileCheckBox);
2362 enableWidget(enable, _rnxScrpLineEdit);
2363 enableWidget(enable, _rnxV2Priority);
2364 enableWidget(enable, _rnxV3CheckBox);
2365
2366 bool enable1 = true;
2367 enable1 = _rnxV3CheckBox->isChecked();
2368 if (enable && enable1) {
2369 enableWidget(false, _rnxV2Priority);
2370 }
2371 if (enable && !enable1) {
2372 enableWidget(true, _rnxV2Priority);
2373 }
2374 }
2375
2376 // RINEX Observations, Signal Priority
2377 // -----------------------------------
2378 if (sender() == 0 || sender() == _rnxV3CheckBox) {
2379 if (!_rnxPathLineEdit->text().isEmpty()) {
2380 enableWidget(enable, _rnxIntrComboBox);
2381 enable = !_rnxV3CheckBox->isChecked();
2382 enableWidget(enable, _rnxV2Priority);
2383 }
2384 }
2385
2386 // RINEX Ephemeris
2387 // ---------------
2388 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _ephOutPortLineEdit) {
2389 enable = !_ephPathLineEdit->text().isEmpty() || !_ephOutPortLineEdit->text().isEmpty();
2390 enableWidget(enable, _ephIntrComboBox);
2391 enableWidget(enable, _ephV3CheckBox);
2392 }
2393
2394 // Broadcast Corrections
2395 // ---------------------
2396 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2397 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2398 enableWidget(enable, _corrIntrComboBox);
2399 }
2400
2401 // Feed Engine
2402 // -----------
2403 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2404 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2405 enableWidget(enable, _outWaitSpinBox);
2406 enableWidget(enable, _outSamplComboBox);
2407 }
2408
2409 // Serial Output
2410 // -------------
2411 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
2412 sender() == _serialAutoNMEAComboBox) {
2413 enable = !_serialMountPointLineEdit->text().isEmpty();
2414 enableWidget(enable, _serialPortNameLineEdit);
2415 enableWidget(enable, _serialBaudRateComboBox);
2416 enableWidget(enable, _serialParityComboBox);
2417 enableWidget(enable, _serialDataBitsComboBox);
2418 enableWidget(enable, _serialStopBitsComboBox);
2419 enableWidget(enable, _serialFlowControlComboBox);
2420 enableWidget(enable, _serialAutoNMEAComboBox);
2421 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() == "Auto";
2422 enableWidget(enable2, _serialFileNMEALineEdit);
2423 bool enable3 = enable && _serialAutoNMEAComboBox->currentText().contains("Manual");
2424 enableWidget(enable3, _serialHeightNMEALineEdit);
2425 enableWidget(enable3, _serialManualNMEASamplingSpinBox);
2426 }
2427
2428 // Outages
2429 // -------
2430 if (sender() == 0 || sender() == _adviseObsRateComboBox) {
2431 enable = !_adviseObsRateComboBox->currentText().isEmpty();
2432 enableWidget(enable, _adviseFailSpinBox);
2433 enableWidget(enable, _adviseRecoSpinBox);
2434 enableWidget(enable, _adviseScriptLineEdit);
2435 }
2436
2437 // Miscellaneous
2438 // -------------
2439 if (sender() == 0 || sender() == _miscMountLineEdit) {
2440 enable = !_miscMountLineEdit->text().isEmpty();
2441 enableWidget(enable, _miscIntrComboBox);
2442 enableWidget(enable, _miscScanRTCMCheckBox);
2443 enableWidget(enable, _miscPortLineEdit);
2444 }
2445
2446 // Enable/disable Broadcast Ephemerides
2447 // ------------------------------------
2448 if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2449 enable = !_uploadEphHostLineEdit->text().isEmpty();
2450 enableWidget(enable, _uploadEphPortLineEdit);
2451 enableWidget(enable, _uploadEphMountpointLineEdit);
2452 enableWidget(enable, _uploadEphPasswordLineEdit);
2453 enableWidget(enable, _uploadEphSampleSpinBox);
2454 }
2455
2456 // Combine Corrections
2457 // -------------------
2458 if (sender() == 0 || sender() == _cmbTable) {
2459 int iRow = _cmbTable->rowCount();
2460 if (iRow > 0) {
2461 enableWidget(true, _cmbMethodComboBox);
2462 enableWidget(true, _cmbMaxresLineEdit);
2463 enableWidget(true, _cmbSamplSpinBox);
2464 enableWidget(true, _cmbUseGlonass);
2465 }
2466 else {
2467 enableWidget(false, _cmbMethodComboBox);
2468 enableWidget(false, _cmbMaxresLineEdit);
2469 enableWidget(false, _cmbSamplSpinBox);
2470 enableWidget(false, _cmbUseGlonass);
2471 }
2472 }
2473
2474 // Upload(clk)
2475 // -----------
2476 int iRow = _uploadTable->rowCount();
2477 if (iRow > 0) {
2478 enableWidget(true, _uploadIntrComboBox);
2479 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2480 enableWidget(true, _uploadSamplClkRnxSpinBox);
2481 enableWidget(true, _uploadSamplSp3SpinBox);
2482 enableWidget(true, _uploadAntexFile);
2483 }
2484 else {
2485 enableWidget(false, _uploadIntrComboBox);
2486 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2487 enableWidget(false, _uploadSamplClkRnxSpinBox);
2488 enableWidget(false, _uploadSamplSp3SpinBox);
2489 enableWidget(false, _uploadAntexFile);
2490 }
2491
2492 // QC
2493 // --
2494 if (sender() == 0 || sender() == _reqcActionComboBox || sender() == _reqcSkyPlotSignals) {
2495 enable = !_reqcActionComboBox->currentText().isEmpty();
2496 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2497// bool enablePlot = !_reqcSkyPlotSignals->text().isEmpty();
2498 enableWidget(enable, _reqcObsFileChooser);
2499 enableWidget(enable, _reqcNavFileChooser);
2500 enableWidget(enable, _reqcOutLogLineEdit);
2501 enableWidget(enable && enable10, _reqcEditOptionButton);
2502 enableWidget(enable && enable10, _reqcOutObsLineEdit);
2503 enableWidget(enable && enable10, _reqcOutNavLineEdit);
2504 enableWidget(enable && !enable10, _reqcLogSummaryOnly);
2505 enableWidget(enable && !enable10, _reqcSkyPlotSignals);
2506// enableWidget(enable && !enable10 && enablePlot, _reqcPlotDirLineEdit);
2507 enableWidget(enable && !enable10, _reqcPlotDirLineEdit);
2508 }
2509
2510 // SP3 File Comparison
2511 // -------------------
2512 if (sender() == 0 || sender() == _sp3CompFileChooser) {
2513 enable = !_sp3CompFileChooser->fileName().isEmpty();
2514 enableWidget(enable, _sp3CompLogLineEdit);
2515 enableWidget(enable, _sp3CompExclude);
2516 }
2517
2518 enableStartStop();
2519}
2520
2521//
2522////////////////////////////////////////////////////////////////////////////
2523void bncWindow::slotAddCmbRow() {
2524 int iRow = _cmbTable->rowCount();
2525 _cmbTable->insertRow(iRow);
2526 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2527 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2528 }
2529}
2530
2531//
2532////////////////////////////////////////////////////////////////////////////
2533void bncWindow::slotDelCmbRow() {
2534
2535 const static QPalette paletteWhite(QColor(255, 255, 255));
2536 const static QPalette paletteGray(QColor(230, 230, 230));
2537
2538 int nRows = _cmbTable->rowCount();
2539 bool flg[nRows];
2540 for (int iRow = 0; iRow < nRows; iRow++) {
2541 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2542 flg[iRow] = true;
2543 }
2544 else {
2545 flg[iRow] = false;
2546 }
2547 }
2548 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2549 if (flg[iRow]) {
2550 _cmbTable->removeRow(iRow);
2551 }
2552 }
2553 nRows = _cmbTable->rowCount();
2554 if (nRows < 1) {
2555 enableWidget(false, _cmbMethodComboBox);
2556 enableWidget(false, _cmbMaxresLineEdit);
2557 enableWidget(false, _cmbSamplSpinBox);
2558 enableWidget(false, _cmbUseGlonass);
2559 }
2560}
2561
2562//
2563////////////////////////////////////////////////////////////////////////////
2564void bncWindow::populateCmbTable() {
2565
2566 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2567 _cmbTable->removeRow(iRow);
2568 }
2569
2570 bncSettings settings;
2571
2572 int iRow = -1;
2573 QListIterator<QString> it(settings.value("cmbStreams").toStringList());
2574 while (it.hasNext()) {
2575 QStringList hlp = it.next().split(" ");
2576 if (hlp.size() > 2) {
2577 ++iRow;
2578 _cmbTable->insertRow(iRow);
2579 }
2580 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2581 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2582 }
2583 }
2584}
2585
2586//
2587////////////////////////////////////////////////////////////////////////////
2588void bncWindow::slotAddUploadRow() {
2589 int iRow = _uploadTable->rowCount();
2590 _uploadTable->insertRow(iRow);
2591 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2592 if (iCol == 3) {
2593 QLineEdit* passwd = new QLineEdit();
2594 passwd->setFrame(false);
2595 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2596 _uploadTable->setCellWidget(iRow, iCol, passwd);
2597 }
2598 else if (iCol == 4) {
2599 QComboBox* system = new QComboBox();
2600 system->setEditable(false);
2601 system->addItems(QString("IGS14,ETRF2000,GDA2020,SIRGAS2000,DREF91,Custom").split(","));
2602 system->setFrame(false);
2603 _uploadTable->setCellWidget(iRow, iCol, system);
2604 }
2605 else if (iCol == 5) {
2606 QComboBox* format = new QComboBox();
2607 format->setEditable(false);
2608 format->addItems(QString("IGS-SSR,RTCM-SSR").split(","));
2609 format->setFrame(false);
2610 _uploadTable->setCellWidget(iRow, iCol, format);
2611 }
2612 else if (iCol == 6) {
2613 QCheckBox* com = new QCheckBox();
2614 _uploadTable->setCellWidget(iRow, iCol, com);
2615 }
2616 else if (iCol == 12) {
2617 bncTableItem* bncIt = new bncTableItem();
2618 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2619 _uploadTable->setItem(iRow, iCol, bncIt);
2620 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2621 }
2622 else {
2623 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2624 }
2625 }
2626}
2627
2628//
2629////////////////////////////////////////////////////////////////////////////
2630void bncWindow::slotDelUploadRow() {
2631 BNC_CORE->_uploadTableItems.clear();
2632 int nRows = _uploadTable->rowCount();
2633 bool flg[nRows];
2634 for (int iRow = 0; iRow < nRows; iRow++) {
2635 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2636 flg[iRow] = true;
2637 }
2638 else {
2639 flg[iRow] = false;
2640 }
2641 }
2642 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2643 if (flg[iRow]) {
2644 _uploadTable->removeRow(iRow);
2645 }
2646 }
2647 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2648 BNC_CORE->_uploadTableItems[iRow] =
2649 (bncTableItem*) _uploadTable->item(iRow, 12);
2650 }
2651 nRows = _uploadTable->rowCount();
2652 if (nRows < 1) {
2653 enableWidget(false, _uploadIntrComboBox);
2654 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2655 enableWidget(false, _uploadSamplSp3SpinBox);
2656 enableWidget(false, _uploadSamplClkRnxSpinBox);
2657 enableWidget(false, _uploadAntexFile);
2658 }
2659}
2660
2661//
2662////////////////////////////////////////////////////////////////////////////
2663void bncWindow::populateUploadTable() {
2664 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2665 _uploadTable->removeRow(iRow);
2666 }
2667
2668 bncSettings settings;
2669
2670 int iRow = -1;
2671 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2672 while (it.hasNext()) {
2673 QStringList hlp = it.next().split(",");
2674 if (hlp.size() > 6) {
2675 ++iRow;
2676 _uploadTable->insertRow(iRow);
2677 }
2678 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2679 if (iCol == 3) {
2680 QLineEdit* passwd = new QLineEdit();
2681 passwd->setFrame(false);
2682 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2683 passwd->setText(hlp[iCol]);
2684 _uploadTable->setCellWidget(iRow, iCol, passwd);
2685 }
2686 else if (iCol == 4) {
2687 QComboBox* system = new QComboBox();
2688 system->setEditable(false);
2689 system->addItems(QString("IGS14,ETRF2000,GDA2020,SIRGAS2000,DREF91,Custom").split(","));
2690 system->setFrame(false);
2691 system->setCurrentIndex(system->findText(hlp[iCol]));
2692 _uploadTable->setCellWidget(iRow, iCol, system);
2693 }
2694 else if (iCol == 5) {
2695 QComboBox* format = new QComboBox();
2696 format->setEditable(false);
2697 format->addItems(QString("IGS-SSR,RTCM-SSR").split(","));
2698 format->setFrame(false);
2699 format->setCurrentIndex(format->findText(hlp[iCol]));
2700 _uploadTable->setCellWidget(iRow, iCol, format);
2701 }
2702 else if (iCol == 6) {
2703 QCheckBox* com = new QCheckBox();
2704 if (hlp[iCol].toInt() == Qt::Checked) {
2705 com->setCheckState(Qt::Checked);
2706 }
2707 _uploadTable->setCellWidget(iRow, iCol, com);
2708 }
2709 else if (iCol == 12) {
2710 bncTableItem* bncIt = new bncTableItem();
2711 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2712 _uploadTable->setItem(iRow, iCol, bncIt);
2713 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2714 }
2715 else {
2716 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2717 }
2718 }
2719 }
2720}
2721
2722//
2723////////////////////////////////////////////////////////////////////////////
2724void bncWindow::slotSetUploadTrafo() {
2725 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2726 dlg->exec();
2727 delete dlg;
2728}
2729
2730// Progress Bar Change
2731////////////////////////////////////////////////////////////////////////////
2732void bncWindow::slotPostProcessingProgress(int nEpo) {
2733 _actStart->setText(QString("%1 Epochs").arg(nEpo));
2734}
2735
2736// Post-Processing Reqc Finished
2737////////////////////////////////////////////////////////////////////////////
2738void bncWindow::slotPostProcessingFinished() {
2739 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
2740 _runningPPP = false;
2741 _runningEdit = false;
2742 _runningQC = false;
2743 _runningSp3Comp = false;
2744 _actStart->setText(tr("Sta&rt"));
2745 enableStartStop();
2746}
2747
2748// Edit teqc-like editing options
2749////////////////////////////////////////////////////////////////////////////
2750void bncWindow::slotReqcEditOption() {
2751 saveOptions();
2752 reqcDlg* dlg = new reqcDlg(this);
2753 dlg->move(this->pos().x()+50, this->pos().y()+50);
2754 dlg->exec();
2755 delete dlg;
2756}
2757
2758// Enable/Disable Start and Stop Buttons
2759////////////////////////////////////////////////////////////////////////////
2760void bncWindow::enableStartStop() {
2761 if ( running() ) {
2762 _actStart->setEnabled(false);
2763 if (_runningRealTime || _runningPPP) {
2764 _actStop->setEnabled(true);
2765 }
2766 }
2767 else {
2768 _actStart->setEnabled(true);
2769 _actStop->setEnabled(false);
2770 }
2771}
2772
2773// Show Map
2774////////////////////////////////////////////////////////////////////////////
2775void bncWindow::slotMapMountPoints() {
2776 saveOptions();
2777 t_bncMap* bncMap = new t_bncMap(this);
2778 bncMap->setMinimumSize(800, 600);
2779 bncMap->setWindowTitle("Selected Mountpoints");
2780
2781 bncSettings settings;
2782 QListIterator<QString> it(settings.value("mountPoints").toStringList());
2783 while (it.hasNext()) {
2784 QStringList hlp = it.next().split(" ");
2785 if (hlp.size() < 5) continue;
2786 QUrl url(hlp[0]);
2787 double latDeg = hlp[3].toDouble();
2788 double lonDeg = hlp[4].toDouble();
2789 bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
2790 }
2791
2792 bncMap->show();
2793}
2794
2795// Show Map
2796////////////////////////////////////////////////////////////////////////////
2797void bncWindow::slotMapPPP() {
2798#ifdef QT_WEBKIT
2799 saveOptions();
2800 enableWidget(false, _pppWidgets._mapWinButton);
2801 enableWidget(false, _pppWidgets._useGoogleMap);
2802 enableWidget(false, _pppWidgets._useOpenStreetMap);
2803 enableWidget(false, _pppWidgets._mapWinDotSize);
2804 enableWidget(false, _pppWidgets._mapWinDotColor);
2805
2806 if (!_mapWin) {
2807 _mapWin = new bncMapWin(this);
2808 connect(_mapWin, SIGNAL(mapClosed()), this, SLOT(slotMapPPPClosed()));
2809 connect(BNC_CORE, SIGNAL(newPosition(QByteArray, bncTime, QVector<double>)),
2810 _mapWin, SLOT(slotNewPosition(QByteArray, bncTime, QVector<double>)));
2811 }
2812 _mapWin->show();
2813#else
2814 QMessageBox::information(this, "Information",
2815 "Qt Library compiled without QtWebKit");
2816#endif
2817}
2818
2819// Show Map
2820////////////////////////////////////////////////////////////////////////////
2821void bncWindow::slotMapPPPClosed() {
2822#ifdef QT_WEBKIT
2823 enableWidget(true, _pppWidgets._mapWinButton);
2824 enableWidget(true, _pppWidgets._useGoogleMap);
2825 enableWidget(true, _pppWidgets._useOpenStreetMap);
2826 enableWidget(true, _pppWidgets._mapWinDotSize);
2827 enableWidget(true, _pppWidgets._mapWinDotColor);
2828 if (_mapWin) {
2829 QListIterator<bncGetThread*> it(_threads);
2830 while (it.hasNext()) {
2831 bncGetThread* thread = it.next();
2832 thread->disconnect(_mapWin);
2833 }
2834 _mapWin->deleteLater();
2835 _mapWin = 0;
2836 }
2837#endif
2838}
Note: See TracBrowser for help on using the repository browser.