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

Last change on this file since 7961 was 7961, checked in by stuerze, 8 years ago

the possibility to load an ocean loading file is added in GUI for internal use

File size: 154.2 KB
Line 
1// Part of BNC, a utility for retrieving decoding and
2// converting GNSS data streams from NTRIP broadcasters.
3//
4// Copyright (C) 2007
5// German Federal Agency for Cartography and Geodesy (BKG)
6// http://www.bkg.bund.de
7// Czech Technical University Prague, Department of Geodesy
8// http://www.fsv.cvut.cz
9//
10// Email: euref-ip@bkg.bund.de
11//
12// This program is free software; you can redistribute it and/or
13// modify it under the terms of the GNU General Public License
14// as published by the Free Software Foundation, version 2.
15//
16// This program is distributed in the hope that it will be useful,
17// but WITHOUT ANY WARRANTY; without even the implied warranty of
18// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19// GNU General Public License for more details.
20//
21// You should have received a copy of the GNU General Public License
22// along with this program; if not, write to the Free Software
23// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24
25/* -------------------------------------------------------------------------
26 * BKG NTRIP Client
27 * -------------------------------------------------------------------------
28 *
29 * Class: bncWindow
30 *
31 * Purpose: This class implements the main application window.
32 *
33 * Author: L. Mervart
34 *
35 * Created: 24-Dec-2005
36 *
37 * Changes:
38 *
39 * -----------------------------------------------------------------------*/
40
41#include <iostream>
42
43#include <unistd.h>
44#include "bncwindow.h"
45#include "bnccore.h"
46#include "bncgetthread.h"
47#include "bnctabledlg.h"
48#include "bncipport.h"
49#include "bncudpport.h"
50#include "bncserialport.h"
51#include "bnchlpdlg.h"
52#include "bnchtml.h"
53#include "bnctableitem.h"
54#include "bncsettings.h"
55#include "bncfigure.h"
56#include "bncfigurelate.h"
57#include "bncfigureppp.h"
58#include "bncversion.h"
59#include "bncbytescounter.h"
60#include "bncsslconfig.h"
61#include "upload/bnccustomtrafo.h"
62#include "upload/bncephuploadcaster.h"
63#include "qtfilechooser.h"
64#include "reqcdlg.h"
65#include "bncmap.h"
66#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("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 _rnxSamplSpinBox = new QSpinBox();
209 _rnxSamplSpinBox->setMinimum(0);
210 _rnxSamplSpinBox->setMaximum(60);
211 _rnxSamplSpinBox->setSingleStep(5);
212 _rnxSamplSpinBox->setValue(settings.value("rnxSampl").toInt());
213 _rnxFileCheckBox = new QCheckBox();
214 _rnxFileCheckBox->setCheckState(Qt::CheckState(settings.value("rnxOnlyWithSKL").toInt()));
215 _rnxSamplSpinBox->setSuffix(" sec");
216 _rnxSkelLineEdit = new QLineEdit(settings.value("rnxSkel").toString());
217 _rnxSkelLineEdit->setMaximumWidth(5*ww);
218 _rnxScrpLineEdit = new QLineEdit(settings.value("rnxScript").toString());
219 _rnxV3CheckBox = new QCheckBox();
220 _rnxV3CheckBox->setCheckState(Qt::CheckState(settings.value("rnxV3").toInt()));
221 _rnxV3filenameCheckBox = new QCheckBox();
222 _rnxV3filenameCheckBox->setCheckState(Qt::CheckState(settings.value("rnxV3filenames").toInt()));
223 QString hlp = settings.value("rnxV2Priority").toString();
224 if (hlp.isEmpty()) {
225 hlp = "CWPX_?";
226 }
227 _rnxV2Priority = new QLineEdit(hlp);
228
229 connect(_rnxPathLineEdit, SIGNAL(textChanged(const QString &)),
230 this, SLOT(slotBncTextChanged()));
231 connect(_rnxV3CheckBox, SIGNAL(stateChanged(int)),
232 this, SLOT(slotBncTextChanged()));
233
234 // RINEX Ephemeris Options
235 // -----------------------
236 _ephPathLineEdit = new QLineEdit(settings.value("ephPath").toString());
237 _ephIntrComboBox = new QComboBox();
238 _ephIntrComboBox->setEditable(false);
239 _ephIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
240 int jj = _ephIntrComboBox->findText(settings.value("ephIntr").toString());
241 if (jj != -1) {
242 _ephIntrComboBox->setCurrentIndex(jj);
243 }
244 _ephOutPortLineEdit = new QLineEdit(settings.value("ephOutPort").toString());
245 _ephV3CheckBox = new QCheckBox();
246 _ephV3CheckBox->setCheckState(Qt::CheckState(settings.value("ephV3").toInt()));
247
248 _ephV3filenameCheckBox = new QCheckBox();
249 _ephV3filenameCheckBox->setCheckState(Qt::CheckState(settings.value("ephV3filenames").toInt()));
250
251 connect(_ephOutPortLineEdit, SIGNAL(textChanged(const QString &)),
252 this, SLOT(slotBncTextChanged()));
253
254 connect(_ephPathLineEdit, SIGNAL(textChanged(const QString &)),
255 this, SLOT(slotBncTextChanged()));
256
257 // Broadcast Corrections Options
258 // -----------------------------
259 _corrPathLineEdit = new QLineEdit(settings.value("corrPath").toString());
260 _corrIntrComboBox = new QComboBox();
261 _corrIntrComboBox->setEditable(false);
262 _corrIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
263 int mm = _corrIntrComboBox->findText(settings.value("corrIntr").toString());
264 if (mm != -1) {
265 _corrIntrComboBox->setCurrentIndex(mm);
266 }
267 _corrPortLineEdit = new QLineEdit(settings.value("corrPort").toString());
268
269 connect(_corrPathLineEdit, SIGNAL(textChanged(const QString &)),
270 this, SLOT(slotBncTextChanged()));
271
272 connect(_corrPortLineEdit, SIGNAL(textChanged(const QString &)),
273 this, SLOT(slotBncTextChanged()));
274
275 // Feed Engine Options
276 // -------------------
277 _outPortLineEdit = new QLineEdit(settings.value("outPort").toString());
278 _outWaitSpinBox = new QSpinBox();
279 _outWaitSpinBox->setMinimum(1);
280 _outWaitSpinBox->setMaximum(30);
281 _outWaitSpinBox->setSingleStep(1);
282 _outWaitSpinBox->setSuffix(" sec");
283 _outWaitSpinBox->setValue(settings.value("outWait").toInt());
284 _outSamplSpinBox = new QSpinBox();
285 _outSamplSpinBox->setMinimum(0);
286 _outSamplSpinBox->setMaximum(60);
287 _outSamplSpinBox->setSingleStep(5);
288 _outSamplSpinBox->setValue(settings.value("outSampl").toInt());
289 _outSamplSpinBox->setSuffix(" sec");
290 _outFileLineEdit = new QLineEdit(settings.value("outFile").toString());
291 _outUPortLineEdit = new QLineEdit(settings.value("outUPort").toString());
292
293 connect(_outPortLineEdit, SIGNAL(textChanged(const QString &)),
294 this, SLOT(slotBncTextChanged()));
295
296 connect(_outFileLineEdit, SIGNAL(textChanged(const QString &)),
297 this, SLOT(slotBncTextChanged()));
298
299 // Serial Output Options
300 // ---------------------
301 _serialMountPointLineEdit = new QLineEdit(settings.value("serialMountPoint").toString());
302 _serialPortNameLineEdit = new QLineEdit(settings.value("serialPortName").toString());
303 _serialBaudRateComboBox = new QComboBox();
304 _serialBaudRateComboBox->addItems(QString("110,300,600,"
305 "1200,2400,4800,9600,19200,38400,57600,115200").split(","));
306 int kk = _serialBaudRateComboBox->findText(settings.value("serialBaudRate").toString());
307 if (kk != -1) {
308 _serialBaudRateComboBox->setCurrentIndex(kk);
309 }
310 _serialFlowControlComboBox = new QComboBox();
311 _serialFlowControlComboBox->addItems(QString("OFF,XONXOFF,HARDWARE").split(","));
312 kk = _serialFlowControlComboBox->findText(settings.value("serialFlowControl").toString());
313 if (kk != -1) {
314 _serialFlowControlComboBox->setCurrentIndex(kk);
315 }
316 _serialDataBitsComboBox = new QComboBox();
317 _serialDataBitsComboBox->addItems(QString("5,6,7,8").split(","));
318 kk = _serialDataBitsComboBox->findText(settings.value("serialDataBits").toString());
319 if (kk != -1) {
320 _serialDataBitsComboBox->setCurrentIndex(kk);
321 }
322 _serialParityComboBox = new QComboBox();
323 _serialParityComboBox->addItems(QString("NONE,ODD,EVEN,SPACE").split(","));
324 kk = _serialParityComboBox->findText(settings.value("serialParity").toString());
325 if (kk != -1) {
326 _serialParityComboBox->setCurrentIndex(kk);
327 }
328 _serialStopBitsComboBox = new QComboBox();
329 _serialStopBitsComboBox->addItems(QString("1,2").split(","));
330 kk = _serialStopBitsComboBox->findText(settings.value("serialStopBits").toString());
331 if (kk != -1) {
332 _serialStopBitsComboBox->setCurrentIndex(kk);
333 }
334 _serialAutoNMEAComboBox = new QComboBox();
335 _serialAutoNMEAComboBox->addItems(QString("no,Auto,Manual GPGGA,Manual GNGGA").split(","));
336 kk = _serialAutoNMEAComboBox->findText(settings.value("serialAutoNMEA").toString());
337 if (kk != -1) {
338 _serialAutoNMEAComboBox->setCurrentIndex(kk);
339 }
340 _serialFileNMEALineEdit = new QLineEdit(settings.value("serialFileNMEA").toString());
341 _serialHeightNMEALineEdit = new QLineEdit(settings.value("serialHeightNMEA").toString());
342
343 _serialManualNMEASamplingSpinBox = new QSpinBox();
344 _serialManualNMEASamplingSpinBox->setMinimum(0);
345 _serialManualNMEASamplingSpinBox->setMaximum(300);
346 _serialManualNMEASamplingSpinBox->setSingleStep(10);
347 _serialManualNMEASamplingSpinBox->setValue(settings.value("serialManualNMEASampling").toInt());
348 _serialManualNMEASamplingSpinBox->setSuffix(" sec");
349
350 connect(_serialMountPointLineEdit, SIGNAL(textChanged(const QString &)),
351 this, SLOT(slotBncTextChanged()));
352
353 connect(_serialAutoNMEAComboBox, SIGNAL(currentIndexChanged(const QString &)),
354 this, SLOT(slotBncTextChanged()));
355
356 // Outages Options
357 // ---------------
358 _adviseObsRateComboBox = new QComboBox();
359 _adviseObsRateComboBox->setEditable(false);
360 _adviseObsRateComboBox->addItems(QString(",0.1 Hz,0.2 Hz,0.5 Hz,1 Hz,5 Hz").split(","));
361 kk = _adviseObsRateComboBox->findText(settings.value("adviseObsRate").toString());
362 if (kk != -1) {
363 _adviseObsRateComboBox->setCurrentIndex(kk);
364 }
365 _adviseFailSpinBox = new QSpinBox();
366 _adviseFailSpinBox->setMinimum(0);
367 _adviseFailSpinBox->setMaximum(60);
368 _adviseFailSpinBox->setSingleStep(1);
369 _adviseFailSpinBox->setSuffix(" min");
370 _adviseFailSpinBox->setValue(settings.value("adviseFail").toInt());
371 _adviseRecoSpinBox = new QSpinBox();
372 _adviseRecoSpinBox->setMinimum(0);
373 _adviseRecoSpinBox->setMaximum(60);
374 _adviseRecoSpinBox->setSingleStep(1);
375 _adviseRecoSpinBox->setSuffix(" min");
376 _adviseRecoSpinBox->setValue(settings.value("adviseReco").toInt());
377 _adviseScriptLineEdit = new QLineEdit(settings.value("adviseScript").toString());
378
379 connect(_adviseObsRateComboBox, SIGNAL(currentIndexChanged(const QString &)),
380 this, SLOT(slotBncTextChanged()));
381
382 // Miscellaneous Options
383 // ---------------------
384 _miscMountLineEdit = new QLineEdit(settings.value("miscMount").toString());
385 _miscPortLineEdit = new QLineEdit(settings.value("miscPort").toString());
386 _miscIntrComboBox = new QComboBox();
387 _miscIntrComboBox->setEditable(false);
388 _miscIntrComboBox->addItems(QString(",2 sec,10 sec,1 min,5 min,15 min,1 hour,6 hours,1 day").split(","));
389 int ll = _miscIntrComboBox->findText(settings.value("miscIntr").toString());
390 if (ll != -1) {
391 _miscIntrComboBox->setCurrentIndex(ll);
392 }
393 _miscScanRTCMCheckBox = new QCheckBox();
394 _miscScanRTCMCheckBox->setCheckState(Qt::CheckState(
395 settings.value("miscScanRTCM").toInt()));
396
397 connect(_miscMountLineEdit, SIGNAL(textChanged(const QString &)),
398 this, SLOT(slotBncTextChanged()));
399
400 // Streams
401 // -------
402 _mountPointsTable = new QTableWidget(0,9);
403
404 _mountPointsTable->horizontalHeader()->resizeSection(1,34*ww);
405 _mountPointsTable->horizontalHeader()->resizeSection(2,9*ww);
406 _mountPointsTable->horizontalHeader()->resizeSection(3,9*ww);
407 _mountPointsTable->horizontalHeader()->resizeSection(4,7*ww);
408 _mountPointsTable->horizontalHeader()->resizeSection(5,7*ww);
409 _mountPointsTable->horizontalHeader()->resizeSection(6,5*ww);
410 _mountPointsTable->horizontalHeader()->resizeSection(7,5*ww);
411 _mountPointsTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
412 _mountPointsTable->horizontalHeader()->setStretchLastSection(true);
413 _mountPointsTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
414 _mountPointsTable->setHorizontalHeaderLabels(labels);
415 _mountPointsTable->setGridStyle(Qt::NoPen);
416 _mountPointsTable->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
417 _mountPointsTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
418 _mountPointsTable->setSelectionBehavior(QAbstractItemView::SelectRows);
419 _mountPointsTable->hideColumn(0);
420 _mountPointsTable->hideColumn(3);
421 connect(_mountPointsTable, SIGNAL(itemSelectionChanged()),
422 SLOT(slotSelectionChanged()));
423 populateMountPointsTable();
424
425 _log = new QTextEdit();
426 _log->setReadOnly(true);
427 QFont msFont(""); msFont.setStyleHint(QFont::TypeWriter); // default monospace font
428 _log->setFont(msFont);
429 _log->document()->setMaximumBlockCount(1000);
430
431 // Combine Corrections
432 // -------------------
433 _cmbTable = new QTableWidget(0,3);
434 _cmbTable->setHorizontalHeaderLabels(QString("Mountpoint, AC Name, Weight").split(","));
435 _cmbTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
436 _cmbTable->setSelectionBehavior(QAbstractItemView::SelectRows);
437 _cmbTable->setMaximumWidth(30*ww);
438 _cmbTable->horizontalHeader()->resizeSection(0,10*ww);
439 _cmbTable->horizontalHeader()->resizeSection(1,8*ww);
440 _cmbTable->horizontalHeader()->resizeSection(2,8*ww);
441 _cmbTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
442 _cmbTable->horizontalHeader()->setStretchLastSection(true);
443 _cmbTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
444
445 _cmbMaxresLineEdit = new QLineEdit(settings.value("cmbMaxres").toString());
446 _cmbUseGlonass = new QCheckBox();
447 _cmbUseGlonass->setCheckState(Qt::CheckState(settings.value("cmbUseGlonass").toInt()));
448
449 _cmbSamplSpinBox = new QSpinBox;
450 _cmbSamplSpinBox->setMinimum(10);
451 _cmbSamplSpinBox->setMaximum(60);
452 _cmbSamplSpinBox->setSingleStep(10);
453 _cmbSamplSpinBox->setMaximumWidth(9*ww);
454 _cmbSamplSpinBox->setValue(settings.value("cmbSampl").toInt());
455 _cmbSamplSpinBox->setSuffix(" sec");
456
457 QPushButton* addCmbRowButton = new QPushButton("Add Row");
458 QPushButton* delCmbRowButton = new QPushButton("Delete");
459
460 connect(_cmbTable, SIGNAL(itemSelectionChanged()),
461 SLOT(slotBncTextChanged()));
462
463 _cmbMethodComboBox = new QComboBox();
464 _cmbMethodComboBox->setEditable(false);
465 _cmbMethodComboBox->addItems(QString("Filter,Single-Epoch").split(","));
466 int im = _cmbMethodComboBox->findText(settings.value("cmbMethod").toString());
467 if (im != -1) {
468 _cmbMethodComboBox->setCurrentIndex(im);
469 }
470
471 int iRow = _cmbTable->rowCount();
472 if (iRow > 0) {
473 enableWidget(true, _cmbMethodComboBox);
474 enableWidget(true, _cmbMaxresLineEdit);
475 enableWidget(true, _cmbSamplSpinBox);
476 enableWidget(true, _cmbUseGlonass);
477 }
478 else {
479 enableWidget(false, _cmbMethodComboBox);
480 enableWidget(false, _cmbMaxresLineEdit);
481 enableWidget(false, _cmbSamplSpinBox);
482 enableWidget(false, _cmbUseGlonass);
483 }
484
485 // Upload Results
486 // -------------
487 _uploadTable = new QTableWidget(0,12);
488 _uploadTable->setHorizontalHeaderLabels(QString("Host, Port, Mount, Password, System, CoM, SP3 File, RNX File, PID, SID, IOD, bytes").split(","));
489 _uploadTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
490 _uploadTable->setSelectionBehavior(QAbstractItemView::SelectRows);
491 _uploadTable->horizontalHeader()->resizeSection( 0,13*ww);
492 _uploadTable->horizontalHeader()->resizeSection( 1, 5*ww);
493 _uploadTable->horizontalHeader()->resizeSection( 2, 6*ww);
494 _uploadTable->horizontalHeader()->resizeSection( 3, 8*ww);
495 _uploadTable->horizontalHeader()->resizeSection( 4,11*ww);
496 _uploadTable->horizontalHeader()->resizeSection( 5, 4*ww);
497 _uploadTable->horizontalHeader()->resizeSection( 6,15*ww);
498 _uploadTable->horizontalHeader()->resizeSection( 7,15*ww);
499 _uploadTable->horizontalHeader()->resizeSection( 8, 4*ww);
500 _uploadTable->horizontalHeader()->resizeSection( 9, 4*ww);
501 _uploadTable->horizontalHeader()->resizeSection(10, 4*ww);
502 _uploadTable->horizontalHeader()->resizeSection(11,12*ww);
503 _uploadTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
504 _uploadTable->horizontalHeader()->setStretchLastSection(true);
505 _uploadTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
506
507 connect(_uploadTable, SIGNAL(itemSelectionChanged()),
508 SLOT(slotBncTextChanged()));
509
510 QPushButton* addUploadRowButton = new QPushButton("Add Row");
511 QPushButton* delUploadRowButton = new QPushButton("Del Row");
512 QPushButton* setUploadTrafoButton = new QPushButton("Custom Trafo");
513 _uploadIntrComboBox = new QComboBox;
514 _uploadIntrComboBox->setEditable(false);
515 _uploadIntrComboBox->addItems(QString("1 day,1 hour, 30 min,15 min,10 min,5 min,2 min,1 min").split(","));
516 ii = _uploadIntrComboBox->findText(settings.value("uploadIntr").toString());
517 if (ii != -1) {
518 _uploadIntrComboBox->setCurrentIndex(ii);
519 }
520
521 _uploadAntexFile = new qtFileChooser(0, qtFileChooser::File);
522 _uploadAntexFile->setFileName(settings.value("uploadAntexFile").toString());
523
524 _uploadSamplRtcmEphCorrSpinBox = new QSpinBox;
525 _uploadSamplRtcmEphCorrSpinBox->setMinimum(0);
526 _uploadSamplRtcmEphCorrSpinBox->setMaximum(60);
527 _uploadSamplRtcmEphCorrSpinBox->setSingleStep(5);
528 _uploadSamplRtcmEphCorrSpinBox->setMaximumWidth(9*ww);
529 _uploadSamplRtcmEphCorrSpinBox->setValue(settings.value("uploadSamplRtcmEphCorr").toInt());
530 _uploadSamplRtcmEphCorrSpinBox->setSuffix(" sec");
531
532 _uploadSamplSp3SpinBox = new QSpinBox;
533 _uploadSamplSp3SpinBox->setMinimum(0);
534 _uploadSamplSp3SpinBox->setMaximum(15);
535 _uploadSamplSp3SpinBox->setSingleStep(1);
536 _uploadSamplSp3SpinBox->setMaximumWidth(9*ww);
537 _uploadSamplSp3SpinBox->setValue(settings.value("uploadSamplSp3").toInt());
538 _uploadSamplSp3SpinBox->setSuffix(" min");
539
540 _uploadSamplClkRnxSpinBox = new QSpinBox;
541 _uploadSamplClkRnxSpinBox->setMinimum(0);
542 _uploadSamplClkRnxSpinBox->setMaximum(60);
543 _uploadSamplClkRnxSpinBox->setSingleStep(5);
544 _uploadSamplClkRnxSpinBox->setMaximumWidth(9*ww);
545 _uploadSamplClkRnxSpinBox->setValue(settings.value("uploadSamplClkRnx").toInt());
546 _uploadSamplClkRnxSpinBox->setSuffix(" sec");
547
548 int iRowT = _uploadTable->rowCount();
549 if (iRowT > 0) {
550 enableWidget(true, _uploadIntrComboBox);
551 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
552 enableWidget(true, _uploadSamplSp3SpinBox);
553 enableWidget(true, _uploadSamplClkRnxSpinBox);
554 enableWidget(true, _uploadAntexFile);
555 }
556 else {
557 enableWidget(false, _uploadIntrComboBox);
558 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
559 enableWidget(false, _uploadSamplSp3SpinBox);
560 enableWidget(false, _uploadSamplClkRnxSpinBox);
561 enableWidget(false, _uploadAntexFile);
562 }
563
564 // Upload RTCM3 Ephemeris
565 // ----------------------
566 _uploadEphTable = new QTableWidget(0,6);
567 _uploadEphTable->setColumnCount(6);
568 _uploadEphTable->setRowCount(0);
569 _uploadEphTable->setHorizontalHeaderLabels(QString("Host, Port, Mount, Password, System, bytes").split(","));
570 _uploadEphTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
571 _uploadEphTable->setSelectionBehavior(QAbstractItemView::SelectRows);
572 _uploadEphTable->horizontalHeader()->resizeSection( 0,13*ww);
573 _uploadEphTable->horizontalHeader()->resizeSection( 1, 5*ww);
574 _uploadEphTable->horizontalHeader()->resizeSection( 2, 8*ww);
575 _uploadEphTable->horizontalHeader()->resizeSection( 3, 8*ww);
576 _uploadEphTable->horizontalHeader()->resizeSection( 4,10*ww);
577 _uploadEphTable->horizontalHeader()->resizeSection( 5,12*ww);
578 _uploadEphTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
579 _uploadEphTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
580
581 connect(_uploadEphTable, SIGNAL(itemSelectionChanged()),
582 SLOT(slotBncTextChanged()));
583
584 QPushButton* addUploadEphRowButton = new QPushButton("Add Row");
585 addUploadEphRowButton->setMaximumWidth(9*ww);
586 QPushButton* delUploadEphRowButton = new QPushButton("Del Row");
587 delUploadEphRowButton->setMaximumWidth(9*ww);
588
589 _uploadSamplRtcmEphSpinBox = new QSpinBox;
590 _uploadSamplRtcmEphSpinBox->setMinimum(0);
591 _uploadSamplRtcmEphSpinBox->setMaximum(60);
592 _uploadSamplRtcmEphSpinBox->setSingleStep(5);
593 _uploadSamplRtcmEphSpinBox->setMaximumWidth(9*ww);
594 _uploadSamplRtcmEphSpinBox->setValue(settings.value("uploadSamplRtcmEph").toInt());
595 _uploadSamplRtcmEphSpinBox->setSuffix(" sec");
596
597 iRowT = _uploadEphTable->rowCount();
598 if (iRowT > 0) {
599 enableWidget(true, _uploadSamplRtcmEphSpinBox);
600 }
601 else {
602 enableWidget(false, _uploadSamplRtcmEphSpinBox);
603 }
604
605 // Canvas with Editable Fields
606 // ---------------------------
607 _canvas = new QWidget;
608 setCentralWidget(_canvas);
609
610 _aogroup = new QTabWidget();
611 _aogroup->setElideMode(Qt::ElideNone);
612 _aogroup->setUsesScrollButtons(true);
613 QWidget* pgroup = new QWidget();
614 QWidget* ggroup = new QWidget();
615 QWidget* sgroup = new QWidget();
616 QWidget* egroup = new QWidget();
617 QWidget* agroup = new QWidget();
618 QWidget* cgroup = new QWidget();
619 QWidget* ogroup = new QWidget();
620 QWidget* rgroup = new QWidget();
621 QWidget* sergroup = new QWidget();
622 QWidget* pppGroup1 = new QWidget();
623 QWidget* pppGroup2 = new QWidget();
624 QWidget* pppGroup3 = new QWidget();
625 QWidget* pppGroup4 = new QWidget();
626 QWidget* reqcgroup = new QWidget();
627 QWidget* sp3CompGroup = new QWidget();
628 QWidget* cmbgroup = new QWidget();
629 QWidget* uploadgroup = new QWidget();
630 QWidget* uploadEphgroup = new QWidget();
631 _aogroup->addTab(pgroup,tr("Network"));
632 _aogroup->addTab(ggroup,tr("General"));
633 _aogroup->addTab(ogroup,tr("RINEX Observations"));
634 _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
635 _aogroup->addTab(reqcgroup,tr("RINEX Editing && QC"));
636 _aogroup->addTab(sp3CompGroup,tr("SP3 Comparison"));
637 _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
638 _aogroup->addTab(sgroup,tr("Feed Engine"));
639 _aogroup->addTab(sergroup,tr("Serial Output"));
640 _aogroup->addTab(agroup,tr("Outages"));
641 _aogroup->addTab(rgroup,tr("Miscellaneous"));
642 _aogroup->addTab(pppGroup1,tr("PPP (1)"));
643 _aogroup->addTab(pppGroup2,tr("PPP (2)"));
644 _aogroup->addTab(pppGroup3,tr("PPP (3)"));
645 _aogroup->addTab(pppGroup4,tr("PPP (4)"));
646 _aogroup->addTab(cmbgroup,tr("Combine Corrections"));
647 _aogroup->addTab(uploadgroup,tr("Upload Corrections"));
648 _aogroup->addTab(uploadEphgroup,tr("Upload Ephemeris"));
649
650 // Log Tab
651 // -------
652 _loggroup = new QTabWidget();
653 _loggroup->addTab(_log,tr("Log"));
654 _loggroup->addTab(_bncFigure,tr("Throughput"));
655 _loggroup->addTab(_bncFigureLate,tr("Latency"));
656 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
657
658 // Netowork (Proxy and SSL) Tab
659 // ----------------------------
660 QGridLayout* pLayout = new QGridLayout;
661 pLayout->setColumnMinimumWidth(0,13*ww);
662 _proxyPortLineEdit->setMaximumWidth(9*ww);
663
664 pLayout->addWidget(new QLabel("Settings for proxy in protected networks and for SSL authorization, leave boxes blank if none.<br>"),0, 0, 1, 50);
665 pLayout->addWidget(new QLabel("Proxy host"), 1, 0);
666 pLayout->addWidget(_proxyHostLineEdit, 1, 1, 1,10);
667 pLayout->addWidget(new QLabel("Proxy port"), 2, 0);
668 pLayout->addWidget(_proxyPortLineEdit, 2, 1);
669 pLayout->addWidget(new QLabel("Path to SSL certificates"), 3, 0);
670 pLayout->addWidget(_sslCaCertPathLineEdit, 3, 1, 1,10);
671 pLayout->addWidget(new QLabel("Default: " + bncSslConfig::defaultPath()), 3,11, 1,20);
672 pLayout->addWidget(new QLabel("Ignore SSL authorization errors"), 4, 0);
673 pLayout->addWidget(_sslIgnoreErrorsCheckBox, 4, 1, 1,10);
674 pLayout->addWidget(new QLabel(""), 5, 1);
675 pLayout->setRowStretch(6, 999);
676
677 pgroup->setLayout(pLayout);
678
679 // General Tab
680 // -----------
681 QGridLayout* gLayout = new QGridLayout;
682 gLayout->setColumnMinimumWidth(0,14*ww);
683 _onTheFlyComboBox->setMaximumWidth(9*ww);
684
685 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);
686 gLayout->addWidget(new QLabel("Logfile (full path)"), 1, 0);
687 gLayout->addWidget(_logFileLineEdit, 1, 1, 1,20);
688 gLayout->addWidget(new QLabel("Append files"), 2, 0);
689 gLayout->addWidget(_rnxAppendCheckBox, 2, 1);
690 gLayout->addWidget(new QLabel("Reread configuration"), 3, 0);
691 gLayout->addWidget(_onTheFlyComboBox, 3, 1);
692 gLayout->addWidget(new QLabel("Auto start"), 4, 0);
693 gLayout->addWidget(_autoStartCheckBox, 4, 1);
694 gLayout->addWidget(new QLabel("Raw output file (full path)"), 5, 0);
695 gLayout->addWidget(_rawOutFileLineEdit, 5, 1, 1,20);
696 gLayout->addWidget(new QLabel(""), 6, 1);
697 gLayout->setRowStretch(7, 999);
698
699 ggroup->setLayout(gLayout);
700
701 // RINEX Observations
702 // ------------------
703 QGridLayout* oLayout = new QGridLayout;
704 oLayout->setColumnMinimumWidth(0,14*ww);
705 _rnxIntrComboBox->setMaximumWidth(9*ww);
706 _rnxSamplSpinBox->setMaximumWidth(9*ww);
707
708 _rnxV2Priority->setMaximumWidth(19*ww);
709
710 oLayout->addWidget(new QLabel("Saving RINEX observation files.<br>"),0, 0, 1,50);
711 oLayout->addWidget(new QLabel("Directory"), 1, 0);
712 oLayout->addWidget(_rnxPathLineEdit, 1, 1, 1, 15);
713 oLayout->addWidget(new QLabel("Interval"), 2, 0);
714 oLayout->addWidget(_rnxIntrComboBox, 2, 1);
715 oLayout->addWidget(new QLabel(" Sampling"), 2, 2, Qt::AlignRight);
716 oLayout->addWidget(_rnxSamplSpinBox, 2, 3, Qt::AlignLeft);
717 oLayout->addWidget(new QLabel("Skeleton extension"), 3, 0);
718 oLayout->addWidget(_rnxSkelLineEdit, 3, 1, Qt::AlignLeft);
719 oLayout->addWidget(new QLabel("Skeleton mandatory"), 3, 2);
720 oLayout->addWidget(_rnxFileCheckBox, 3, 3);
721 oLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
722 oLayout->addWidget(_rnxScrpLineEdit, 4, 1, 1, 15);
723 oLayout->addWidget(new QLabel("Version 2"), 5, 0);
724 oLayout->addWidget(_rnxV2Priority, 5, 1);
725 oLayout->addWidget(new QLabel("Signal priority"), 5, 2);
726 oLayout->addWidget(new QLabel("Version 3"), 6, 0);
727 oLayout->addWidget(_rnxV3CheckBox, 6, 1);
728 oLayout->addWidget(new QLabel("Version 3 filenames"), 6, 2);
729 oLayout->addWidget(_rnxV3filenameCheckBox, 6, 3);
730 oLayout->addWidget(new QLabel(""), 7, 1);
731 oLayout->setRowStretch(8, 999);
732
733 ogroup->setLayout(oLayout);
734
735 // RINEX Ephemeris
736 // ---------------
737 QGridLayout* eLayout = new QGridLayout;
738 eLayout->setColumnMinimumWidth(0,14*ww);
739 _ephIntrComboBox->setMaximumWidth(9*ww);
740 _ephOutPortLineEdit->setMaximumWidth(9*ww);
741
742 eLayout->addWidget(new QLabel("Saving RINEX navigation files and ephemeris output through IP port.<br>"),0,0,1,70);
743 eLayout->addWidget(new QLabel("Directory"), 1, 0);
744 eLayout->addWidget(_ephPathLineEdit, 1, 1, 1,30);
745 eLayout->addWidget(new QLabel("Interval"), 2, 0);
746 eLayout->addWidget(_ephIntrComboBox, 2, 1);
747 eLayout->addWidget(new QLabel("Port"), 3, 0);
748 eLayout->addWidget(_ephOutPortLineEdit, 3, 1);
749 eLayout->addWidget(new QLabel("Version 3"), 4, 0);
750 eLayout->addWidget(_ephV3CheckBox, 4, 1);
751 eLayout->addWidget(new QLabel("Version 3 filenames"), 4, 2);
752 eLayout->addWidget(_ephV3filenameCheckBox, 4, 3);
753 eLayout->setRowStretch(5, 999);
754
755 egroup->setLayout(eLayout);
756
757
758 // Broadcast Corrections
759 // ---------------------
760 QGridLayout* cLayout = new QGridLayout;
761 cLayout->setColumnMinimumWidth(0,14*ww);
762 _corrIntrComboBox->setMaximumWidth(9*ww);
763 _corrPortLineEdit->setMaximumWidth(9*ww);
764
765 cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port.<br>"),0,0,1,70);
766 cLayout->addWidget(new QLabel("Directory, ASCII"), 1, 0);
767 cLayout->addWidget(_corrPathLineEdit, 1, 1, 1,30);
768 cLayout->addWidget(new QLabel("Interval"), 2, 0);
769 cLayout->addWidget(_corrIntrComboBox, 2, 1);
770 cLayout->addWidget(new QLabel("Port"), 3, 0);
771 cLayout->addWidget(_corrPortLineEdit, 3, 1);
772 cLayout->addWidget(new QLabel(""), 4, 1);
773 cLayout->setRowStretch(7, 999);
774 cgroup->setLayout(cLayout);
775
776 // Feed Engine
777 // -----------
778 QGridLayout* sLayout = new QGridLayout;
779 sLayout->setColumnMinimumWidth(0,14*ww);
780 _outPortLineEdit->setMaximumWidth(9*ww);
781 _outWaitSpinBox->setMaximumWidth(9*ww);
782 _outSamplSpinBox->setMaximumWidth(9*ww);
783 _outUPortLineEdit->setMaximumWidth(9*ww);
784
785 sLayout->addWidget(new QLabel("Output decoded observations in ASCII format to feed a real-time GNSS network engine.<br>"),0,0,1,50);
786 sLayout->addWidget(new QLabel("Port"), 1, 0);
787 sLayout->addWidget(_outPortLineEdit, 1, 1);
788 sLayout->addWidget(new QLabel(" Wait for full obs epoch"), 1, 2, Qt::AlignRight);
789 sLayout->addWidget(_outWaitSpinBox, 1, 3, Qt::AlignLeft);
790 sLayout->addWidget(new QLabel("Sampling"), 2, 0);
791 sLayout->addWidget(_outSamplSpinBox, 2, 1, Qt::AlignLeft);
792 sLayout->addWidget(new QLabel("File (full path)"), 3, 0);
793 sLayout->addWidget(_outFileLineEdit, 3, 1, 1, 10);
794 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 4, 0);
795 sLayout->addWidget(_outUPortLineEdit, 4, 1);
796 sLayout->addWidget(new QLabel(""), 5, 1);
797 sLayout->setRowStretch(6, 999);
798
799 sgroup->setLayout(sLayout);
800
801 // Serial Output
802 // -------------
803 QGridLayout* serLayout = new QGridLayout;
804 serLayout->setColumnMinimumWidth(0,12*ww);
805 _serialBaudRateComboBox->setMaximumWidth(9*ww);
806 _serialFlowControlComboBox->setMaximumWidth(11*ww);
807 _serialDataBitsComboBox->setMaximumWidth(5*ww);
808 _serialParityComboBox->setMaximumWidth(9*ww);
809 _serialStopBitsComboBox->setMaximumWidth(5*ww);
810 _serialAutoNMEAComboBox->setMaximumWidth(14*ww);
811 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
812 _serialManualNMEASamplingSpinBox->setMaximumWidth(8*ww);
813
814 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver.<br>"),0,0,1,30);
815 serLayout->addWidget(new QLabel("Mountpoint"), 1, 0, Qt::AlignLeft);
816 serLayout->addWidget(_serialMountPointLineEdit, 1, 1, 1, 2);
817 serLayout->addWidget(new QLabel("Port name"), 2, 0, Qt::AlignLeft);
818 serLayout->addWidget(_serialPortNameLineEdit, 2, 1, 1, 2);
819 serLayout->addWidget(new QLabel("Baud rate"), 3, 0, Qt::AlignLeft);
820 serLayout->addWidget(_serialBaudRateComboBox, 3, 1);
821 serLayout->addWidget(new QLabel("Flow control"), 3, 2, Qt::AlignRight);
822 serLayout->addWidget(_serialFlowControlComboBox, 3, 3);
823 serLayout->addWidget(new QLabel("Data bits"), 4, 0, Qt::AlignLeft);
824 serLayout->addWidget(_serialDataBitsComboBox, 4, 1);
825 serLayout->addWidget(new QLabel("Parity"), 4, 2, Qt::AlignRight);
826 serLayout->addWidget(_serialParityComboBox, 4, 3);
827 serLayout->addWidget(new QLabel(" Stop bits"), 4, 4, Qt::AlignRight);
828 serLayout->addWidget(_serialStopBitsComboBox, 4, 5);
829 serLayout->addWidget(new QLabel("NMEA"), 5, 0);
830 serLayout->addWidget(_serialAutoNMEAComboBox, 5, 1);
831 serLayout->addWidget(new QLabel(" File (full path)"), 5, 2, Qt::AlignRight);
832 serLayout->addWidget(_serialFileNMEALineEdit, 5, 3, 1,10);
833 serLayout->addWidget(new QLabel("Height"), 5,14, Qt::AlignRight);
834 serLayout->addWidget(_serialHeightNMEALineEdit, 5,15, 1,11);
835 serLayout->addWidget(new QLabel("Sampling"), 5,25, Qt::AlignRight);
836 serLayout->addWidget(_serialManualNMEASamplingSpinBox, 5,26, 1,12);
837 serLayout->addWidget(new QLabel(""), 6, 1);
838 serLayout->setRowStretch(7, 999);
839
840 sergroup->setLayout(serLayout);
841
842 // Outages
843 // -------
844 QGridLayout* aLayout = new QGridLayout;
845 aLayout->setColumnMinimumWidth(0,14*ww);
846 _adviseObsRateComboBox->setMaximumWidth(9*ww);
847 _adviseFailSpinBox->setMaximumWidth(9*ww);
848 _adviseRecoSpinBox->setMaximumWidth(9*ww);
849
850 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes.<br>"),0,0,1,50,Qt::AlignLeft);
851 aLayout->addWidget(new QLabel("Observation rate"), 1, 0);
852 aLayout->addWidget(_adviseObsRateComboBox, 1, 1);
853 aLayout->addWidget(new QLabel("Failure threshold"), 2, 0);
854 aLayout->addWidget(_adviseFailSpinBox, 2, 1);
855 aLayout->addWidget(new QLabel("Recovery threshold"), 3, 0);
856 aLayout->addWidget(_adviseRecoSpinBox, 3, 1);
857 aLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
858 aLayout->addWidget(_adviseScriptLineEdit, 4, 1, 1,20);
859 aLayout->addWidget(new QLabel(""), 5, 1);
860 aLayout->setRowStretch(6, 999);
861
862 agroup->setLayout(aLayout);
863
864 // Miscellaneous
865 // -------------
866 QGridLayout* rLayout = new QGridLayout;
867 rLayout->setColumnMinimumWidth(0,14*ww);
868 _miscIntrComboBox->setMaximumWidth(9*ww);
869 _miscPortLineEdit->setMaximumWidth(9*ww);
870
871 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);
872 rLayout->addWidget(new QLabel("Mountpoint"), 1, 0);
873 rLayout->addWidget(_miscMountLineEdit, 1, 1, 1, 7);
874 rLayout->addWidget(new QLabel("Log latency"), 2, 0);
875 rLayout->addWidget(_miscIntrComboBox, 2, 1);
876 rLayout->addWidget(new QLabel("Scan RTCM"), 3, 0);
877 rLayout->addWidget(_miscScanRTCMCheckBox, 3, 1);
878 rLayout->addWidget(new QLabel("Port"), 4, 0);
879 rLayout->addWidget(_miscPortLineEdit, 4, 1);
880 rLayout->addWidget(new QLabel(""), 5, 1);
881 rLayout->setRowStretch(6, 999);
882
883 rgroup->setLayout(rLayout);
884
885 // PPP
886 // ---
887 _pppWidgets._dataSource->setMaximumWidth(20*ww);
888 _pppWidgets._corrMount->setMaximumWidth(20*ww);
889
890 _pppWidgets._corrFile->setMaximumWidth(35*ww);
891 _pppWidgets._crdFile->setMaximumWidth(35*ww);
892 _pppWidgets._logPath->setMaximumWidth(35*ww);
893 _pppWidgets._snxtroPath->setMaximumWidth(35*ww);
894 _pppWidgets._snxtroIntr->setMaximumWidth(10*ww);
895 _pppWidgets._snxtroAc ->setMaximumWidth(10*ww);
896 _pppWidgets._snxtroSol ->setMaximumWidth(7*ww);
897
898 QGridLayout* pppLayout1 = new QGridLayout();
899 int ir = 0;
900 pppLayout1->addWidget(new QLabel("Precise Point Positioning - Input and Output."), ir, 0, 1, 7, Qt::AlignLeft);
901 ++ir;
902 pppLayout1->addWidget(new QLabel("Data source"), ir, 0);
903 pppLayout1->addWidget(_pppWidgets._dataSource, ir, 1);
904 pppLayout1->addWidget(new QLabel(" RINEX Obs file"), ir, 3);
905 pppLayout1->addWidget(_pppWidgets._rinexObs, ir, 4, 1, 3);
906 ++ir;
907 pppLayout1->addWidget(new QLabel("Corrections stream"), ir, 0);
908 pppLayout1->addWidget(_pppWidgets._corrMount, ir, 1);
909 pppLayout1->addWidget(new QLabel(" RINEX Nav file"), ir, 3);
910 pppLayout1->addWidget(_pppWidgets._rinexNav, ir, 4, 1, 3);
911 ++ir;
912 pppLayout1->addWidget(new QLabel("Corrections file"), ir, 0);
913 pppLayout1->addWidget(_pppWidgets._corrFile, ir, 1);
914 pppLayout1->addWidget(new QLabel(" ANTEX file"), ir, 3);
915 pppLayout1->addWidget(_pppWidgets._antexFile, ir, 4, 1, 3);
916 ++ir;
917 pppLayout1->addWidget(new QLabel("Coordinates file"), ir, 0);
918 pppLayout1->addWidget(_pppWidgets._crdFile, ir, 1);
919#ifdef USE_PPP
920 pppLayout1->addWidget(new QLabel(" BLQ file"), ir, 3);
921 pppLayout1->addWidget(_pppWidgets._blqFile, ir, 4, 1, 3);
922#endif
923 ++ir;
924 pppLayout1->addWidget(new QLabel("Logfile directory"), ir, 0);
925 pppLayout1->addWidget(_pppWidgets._logPath, ir, 1);
926 pppLayout1->addWidget(new QLabel(" NMEA directory"), ir, 3);
927 pppLayout1->addWidget(_pppWidgets._nmeaPath, ir, 4, 1, 3);
928 ++ir;
929 pppLayout1->addWidget(new QLabel("SNX TRO directory"), ir, 0);
930 pppLayout1->addWidget(_pppWidgets._snxtroPath, ir, 1);
931 pppLayout1->addWidget(new QLabel(" SNX TRO interval"), ir, 3);
932 pppLayout1->addWidget(_pppWidgets._snxtroIntr, ir, 4);
933 pppLayout1->addWidget(new QLabel(" SNX TRO sampling"), ir, 5);
934 pppLayout1->addWidget(_pppWidgets._snxtroSampl, ir, 6, Qt::AlignRight);
935 ++ir;
936 pppLayout1->addWidget(new QLabel("Version 3 filenames"), ir, 0);
937 pppLayout1->addWidget(_pppWidgets._v3filenames, ir, 1, 1, 3);
938 pppLayout1->addWidget(new QLabel(" SNX TRO AC"), ir, 3);
939 pppLayout1->addWidget(_pppWidgets._snxtroAc, ir, 4);
940 pppLayout1->addWidget(new QLabel(" SNX TRO solution"), ir, 5);
941 pppLayout1->addWidget(_pppWidgets._snxtroSol, ir, 6, Qt::AlignRight);
942 pppLayout1->setRowStretch(ir, 999);
943
944 pppGroup1->setLayout(pppLayout1);
945
946 QVBoxLayout* pppLayout2 = new QVBoxLayout();
947 pppLayout2->addWidget(new QLabel("Precise Point Positioning - Processed Stations.<br>"));
948 pppLayout2->addWidget(_pppWidgets._staTable, 99);
949 QHBoxLayout* pppLayout2sub = new QHBoxLayout();
950 pppLayout2sub->addWidget(_pppWidgets._addStaButton);
951 pppLayout2sub->addWidget(_pppWidgets._delStaButton);
952 pppLayout2sub->addStretch(99);
953
954 pppLayout2->addLayout(pppLayout2sub);
955
956 pppGroup2->setLayout(pppLayout2);
957
958 QGridLayout* pppLayout3 = new QGridLayout();
959 ir = 0;
960 pppLayout3->addWidget(new QLabel("Precise Point Positioning - Options.<br>"), ir, 0, 1, 2, Qt::AlignLeft);
961 ++ir;
962 pppLayout3->addWidget(new QLabel("GPS LCs"), ir, 0, Qt::AlignLeft);
963 pppLayout3->addWidget(_pppWidgets._lcGPS, ir, 1);
964 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 2);
965 pppLayout3->addWidget(new QLabel("Sigma C1"), ir, 3, Qt::AlignLeft);
966 pppLayout3->addWidget(_pppWidgets._sigmaC1, ir, 4); _pppWidgets._sigmaC1->setMaximumWidth(8*ww);
967 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 5);
968 pppLayout3->addWidget(new QLabel("Sigma L1"), ir, 6, Qt::AlignLeft);
969 pppLayout3->addWidget(_pppWidgets._sigmaL1, ir, 7); _pppWidgets._sigmaL1->setMaximumWidth(8*ww);
970 ++ir;
971 pppLayout3->addWidget(new QLabel("GLONASS LCs"), ir, 0, Qt::AlignLeft);
972 pppLayout3->addWidget(_pppWidgets._lcGLONASS, ir, 1);
973 pppLayout3->addWidget(new QLabel("Max Res C1"), ir, 3, Qt::AlignLeft);
974 pppLayout3->addWidget(_pppWidgets._maxResC1, ir, 4); _pppWidgets._maxResC1->setMaximumWidth(8*ww);
975 pppLayout3->addWidget(new QLabel("Max Res L1"), ir, 6, Qt::AlignLeft);
976 pppLayout3->addWidget(_pppWidgets._maxResL1, ir, 7); _pppWidgets._maxResL1->setMaximumWidth(8*ww);
977 ++ir;
978 pppLayout3->addWidget(new QLabel("Galileo LCs"), ir, 0, Qt::AlignLeft);
979 pppLayout3->addWidget(_pppWidgets._lcGalileo, ir, 1);
980 pppLayout3->addWidget(new QLabel("Ele Wgt Code"), ir, 3, Qt::AlignLeft);
981 pppLayout3->addWidget(_pppWidgets._eleWgtCode, ir, 4);
982 pppLayout3->addWidget(new QLabel("Ele Wgt Phase"), ir, 6, Qt::AlignLeft);
983 pppLayout3->addWidget(_pppWidgets._eleWgtPhase, ir, 7);
984 ++ir;
985 pppLayout3->addWidget(new QLabel("BDS LCs"), ir, 0, Qt::AlignLeft);
986 pppLayout3->addWidget(_pppWidgets._lcBDS, ir, 1);
987 pppLayout3->addWidget(new QLabel("Min # of Obs"), ir, 3, Qt::AlignLeft);
988 pppLayout3->addWidget(_pppWidgets._minObs, ir, 4);
989 pppLayout3->addWidget(new QLabel("Min Elevation"), ir, 6, Qt::AlignLeft);
990 pppLayout3->addWidget(_pppWidgets._minEle, ir, 7);
991 ++ir;
992 pppLayout3->addWidget(new QLabel("Wait for clock corr."), ir, 0, Qt::AlignLeft);
993 pppLayout3->addWidget(_pppWidgets._corrWaitTime, ir, 1);
994 pppLayout3->addWidget(new QLabel("Seeding (sec)"), ir, 3, Qt::AlignLeft);
995 pppLayout3->addWidget(_pppWidgets._seedingTime, ir, 4);
996 ++ir;
997 pppLayout3->addWidget(new QLabel(""), ir, 8);
998 pppLayout3->setColumnStretch(8, 999);
999 ++ir;
1000 pppLayout3->addWidget(new QLabel(""), ir, 1);
1001 pppLayout3->setRowStretch(ir, 999);
1002
1003 pppGroup3->setLayout(pppLayout3);
1004
1005 // ------------------------
1006 connect(_pppWidgets._mapWinButton, SIGNAL(clicked()), SLOT(slotMapPPP()));
1007 _pppWidgets._mapSpeedSlider->setMinimumWidth(33*ww);
1008 _pppWidgets._audioResponse->setMaximumWidth(8*ww);
1009
1010 QGridLayout* pppLayout4 = new QGridLayout();
1011 ir = 0;
1012 pppLayout4->addWidget(new QLabel("Precise Point Positioning - Plots.<br>"), ir, 0, 1, 50, Qt::AlignLeft);
1013 ++ir;
1014 pppLayout4->addWidget(new QLabel("PPP Plot"), ir, 0, Qt::AlignLeft);
1015 pppLayout4->addWidget(_pppWidgets._plotCoordinates, ir, 1, Qt::AlignLeft);
1016 pppLayout4->addWidget(new QLabel("Mountpoint"), ir, 2, 1, 10, Qt::AlignLeft);
1017 pppLayout4->addWidget(_pppWidgets._audioResponse, ir, 4, Qt::AlignLeft);
1018 pppLayout4->addWidget(new QLabel("Audio response"), ir, 5, Qt::AlignRight);
1019
1020 ++ir;
1021 pppLayout4->addWidget(new QLabel("Track map"), ir, 0, Qt::AlignLeft);
1022 pppLayout4->addWidget(_pppWidgets._mapWinButton, ir, 1, Qt::AlignLeft);
1023 pppLayout4->addWidget(new QLabel("OSM"), ir, 2, Qt::AlignLeft);
1024 pppLayout4->addWidget(_pppWidgets._useOpenStreetMap, ir, 3, Qt::AlignLeft);
1025 pppLayout4->addWidget(new QLabel("Google"), ir, 3, Qt::AlignRight);
1026 pppLayout4->addWidget(_pppWidgets._useGoogleMap, ir, 4, Qt::AlignLeft);
1027 ++ir;
1028 pppLayout4->addWidget(new QLabel("Dot-properties"), ir, 0, Qt::AlignLeft);
1029 pppLayout4->addWidget(_pppWidgets._mapWinDotSize, ir, 1, Qt::AlignLeft);
1030 pppLayout4->addWidget(new QLabel("Size "), ir, 2, Qt::AlignLeft);
1031 pppLayout4->addWidget(_pppWidgets._mapWinDotColor, ir, 3, Qt::AlignLeft);
1032 pppLayout4->addWidget(new QLabel("Color"), ir, 4, Qt::AlignLeft);
1033 ++ir;
1034 pppLayout4->addWidget(new QLabel("Post-processing speed"), ir, 0, Qt::AlignLeft);
1035 pppLayout4->addWidget(_pppWidgets._mapSpeedSlider, ir, 1, 1, 20, Qt::AlignLeft);
1036 ++ir;
1037 pppLayout4->addWidget(new QLabel(""), ir, 1);
1038 pppLayout4->setRowStretch(ir, 999);
1039
1040 pppGroup4->setLayout(pppLayout4);
1041
1042 // Reqc Processing
1043 // ---------------
1044 _reqcActionComboBox = new QComboBox();
1045 _reqcActionComboBox->setEditable(false);
1046 _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
1047 int ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
1048 if (ik != -1) {
1049 _reqcActionComboBox->setCurrentIndex(ik);
1050 }
1051 connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
1052 this, SLOT(slotBncTextChanged()));
1053
1054 QGridLayout* reqcLayout = new QGridLayout;
1055 _reqcActionComboBox->setMinimumWidth(15*ww);
1056 _reqcActionComboBox->setMaximumWidth(20*ww);
1057
1058 _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1059 _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
1060
1061 _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1062 _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
1063 _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
1064 _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
1065 _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
1066 _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
1067 _reqcSkyPlotSignals = new QLineEdit(settings.value("reqcSkyPlotSignals").toString());
1068
1069 connect(_reqcSkyPlotSignals, SIGNAL(textChanged(const QString &)),
1070 this, SLOT(slotBncTextChanged()));
1071
1072 _reqcLogSummaryOnly = new QCheckBox();
1073 _reqcLogSummaryOnly->setCheckState(Qt::CheckState(settings.value("reqcLogSummaryOnly").toInt()));
1074
1075 ir = 0;
1076 reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check.<br>"),ir, 0, 1, 8);
1077 ++ir;
1078 reqcLayout->addWidget(new QLabel("Action"), ir, 0);
1079 reqcLayout->addWidget(_reqcActionComboBox, ir, 1);
1080 _reqcEditOptionButton = new QPushButton("Set Edit Options");
1081 _reqcEditOptionButton->setMinimumWidth(15*ww);
1082 _reqcEditOptionButton->setMaximumWidth(20*ww);
1083
1084 reqcLayout->addWidget(_reqcEditOptionButton, ir, 3);
1085 ++ir;
1086 reqcLayout->addWidget(new QLabel("Input files (full path)"), ir, 0);
1087 reqcLayout->addWidget(_reqcObsFileChooser, ir, 1);
1088 _reqcObsFileChooser->setMaximumWidth(40*ww);
1089 reqcLayout->addWidget(new QLabel(" Obs"), ir, 2);
1090 reqcLayout->addWidget(_reqcNavFileChooser, ir, 3);
1091 _reqcNavFileChooser->setMaximumWidth(40*ww);
1092 reqcLayout->addWidget(new QLabel(" Nav"), ir, 4);
1093 ++ir;
1094 reqcLayout->addWidget(new QLabel("Output file (full path)"), ir, 0);
1095 reqcLayout->addWidget(_reqcOutObsLineEdit, ir, 1);
1096 _reqcOutObsLineEdit->setMaximumWidth(40*ww);
1097 reqcLayout->addWidget(new QLabel(" Obs"), ir, 2);
1098 reqcLayout->addWidget(_reqcOutNavLineEdit, ir, 3);
1099 _reqcOutNavLineEdit->setMaximumWidth(40*ww);
1100 reqcLayout->addWidget(new QLabel(" Nav"), ir, 4);
1101 ++ir;
1102 reqcLayout->addWidget(new QLabel("Logfile"), ir, 0);
1103 reqcLayout->addWidget(_reqcOutLogLineEdit, ir, 1);
1104 _reqcOutLogLineEdit->setMaximumWidth(40*ww);
1105 reqcLayout->addWidget(new QLabel(" Summary only"), ir, 2);
1106 reqcLayout->addWidget(_reqcLogSummaryOnly, ir, 3);
1107 ++ir;
1108 reqcLayout->addWidget(new QLabel("Plots for signals"), ir, 0);
1109 reqcLayout->addWidget(_reqcSkyPlotSignals, ir, 1);
1110 _reqcSkyPlotSignals->setMaximumWidth(40*ww);
1111 ++ir;
1112 reqcLayout->addWidget(new QLabel("Directory for plots"), ir, 0);
1113 reqcLayout->addWidget(_reqcPlotDirLineEdit, ir, 1);
1114 _reqcPlotDirLineEdit->setMaximumWidth(40*ww);
1115 ++ir;
1116 reqcLayout->setRowStretch(ir, 999);
1117
1118 reqcLayout->setColumnMinimumWidth(2, 8*ww);
1119 reqcLayout->setColumnMinimumWidth(4, 8*ww);
1120
1121 reqcgroup->setLayout(reqcLayout);
1122
1123 connect(_reqcEditOptionButton, SIGNAL(clicked()),
1124 this, SLOT(slotReqcEditOption()));
1125
1126 QGridLayout* sp3CompLayout = new QGridLayout;
1127
1128 _sp3CompFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1129 _sp3CompFileChooser->setFileName(settings.value("sp3CompFile").toString());
1130 _sp3CompFileChooser->setMinimumWidth(15*ww);
1131 _sp3CompFileChooser->setMaximumWidth(40*ww);
1132
1133 _sp3CompExclude = new QLineEdit(settings.value("sp3CompExclude").toString());
1134 _sp3CompExclude->setMinimumWidth(18*ww);
1135 _sp3CompExclude->setMaximumWidth(18*ww);
1136
1137 _sp3CompLogLineEdit = new QLineEdit(settings.value("sp3CompOutLogFile").toString());
1138 _sp3CompLogLineEdit->setMinimumWidth(18*ww);
1139 _sp3CompLogLineEdit->setMaximumWidth(18*ww);
1140
1141 ir = 0;
1142 sp3CompLayout->addWidget(new QLabel("Orbit and clock comparison.<br>"), ir, 0, 1, 40);
1143 ++ir;
1144 sp3CompLayout->addWidget(new QLabel("Input SP3 files (full path)"), ir, 0, Qt::AlignLeft);
1145 sp3CompLayout->addWidget(_sp3CompFileChooser, ir, 1, 1, 20);
1146 ++ir;
1147 sp3CompLayout->addWidget(new QLabel("Exclude satellites"), ir, 0, Qt::AlignLeft);
1148 sp3CompLayout->addWidget(_sp3CompExclude, ir, 1, Qt::AlignRight);
1149 ++ir;
1150 sp3CompLayout->addWidget(new QLabel("Logfile"), ir, 0, Qt::AlignLeft);
1151 sp3CompLayout->addWidget(_sp3CompLogLineEdit, ir, 1, Qt::AlignRight);
1152 ++ir;
1153 sp3CompLayout->addWidget(new QLabel(""), ir, 1);
1154 ++ir;
1155 sp3CompLayout->setRowStretch(ir, 999);
1156
1157 sp3CompLayout->setColumnMinimumWidth(2, 8*ww);
1158 sp3CompLayout->setColumnMinimumWidth(4, 8*ww);
1159
1160 sp3CompGroup->setLayout(sp3CompLayout);
1161
1162 connect(_sp3CompFileChooser, SIGNAL(fileNameChanged(const QString &)),
1163 this, SLOT(slotBncTextChanged()));
1164
1165 // Combine Corrections
1166 // -------------------
1167 QGridLayout* cmbLayout = new QGridLayout;
1168
1169 populateCmbTable();
1170 cmbLayout->addWidget(_cmbTable, 0, 0, 8, 3);
1171 cmbLayout->addWidget(new QLabel(" Combine Broadcast Correction streams.<br>"), 1, 6, 1, 10);
1172 cmbLayout->addWidget(addCmbRowButton, 2, 6);
1173 cmbLayout->addWidget(delCmbRowButton, 2, 7);
1174 cmbLayout->addWidget(new QLabel("Method"), 3, 6, Qt::AlignRight);
1175 cmbLayout->addWidget(_cmbMethodComboBox, 3, 7);
1176 cmbLayout->addWidget(new QLabel(" Maximal residuum"), 4, 6, Qt::AlignRight);
1177 cmbLayout->addWidget(_cmbMaxresLineEdit, 4, 7, Qt::AlignRight);
1178 cmbLayout->addWidget(new QLabel("Sampling"), 5, 6, Qt::AlignRight);
1179 cmbLayout->addWidget(_cmbSamplSpinBox, 5, 7);
1180 cmbLayout->addWidget(new QLabel(" Use GLONASS"), 6, 6, Qt::AlignRight);
1181 cmbLayout->addWidget(_cmbUseGlonass, 6, 7);
1182 cmbLayout->setRowStretch(7, 999);
1183
1184 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1185 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
1186
1187 cmbgroup->setLayout(cmbLayout);
1188
1189 // Upload Layout (Clocks)
1190 // ----------------------
1191 QGridLayout* uploadHlpLayout = new QGridLayout();
1192
1193 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1194 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1195 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
1196
1197 uploadHlpLayout->addWidget(addUploadRowButton, 0, 0);
1198 uploadHlpLayout->addWidget(delUploadRowButton, 0, 1);
1199 uploadHlpLayout->addWidget(new QLabel("Interval"), 0, 2, Qt::AlignRight);
1200 uploadHlpLayout->addWidget(_uploadIntrComboBox, 0, 3);
1201 uploadHlpLayout->addWidget(new QLabel(" Sampling: Orb"), 0, 4, Qt::AlignRight);
1202 uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox, 0, 5);
1203 uploadHlpLayout->addWidget(new QLabel("SP3"), 0, 6, Qt::AlignRight);
1204 uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox, 0, 7);
1205 uploadHlpLayout->addWidget(new QLabel("RNX"), 0, 8, Qt::AlignRight);
1206 uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox, 0, 9);
1207 uploadHlpLayout->addWidget(setUploadTrafoButton, 0,10);
1208 uploadHlpLayout->addWidget(new QLabel("ANTEX file"), 1, 0, Qt::AlignLeft);
1209 uploadHlpLayout->addWidget(_uploadAntexFile, 1, 1, 1, 4);
1210
1211 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1212 populateUploadTable();
1213
1214 uploadLayout->addWidget(new QLabel("Upload RTCM Version 3 Broadcast Corrections to caster.<br>"));
1215 uploadLayout->addWidget(_uploadTable);
1216 uploadLayout->addLayout(uploadHlpLayout);
1217
1218 uploadgroup->setLayout(uploadLayout);
1219
1220 // Upload Layout (Ephemeris)
1221 // -------------------------
1222 QGridLayout* uploadHlpLayoutEph = new QGridLayout();
1223
1224 connect(addUploadEphRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadEphRow()));
1225 connect(delUploadEphRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadEphRow()));
1226
1227 uploadHlpLayoutEph->addWidget(addUploadEphRowButton, 0, 0);
1228 uploadHlpLayoutEph->addWidget(delUploadEphRowButton, 0, 1);
1229 uploadHlpLayoutEph->addWidget(new QLabel(" Sampling"), 0, 2, Qt::AlignRight);
1230 uploadHlpLayoutEph->addWidget(_uploadSamplRtcmEphSpinBox, 0, 3);
1231
1232 QBoxLayout* uploadLayoutEph = new QBoxLayout(QBoxLayout::TopToBottom);
1233 populateUploadEphTable();
1234
1235 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster.<br>"));
1236 uploadLayoutEph->addWidget(_uploadEphTable);
1237 uploadLayoutEph->addLayout(uploadHlpLayoutEph);
1238
1239 uploadEphgroup->setLayout(uploadLayoutEph);
1240
1241
1242 // Main Layout
1243 // -----------
1244 QGridLayout* mLayout = new QGridLayout;
1245 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
1246 mLayout->addWidget(_aogroup, 0,0);
1247 mLayout->addWidget(_mountPointsTable, 1,0);
1248 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
1249 mLayout->addWidget(_loggroup, 2,0);
1250
1251 _canvas->setLayout(mLayout);
1252
1253 // WhatsThis, Network
1254 // ------------------
1255 _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>"));
1256 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1257 _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>"));
1258 _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>"));
1259
1260 // WhatsThis, General
1261 // ------------------
1262 _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>"));
1263 _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>"));
1264 _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>"));
1265 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1266 _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>"));
1267
1268 // WhatsThis, RINEX Observations
1269 // -----------------------------
1270 _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>"));
1271 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1272 _rnxSamplSpinBox->setWhatsThis(tr("<p>Select the RINEX Observation sampling interval in seconds.</p><p>A value of zero '0' tells BNC to store all received epochs into RINEX Observation files.</p>"));
1273 _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-char ID forming the base name has to be written in upper/lower cases. </p>"));
1274 _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>"));
1275 _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>"));
1276 _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 either as equal for all systems or as system specific. The following are example priority strings:</li><ul><li>'CWPX_?' (Same signal priorities valid for all systems)</li><li>'G:CWPX_? R:PCX_? E:CPX_?' (Specific signal priorities for GPS, GLONASS and Galileo system)</li></ul>Default is priority list 'CWPX_?'.</p>"));
1277 _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>"));
1278 _rnxV3filenameCheckBox->setWhatsThis(tr("<p>Tick 'Version 3 filenames' to let BNC create so-called extended filenames following the RINEX Version 3 standard.</p><p>Default is an empty check box, meaning to create filenames following the RINEX Version 2 standard although the file content is saved in RINEX Version 3 format.</p>"));
1279
1280 // WhatsThis, RINEX Ephemeris
1281 // --------------------------
1282 _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>"));
1283 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1284 _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>"));
1285 _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>"));
1286 _ephV3filenameCheckBox->setWhatsThis(tr("<p>Tick 'Version 3 filenames' to let BNC create so-called extended filenames following the RINEX Version 3 standard.</p><p>Default is an empty check box, meaning to create filenames following the RINEX Version 2 standard although the file content is saved in RINEX Version 3 format.</p>"));
1287
1288 // WhatsThis, RINEX Editing & QC
1289 // -----------------------------
1290 _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>"));
1291 _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX Version 2 or 3 files.</p>"));
1292 _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>"));
1293 _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>"));
1294 _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>"));
1295 _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>"));
1296 _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>"));
1297 _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>"));
1298 _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>"));
1299 _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'. Specifying an empty option string would be overruled by this default.</p>"));
1300
1301 // WhatsThis, SP3 Comparison
1302 // -------------------------
1303 _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>"));
1304 _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>"));
1305 _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>"));
1306
1307 // WhatsThis, Broadcast Corrections
1308 // --------------------------------
1309 _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>"));
1310 _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>"));
1311 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of Broadcast Ephemeris Correction files.</p>"));
1312
1313 // WhatsThis, Feed Engine
1314 // ----------------------
1315 _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>"));
1316 _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>"));
1317 _outSamplSpinBox->setWhatsThis(tr("<p>Select a synchronized observation sampling interval in seconds.</p><p>A value of zero '0' tells BNC to send/store all received epochs.</p>"));
1318 _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>"));
1319 _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>"));
1320
1321 // WhatsThis, Serial Output
1322 // ------------------------
1323 _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>"));
1324 _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>"));
1325 _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>"));
1326 _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>"));
1327 _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>"));
1328 _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>"));
1329 _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>"));
1330 _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>"));
1331 _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>"));
1332 _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>"));
1333 _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>"));
1334
1335 // WhatsThis, Outages
1336 // ------------------
1337 _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>"));
1338 _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>"));
1339 _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>"));
1340 _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>"));
1341
1342 // WhatsThis, Miscellaneous
1343 // ------------------------
1344 _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>"));
1345 _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>"));
1346 _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>."));
1347 _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>"));
1348
1349 // WhatsThis, PPP (1)
1350 // ------------------
1351 _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>"));
1352 _pppWidgets._rinexObs->setWhatsThis(tr("<p>Specify the RINEX Observation file.</p>"));
1353 _pppWidgets._rinexNav->setWhatsThis(tr("<p>Specify the RINEX Navigation file.</p>"));
1354 _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>"));
1355 _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>"));
1356 _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>"));
1357 _pppWidgets._blqFile->setWhatsThis(tr("<p>Enter the full path to an ocean loading file in BLQ format. It contains a record for each site, which shows a header with information on the ocean tide model, the site name and the geographic coordinates. The first three rows of numbers designate amplitudes (meter), radial, west, south, and are followed by three lines with the corresponding phase values (degrees).</p>"));
1358 _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>"));
1359 _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>"));
1360 _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>"));
1361 _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>"));
1362 _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>"));
1363 _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>"));
1364 _pppWidgets._snxtroSampl->setWhatsThis(tr("<p>Select a 'Sampling' rate for saving troposphere parameters.</p><p>Default 'SNX TRO sampling' rate is '0', meaning that all troposphere estimates will be saved on disk.</p>"));
1365 _pppWidgets._snxtroAc->setWhatsThis(tr("<p>Specify a 3-character abbreviation describing you as the generating Analysis Center (AC) in your SINEX troposphere files.</p>"));
1366 _pppWidgets._snxtroSol->setWhatsThis(tr("<p>Specify a 4-character solution ID to allow a distingtion between different solutions per AC.</p>"));
1367
1368 // WhatsThis, PPP (3)
1369 // ------------------
1370 _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>"));
1371 _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>"));
1372 _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>"));
1373 _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>"));
1374 _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>"));
1375 _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>"));
1376 _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>"));
1377 _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>"));
1378 _pppWidgets._eleWgtCode->setWhatsThis(tr("<p>Tic 'Ele Wgt Code' to use satellite Elevation depending Weights for Code observations in the PPP solution.</p>"));
1379 _pppWidgets._eleWgtPhase->setWhatsThis(tr("<p>Tic 'Ele Wgt Phase' to use satellite Elevation depending Weights for Phase observations in the PPP solution.</p>"));
1380 _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>"));
1381 _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>"));
1382
1383 // WhatsThis, Combine Corrections
1384 // ------------------------------
1385 _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>"));
1386 addCmbRowButton->setWhatsThis(tr("<p>Hit 'Add Row' button to add another line to the 'Combine Corrections' table.</p>"));
1387 delCmbRowButton->setWhatsThis(tr("<p>Hit 'Delete' button to delete the highlighted line(s) from the 'Combine Corrections' table.</p>"));
1388 _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>"));
1389 _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>"));
1390 _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>"));
1391 _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>"));
1392
1393 // WhatsThis, Upload Corrections
1394 // -----------------------------
1395 _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. IGS08) for outgoing clock and orbit corrections.</p><p>By default orbit and clock corrections refer to Antenna Phase Center (APC). Tick 'CoM' to refer uploaded corrections to Center of Mass instead of APC.</p><p>Specify a path for saving 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>"));
1396 addUploadRowButton->setWhatsThis(tr("<p>Hit 'Add Row' button to add another line to the 'Upload Corrections' table.</p>"));
1397 delUploadRowButton->setWhatsThis(tr("<p>Hit 'Del Row' button to delete the highlighted line(s) from the 'Upload Corrections' table.</p>"));
1398 _uploadIntrComboBox->setWhatsThis(tr("<p>Select the length of the SP3 and Clock RINEX files.</p>"));
1399 _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>"));
1400 _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>"));
1401 _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>"));
1402 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>"));
1403 _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>"));
1404
1405 // WhatsThis, Upload Ephemeris
1406 // ---------------------------
1407 _uploadEphTable->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 respective stream.</p>"));
1408 addUploadEphRowButton->setWhatsThis(tr("<p>Hit 'Add Row' button to add another line to the 'Upload Ephemeris' table.</p>"));
1409 delUploadEphRowButton->setWhatsThis(tr("<p>Hit 'Del Row' button to delete the highlighted line(s) from the 'Upload Ephemeris' table.</p>"));
1410 _uploadSamplRtcmEphSpinBox->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>"));
1411
1412 // WhatsThis, Streams Canvas
1413 // -------------------------
1414 _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>"));
1415 _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
1416 _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1417 _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>"));
1418 _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1419 _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1420
1421 // WhatsThis, Log Canvas
1422 // ---------------------
1423 _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>"));
1424 _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>"));
1425 _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>"));
1426 _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>"));
1427
1428
1429 // Enable/Disable all Widgets
1430 // --------------------------
1431 slotBncTextChanged();
1432 enableStartStop();
1433
1434 // Auto start
1435 // ----------
1436 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1437 slotStart();
1438 }
1439}
1440
1441// Destructor
1442////////////////////////////////////////////////////////////////////////////
1443bncWindow::~bncWindow() {
1444 if (_caster) {
1445 delete _caster; BNC_CORE->setCaster(0);
1446 }
1447 if (_casterEph) {
1448 delete _casterEph;
1449 }
1450 delete _bncFigureLate;
1451 delete _bncFigurePPP;
1452 delete _actHelp;
1453 delete _actAbout;
1454 delete _actFlowchart;
1455 delete _actFontSel;
1456 delete _actSaveOpt;
1457 delete _actQuit;
1458 delete _actAddMountPoints;
1459 delete _actDeleteMountPoints;
1460 delete _actMapMountPoints;
1461 delete _actStart;
1462 delete _actStop;
1463 delete _actwhatsthis;
1464 delete _proxyHostLineEdit;
1465 delete _proxyPortLineEdit;
1466 delete _sslCaCertPathLineEdit;
1467 delete _sslIgnoreErrorsCheckBox;
1468 delete _logFileLineEdit;
1469 delete _rawOutFileLineEdit;
1470 delete _rnxAppendCheckBox;
1471 delete _onTheFlyComboBox;
1472 delete _autoStartCheckBox;
1473 delete _rnxPathLineEdit;
1474 delete _rnxIntrComboBox;
1475 delete _rnxSamplSpinBox;
1476 delete _rnxFileCheckBox;
1477 delete _rnxSkelLineEdit;
1478 delete _rnxScrpLineEdit;
1479 delete _rnxV3CheckBox;
1480 delete _rnxV3filenameCheckBox;
1481 delete _rnxV2Priority;
1482 delete _ephPathLineEdit;
1483 delete _ephIntrComboBox;
1484 delete _ephOutPortLineEdit;
1485 delete _ephV3CheckBox;
1486 delete _ephV3filenameCheckBox;
1487 delete _corrPathLineEdit;
1488 delete _corrIntrComboBox;
1489 delete _corrPortLineEdit;
1490 delete _outPortLineEdit;
1491 delete _outWaitSpinBox;
1492 delete _outSamplSpinBox;
1493 delete _outFileLineEdit;
1494 delete _outUPortLineEdit;
1495 delete _serialMountPointLineEdit;
1496 delete _serialPortNameLineEdit;
1497 delete _serialBaudRateComboBox;
1498 delete _serialFlowControlComboBox;
1499 delete _serialDataBitsComboBox;
1500 delete _serialParityComboBox;
1501 delete _serialStopBitsComboBox;
1502 delete _serialAutoNMEAComboBox;
1503 delete _serialFileNMEALineEdit;
1504 delete _serialHeightNMEALineEdit;
1505 delete _serialManualNMEASamplingSpinBox;
1506 delete _adviseObsRateComboBox;
1507 delete _adviseFailSpinBox;
1508 delete _adviseRecoSpinBox;
1509 delete _adviseScriptLineEdit;
1510 delete _miscMountLineEdit;
1511 delete _miscPortLineEdit;
1512 delete _miscIntrComboBox;
1513 delete _miscScanRTCMCheckBox;
1514 _mountPointsTable->deleteLater();
1515 delete _log;
1516 delete _loggroup;
1517 _cmbTable->deleteLater();
1518 delete _cmbMaxresLineEdit;
1519 delete _cmbUseGlonass;
1520 delete _cmbSamplSpinBox;
1521 delete _cmbMethodComboBox;;
1522 _uploadEphTable->deleteLater();
1523 delete _uploadSamplRtcmEphCorrSpinBox;
1524 _uploadTable->deleteLater();
1525 delete _uploadIntrComboBox;
1526 delete _uploadAntexFile;
1527 delete _uploadSamplRtcmEphSpinBox;
1528 delete _uploadSamplSp3SpinBox;
1529 delete _uploadSamplClkRnxSpinBox;
1530 delete _reqcActionComboBox;
1531 delete _reqcObsFileChooser;
1532 delete _reqcNavFileChooser;
1533 delete _reqcOutObsLineEdit;
1534 delete _reqcOutNavLineEdit;
1535 delete _reqcOutLogLineEdit;
1536 delete _reqcPlotDirLineEdit;
1537 delete _reqcSkyPlotSignals;
1538 delete _reqcLogSummaryOnly;
1539 delete _reqcEditOptionButton;
1540 delete _sp3CompFileChooser;
1541 delete _sp3CompExclude;
1542 delete _sp3CompLogLineEdit;
1543 //delete _canvas;
1544}
1545
1546//
1547////////////////////////////////////////////////////////////////////////////
1548void bncWindow::populateMountPointsTable() {
1549
1550 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1551 _mountPointsTable->removeRow(iRow);
1552 }
1553
1554 bncSettings settings;
1555
1556 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1557 int iRow = 0;
1558 while (it.hasNext()) {
1559 QStringList hlp = it.next().split(" ");
1560 if (hlp.size() < 7) continue;
1561 _mountPointsTable->insertRow(iRow);
1562
1563 QUrl url(hlp[0]);
1564
1565 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1566 QString format(hlp[1]); QString country(hlp[2]); QString latitude(hlp[3]); QString longitude(hlp[4]);
1567 QString nmea(hlp[5]);
1568 if (hlp[6] == "S") {
1569 fullPath = hlp[0].replace(0,2,"");
1570 }
1571 QString ntripVersion = "2";
1572 if (hlp.size() >= 7) {
1573 ntripVersion = (hlp[6]);
1574 }
1575
1576 QTableWidgetItem* it;
1577 it = new QTableWidgetItem(url.userInfo());
1578 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1579 _mountPointsTable->setItem(iRow, 0, it);
1580
1581 it = new QTableWidgetItem(fullPath);
1582 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1583 _mountPointsTable->setItem(iRow, 1, it);
1584
1585 it = new QTableWidgetItem(format);
1586 _mountPointsTable->setItem(iRow, 2, it);
1587
1588 it = new QTableWidgetItem(country);
1589 _mountPointsTable->setItem(iRow, 3, it);
1590
1591 if (nmea == "yes") {
1592 it = new QTableWidgetItem(latitude);
1593 _mountPointsTable->setItem(iRow, 4, it);
1594 it = new QTableWidgetItem(longitude);
1595 _mountPointsTable->setItem(iRow, 5, it);
1596 } else {
1597 it = new QTableWidgetItem(latitude);
1598 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1599 _mountPointsTable->setItem(iRow, 4, it);
1600
1601 it = new QTableWidgetItem(longitude);
1602 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1603 _mountPointsTable->setItem(iRow, 5, it);
1604 }
1605
1606 it = new QTableWidgetItem(nmea);
1607 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1608 _mountPointsTable->setItem(iRow, 6, it);
1609
1610 it = new QTableWidgetItem(ntripVersion);
1611 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1612 _mountPointsTable->setItem(iRow, 7, it);
1613
1614 bncTableItem* bncIt = new bncTableItem();
1615 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1616 _mountPointsTable->setItem(iRow, 8, bncIt);
1617
1618 iRow++;
1619 }
1620
1621 _mountPointsTable->sortItems(1);
1622
1623 enableStartStop();
1624}
1625
1626// Retrieve Table
1627////////////////////////////////////////////////////////////////////////////
1628void bncWindow::slotAddMountPoints() {
1629
1630 bncSettings settings;
1631 QString proxyHost = settings.value("proxyHost").toString();
1632 int proxyPort = settings.value("proxyPort").toInt();
1633 if (proxyHost != _proxyHostLineEdit->text() ||
1634 proxyPort != _proxyPortLineEdit->text().toInt()) {
1635 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1636 "changed. Use the new ones?",
1637 QMessageBox::Yes, QMessageBox::No,
1638 QMessageBox::NoButton);
1639 if (iRet == QMessageBox::Yes) {
1640 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1641 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1642 }
1643 }
1644
1645 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1646 settings.setValue("sslIgnoreErrors", _sslIgnoreErrorsCheckBox->checkState());
1647
1648 QMessageBox msgBox;
1649 msgBox.setIcon(QMessageBox::Question);
1650 msgBox.setWindowTitle("Add Stream");
1651 msgBox.setText("Add stream(s) coming from:");
1652
1653 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1654 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1655 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1656 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1657 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1658
1659 msgBox.exec();
1660
1661 if (msgBox.clickedButton() == buttonNtrip) {
1662 bncTableDlg* dlg = new bncTableDlg(this);
1663 dlg->move(this->pos().x()+50, this->pos().y()+50);
1664 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1665 this, SLOT(slotNewMountPoints(QStringList*)));
1666 dlg->exec();
1667 delete dlg;
1668 } else if (msgBox.clickedButton() == buttonIP) {
1669 bncIpPort* ipp = new bncIpPort(this);
1670 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1671 this, SLOT(slotNewMountPoints(QStringList*)));
1672 ipp->exec();
1673 delete ipp;
1674 } else if (msgBox.clickedButton() == buttonUDP) {
1675 bncUdpPort* udp = new bncUdpPort(this);
1676 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1677 this, SLOT(slotNewMountPoints(QStringList*)));
1678 udp->exec();
1679 delete udp;
1680 } else if (msgBox.clickedButton() == buttonSerial) {
1681 bncSerialPort* sep = new bncSerialPort(this);
1682 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1683 this, SLOT(slotNewMountPoints(QStringList*)));
1684 sep->exec();
1685 delete sep;
1686 } else if (msgBox.clickedButton() == buttonCancel) {
1687 // Cancel
1688 }
1689
1690 enableStartStop();
1691}
1692
1693// Delete Selected Mount Points
1694////////////////////////////////////////////////////////////////////////////
1695void bncWindow::slotDeleteMountPoints() {
1696
1697 int nRows = _mountPointsTable->rowCount();
1698 bool flg[nRows];
1699 for (int iRow = 0; iRow < nRows; iRow++) {
1700 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1701 flg[iRow] = true;
1702 }
1703 else {
1704 flg[iRow] = false;
1705 }
1706 }
1707 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1708 if (flg[iRow]) {
1709 _mountPointsTable->removeRow(iRow);
1710 }
1711 }
1712 _actDeleteMountPoints->setEnabled(false);
1713
1714 enableStartStop();
1715}
1716
1717// New Mount Points Selected
1718////////////////////////////////////////////////////////////////////////////
1719void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1720 int iRow = 0;
1721 QListIterator<QString> it(*mountPoints);
1722 while (it.hasNext()) {
1723 QStringList hlp = it.next().split(" ");
1724 QUrl url(hlp[0]);
1725 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1726 QString format(hlp[1]); QString country(hlp[2]); QString latitude(hlp[3]); QString longitude(hlp[4]);
1727 QString nmea(hlp[5]);
1728 if (hlp[6] == "S") {
1729 fullPath = hlp[0].replace(0,2,"");
1730 }
1731 QString ntripVersion = "2";
1732 if (hlp.size() >= 7) {
1733 ntripVersion = (hlp[6]);
1734 }
1735
1736 _mountPointsTable->insertRow(iRow);
1737
1738 QTableWidgetItem* it;
1739 it = new QTableWidgetItem(url.userInfo());
1740 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1741 _mountPointsTable->setItem(iRow, 0, it);
1742
1743 it = new QTableWidgetItem(fullPath);
1744 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1745 _mountPointsTable->setItem(iRow, 1, it);
1746
1747 it = new QTableWidgetItem(format);
1748 _mountPointsTable->setItem(iRow, 2, it);
1749
1750 it = new QTableWidgetItem(country);
1751 _mountPointsTable->setItem(iRow, 3, it);
1752
1753 if (nmea == "yes") {
1754 it = new QTableWidgetItem(latitude);
1755 _mountPointsTable->setItem(iRow, 4, it);
1756 it = new QTableWidgetItem(longitude);
1757 _mountPointsTable->setItem(iRow, 5, it);
1758 } else {
1759 it = new QTableWidgetItem(latitude);
1760 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1761 _mountPointsTable->setItem(iRow, 4, it);
1762 it = new QTableWidgetItem(longitude);
1763 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1764 _mountPointsTable->setItem(iRow, 5, it);
1765 }
1766
1767 it = new QTableWidgetItem(nmea);
1768 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1769 _mountPointsTable->setItem(iRow, 6, it);
1770
1771 it = new QTableWidgetItem(ntripVersion);
1772 ////it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1773 _mountPointsTable->setItem(iRow, 7, it);
1774
1775 bncTableItem* bncIt = new bncTableItem();
1776 _mountPointsTable->setItem(iRow, 8, bncIt);
1777
1778 iRow++;
1779 }
1780 _mountPointsTable->hideColumn(0);
1781 _mountPointsTable->hideColumn(3);
1782 _mountPointsTable->sortItems(1);
1783 delete mountPoints;
1784
1785 enableStartStop();
1786}
1787
1788// Save Options (serialize)
1789////////////////////////////////////////////////////////////////////////////
1790void bncWindow::slotSaveOptions() {
1791 saveOptions();
1792 bncSettings settings;
1793 settings.sync();
1794}
1795
1796// Save Options (memory only)
1797////////////////////////////////////////////////////////////////////////////
1798void bncWindow::saveOptions() {
1799
1800 QStringList mountPoints;
1801 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1802
1803 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1804 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1805 "@" + _mountPointsTable->item(iRow, 1)->text() );
1806
1807 mountPoints.append(url.toString() + " " +
1808 _mountPointsTable->item(iRow, 2)->text()
1809 + " " + _mountPointsTable->item(iRow, 3)->text()
1810 + " " + _mountPointsTable->item(iRow, 4)->text()
1811 + " " + _mountPointsTable->item(iRow, 5)->text()
1812 + " " + _mountPointsTable->item(iRow, 6)->text()
1813 + " " + _mountPointsTable->item(iRow, 7)->text());
1814 } else {
1815 mountPoints.append(
1816 "//" + _mountPointsTable->item(iRow, 1)->text()
1817 + " " + _mountPointsTable->item(iRow, 2)->text()
1818 + " " + _mountPointsTable->item(iRow, 3)->text()
1819 + " " + _mountPointsTable->item(iRow, 4)->text()
1820 + " " + _mountPointsTable->item(iRow, 5)->text()
1821 + " " + _mountPointsTable->item(iRow, 6)->text()
1822 + " " + _mountPointsTable->item(iRow, 7)->text());
1823 }
1824 }
1825
1826 QStringList cmbStreams;
1827 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1828 QString hlp;
1829 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1830 if (_cmbTable->item(iRow, iCol)) {
1831 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1832 }
1833 }
1834 if (!hlp.isEmpty()) {
1835 cmbStreams << hlp;
1836 }
1837 }
1838
1839 QStringList uploadMountpointsOut;
1840 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1841 QString hlp;
1842 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1843 if (_uploadTable->cellWidget(iRow, iCol) &&
1844 (iCol == 3 || iCol == 4 || iCol == 5)) {
1845 if (iCol == 3) {
1846 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1847 hlp += passwd->text() + ",";
1848 }
1849 else if (iCol == 4) {
1850 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1851 hlp += system->currentText() + ",";
1852 }
1853 else if (iCol == 5) {
1854 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1855 QString state; state.setNum(com->checkState());
1856 hlp += state + ",";
1857 }
1858 }
1859 else if (_uploadTable->item(iRow, iCol)) {
1860 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1861 }
1862 }
1863 if (!hlp.isEmpty()) {
1864 uploadMountpointsOut << hlp;
1865 }
1866 }
1867
1868 QStringList uploadEphMountpointsOut;
1869 for (int iRow = 0; iRow < _uploadEphTable->rowCount(); iRow++) {
1870 QString hlp;
1871 for (int iCol = 0; iCol < _uploadEphTable->columnCount(); iCol++) {
1872 if (_uploadEphTable->cellWidget(iRow, iCol) &&
1873 (iCol == 3 || iCol == 4)) {
1874 if (iCol == 3) {
1875 QLineEdit* passwd = (QLineEdit*)(_uploadEphTable->cellWidget(iRow, iCol));
1876 hlp += passwd->text() + ",";
1877 }
1878 else if (iCol == 4) {
1879 QComboBox* system = (QComboBox*)(_uploadEphTable->cellWidget(iRow, iCol));
1880 hlp += system->currentText() + ",";
1881 }
1882 }
1883 else if (_uploadEphTable->item(iRow, iCol)) {
1884 hlp += _uploadEphTable->item(iRow, iCol)->text() + ",";
1885 }
1886 }
1887 if (!hlp.isEmpty()) {
1888 uploadEphMountpointsOut << hlp;
1889 }
1890 }
1891
1892 bncSettings settings;
1893
1894 settings.setValue("startTab", _aogroup->currentIndex());
1895 settings.setValue("statusTab", _loggroup->currentIndex());
1896 settings.setValue("mountPoints", mountPoints);
1897// Network
1898 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1899 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1900 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1901 settings.setValue("sslIgnoreErrors", _sslIgnoreErrorsCheckBox->checkState());
1902// General
1903 settings.setValue("logFile", _logFileLineEdit->text());
1904 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1905 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1906 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1907 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1908// RINEX Observations
1909 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1910 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1911 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1912 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1913 settings.setValue("rnxOnlyWithSKL",_rnxFileCheckBox->checkState());
1914 settings.setValue("rnxV3filenames",_rnxV3filenameCheckBox->checkState());
1915 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1916 (_rnxV3filenameCheckBox->checkState()) ?
1917 settings.setValue("rnxV3", _rnxV3filenameCheckBox->checkState()) :
1918 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1919 settings.setValue("rnxV2Priority",_rnxV2Priority->text());
1920// RINEX Ephemeris
1921 settings.setValue("ephPath", _ephPathLineEdit->text());
1922 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1923 settings.setValue("ephOutPort", _ephOutPortLineEdit->text());
1924 settings.setValue("ephV3filenames", _ephV3filenameCheckBox->checkState());
1925 (_ephV3filenameCheckBox->checkState()) ?
1926 settings.setValue("ephV3", _ephV3filenameCheckBox->checkState()) :
1927 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1928// Broadcast Corrections
1929 settings.setValue("corrPath", _corrPathLineEdit->text());
1930 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1931 settings.setValue("corrPort", _corrPortLineEdit->text());
1932// Feed Engine
1933 settings.setValue("outPort", _outPortLineEdit->text());
1934 settings.setValue("outWait", _outWaitSpinBox->value());
1935 settings.setValue("outSampl", _outSamplSpinBox->value());
1936 settings.setValue("outFile", _outFileLineEdit->text());
1937 settings.setValue("outUPort", _outUPortLineEdit->text());
1938// Serial Output
1939 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1940 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1941 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1942 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1943 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1944 settings.setValue("serialParity", _serialParityComboBox->currentText());
1945 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1946 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1947 settings.setValue("serialFileNMEA", _serialFileNMEALineEdit->text());
1948 settings.setValue("serialHeightNMEA", _serialHeightNMEALineEdit->text());
1949 settings.setValue("serialManualNMEASampling", _serialManualNMEASamplingSpinBox->value());
1950// Outages
1951 settings.setValue("adviseObsRate", _adviseObsRateComboBox->currentText());
1952 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1953 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1954 settings.setValue("adviseScript", _adviseScriptLineEdit->text());
1955// Miscellaneous
1956 settings.setValue("miscMount", _miscMountLineEdit->text());
1957 settings.setValue("miscPort", _miscPortLineEdit->text());
1958 settings.setValue("miscIntr", _miscIntrComboBox->currentText());
1959 settings.setValue("miscScanRTCM", _miscScanRTCMCheckBox->checkState());
1960// Reqc
1961 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1962 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1963 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1964 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1965 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1966 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
1967 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
1968 settings.setValue("reqcSkyPlotSignals", _reqcSkyPlotSignals->text());
1969 settings.setValue("reqcLogSummaryOnly", _reqcLogSummaryOnly->checkState());
1970// SP3 Comparison
1971 settings.setValue("sp3CompFile", _sp3CompFileChooser->fileName());
1972 settings.setValue("sp3CompExclude", _sp3CompExclude->text());
1973 settings.setValue("sp3CompOutLogFile", _sp3CompLogLineEdit->text());
1974// Combine Corrections
1975 if (!cmbStreams.isEmpty()) {
1976 settings.setValue("cmbStreams", cmbStreams);
1977 }
1978 else {
1979 settings.setValue("cmbStreams", "");
1980 }
1981 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1982 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1983 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1984 settings.setValue("cmbUseGlonass", _cmbUseGlonass->checkState());
1985// Upload Corrections
1986 if (!uploadMountpointsOut.isEmpty()) {
1987 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1988 }
1989 else {
1990 settings.setValue("uploadMountpointsOut", "");
1991 }
1992 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1993 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1994 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1995 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
1996 settings.setValue("uploadAntexFile", _uploadAntexFile->fileName());
1997// Upload Ephemeris
1998 if (!uploadEphMountpointsOut.isEmpty()) {
1999 settings.setValue("uploadEphMountpointsOut", uploadEphMountpointsOut);
2000 }
2001 else {
2002 settings.setValue("uploadEphMountpointsOut", "");
2003 }
2004 settings.setValue("uploadSamplRtcmEph", _uploadSamplRtcmEphSpinBox->value());
2005
2006 if (_caster) {
2007 _caster->readMountPoints();
2008 }
2009
2010 _pppWidgets.saveOptions();
2011}
2012
2013// All get slots terminated
2014////////////////////////////////////////////////////////////////////////////
2015void bncWindow::slotGetThreadsFinished() {
2016 BNC_CORE->slotMessage("All Get Threads Terminated", true);
2017 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
2018 delete _casterEph; _casterEph = 0;
2019 _runningRealTime = false;
2020}
2021
2022// Start It!
2023////////////////////////////////////////////////////////////////////////////
2024void bncWindow::slotStart() {
2025 saveOptions();
2026 if ( _pppWidgets._dataSource->currentText() == "RINEX Files") {
2027 _runningPPP = true;
2028 enableStartStop();
2029 _caster = new bncCaster(); BNC_CORE->setCaster(_caster);
2030 BNC_CORE->startPPP();
2031 _bncFigurePPP->reset();
2032 }
2033 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
2034 if (_reqcActionComboBox->currentText() == "Analyze") {
2035 _runningQC = true;
2036 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
2037 connect(reqcAnalyze, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
2038 reqcAnalyze->start();
2039 }
2040 else {
2041 _runningEdit = true;
2042 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
2043 connect(reqcEdit, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
2044 reqcEdit->start();
2045 }
2046 enableStartStop();
2047 }
2048 else if (!_sp3CompFileChooser->fileName().isEmpty()) {
2049 _runningSp3Comp = true;
2050 t_sp3Comp* sp3Comp = new t_sp3Comp(this);
2051 connect(sp3Comp, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
2052 sp3Comp->start();
2053 enableStartStop();
2054 }
2055 else {
2056 startRealTime();
2057 BNC_CORE->startPPP();
2058 }
2059}
2060
2061// Start Real-Time (Retrieve Data etc.)
2062////////////////////////////////////////////////////////////////////////////
2063void bncWindow::startRealTime() {
2064
2065 _runningRealTime = true;
2066
2067 _bncFigurePPP->reset();
2068
2069 _actDeleteMountPoints->setEnabled(false);
2070
2071 enableStartStop();
2072
2073 _caster = new bncCaster();
2074
2075 BNC_CORE->setCaster(_caster);
2076 BNC_CORE->setPortEph(_ephOutPortLineEdit->text().toInt());
2077 BNC_CORE->setPortCorr(_corrPortLineEdit->text().toInt());
2078 BNC_CORE->initCombination();
2079
2080 connect(_caster, SIGNAL(getThreadsFinished()),
2081 this, SLOT(slotGetThreadsFinished()));
2082
2083 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
2084 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
2085
2086 BNC_CORE->slotMessage("========== Start BNC v" BNCVERSION" ("BNC_OS") ==========", true);
2087
2088 bncSettings settings;
2089
2090 // Active panels
2091 // -------------
2092 if (!_rnxPathLineEdit->text().isEmpty())
2093 BNC_CORE->slotMessage("Panel 'RINEX Observations' active", true);
2094 if (!_ephPathLineEdit->text().isEmpty())
2095 BNC_CORE->slotMessage("Panel 'RINEX Ephemeris' active", true);
2096 if (!_corrPathLineEdit->text().isEmpty())
2097 BNC_CORE->slotMessage("Panel 'Broadcast Corrections' active", true);
2098 if (!_outPortLineEdit->text().isEmpty())
2099 BNC_CORE->slotMessage("Panel 'Feed Engine' active", true);
2100 if (!_serialMountPointLineEdit->text().isEmpty())
2101 BNC_CORE->slotMessage("Panel 'Serial Output' active", true);
2102 if (!_adviseObsRateComboBox->currentText().isEmpty())
2103 BNC_CORE->slotMessage("Panel 'Outages' active", true);
2104 if (!_miscMountLineEdit->text().isEmpty())
2105 BNC_CORE->slotMessage("Panel 'Miscellaneous' active", true);
2106 if (_pppWidgets._dataSource->currentText() == "Real-Time Streams")
2107 BNC_CORE->slotMessage("Panel 'PPP' active", true);
2108 if (_cmbTable->rowCount() > 0)
2109 BNC_CORE->slotMessage("Panel 'Combine Corrections' active", true);
2110 if (_uploadTable->rowCount() > 0)
2111 BNC_CORE->slotMessage("Panel 'Upload Corrections' active", true);
2112 if (_uploadEphTable->rowCount() > 0)
2113 BNC_CORE->slotMessage("Panel 'UploadEphemeris' active", true);
2114
2115 QDir rnxdir(settings.value("rnxPath").toString());
2116 if (!rnxdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations directory", true);
2117
2118 QString rnx_file = settings.value("rnxScript").toString();
2119 if ( !rnx_file.isEmpty() ) {
2120 QFile rnxfile(settings.value("rnxScript").toString());
2121 if (!rnxfile.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations script", true);
2122 }
2123
2124 QDir ephdir(settings.value("ephPath").toString());
2125 if (!ephdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Ephemeris directory", true);
2126
2127 QDir corrdir(settings.value("corrPath").toString());
2128 if (!corrdir.exists()) BNC_CORE->slotMessage("Cannot find Broadcast Corrections directory", true);
2129
2130 QString advise_file = settings.value("adviseScript").toString();
2131 if ( !advise_file.isEmpty() ) {
2132 QFile advisefile(settings.value("adviseScript").toString());
2133 if (!advisefile.exists()) BNC_CORE->slotMessage("Cannot find Outages script", true);
2134 }
2135
2136 _caster->readMountPoints();
2137
2138 _casterEph = new bncEphUploadCaster();
2139}
2140
2141// Retrieve Data
2142////////////////////////////////////////////////////////////////////////////
2143void bncWindow::slotStop() {
2144 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving/processing data?",
2145 QMessageBox::Yes, QMessageBox::No,
2146 QMessageBox::NoButton);
2147 if (iRet == QMessageBox::Yes) {
2148 BNC_CORE->stopPPP();
2149 BNC_CORE->stopCombination();
2150 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
2151 delete _casterEph; _casterEph = 0;
2152 _runningRealTime = false;
2153 _runningPPP = false;
2154 enableStartStop();
2155 }
2156}
2157
2158// Close Application gracefully
2159////////////////////////////////////////////////////////////////////////////
2160void bncWindow::closeEvent(QCloseEvent* event) {
2161
2162 int iRet = QMessageBox::question(this, "Close", "Save Options?",
2163 QMessageBox::Yes, QMessageBox::No,
2164 QMessageBox::Cancel);
2165
2166 if (iRet == QMessageBox::Cancel) {
2167 event->ignore();
2168 return;
2169 }
2170 else if (iRet == QMessageBox::Yes) {
2171 slotSaveOptions();
2172 }
2173
2174 BNC_CORE->stopPPP();
2175
2176 QMainWindow::closeEvent(event);
2177}
2178
2179// User changed the selection of mountPoints
2180////////////////////////////////////////////////////////////////////////////
2181void bncWindow::slotSelectionChanged() {
2182 if (_mountPointsTable->selectedItems().isEmpty()) {
2183 _actDeleteMountPoints->setEnabled(false);
2184 }
2185 else {
2186 _actDeleteMountPoints->setEnabled(true);
2187 }
2188}
2189
2190// Display Program Messages
2191////////////////////////////////////////////////////////////////////////////
2192void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
2193 if (showOnScreen ) {
2194 _log->append(QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg);
2195 }
2196}
2197
2198// About Message
2199////////////////////////////////////////////////////////////////////////////
2200void bncWindow::slotAbout() {
2201 new bncAboutDlg(0);
2202}
2203
2204//Flowchart
2205////////////////////////////////////////////////////////////////////////////
2206void bncWindow::slotFlowchart() {
2207 new bncFlowchartDlg(0);
2208}
2209
2210// Help Window
2211////////////////////////////////////////////////////////////////////////////
2212void bncWindow::slotHelp() {
2213 QUrl url;
2214 url.setPath(":bnchelp.html");
2215 new bncHlpDlg(0, url);
2216}
2217
2218// Select Fonts
2219////////////////////////////////////////////////////////////////////////////
2220void bncWindow::slotFontSel() {
2221 bool ok;
2222 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
2223 if (ok) {
2224 bncSettings settings;
2225 settings.setValue("font", newFont.toString());
2226 QApplication::setFont(newFont);
2227 int ww = QFontMetrics(newFont).width('w');
2228 setMinimumSize(60*ww, 80*ww);
2229 resize(60*ww, 80*ww);
2230 }
2231}
2232
2233// Whats This Help
2234void bncWindow::slotWhatsThis() {
2235 QWhatsThis::enterWhatsThisMode();
2236}
2237
2238//
2239////////////////////////////////////////////////////////////////////////////
2240void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
2241 _threads = threads;
2242
2243 _bncFigure->updateMountPoints();
2244 _bncFigureLate->updateMountPoints();
2245
2246 populateMountPointsTable();
2247 bncSettings settings;
2248 _outSamplSpinBox->setValue(settings.value("outSampl").toInt());
2249 _outWaitSpinBox->setValue(settings.value("outWait").toInt());
2250 QListIterator<bncGetThread*> iTh(threads);
2251 while (iTh.hasNext()) {
2252 bncGetThread* thread = iTh.next();
2253 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
2254 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
2255 "@" + _mountPointsTable->item(iRow, 1)->text() );
2256 if (url == thread->mountPoint() &&
2257 _mountPointsTable->item(iRow, 4)->text() == thread->latitude() &&
2258 _mountPointsTable->item(iRow, 5)->text() == thread->longitude() ) {
2259 ((bncTableItem*) _mountPointsTable->item(iRow, 8))->setGetThread(thread);
2260 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
2261 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2262 connect(thread, SIGNAL(newBytes(QByteArray, double)),
2263 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2264 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
2265 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2266 connect(thread, SIGNAL(newLatency(QByteArray, double)),
2267 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2268 break;
2269 }
2270 }
2271 }
2272}
2273
2274//
2275////////////////////////////////////////////////////////////////////////////
2276void bncWindow::CreateMenu() {
2277 // Create Menus
2278 // ------------
2279 _menuFile = menuBar()->addMenu(tr("&File"));
2280 _menuFile->addAction(_actFontSel);
2281 _menuFile->addSeparator();
2282 _menuFile->addAction(_actSaveOpt);
2283 _menuFile->addSeparator();
2284 _menuFile->addAction(_actQuit);
2285
2286 _menuHlp = menuBar()->addMenu(tr("&Help"));
2287 _menuHlp->addAction(_actHelp);
2288 _menuHlp->addAction(_actFlowchart);
2289 _menuHlp->addAction(_actAbout);
2290}
2291
2292// Toolbar
2293////////////////////////////////////////////////////////////////////////////
2294void bncWindow::AddToolbar() {
2295 QToolBar* toolBar = new QToolBar;
2296 addToolBar(Qt::BottomToolBarArea, toolBar);
2297 toolBar->setMovable(false);
2298 toolBar->addAction(_actAddMountPoints);
2299 toolBar->addAction(_actDeleteMountPoints);
2300 toolBar->addAction(_actMapMountPoints);
2301 toolBar->addAction(_actStart);
2302 toolBar->addAction(_actStop);
2303 toolBar->addWidget(new QLabel(" "));
2304 toolBar->addAction(_actwhatsthis);
2305}
2306
2307// About
2308////////////////////////////////////////////////////////////////////////////
2309bncAboutDlg::bncAboutDlg(QWidget* parent) :
2310 QDialog(parent) {
2311
2312 QTextBrowser* tb = new QTextBrowser;
2313 QUrl url; url.setPath(":bncabout.html");
2314 tb->setSource(url);
2315 tb->setReadOnly(true);
2316
2317 int ww = QFontMetrics(font()).width('w');
2318 QPushButton* _closeButton = new QPushButton("Close");
2319 _closeButton->setMaximumWidth(10*ww);
2320 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2321
2322 QGridLayout* dlgLayout = new QGridLayout();
2323 QLabel* img = new QLabel();
2324 img->setPixmap(QPixmap(":ntrip-logo.png"));
2325 dlgLayout->addWidget(img, 0,0);
2326 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
2327 dlgLayout->addWidget(tb,1,0,1,2);
2328 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2329
2330 setLayout(dlgLayout);
2331 resize(60*ww, 60*ww);
2332 setWindowTitle("About BNC");
2333 show();
2334}
2335
2336//
2337////////////////////////////////////////////////////////////////////////////
2338bncAboutDlg::~bncAboutDlg() {
2339
2340};
2341
2342// Flowchart
2343////////////////////////////////////////////////////////////////////////////
2344bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2345 QDialog(parent) {
2346
2347 int ww = QFontMetrics(font()).width('w');
2348 QPushButton* _closeButton = new QPushButton("Close");
2349 _closeButton->setMaximumWidth(10*ww);
2350 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2351
2352 QGridLayout* dlgLayout = new QGridLayout();
2353 QLabel* img = new QLabel();
2354 img->setPixmap(QPixmap(":bncflowchart.png"));
2355 dlgLayout->addWidget(img, 0,0);
2356 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2357
2358 setLayout(dlgLayout);
2359 setWindowTitle("Flow Chart");
2360 show();
2361}
2362
2363//
2364////////////////////////////////////////////////////////////////////////////
2365bncFlowchartDlg::~bncFlowchartDlg() {
2366};
2367
2368// Enable/Disable Widget (and change its color)
2369////////////////////////////////////////////////////////////////////////////
2370void bncWindow::enableWidget(bool enable, QWidget* widget) {
2371
2372 const static QPalette paletteWhite(QColor(255, 255, 255));
2373 const static QPalette paletteGray(QColor(230, 230, 230));
2374
2375 widget->setEnabled(enable);
2376 if (enable) {
2377 widget->setPalette(paletteWhite);
2378 }
2379 else {
2380 widget->setPalette(paletteGray);
2381 }
2382}
2383
2384// Bnc Text
2385////////////////////////////////////////////////////////////////////////////
2386void bncWindow::slotBncTextChanged(){
2387
2388 const static QPalette paletteWhite(QColor(255, 255, 255));
2389 const static QPalette paletteGray(QColor(230, 230, 230));
2390
2391 bool enable = true;
2392
2393 // Proxy
2394 //------
2395 if (sender() == 0 || sender() == _proxyHostLineEdit) {
2396 enable = !_proxyHostLineEdit->text().isEmpty();
2397 enableWidget(enable, _proxyPortLineEdit);
2398 }
2399
2400 // RINEX Observations
2401 // ------------------
2402 if (sender() == 0 || sender() == _rnxPathLineEdit) {
2403 enable = !_rnxPathLineEdit->text().isEmpty();
2404 enableWidget(enable, _rnxIntrComboBox);
2405 enableWidget(enable, _rnxSamplSpinBox);
2406 enableWidget(enable, _rnxSkelLineEdit);
2407 enableWidget(enable, _rnxFileCheckBox);
2408 enableWidget(enable, _rnxScrpLineEdit);
2409 enableWidget(enable, _rnxV2Priority);
2410 enableWidget(enable, _rnxV3CheckBox);
2411
2412 bool enable1 = true;
2413 enable1 = _rnxV3CheckBox->isChecked();
2414 if (enable && enable1) {
2415 enableWidget(false, _rnxV2Priority);
2416 }
2417 if (enable && !enable1) {
2418 enableWidget(true, _rnxV2Priority);
2419 }
2420 }
2421
2422 // RINEX Observations, Signal Priority
2423 // -----------------------------------
2424 if (sender() == 0 || sender() == _rnxV3CheckBox) {
2425 if (!_rnxPathLineEdit->text().isEmpty()) {
2426 enableWidget(enable, _rnxIntrComboBox);
2427 enable = !_rnxV3CheckBox->isChecked();
2428 enableWidget(enable, _rnxV2Priority);
2429 }
2430 }
2431
2432 // RINEX Ephemeris
2433 // ---------------
2434 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _ephOutPortLineEdit) {
2435 enable = !_ephPathLineEdit->text().isEmpty() || !_ephOutPortLineEdit->text().isEmpty();
2436 enableWidget(enable, _ephIntrComboBox);
2437 enableWidget(enable, _ephV3CheckBox);
2438 enableWidget(enable, _ephV3filenameCheckBox);
2439 }
2440
2441 // Broadcast Corrections
2442 // ---------------------
2443 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2444 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2445 enableWidget(enable, _corrIntrComboBox);
2446 }
2447
2448 // Feed Engine
2449 // -----------
2450 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2451 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2452 enableWidget(enable, _outWaitSpinBox);
2453 enableWidget(enable, _outSamplSpinBox);
2454 }
2455
2456 // Serial Output
2457 // -------------
2458 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
2459 sender() == _serialAutoNMEAComboBox) {
2460 enable = !_serialMountPointLineEdit->text().isEmpty();
2461 enableWidget(enable, _serialPortNameLineEdit);
2462 enableWidget(enable, _serialBaudRateComboBox);
2463 enableWidget(enable, _serialParityComboBox);
2464 enableWidget(enable, _serialDataBitsComboBox);
2465 enableWidget(enable, _serialStopBitsComboBox);
2466 enableWidget(enable, _serialFlowControlComboBox);
2467 enableWidget(enable, _serialAutoNMEAComboBox);
2468 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() == "Auto";
2469 enableWidget(enable2, _serialFileNMEALineEdit);
2470 bool enable3 = enable && _serialAutoNMEAComboBox->currentText().contains("Manual");
2471 enableWidget(enable3, _serialHeightNMEALineEdit);
2472 enableWidget(enable3, _serialManualNMEASamplingSpinBox);
2473 }
2474
2475 // Outages
2476 // -------
2477 if (sender() == 0 || sender() == _adviseObsRateComboBox) {
2478 enable = !_adviseObsRateComboBox->currentText().isEmpty();
2479 enableWidget(enable, _adviseFailSpinBox);
2480 enableWidget(enable, _adviseRecoSpinBox);
2481 enableWidget(enable, _adviseScriptLineEdit);
2482 }
2483
2484 // Miscellaneous
2485 // -------------
2486 if (sender() == 0 || sender() == _miscMountLineEdit) {
2487 enable = !_miscMountLineEdit->text().isEmpty();
2488 enableWidget(enable, _miscIntrComboBox);
2489 enableWidget(enable, _miscScanRTCMCheckBox);
2490 enableWidget(enable, _miscPortLineEdit);
2491 }
2492
2493 // Combine Corrections
2494 // -------------------
2495 if (sender() == 0 || sender() == _cmbTable) {
2496 int iRow = _cmbTable->rowCount();
2497 if (iRow > 0) {
2498 enableWidget(true, _cmbMethodComboBox);
2499 enableWidget(true, _cmbMaxresLineEdit);
2500 enableWidget(true, _cmbSamplSpinBox);
2501 enableWidget(true, _cmbUseGlonass);
2502 }
2503 else {
2504 enableWidget(false, _cmbMethodComboBox);
2505 enableWidget(false, _cmbMaxresLineEdit);
2506 enableWidget(false, _cmbSamplSpinBox);
2507 enableWidget(false, _cmbUseGlonass);
2508 }
2509 }
2510
2511 // Upload(clk)
2512 // -----------
2513 int iRow = _uploadTable->rowCount();
2514 if (iRow > 0) {
2515 enableWidget(true, _uploadIntrComboBox);
2516 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2517 enableWidget(true, _uploadSamplClkRnxSpinBox);
2518 enableWidget(true, _uploadSamplSp3SpinBox);
2519 enableWidget(true, _uploadAntexFile);
2520 }
2521 else {
2522 enableWidget(false, _uploadIntrComboBox);
2523 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2524 enableWidget(false, _uploadSamplClkRnxSpinBox);
2525 enableWidget(false, _uploadSamplSp3SpinBox);
2526 enableWidget(false, _uploadAntexFile);
2527 }
2528
2529 // Upload(eph)
2530 // -----------
2531 iRow = _uploadEphTable->rowCount();
2532 if (iRow > 0) {
2533 enableWidget(true, _uploadSamplRtcmEphSpinBox);
2534 }
2535 else {
2536 enableWidget(false, _uploadSamplRtcmEphSpinBox);
2537 }
2538
2539 // QC
2540 // --
2541 if (sender() == 0 || sender() == _reqcActionComboBox || sender() == _reqcSkyPlotSignals) {
2542 enable = !_reqcActionComboBox->currentText().isEmpty();
2543 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2544// bool enablePlot = !_reqcSkyPlotSignals->text().isEmpty();
2545 enableWidget(enable, _reqcObsFileChooser);
2546 enableWidget(enable, _reqcNavFileChooser);
2547 enableWidget(enable, _reqcOutLogLineEdit);
2548 enableWidget(enable && enable10, _reqcEditOptionButton);
2549 enableWidget(enable && enable10, _reqcOutObsLineEdit);
2550 enableWidget(enable && enable10, _reqcOutNavLineEdit);
2551 enableWidget(enable && !enable10, _reqcLogSummaryOnly);
2552 enableWidget(enable && !enable10, _reqcSkyPlotSignals);
2553// enableWidget(enable && !enable10 && enablePlot, _reqcPlotDirLineEdit);
2554 enableWidget(enable && !enable10, _reqcPlotDirLineEdit);
2555 }
2556
2557 // SP3 File Comparison
2558 // -------------------
2559 if (sender() == 0 || sender() == _sp3CompFileChooser) {
2560 enable = !_sp3CompFileChooser->fileName().isEmpty();
2561 enableWidget(enable, _sp3CompLogLineEdit);
2562 enableWidget(enable, _sp3CompExclude);
2563 }
2564
2565 enableStartStop();
2566}
2567
2568//
2569////////////////////////////////////////////////////////////////////////////
2570void bncWindow::slotAddCmbRow() {
2571 int iRow = _cmbTable->rowCount();
2572 _cmbTable->insertRow(iRow);
2573 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2574 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2575 }
2576}
2577
2578//
2579////////////////////////////////////////////////////////////////////////////
2580void bncWindow::slotDelCmbRow() {
2581
2582 const static QPalette paletteWhite(QColor(255, 255, 255));
2583 const static QPalette paletteGray(QColor(230, 230, 230));
2584
2585 int nRows = _cmbTable->rowCount();
2586 bool flg[nRows];
2587 for (int iRow = 0; iRow < nRows; iRow++) {
2588 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2589 flg[iRow] = true;
2590 }
2591 else {
2592 flg[iRow] = false;
2593 }
2594 }
2595 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2596 if (flg[iRow]) {
2597 _cmbTable->removeRow(iRow);
2598 }
2599 }
2600 nRows = _cmbTable->rowCount();
2601 if (nRows < 1) {
2602 enableWidget(false, _cmbMethodComboBox);
2603 enableWidget(false, _cmbMaxresLineEdit);
2604 enableWidget(false, _cmbSamplSpinBox);
2605 enableWidget(false, _cmbUseGlonass);
2606 }
2607}
2608
2609//
2610////////////////////////////////////////////////////////////////////////////
2611void bncWindow::populateCmbTable() {
2612
2613 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2614 _cmbTable->removeRow(iRow);
2615 }
2616
2617 bncSettings settings;
2618
2619 int iRow = -1;
2620 QListIterator<QString> it(settings.value("cmbStreams").toStringList());
2621 while (it.hasNext()) {
2622 QStringList hlp = it.next().split(" ");
2623 if (hlp.size() > 2) {
2624 ++iRow;
2625 _cmbTable->insertRow(iRow);
2626 }
2627 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2628 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2629 }
2630 }
2631}
2632
2633//
2634////////////////////////////////////////////////////////////////////////////
2635void bncWindow::slotAddUploadRow() {
2636 int iRow = _uploadTable->rowCount();
2637 _uploadTable->insertRow(iRow);
2638 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2639 if (iCol == 3) {
2640 QLineEdit* passwd = new QLineEdit();
2641 passwd->setFrame(false);
2642 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2643 _uploadTable->setCellWidget(iRow, iCol, passwd);
2644 }
2645 else if (iCol == 4) {
2646 QComboBox* system = new QComboBox();
2647 system->setEditable(false);
2648 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2649 system->setFrame(false);
2650 _uploadTable->setCellWidget(iRow, iCol, system);
2651 }
2652 else if (iCol == 5) {
2653 QCheckBox* com = new QCheckBox();
2654 _uploadTable->setCellWidget(iRow, iCol, com);
2655 }
2656 else if (iCol == 11) {
2657 bncTableItem* bncIt = new bncTableItem();
2658 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2659 _uploadTable->setItem(iRow, iCol, bncIt);
2660 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2661 }
2662 else {
2663 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2664 }
2665 }
2666}
2667
2668//
2669////////////////////////////////////////////////////////////////////////////
2670void bncWindow::slotDelUploadRow() {
2671 BNC_CORE->_uploadTableItems.clear();
2672 int nRows = _uploadTable->rowCount();
2673 bool flg[nRows];
2674 for (int iRow = 0; iRow < nRows; iRow++) {
2675 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2676 flg[iRow] = true;
2677 }
2678 else {
2679 flg[iRow] = false;
2680 }
2681 }
2682 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2683 if (flg[iRow]) {
2684 _uploadTable->removeRow(iRow);
2685 }
2686 }
2687 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2688 BNC_CORE->_uploadTableItems[iRow] =
2689 (bncTableItem*) _uploadTable->item(iRow, 11);
2690 }
2691 nRows = _uploadTable->rowCount();
2692 if (nRows < 1) {
2693 enableWidget(false, _uploadIntrComboBox);
2694 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2695 enableWidget(false, _uploadSamplSp3SpinBox);
2696 enableWidget(false, _uploadSamplClkRnxSpinBox);
2697 enableWidget(false, _uploadAntexFile);
2698 }
2699}
2700
2701//
2702////////////////////////////////////////////////////////////////////////////
2703void bncWindow::populateUploadTable() {
2704 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2705 _uploadTable->removeRow(iRow);
2706 }
2707
2708 bncSettings settings;
2709
2710 int iRow = -1;
2711 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2712 while (it.hasNext()) {
2713 QStringList hlp = it.next().split(",");
2714 if (hlp.size() > 6) {
2715 ++iRow;
2716 _uploadTable->insertRow(iRow);
2717 }
2718 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2719 if (iCol == 3) {
2720 QLineEdit* passwd = new QLineEdit();
2721 passwd->setFrame(false);
2722 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2723 passwd->setText(hlp[iCol]);
2724 _uploadTable->setCellWidget(iRow, iCol, passwd);
2725 }
2726 else if (iCol == 4) {
2727 QComboBox* system = new QComboBox();
2728 system->setEditable(false);
2729 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2730 system->setFrame(false);
2731 system->setCurrentIndex(system->findText(hlp[iCol]));
2732 _uploadTable->setCellWidget(iRow, iCol, system);
2733 }
2734 else if (iCol == 5) {
2735 QCheckBox* com = new QCheckBox();
2736 if (hlp[iCol].toInt() == Qt::Checked) {
2737 com->setCheckState(Qt::Checked);
2738 }
2739 _uploadTable->setCellWidget(iRow, iCol, com);
2740 }
2741 else if (iCol == 11) {
2742 bncTableItem* bncIt = new bncTableItem();
2743 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2744 _uploadTable->setItem(iRow, iCol, bncIt);
2745 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2746 }
2747 else {
2748 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2749 }
2750 }
2751 }
2752}
2753
2754//
2755////////////////////////////////////////////////////////////////////////////
2756void bncWindow::slotSetUploadTrafo() {
2757 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2758 dlg->exec();
2759 delete dlg;
2760}
2761
2762//
2763////////////////////////////////////////////////////////////////////////////
2764void bncWindow::slotAddUploadEphRow() {
2765 int iRow = _uploadEphTable->rowCount();
2766 _uploadEphTable->insertRow(iRow);
2767 for (int iCol = 0; iCol < _uploadEphTable->columnCount(); iCol++) {
2768 if (iCol == 3) {
2769 QLineEdit* passwd = new QLineEdit();
2770 passwd->setFrame(false);
2771 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2772 _uploadEphTable->setCellWidget(iRow, iCol, passwd);
2773 }
2774 else if (iCol == 4) {
2775 QComboBox* system = new QComboBox();
2776 system->setEditable(false);
2777 system->addItems(QString("ALL,GPS,GLONASS,Galileo,BDS,QZSS,SBAS").split(","));
2778 system->setFrame(false);
2779 _uploadEphTable->setCellWidget(iRow, iCol, system);
2780 }
2781 else if (iCol == 5) {
2782 bncTableItem* bncIt = new bncTableItem();
2783 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2784 _uploadEphTable->setItem(iRow, iCol, bncIt);
2785 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2786 }
2787 else {
2788 _uploadEphTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2789 }
2790 }
2791}
2792
2793//
2794////////////////////////////////////////////////////////////////////////////
2795void bncWindow::slotDelUploadEphRow() {
2796 BNC_CORE->_uploadTableItems.clear();
2797 int nRows = _uploadEphTable->rowCount();
2798 bool flg[nRows];
2799 for (int iRow = 0; iRow < nRows; iRow++) {
2800 if (_uploadEphTable->isItemSelected(_uploadEphTable->item(iRow,1))) {
2801 flg[iRow] = true;
2802 }
2803 else {
2804 flg[iRow] = false;
2805 }
2806 }
2807 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2808 if (flg[iRow]) {
2809 _uploadEphTable->removeRow(iRow);
2810 }
2811 }
2812 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2813 BNC_CORE->_uploadTableItems[iRow] =
2814 (bncTableItem*) _uploadEphTable->item(iRow, 5);
2815 }
2816 nRows = _uploadEphTable->rowCount();
2817 if (nRows < 1) {
2818 enableWidget(false, _uploadSamplRtcmEphSpinBox);
2819 }
2820}
2821
2822//
2823////////////////////////////////////////////////////////////////////////////
2824void bncWindow::populateUploadEphTable() {
2825 for (int iRow = _uploadEphTable->rowCount()-1; iRow >=0; iRow--) {
2826 _uploadEphTable->removeRow(iRow);
2827 }
2828
2829 bncSettings settings;
2830
2831 int iRow = -1;
2832 QListIterator<QString> it(settings.value("uploadEphMountpointsOut").toStringList());
2833 while (it.hasNext()) {
2834 QStringList hlp = it.next().split(",");
2835 if (hlp.size() > 4) {
2836 ++iRow;
2837 _uploadEphTable->insertRow(iRow);
2838 }
2839 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2840 if (iCol == 3) {
2841 QLineEdit* passwd = new QLineEdit();
2842 passwd->setFrame(false);
2843 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2844 passwd->setText(hlp[iCol]);
2845 _uploadEphTable->setCellWidget(iRow, iCol, passwd);
2846 }
2847 else if (iCol == 4) {
2848 QComboBox* system = new QComboBox();
2849 system->setEditable(false);
2850 system->addItems(QString("ALL,GPS,GLONASS,Galileo,BDS,QZSS,SBAS").split(","));
2851 system->setFrame(false);
2852 system->setCurrentIndex(system->findText(hlp[iCol]));
2853 _uploadEphTable->setCellWidget(iRow, iCol, system);
2854 }
2855 else if (iCol == 5) {
2856 bncTableItem* bncIt = new bncTableItem();
2857 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2858 _uploadEphTable->setItem(iRow, iCol, bncIt);
2859 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2860 }
2861 else {
2862 _uploadEphTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2863 }
2864 }
2865 }
2866}
2867
2868
2869// Progress Bar Change
2870////////////////////////////////////////////////////////////////////////////
2871void bncWindow::slotPostProcessingProgress(int nEpo) {
2872 _actStart->setText(QString("%1 Epochs").arg(nEpo));
2873}
2874
2875// Post-Processing Reqc Finished
2876////////////////////////////////////////////////////////////////////////////
2877void bncWindow::slotPostProcessingFinished() {
2878 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
2879 _runningPPP = false;
2880 _runningEdit = false;
2881 _runningQC = false;
2882 _runningSp3Comp = false;
2883 _actStart->setText(tr("Sta&rt"));
2884 enableStartStop();
2885}
2886
2887// Edit teqc-like editing options
2888////////////////////////////////////////////////////////////////////////////
2889void bncWindow::slotReqcEditOption() {
2890 saveOptions();
2891 reqcDlg* dlg = new reqcDlg(this);
2892 dlg->move(this->pos().x()+50, this->pos().y()+50);
2893 dlg->exec();
2894 delete dlg;
2895}
2896
2897// Enable/Disable Start and Stop Buttons
2898////////////////////////////////////////////////////////////////////////////
2899void bncWindow::enableStartStop() {
2900 if ( running() ) {
2901 _actStart->setEnabled(false);
2902 if (_runningRealTime || _runningPPP) {
2903 _actStop->setEnabled(true);
2904 }
2905 }
2906 else {
2907 _actStart->setEnabled(true);
2908 _actStop->setEnabled(false);
2909 }
2910}
2911
2912// Show Map
2913////////////////////////////////////////////////////////////////////////////
2914void bncWindow::slotMapMountPoints() {
2915 saveOptions();
2916 t_bncMap* bncMap = new t_bncMap(this);
2917 bncMap->setMinimumSize(800, 600);
2918 bncMap->setWindowTitle("Selected Mountpoints");
2919
2920 bncSettings settings;
2921 QListIterator<QString> it(settings.value("mountPoints").toStringList());
2922 while (it.hasNext()) {
2923 QStringList hlp = it.next().split(" ");
2924 if (hlp.size() < 5) continue;
2925 QUrl url(hlp[0]);
2926 double latDeg = hlp[3].toDouble();
2927 double lonDeg = hlp[4].toDouble();
2928 bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
2929 }
2930
2931 bncMap->show();
2932}
2933
2934// Show Map
2935////////////////////////////////////////////////////////////////////////////
2936void bncWindow::slotMapPPP() {
2937#ifdef QT_WEBKIT
2938 saveOptions();
2939 enableWidget(false, _pppWidgets._mapWinButton);
2940 enableWidget(false, _pppWidgets._useGoogleMap);
2941 enableWidget(false, _pppWidgets._useOpenStreetMap);
2942 enableWidget(false, _pppWidgets._mapWinDotSize);
2943 enableWidget(false, _pppWidgets._mapWinDotColor);
2944
2945 if (!_mapWin) {
2946 _mapWin = new bncMapWin(this);
2947 connect(_mapWin, SIGNAL(mapClosed()), this, SLOT(slotMapPPPClosed()));
2948 connect(BNC_CORE, SIGNAL(newPosition(QByteArray, bncTime, QVector<double>)),
2949 _mapWin, SLOT(slotNewPosition(QByteArray, bncTime, QVector<double>)));
2950 }
2951 _mapWin->show();
2952#else
2953 QMessageBox::information(this, "Information",
2954 "Qt Library compiled without QtWebKit");
2955#endif
2956}
2957
2958// Show Map
2959////////////////////////////////////////////////////////////////////////////
2960void bncWindow::slotMapPPPClosed() {
2961#ifdef QT_WEBKIT
2962 enableWidget(true, _pppWidgets._mapWinButton);
2963 enableWidget(true, _pppWidgets._useGoogleMap);
2964 enableWidget(true, _pppWidgets._useOpenStreetMap);
2965 enableWidget(true, _pppWidgets._mapWinDotSize);
2966 enableWidget(true, _pppWidgets._mapWinDotColor);
2967 if (_mapWin) {
2968 QListIterator<bncGetThread*> it(_threads);
2969 while (it.hasNext()) {
2970 bncGetThread* thread = it.next();
2971 thread->disconnect(_mapWin);
2972 }
2973 _mapWin->deleteLater();
2974 _mapWin = 0;
2975 }
2976#endif
2977}
Note: See TracBrowser for help on using the repository browser.