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

Last change on this file since 7884 was 7884, checked in by stuerze, 6 years ago

BNC's release number is now part of variable BNCVERSION

File size: 150.0 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 _uploadEphHostLineEdit = new QLineEdit(settings.value("uploadEphHost").toString());
567 _uploadEphPortLineEdit = new QLineEdit(settings.value("uploadEphPort").toString());
568 _uploadEphPasswordLineEdit = new QLineEdit(settings.value("uploadEphPassword").toString());
569 _uploadEphPasswordLineEdit->setEchoMode(QLineEdit::PasswordEchoOnEdit);
570 _uploadEphMountpointLineEdit = new QLineEdit(settings.value("uploadEphMountpoint").toString());
571 _uploadEphSampleSpinBox = new QSpinBox;
572 _uploadEphSampleSpinBox->setMinimum(5);
573 _uploadEphSampleSpinBox->setMaximum(60);
574 _uploadEphSampleSpinBox->setSingleStep(5);
575 _uploadEphSampleSpinBox->setMaximumWidth(9*ww);
576 _uploadEphSampleSpinBox->setValue(settings.value("uploadEphSample").toInt());
577 _uploadEphSampleSpinBox->setSuffix(" sec");
578 _uploadEphBytesCounter = new bncBytesCounter;
579
580 // Canvas with Editable Fields
581 // ---------------------------
582 _canvas = new QWidget;
583 setCentralWidget(_canvas);
584
585 _aogroup = new QTabWidget();
586 _aogroup->setElideMode(Qt::ElideNone);
587 _aogroup->setUsesScrollButtons(true);
588 QWidget* pgroup = new QWidget();
589 QWidget* ggroup = new QWidget();
590 QWidget* sgroup = new QWidget();
591 QWidget* egroup = new QWidget();
592 QWidget* agroup = new QWidget();
593 QWidget* cgroup = new QWidget();
594 QWidget* ogroup = new QWidget();
595 QWidget* rgroup = new QWidget();
596 QWidget* sergroup = new QWidget();
597 QWidget* pppGroup1 = new QWidget();
598 QWidget* pppGroup2 = new QWidget();
599 QWidget* pppGroup3 = new QWidget();
600 QWidget* pppGroup4 = new QWidget();
601 QWidget* reqcgroup = new QWidget();
602 QWidget* sp3CompGroup = new QWidget();
603 QWidget* cmbgroup = new QWidget();
604 QWidget* uploadgroup = new QWidget();
605 QWidget* uploadEphgroup = new QWidget();
606 _aogroup->addTab(pgroup,tr("Network"));
607 _aogroup->addTab(ggroup,tr("General"));
608 _aogroup->addTab(ogroup,tr("RINEX Observations"));
609 _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
610 _aogroup->addTab(reqcgroup,tr("RINEX Editing && QC"));
611 _aogroup->addTab(sp3CompGroup,tr("SP3 Comparison"));
612 _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
613 _aogroup->addTab(sgroup,tr("Feed Engine"));
614 _aogroup->addTab(sergroup,tr("Serial Output"));
615 _aogroup->addTab(agroup,tr("Outages"));
616 _aogroup->addTab(rgroup,tr("Miscellaneous"));
617 _aogroup->addTab(pppGroup1,tr("PPP (1)"));
618 _aogroup->addTab(pppGroup2,tr("PPP (2)"));
619 _aogroup->addTab(pppGroup3,tr("PPP (3)"));
620 _aogroup->addTab(pppGroup4,tr("PPP (4)"));
621 _aogroup->addTab(cmbgroup,tr("Combine Corrections"));
622 _aogroup->addTab(uploadgroup,tr("Upload Corrections"));
623 _aogroup->addTab(uploadEphgroup,tr("Upload Ephemeris"));
624
625 // Log Tab
626 // -------
627 _loggroup = new QTabWidget();
628 _loggroup->addTab(_log,tr("Log"));
629 _loggroup->addTab(_bncFigure,tr("Throughput"));
630 _loggroup->addTab(_bncFigureLate,tr("Latency"));
631 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
632
633 // Netowork (Proxy and SSL) Tab
634 // ----------------------------
635 QGridLayout* pLayout = new QGridLayout;
636 pLayout->setColumnMinimumWidth(0,13*ww);
637 _proxyPortLineEdit->setMaximumWidth(9*ww);
638
639 pLayout->addWidget(new QLabel("Settings for proxy in protected networks and for SSL authorization, leave boxes blank if none.<br>"),0, 0, 1, 50);
640 pLayout->addWidget(new QLabel("Proxy host"), 1, 0);
641 pLayout->addWidget(_proxyHostLineEdit, 1, 1, 1,10);
642 pLayout->addWidget(new QLabel("Proxy port"), 2, 0);
643 pLayout->addWidget(_proxyPortLineEdit, 2, 1);
644 pLayout->addWidget(new QLabel("Path to SSL certificates"), 3, 0);
645 pLayout->addWidget(_sslCaCertPathLineEdit, 3, 1, 1,10);
646 pLayout->addWidget(new QLabel("Default: " + bncSslConfig::defaultPath()), 3,11, 1,20);
647 pLayout->addWidget(new QLabel("Ignore SSL authorization errors"), 4, 0);
648 pLayout->addWidget(_sslIgnoreErrorsCheckBox, 4, 1, 1,10);
649 pLayout->addWidget(new QLabel(""), 5, 1);
650 pLayout->setRowStretch(6, 999);
651
652 pgroup->setLayout(pLayout);
653
654 // General Tab
655 // -----------
656 QGridLayout* gLayout = new QGridLayout;
657 gLayout->setColumnMinimumWidth(0,14*ww);
658 _onTheFlyComboBox->setMaximumWidth(9*ww);
659
660 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);
661 gLayout->addWidget(new QLabel("Logfile (full path)"), 1, 0);
662 gLayout->addWidget(_logFileLineEdit, 1, 1, 1,20);
663 gLayout->addWidget(new QLabel("Append files"), 2, 0);
664 gLayout->addWidget(_rnxAppendCheckBox, 2, 1);
665 gLayout->addWidget(new QLabel("Reread configuration"), 3, 0);
666 gLayout->addWidget(_onTheFlyComboBox, 3, 1);
667 gLayout->addWidget(new QLabel("Auto start"), 4, 0);
668 gLayout->addWidget(_autoStartCheckBox, 4, 1);
669 gLayout->addWidget(new QLabel("Raw output file (full path)"), 5, 0);
670 gLayout->addWidget(_rawOutFileLineEdit, 5, 1, 1,20);
671 gLayout->addWidget(new QLabel(""), 6, 1);
672 gLayout->setRowStretch(7, 999);
673
674 ggroup->setLayout(gLayout);
675
676 // RINEX Observations
677 // ------------------
678 QGridLayout* oLayout = new QGridLayout;
679 oLayout->setColumnMinimumWidth(0,14*ww);
680 _rnxIntrComboBox->setMaximumWidth(9*ww);
681 _rnxSamplSpinBox->setMaximumWidth(9*ww);
682
683 _rnxV2Priority->setMaximumWidth(19*ww);
684
685 oLayout->addWidget(new QLabel("Saving RINEX observation files.<br>"),0, 0, 1,50);
686 oLayout->addWidget(new QLabel("Directory"), 1, 0);
687 oLayout->addWidget(_rnxPathLineEdit, 1, 1, 1, 15);
688 oLayout->addWidget(new QLabel("Interval"), 2, 0);
689 oLayout->addWidget(_rnxIntrComboBox, 2, 1);
690 oLayout->addWidget(new QLabel(" Sampling"), 2, 2, Qt::AlignRight);
691 oLayout->addWidget(_rnxSamplSpinBox, 2, 3, Qt::AlignLeft);
692 oLayout->addWidget(new QLabel("Skeleton extension"), 3, 0);
693 oLayout->addWidget(_rnxSkelLineEdit, 3, 1, Qt::AlignLeft);
694 oLayout->addWidget(new QLabel("Skeleton mandatory"), 3, 2);
695 oLayout->addWidget(_rnxFileCheckBox, 3, 3);
696 oLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
697 oLayout->addWidget(_rnxScrpLineEdit, 4, 1, 1, 15);
698 oLayout->addWidget(new QLabel("Version 2"), 5, 0);
699 oLayout->addWidget(_rnxV2Priority, 5, 1);
700 oLayout->addWidget(new QLabel("Signal priority"), 5, 2);
701 oLayout->addWidget(new QLabel("Version 3"), 6, 0);
702 oLayout->addWidget(_rnxV3CheckBox, 6, 1);
703 oLayout->addWidget(new QLabel("Version 3 filenames"), 6, 2);
704 oLayout->addWidget(_rnxV3filenameCheckBox, 6, 3);
705 oLayout->addWidget(new QLabel(""), 7, 1);
706 oLayout->setRowStretch(8, 999);
707
708 ogroup->setLayout(oLayout);
709
710 // RINEX Ephemeris
711 // ---------------
712 QGridLayout* eLayout = new QGridLayout;
713 eLayout->setColumnMinimumWidth(0,14*ww);
714 _ephIntrComboBox->setMaximumWidth(9*ww);
715 _ephOutPortLineEdit->setMaximumWidth(9*ww);
716
717 eLayout->addWidget(new QLabel("Saving RINEX navigation files and ephemeris output through IP port.<br>"),0,0,1,70);
718 eLayout->addWidget(new QLabel("Directory"), 1, 0);
719 eLayout->addWidget(_ephPathLineEdit, 1, 1, 1,30);
720 eLayout->addWidget(new QLabel("Interval"), 2, 0);
721 eLayout->addWidget(_ephIntrComboBox, 2, 1);
722 eLayout->addWidget(new QLabel("Port"), 3, 0);
723 eLayout->addWidget(_ephOutPortLineEdit, 3, 1);
724 eLayout->addWidget(new QLabel("Version 3"), 4, 0);
725 eLayout->addWidget(_ephV3CheckBox, 4, 1);
726 eLayout->addWidget(new QLabel("Version 3 filenames"), 4, 2);
727 eLayout->addWidget(_ephV3filenameCheckBox, 4, 3);
728 eLayout->setRowStretch(5, 999);
729
730 egroup->setLayout(eLayout);
731
732
733 // Broadcast Corrections
734 // ---------------------
735 QGridLayout* cLayout = new QGridLayout;
736 cLayout->setColumnMinimumWidth(0,14*ww);
737 _corrIntrComboBox->setMaximumWidth(9*ww);
738 _corrPortLineEdit->setMaximumWidth(9*ww);
739
740 cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port.<br>"),0,0,1,70);
741 cLayout->addWidget(new QLabel("Directory, ASCII"), 1, 0);
742 cLayout->addWidget(_corrPathLineEdit, 1, 1, 1,30);
743 cLayout->addWidget(new QLabel("Interval"), 2, 0);
744 cLayout->addWidget(_corrIntrComboBox, 2, 1);
745 cLayout->addWidget(new QLabel("Port"), 3, 0);
746 cLayout->addWidget(_corrPortLineEdit, 3, 1);
747 cLayout->addWidget(new QLabel(""), 4, 1);
748 cLayout->setRowStretch(7, 999);
749 cgroup->setLayout(cLayout);
750
751 // Feed Engine
752 // -----------
753 QGridLayout* sLayout = new QGridLayout;
754 sLayout->setColumnMinimumWidth(0,14*ww);
755 _outPortLineEdit->setMaximumWidth(9*ww);
756 _outWaitSpinBox->setMaximumWidth(9*ww);
757 _outSamplSpinBox->setMaximumWidth(9*ww);
758 _outUPortLineEdit->setMaximumWidth(9*ww);
759
760 sLayout->addWidget(new QLabel("Output decoded observations in ASCII format to feed a real-time GNSS network engine.<br>"),0,0,1,50);
761 sLayout->addWidget(new QLabel("Port"), 1, 0);
762 sLayout->addWidget(_outPortLineEdit, 1, 1);
763 sLayout->addWidget(new QLabel(" Wait for full obs epoch"), 1, 2, Qt::AlignRight);
764 sLayout->addWidget(_outWaitSpinBox, 1, 3, Qt::AlignLeft);
765 sLayout->addWidget(new QLabel("Sampling"), 2, 0);
766 sLayout->addWidget(_outSamplSpinBox, 2, 1, Qt::AlignLeft);
767 sLayout->addWidget(new QLabel("File (full path)"), 3, 0);
768 sLayout->addWidget(_outFileLineEdit, 3, 1, 1, 10);
769 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 4, 0);
770 sLayout->addWidget(_outUPortLineEdit, 4, 1);
771 sLayout->addWidget(new QLabel(""), 5, 1);
772 sLayout->setRowStretch(6, 999);
773
774 sgroup->setLayout(sLayout);
775
776 // Serial Output
777 // -------------
778 QGridLayout* serLayout = new QGridLayout;
779 serLayout->setColumnMinimumWidth(0,12*ww);
780 _serialBaudRateComboBox->setMaximumWidth(9*ww);
781 _serialFlowControlComboBox->setMaximumWidth(11*ww);
782 _serialDataBitsComboBox->setMaximumWidth(5*ww);
783 _serialParityComboBox->setMaximumWidth(9*ww);
784 _serialStopBitsComboBox->setMaximumWidth(5*ww);
785 _serialAutoNMEAComboBox->setMaximumWidth(14*ww);
786 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
787 _serialManualNMEASamplingSpinBox->setMaximumWidth(8*ww);
788
789 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver.<br>"),0,0,1,30);
790 serLayout->addWidget(new QLabel("Mountpoint"), 1, 0, Qt::AlignLeft);
791 serLayout->addWidget(_serialMountPointLineEdit, 1, 1, 1, 2);
792 serLayout->addWidget(new QLabel("Port name"), 2, 0, Qt::AlignLeft);
793 serLayout->addWidget(_serialPortNameLineEdit, 2, 1, 1, 2);
794 serLayout->addWidget(new QLabel("Baud rate"), 3, 0, Qt::AlignLeft);
795 serLayout->addWidget(_serialBaudRateComboBox, 3, 1);
796 serLayout->addWidget(new QLabel("Flow control"), 3, 2, Qt::AlignRight);
797 serLayout->addWidget(_serialFlowControlComboBox, 3, 3);
798 serLayout->addWidget(new QLabel("Data bits"), 4, 0, Qt::AlignLeft);
799 serLayout->addWidget(_serialDataBitsComboBox, 4, 1);
800 serLayout->addWidget(new QLabel("Parity"), 4, 2, Qt::AlignRight);
801 serLayout->addWidget(_serialParityComboBox, 4, 3);
802 serLayout->addWidget(new QLabel(" Stop bits"), 4, 4, Qt::AlignRight);
803 serLayout->addWidget(_serialStopBitsComboBox, 4, 5);
804 serLayout->addWidget(new QLabel("NMEA"), 5, 0);
805 serLayout->addWidget(_serialAutoNMEAComboBox, 5, 1);
806 serLayout->addWidget(new QLabel(" File (full path)"), 5, 2, Qt::AlignRight);
807 serLayout->addWidget(_serialFileNMEALineEdit, 5, 3, 1,10);
808 serLayout->addWidget(new QLabel("Height"), 5,14, Qt::AlignRight);
809 serLayout->addWidget(_serialHeightNMEALineEdit, 5,15, 1,11);
810 serLayout->addWidget(new QLabel("Sampling"), 5,25, Qt::AlignRight);
811 serLayout->addWidget(_serialManualNMEASamplingSpinBox, 5,26, 1,12);
812 serLayout->addWidget(new QLabel(""), 6, 1);
813 serLayout->setRowStretch(7, 999);
814
815 sergroup->setLayout(serLayout);
816
817 // Outages
818 // -------
819 QGridLayout* aLayout = new QGridLayout;
820 aLayout->setColumnMinimumWidth(0,14*ww);
821 _adviseObsRateComboBox->setMaximumWidth(9*ww);
822 _adviseFailSpinBox->setMaximumWidth(9*ww);
823 _adviseRecoSpinBox->setMaximumWidth(9*ww);
824
825 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes.<br>"),0,0,1,50,Qt::AlignLeft);
826 aLayout->addWidget(new QLabel("Observation rate"), 1, 0);
827 aLayout->addWidget(_adviseObsRateComboBox, 1, 1);
828 aLayout->addWidget(new QLabel("Failure threshold"), 2, 0);
829 aLayout->addWidget(_adviseFailSpinBox, 2, 1);
830 aLayout->addWidget(new QLabel("Recovery threshold"), 3, 0);
831 aLayout->addWidget(_adviseRecoSpinBox, 3, 1);
832 aLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
833 aLayout->addWidget(_adviseScriptLineEdit, 4, 1, 1,20);
834 aLayout->addWidget(new QLabel(""), 5, 1);
835 aLayout->setRowStretch(6, 999);
836
837 agroup->setLayout(aLayout);
838
839 // Miscellaneous
840 // -------------
841 QGridLayout* rLayout = new QGridLayout;
842 rLayout->setColumnMinimumWidth(0,14*ww);
843 _miscIntrComboBox->setMaximumWidth(9*ww);
844 _miscPortLineEdit->setMaximumWidth(9*ww);
845
846 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);
847 rLayout->addWidget(new QLabel("Mountpoint"), 1, 0);
848 rLayout->addWidget(_miscMountLineEdit, 1, 1, 1, 7);
849 rLayout->addWidget(new QLabel("Log latency"), 2, 0);
850 rLayout->addWidget(_miscIntrComboBox, 2, 1);
851 rLayout->addWidget(new QLabel("Scan RTCM"), 3, 0);
852 rLayout->addWidget(_miscScanRTCMCheckBox, 3, 1);
853 rLayout->addWidget(new QLabel("Port"), 4, 0);
854 rLayout->addWidget(_miscPortLineEdit, 4, 1);
855 rLayout->addWidget(new QLabel(""), 5, 1);
856 rLayout->setRowStretch(6, 999);
857
858 rgroup->setLayout(rLayout);
859
860 // PPP
861 // ---
862 _pppWidgets._dataSource->setMaximumWidth(20*ww);
863 _pppWidgets._corrMount->setMaximumWidth(20*ww);
864
865 _pppWidgets._corrFile->setMaximumWidth(35*ww);
866 _pppWidgets._crdFile->setMaximumWidth(35*ww);
867 _pppWidgets._logPath->setMaximumWidth(35*ww);
868 _pppWidgets._snxtroPath->setMaximumWidth(35*ww);
869 _pppWidgets._snxtroIntr->setMaximumWidth(10*ww);
870 _pppWidgets._snxtroAc ->setMaximumWidth(10*ww);
871 _pppWidgets._snxtroSol ->setMaximumWidth(7*ww);
872
873 QGridLayout* pppLayout1 = new QGridLayout();
874 int ir = 0;
875 pppLayout1->addWidget(new QLabel("Precise Point Positioning - Input and Output."), ir, 0, 1, 7, Qt::AlignLeft);
876 ++ir;
877 pppLayout1->addWidget(new QLabel("Data source"), ir, 0);
878 pppLayout1->addWidget(_pppWidgets._dataSource, ir, 1);
879 pppLayout1->addWidget(new QLabel(" RINEX Obs file"), ir, 3);
880 pppLayout1->addWidget(_pppWidgets._rinexObs, ir, 4, 1, 3);
881 ++ir;
882 pppLayout1->addWidget(new QLabel("Corrections stream"), ir, 0);
883 pppLayout1->addWidget(_pppWidgets._corrMount, ir, 1);
884 pppLayout1->addWidget(new QLabel(" RINEX Nav file"), ir, 3);
885 pppLayout1->addWidget(_pppWidgets._rinexNav, ir, 4, 1, 3);
886 ++ir;
887 pppLayout1->addWidget(new QLabel("Corrections file"), ir, 0);
888 pppLayout1->addWidget(_pppWidgets._corrFile, ir, 1);
889 pppLayout1->addWidget(new QLabel(" ANTEX file"), ir, 3);
890 pppLayout1->addWidget(_pppWidgets._antexFile, ir, 4, 1, 3);
891 ++ir;
892 pppLayout1->addWidget(new QLabel("Coordinates file"), ir, 0);
893 pppLayout1->addWidget(_pppWidgets._crdFile, ir, 1);
894 pppLayout1->addWidget(new QLabel(" Version 3 filenames"),ir, 3);
895 pppLayout1->addWidget(_pppWidgets._v3filenames, ir, 4, 1, 3);
896 ++ir;
897 pppLayout1->addWidget(new QLabel("Logfile directory"), ir, 0);
898 pppLayout1->addWidget(_pppWidgets._logPath, ir, 1);
899 pppLayout1->addWidget(new QLabel(" NMEA directory"), ir, 3);
900 pppLayout1->addWidget(_pppWidgets._nmeaPath, ir, 4, 1, 3);
901 ++ir;
902 pppLayout1->addWidget(new QLabel("SNX TRO directory"), ir, 0);
903 pppLayout1->addWidget(_pppWidgets._snxtroPath, ir, 1);
904 pppLayout1->addWidget(new QLabel(" SNX TRO interval"), ir, 3);
905 pppLayout1->addWidget(_pppWidgets._snxtroIntr, ir, 4);
906 pppLayout1->addWidget(new QLabel(" SNX TRO sampling"), ir, 5);
907 pppLayout1->addWidget(_pppWidgets._snxtroSampl, ir, 6, Qt::AlignRight);
908 ++ir;
909 pppLayout1->addWidget(new QLabel(" SNX TRO AC"), ir, 3);
910 pppLayout1->addWidget(_pppWidgets._snxtroAc, ir, 4);
911 pppLayout1->addWidget(new QLabel(" SNX TRO solution") ,ir, 5);
912 pppLayout1->addWidget(_pppWidgets._snxtroSol, ir, 6, Qt::AlignRight);
913 pppLayout1->setRowStretch(ir, 999);
914
915 pppGroup1->setLayout(pppLayout1);
916
917 QVBoxLayout* pppLayout2 = new QVBoxLayout();
918 pppLayout2->addWidget(new QLabel("Precise Point Positioning - Processed Stations.<br>"));
919 pppLayout2->addWidget(_pppWidgets._staTable, 99);
920 QHBoxLayout* pppLayout2sub = new QHBoxLayout();
921 pppLayout2sub->addWidget(_pppWidgets._addStaButton);
922 pppLayout2sub->addWidget(_pppWidgets._delStaButton);
923 pppLayout2sub->addStretch(99);
924
925 pppLayout2->addLayout(pppLayout2sub);
926
927 pppGroup2->setLayout(pppLayout2);
928
929 QGridLayout* pppLayout3 = new QGridLayout();
930 ir = 0;
931 pppLayout3->addWidget(new QLabel("Precise Point Positioning - Options.<br>"), ir, 0, 1, 2, Qt::AlignLeft);
932 ++ir;
933 pppLayout3->addWidget(new QLabel("GPS LCs"), ir, 0, Qt::AlignLeft);
934 pppLayout3->addWidget(_pppWidgets._lcGPS, ir, 1);
935 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 2);
936 pppLayout3->addWidget(new QLabel("Sigma C1"), ir, 3, Qt::AlignLeft);
937 pppLayout3->addWidget(_pppWidgets._sigmaC1, ir, 4); _pppWidgets._sigmaC1->setMaximumWidth(8*ww);
938 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 5);
939 pppLayout3->addWidget(new QLabel("Sigma L1"), ir, 6, Qt::AlignLeft);
940 pppLayout3->addWidget(_pppWidgets._sigmaL1, ir, 7); _pppWidgets._sigmaL1->setMaximumWidth(8*ww);
941 ++ir;
942 pppLayout3->addWidget(new QLabel("GLONASS LCs"), ir, 0, Qt::AlignLeft);
943 pppLayout3->addWidget(_pppWidgets._lcGLONASS, ir, 1);
944 pppLayout3->addWidget(new QLabel("Max Res C1"), ir, 3, Qt::AlignLeft);
945 pppLayout3->addWidget(_pppWidgets._maxResC1, ir, 4); _pppWidgets._maxResC1->setMaximumWidth(8*ww);
946 pppLayout3->addWidget(new QLabel("Max Res L1"), ir, 6, Qt::AlignLeft);
947 pppLayout3->addWidget(_pppWidgets._maxResL1, ir, 7); _pppWidgets._maxResL1->setMaximumWidth(8*ww);
948 ++ir;
949 pppLayout3->addWidget(new QLabel("Galileo LCs"), ir, 0, Qt::AlignLeft);
950 pppLayout3->addWidget(_pppWidgets._lcGalileo, ir, 1);
951 pppLayout3->addWidget(new QLabel("Ele Wgt Code"), ir, 3, Qt::AlignLeft);
952 pppLayout3->addWidget(_pppWidgets._eleWgtCode, ir, 4);
953 pppLayout3->addWidget(new QLabel("Ele Wgt Phase"), ir, 6, Qt::AlignLeft);
954 pppLayout3->addWidget(_pppWidgets._eleWgtPhase, ir, 7);
955 ++ir;
956 pppLayout3->addWidget(new QLabel("BDS LCs"), ir, 0, Qt::AlignLeft);
957 pppLayout3->addWidget(_pppWidgets._lcBDS, ir, 1);
958 pppLayout3->addWidget(new QLabel("Min # of Obs"), ir, 3, Qt::AlignLeft);
959 pppLayout3->addWidget(_pppWidgets._minObs, ir, 4);
960 pppLayout3->addWidget(new QLabel("Min Elevation"), ir, 6, Qt::AlignLeft);
961 pppLayout3->addWidget(_pppWidgets._minEle, ir, 7);
962 ++ir;
963 pppLayout3->addWidget(new QLabel("Wait for clock corr."), ir, 0, Qt::AlignLeft);
964 pppLayout3->addWidget(_pppWidgets._corrWaitTime, ir, 1);
965 pppLayout3->addWidget(new QLabel("Seeding (sec)"), ir, 3, Qt::AlignLeft);
966 pppLayout3->addWidget(_pppWidgets._seedingTime, ir, 4);
967 ++ir;
968 pppLayout3->addWidget(new QLabel(""), ir, 8);
969 pppLayout3->setColumnStretch(8, 999);
970 ++ir;
971 pppLayout3->addWidget(new QLabel(""), ir, 1);
972 pppLayout3->setRowStretch(ir, 999);
973
974 pppGroup3->setLayout(pppLayout3);
975
976 // ------------------------
977 connect(_pppWidgets._mapWinButton, SIGNAL(clicked()), SLOT(slotMapPPP()));
978 _pppWidgets._mapSpeedSlider->setMinimumWidth(33*ww);
979 _pppWidgets._audioResponse->setMaximumWidth(8*ww);
980
981 QGridLayout* pppLayout4 = new QGridLayout();
982 ir = 0;
983 pppLayout4->addWidget(new QLabel("Precise Point Positioning - Plots.<br>"), ir, 0, 1, 50, Qt::AlignLeft);
984 ++ir;
985 pppLayout4->addWidget(new QLabel("PPP Plot"), ir, 0, Qt::AlignLeft);
986 pppLayout4->addWidget(_pppWidgets._plotCoordinates, ir, 1, Qt::AlignLeft);
987 pppLayout4->addWidget(new QLabel("Mountpoint"), ir, 2, 1, 10, Qt::AlignLeft);
988 pppLayout4->addWidget(_pppWidgets._audioResponse, ir, 4, Qt::AlignLeft);
989 pppLayout4->addWidget(new QLabel("Audio response"), ir, 5, Qt::AlignRight);
990
991 ++ir;
992 pppLayout4->addWidget(new QLabel("Track map"), ir, 0, Qt::AlignLeft);
993 pppLayout4->addWidget(_pppWidgets._mapWinButton, ir, 1, Qt::AlignLeft);
994 pppLayout4->addWidget(new QLabel("OSM"), ir, 2, Qt::AlignLeft);
995 pppLayout4->addWidget(_pppWidgets._useOpenStreetMap, ir, 3, Qt::AlignLeft);
996 pppLayout4->addWidget(new QLabel("Google"), ir, 3, Qt::AlignRight);
997 pppLayout4->addWidget(_pppWidgets._useGoogleMap, ir, 4, Qt::AlignLeft);
998 ++ir;
999 pppLayout4->addWidget(new QLabel("Dot-properties"), ir, 0, Qt::AlignLeft);
1000 pppLayout4->addWidget(_pppWidgets._mapWinDotSize, ir, 1, Qt::AlignLeft);
1001 pppLayout4->addWidget(new QLabel("Size "), ir, 2, Qt::AlignLeft);
1002 pppLayout4->addWidget(_pppWidgets._mapWinDotColor, ir, 3, Qt::AlignLeft);
1003 pppLayout4->addWidget(new QLabel("Color"), ir, 4, Qt::AlignLeft);
1004 ++ir;
1005 pppLayout4->addWidget(new QLabel("Post-processing speed"), ir, 0, Qt::AlignLeft);
1006 pppLayout4->addWidget(_pppWidgets._mapSpeedSlider, ir, 1, 1, 20, Qt::AlignLeft);
1007 ++ir;
1008 pppLayout4->addWidget(new QLabel(""), ir, 1);
1009 pppLayout4->setRowStretch(ir, 999);
1010
1011 pppGroup4->setLayout(pppLayout4);
1012
1013 // Reqc Processing
1014 // ---------------
1015 _reqcActionComboBox = new QComboBox();
1016 _reqcActionComboBox->setEditable(false);
1017 _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
1018 int ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
1019 if (ik != -1) {
1020 _reqcActionComboBox->setCurrentIndex(ik);
1021 }
1022 connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
1023 this, SLOT(slotBncTextChanged()));
1024
1025 QGridLayout* reqcLayout = new QGridLayout;
1026 _reqcActionComboBox->setMinimumWidth(15*ww);
1027 _reqcActionComboBox->setMaximumWidth(20*ww);
1028
1029 _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1030 _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
1031
1032 _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1033 _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
1034 _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
1035 _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
1036 _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
1037 _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
1038 _reqcSkyPlotSignals = new QLineEdit(settings.value("reqcSkyPlotSignals").toString());
1039
1040 connect(_reqcSkyPlotSignals, SIGNAL(textChanged(const QString &)),
1041 this, SLOT(slotBncTextChanged()));
1042
1043 _reqcLogSummaryOnly = new QCheckBox();
1044 _reqcLogSummaryOnly->setCheckState(Qt::CheckState(settings.value("reqcLogSummaryOnly").toInt()));
1045
1046 ir = 0;
1047 reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check.<br>"),ir, 0, 1, 8);
1048 ++ir;
1049 reqcLayout->addWidget(new QLabel("Action"), ir, 0);
1050 reqcLayout->addWidget(_reqcActionComboBox, ir, 1);
1051 _reqcEditOptionButton = new QPushButton("Set Edit Options");
1052 _reqcEditOptionButton->setMinimumWidth(15*ww);
1053 _reqcEditOptionButton->setMaximumWidth(20*ww);
1054
1055 reqcLayout->addWidget(_reqcEditOptionButton, ir, 3);
1056 ++ir;
1057 reqcLayout->addWidget(new QLabel("Input files (full path)"), ir, 0);
1058 reqcLayout->addWidget(_reqcObsFileChooser, ir, 1);
1059 _reqcObsFileChooser->setMaximumWidth(40*ww);
1060 reqcLayout->addWidget(new QLabel(" Obs"), ir, 2);
1061 reqcLayout->addWidget(_reqcNavFileChooser, ir, 3);
1062 _reqcNavFileChooser->setMaximumWidth(40*ww);
1063 reqcLayout->addWidget(new QLabel(" Nav"), ir, 4);
1064 ++ir;
1065 reqcLayout->addWidget(new QLabel("Output file (full path)"), ir, 0);
1066 reqcLayout->addWidget(_reqcOutObsLineEdit, ir, 1);
1067 _reqcOutObsLineEdit->setMaximumWidth(40*ww);
1068 reqcLayout->addWidget(new QLabel(" Obs"), ir, 2);
1069 reqcLayout->addWidget(_reqcOutNavLineEdit, ir, 3);
1070 _reqcOutNavLineEdit->setMaximumWidth(40*ww);
1071 reqcLayout->addWidget(new QLabel(" Nav"), ir, 4);
1072 ++ir;
1073 reqcLayout->addWidget(new QLabel("Logfile"), ir, 0);
1074 reqcLayout->addWidget(_reqcOutLogLineEdit, ir, 1);
1075 _reqcOutLogLineEdit->setMaximumWidth(40*ww);
1076 reqcLayout->addWidget(new QLabel(" Summary only"), ir, 2);
1077 reqcLayout->addWidget(_reqcLogSummaryOnly, ir, 3);
1078 ++ir;
1079 reqcLayout->addWidget(new QLabel("Plots for signals"), ir, 0);
1080 reqcLayout->addWidget(_reqcSkyPlotSignals, ir, 1);
1081 _reqcSkyPlotSignals->setMaximumWidth(40*ww);
1082 ++ir;
1083 reqcLayout->addWidget(new QLabel("Directory for plots"), ir, 0);
1084 reqcLayout->addWidget(_reqcPlotDirLineEdit, ir, 1);
1085 _reqcPlotDirLineEdit->setMaximumWidth(40*ww);
1086 ++ir;
1087 reqcLayout->setRowStretch(ir, 999);
1088
1089 reqcLayout->setColumnMinimumWidth(2, 8*ww);
1090 reqcLayout->setColumnMinimumWidth(4, 8*ww);
1091
1092 reqcgroup->setLayout(reqcLayout);
1093
1094 connect(_reqcEditOptionButton, SIGNAL(clicked()),
1095 this, SLOT(slotReqcEditOption()));
1096
1097 QGridLayout* sp3CompLayout = new QGridLayout;
1098
1099 _sp3CompFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1100 _sp3CompFileChooser->setFileName(settings.value("sp3CompFile").toString());
1101 _sp3CompFileChooser->setMinimumWidth(15*ww);
1102 _sp3CompFileChooser->setMaximumWidth(40*ww);
1103
1104 _sp3CompExclude = new QLineEdit(settings.value("sp3CompExclude").toString());
1105 _sp3CompExclude->setMinimumWidth(18*ww);
1106 _sp3CompExclude->setMaximumWidth(18*ww);
1107
1108 _sp3CompLogLineEdit = new QLineEdit(settings.value("sp3CompOutLogFile").toString());
1109 _sp3CompLogLineEdit->setMinimumWidth(18*ww);
1110 _sp3CompLogLineEdit->setMaximumWidth(18*ww);
1111
1112 ir = 0;
1113 sp3CompLayout->addWidget(new QLabel("Orbit and clock comparison.<br>"), ir, 0, 1, 40);
1114 ++ir;
1115 sp3CompLayout->addWidget(new QLabel("Input SP3 files (full path)"), ir, 0, Qt::AlignLeft);
1116 sp3CompLayout->addWidget(_sp3CompFileChooser, ir, 1, 1, 20);
1117 ++ir;
1118 sp3CompLayout->addWidget(new QLabel("Exclude satellites"), ir, 0, Qt::AlignLeft);
1119 sp3CompLayout->addWidget(_sp3CompExclude, ir, 1, Qt::AlignRight);
1120 ++ir;
1121 sp3CompLayout->addWidget(new QLabel("Logfile"), ir, 0, Qt::AlignLeft);
1122 sp3CompLayout->addWidget(_sp3CompLogLineEdit, ir, 1, Qt::AlignRight);
1123 ++ir;
1124 sp3CompLayout->addWidget(new QLabel(""), ir, 1);
1125 ++ir;
1126 sp3CompLayout->setRowStretch(ir, 999);
1127
1128 sp3CompLayout->setColumnMinimumWidth(2, 8*ww);
1129 sp3CompLayout->setColumnMinimumWidth(4, 8*ww);
1130
1131 sp3CompGroup->setLayout(sp3CompLayout);
1132
1133 connect(_sp3CompFileChooser, SIGNAL(fileNameChanged(const QString &)),
1134 this, SLOT(slotBncTextChanged()));
1135
1136 // Combine Corrections
1137 // -------------------
1138 QGridLayout* cmbLayout = new QGridLayout;
1139
1140 populateCmbTable();
1141 cmbLayout->addWidget(_cmbTable, 0, 0, 8, 3);
1142 cmbLayout->addWidget(new QLabel(" Combine Broadcast Correction streams.<br>"), 1, 6, 1, 10);
1143 cmbLayout->addWidget(addCmbRowButton, 2, 6);
1144 cmbLayout->addWidget(delCmbRowButton, 2, 7);
1145 cmbLayout->addWidget(new QLabel("Method"), 3, 6, Qt::AlignRight);
1146 cmbLayout->addWidget(_cmbMethodComboBox, 3, 7);
1147 cmbLayout->addWidget(new QLabel(" Maximal residuum"), 4, 6, Qt::AlignRight);
1148 cmbLayout->addWidget(_cmbMaxresLineEdit, 4, 7, Qt::AlignRight);
1149 cmbLayout->addWidget(new QLabel("Sampling"), 5, 6, Qt::AlignRight);
1150 cmbLayout->addWidget(_cmbSamplSpinBox, 5, 7);
1151 cmbLayout->addWidget(new QLabel(" Use GLONASS"), 6, 6, Qt::AlignRight);
1152 cmbLayout->addWidget(_cmbUseGlonass, 6, 7);
1153 cmbLayout->setRowStretch(7, 999);
1154
1155 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1156 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
1157
1158 cmbgroup->setLayout(cmbLayout);
1159
1160 // Upload Layout (Clocks)
1161 // ----------------------
1162 QGridLayout* uploadHlpLayout = new QGridLayout();
1163
1164 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1165 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1166 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
1167
1168 uploadHlpLayout->addWidget(addUploadRowButton, 0, 0);
1169 uploadHlpLayout->addWidget(delUploadRowButton, 0, 1);
1170 uploadHlpLayout->addWidget(new QLabel("Interval"), 0, 2, Qt::AlignRight);
1171 uploadHlpLayout->addWidget(_uploadIntrComboBox, 0, 3);
1172 uploadHlpLayout->addWidget(new QLabel(" Sampling: Orb"), 0, 4, Qt::AlignRight);
1173 uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox, 0, 5);
1174 uploadHlpLayout->addWidget(new QLabel("SP3"), 0, 6, Qt::AlignRight);
1175 uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox, 0, 7);
1176 uploadHlpLayout->addWidget(new QLabel("RNX"), 0, 8, Qt::AlignRight);
1177 uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox, 0, 9);
1178 uploadHlpLayout->addWidget(setUploadTrafoButton, 0,10);
1179 uploadHlpLayout->addWidget(new QLabel("ANTEX file"), 1, 0, Qt::AlignLeft);
1180 uploadHlpLayout->addWidget(_uploadAntexFile, 1, 1, 1, 4);
1181
1182 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1183 populateUploadTable();
1184
1185 uploadLayout->addWidget(new QLabel("Upload RTCM Version 3 Broadcast Corrections to caster.<br>"));
1186 uploadLayout->addWidget(_uploadTable);
1187 uploadLayout->addLayout(uploadHlpLayout);
1188
1189 uploadgroup->setLayout(uploadLayout);
1190
1191 // Upload Layout (Ephemeris)
1192 // -------------------------
1193 QGridLayout* uploadLayoutEph = new QGridLayout;
1194
1195 uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1196 _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1197 _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1198 _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1199
1200 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster.<br>"), 0, 0, 1, 50);
1201 uploadLayoutEph->addWidget(new QLabel("Host"), 1, 0);
1202 uploadLayoutEph->addWidget(_uploadEphHostLineEdit, 1, 1, 1, 3);
1203 uploadLayoutEph->addWidget(new QLabel(" Port"), 1, 4, Qt::AlignRight);
1204 uploadLayoutEph->addWidget(_uploadEphPortLineEdit, 1, 5, 1, 1);
1205 uploadLayoutEph->addWidget(new QLabel("Mountpoint "), 2, 0);
1206 uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit, 2, 1);
1207 uploadLayoutEph->addWidget(new QLabel(" Password"), 2, 2, Qt::AlignRight);
1208 uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit, 2, 3);
1209 uploadLayoutEph->addWidget(new QLabel("Sampling"), 3, 0);
1210 uploadLayoutEph->addWidget(_uploadEphSampleSpinBox, 3, 1);
1211 uploadLayoutEph->addWidget(new QLabel("Uploaded"), 4, 0);
1212 uploadLayoutEph->addWidget(_uploadEphBytesCounter, 4, 1);
1213 uploadLayoutEph->setRowStretch(5, 999);
1214
1215 uploadEphgroup->setLayout(uploadLayoutEph);
1216
1217 connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1218 this, SLOT(slotBncTextChanged()));
1219
1220 // Main Layout
1221 // -----------
1222 QGridLayout* mLayout = new QGridLayout;
1223 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
1224 mLayout->addWidget(_aogroup, 0,0);
1225 mLayout->addWidget(_mountPointsTable, 1,0);
1226 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
1227 mLayout->addWidget(_loggroup, 2,0);
1228
1229 _canvas->setLayout(mLayout);
1230
1231 // WhatsThis, Network
1232 // ------------------
1233 _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>"));
1234 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1235 _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>"));
1236 _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>"));
1237
1238 // WhatsThis, General
1239 // ------------------
1240 _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>"));
1241 _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>"));
1242 _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>"));
1243 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1244 _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>"));
1245
1246 // WhatsThis, RINEX Observations
1247 // -----------------------------
1248 _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>"));
1249 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1250 _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>"));
1251 _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>"));
1252 _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>"));
1253 _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>"));
1254 _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>"));
1255 _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>"));
1256 _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>"));
1257
1258 // WhatsThis, RINEX Ephemeris
1259 // --------------------------
1260 _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>"));
1261 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1262 _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>"));
1263 _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>"));
1264 _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>"));
1265
1266 // WhatsThis, RINEX Editing & QC
1267 // -----------------------------
1268 _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>"));
1269 _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX Version 2 or 3 files.</p>"));
1270 _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>"));
1271 _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>"));
1272 _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>"));
1273 _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>"));
1274 _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>"));
1275 _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>"));
1276 _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>"));
1277 _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>"));
1278
1279 // WhatsThis, SP3 Comparison
1280 // -------------------------
1281 _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>"));
1282 _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>"));
1283 _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>"));
1284
1285 // WhatsThis, Broadcast Corrections
1286 // --------------------------------
1287 _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>"));
1288 _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>"));
1289 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of Broadcast Ephemeris Correction files.</p>"));
1290
1291 // WhatsThis, Feed Engine
1292 // ----------------------
1293 _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>"));
1294 _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>"));
1295 _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>"));
1296 _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>"));
1297 _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>"));
1298
1299 // WhatsThis, Serial Output
1300 // ------------------------
1301 _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>"));
1302 _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>"));
1303 _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>"));
1304 _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>"));
1305 _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>"));
1306 _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>"));
1307 _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>"));
1308 _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>"));
1309 _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>"));
1310 _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>"));
1311 _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>"));
1312
1313 // WhatsThis, Outages
1314 // ------------------
1315 _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>"));
1316 _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>"));
1317 _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>"));
1318 _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>"));
1319
1320 // WhatsThis, Miscellaneous
1321 // ------------------------
1322 _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>"));
1323 _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>"));
1324 _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>."));
1325 _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>"));
1326
1327 // WhatsThis, PPP (1)
1328 // ------------------
1329 _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>"));
1330 _pppWidgets._rinexObs->setWhatsThis(tr("<p>Specify the RINEX Observation file.</p>"));
1331 _pppWidgets._rinexNav->setWhatsThis(tr("<p>Specify the RINEX Navigation file.</p>"));
1332 _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>"));
1333 _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>"));
1334 _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>"));
1335 _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>"));
1336 _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>"));
1337 _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>"));
1338 _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>"));
1339 _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>"));
1340 _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>"));
1341 _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>"));
1342 _pppWidgets._snxtroAc->setWhatsThis(tr("<p>Specify a 3-character abbreviation describing you as the generating Analysis Center (AC) in your SINEX troposphere files.</p>"));
1343 _pppWidgets._snxtroSol->setWhatsThis(tr("<p>Specify a 4-character solution ID to allow a distingtion between different solutions per AC.</p>"));
1344
1345 // WhatsThis, PPP (3)
1346 // ------------------
1347 _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>"));
1348 _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>"));
1349 _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>"));
1350 _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>"));
1351 _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>"));
1352 _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>"));
1353 _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>"));
1354 _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>"));
1355 _pppWidgets._eleWgtCode->setWhatsThis(tr("<p>Tic 'Ele Wgt Code' to use satellite Elevation depending Weights for Code observations in the PPP solution.</p>"));
1356 _pppWidgets._eleWgtPhase->setWhatsThis(tr("<p>Tic 'Ele Wgt Phase' to use satellite Elevation depending Weights for Phase observations in the PPP solution.</p>"));
1357 _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>"));
1358 _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>"));
1359
1360 // WhatsThis, Combine Corrections
1361 // ------------------------------
1362 _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>"));
1363 addCmbRowButton->setWhatsThis(tr("<p>Hit 'Add Row' button to add another line to the 'Combine Corrections' table.</p>"));
1364 delCmbRowButton->setWhatsThis(tr("<p>Hit 'Delete' button to delete the highlighted line(s) from the 'Combine Corrections' table.</p>"));
1365 _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>"));
1366 _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>"));
1367 _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>"));
1368 _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>"));
1369
1370 // WhatsThis, Upload Corrections
1371 // -----------------------------
1372 _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>"));
1373 addUploadRowButton->setWhatsThis(tr("<p>Hit 'Add Row' button to add another line to the 'Upload Corrections' table.</p>"));
1374 delUploadRowButton->setWhatsThis(tr("<p>Hit 'Del Row' button to delete the highlighted line(s) from the Upload Corrections' table.</p>"));
1375 _uploadIntrComboBox->setWhatsThis(tr("<p>Select the length of the SP3 and Clock RINEX files.</p>"));
1376 _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>"));
1377 _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>"));
1378 _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>"));
1379 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>"));
1380 _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>"));
1381
1382 // WhatsThis, Upload Ephemeris
1383 // ---------------------------
1384 _uploadEphHostLineEdit->setWhatsThis(tr("<p>BNC can upload a Broadcast Ephemeris stream in RTCM Version 3 format. Specify the IP number or URL of an Ntrip Broadcaster to upload the stream.</p><p>An empty option field means that you don't want to upload Broadcast Ephemeris.</p>"));
1385 _uploadEphPortLineEdit->setWhatsThis(tr("<p>Specify the IP port of the Ntrip Broadcaster to upload the Broadcast Ephemeris stream. Default is port 80.</p>"));
1386 _uploadEphMountpointLineEdit->setWhatsThis(tr("<p>Specify a mountpoint for uploading the Broadcast Ephemeris stream.</p>"));
1387 _uploadEphPasswordLineEdit->setWhatsThis(tr("<p>Specify the stream upload password protecting the mounpoint on the Ntrip Broadcaster.</p>"));
1388 _uploadEphSampleSpinBox->setWhatsThis(tr("<p>Select the Broadcast Ephemeris sampling interval in seconds.</p><p>Default is '5', meaning that a complete set of Broadcast Ephemeris is uploaded every 5 seconds.</p>"));
1389 _uploadEphBytesCounter->setWhatsThis(tr("<p>BNC shows the amount of data uploaded via this stream.</p>"));
1390// weber
1391
1392 // WhatsThis, Streams Canvas
1393 // -------------------------
1394 _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>"));
1395 _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
1396 _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1397 _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>"));
1398 _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1399 _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1400
1401 // WhatsThis, Log Canvas
1402 // ---------------------
1403 _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>"));
1404 _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>"));
1405 _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>"));
1406 _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>"));
1407
1408
1409 // Enable/Disable all Widgets
1410 // --------------------------
1411 slotBncTextChanged();
1412 enableStartStop();
1413
1414 // Auto start
1415 // ----------
1416 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1417 slotStart();
1418 }
1419}
1420
1421// Destructor
1422////////////////////////////////////////////////////////////////////////////
1423bncWindow::~bncWindow() {
1424 if (_caster) {
1425 delete _caster; BNC_CORE->setCaster(0);
1426 }
1427 if (_casterEph) {
1428 delete _casterEph;
1429 }
1430 delete _bncFigureLate;
1431 delete _bncFigurePPP;
1432 delete _actHelp;
1433 delete _actAbout;
1434 delete _actFlowchart;
1435 delete _actFontSel;
1436 delete _actSaveOpt;
1437 delete _actQuit;
1438 delete _actAddMountPoints;
1439 delete _actDeleteMountPoints;
1440 delete _actMapMountPoints;
1441 delete _actStart;
1442 delete _actStop;
1443 delete _actwhatsthis;
1444 delete _proxyHostLineEdit;
1445 delete _proxyPortLineEdit;
1446 delete _sslCaCertPathLineEdit;
1447 delete _sslIgnoreErrorsCheckBox;
1448 delete _logFileLineEdit;
1449 delete _rawOutFileLineEdit;
1450 delete _rnxAppendCheckBox;
1451 delete _onTheFlyComboBox;
1452 delete _autoStartCheckBox;
1453 delete _rnxPathLineEdit;
1454 delete _rnxIntrComboBox;
1455 delete _rnxSamplSpinBox;
1456 delete _rnxFileCheckBox;
1457 delete _rnxSkelLineEdit;
1458 delete _rnxScrpLineEdit;
1459 delete _rnxV3CheckBox;
1460 delete _rnxV3filenameCheckBox;
1461 delete _rnxV2Priority;
1462 delete _ephPathLineEdit;
1463 delete _ephIntrComboBox;
1464 delete _ephOutPortLineEdit;
1465 delete _ephV3CheckBox;
1466 delete _ephV3filenameCheckBox;
1467 delete _corrPathLineEdit;
1468 delete _corrIntrComboBox;
1469 delete _corrPortLineEdit;
1470 delete _outPortLineEdit;
1471 delete _outWaitSpinBox;
1472 delete _outSamplSpinBox;
1473 delete _outFileLineEdit;
1474 delete _outUPortLineEdit;
1475 delete _serialMountPointLineEdit;
1476 delete _serialPortNameLineEdit;
1477 delete _serialBaudRateComboBox;
1478 delete _serialFlowControlComboBox;
1479 delete _serialDataBitsComboBox;
1480 delete _serialParityComboBox;
1481 delete _serialStopBitsComboBox;
1482 delete _serialAutoNMEAComboBox;
1483 delete _serialFileNMEALineEdit;
1484 delete _serialHeightNMEALineEdit;
1485 delete _serialManualNMEASamplingSpinBox;
1486 delete _adviseObsRateComboBox;
1487 delete _adviseFailSpinBox;
1488 delete _adviseRecoSpinBox;
1489 delete _adviseScriptLineEdit;
1490 delete _miscMountLineEdit;
1491 delete _miscPortLineEdit;
1492 delete _miscIntrComboBox;
1493 delete _miscScanRTCMCheckBox;
1494 _mountPointsTable->deleteLater();
1495 delete _log;
1496 _cmbTable->deleteLater();
1497 delete _cmbMaxresLineEdit;
1498 delete _cmbUseGlonass;
1499 delete _cmbSamplSpinBox;
1500 delete _cmbMethodComboBox;
1501 _uploadTable->deleteLater();
1502 delete _uploadIntrComboBox;
1503 delete _uploadAntexFile;
1504 delete _uploadSamplRtcmEphCorrSpinBox;
1505 delete _uploadSamplSp3SpinBox;
1506 delete _uploadSamplClkRnxSpinBox;
1507 delete _uploadEphHostLineEdit;
1508 delete _uploadEphPortLineEdit;
1509 delete _uploadEphPasswordLineEdit;
1510 delete _uploadEphMountpointLineEdit;
1511 delete _uploadEphSampleSpinBox;
1512 delete _uploadEphBytesCounter;
1513 delete _loggroup;
1514 delete _reqcActionComboBox;
1515 delete _reqcObsFileChooser;
1516 delete _reqcNavFileChooser;
1517 delete _reqcOutObsLineEdit;
1518 delete _reqcOutNavLineEdit;
1519 delete _reqcOutLogLineEdit;
1520 delete _reqcPlotDirLineEdit;
1521 delete _reqcSkyPlotSignals;
1522 delete _reqcLogSummaryOnly;
1523 delete _reqcEditOptionButton;
1524 delete _sp3CompFileChooser;
1525 delete _sp3CompExclude;
1526 delete _sp3CompLogLineEdit;
1527 //delete _canvas;
1528}
1529
1530//
1531////////////////////////////////////////////////////////////////////////////
1532void bncWindow::populateMountPointsTable() {
1533
1534 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1535 _mountPointsTable->removeRow(iRow);
1536 }
1537
1538 bncSettings settings;
1539
1540 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1541 int iRow = 0;
1542 while (it.hasNext()) {
1543 QStringList hlp = it.next().split(" ");
1544 if (hlp.size() < 7) continue;
1545 _mountPointsTable->insertRow(iRow);
1546
1547 QUrl url(hlp[0]);
1548
1549 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1550 QString format(hlp[1]); QString country(hlp[2]); QString latitude(hlp[3]); QString longitude(hlp[4]);
1551 QString nmea(hlp[5]);
1552 if (hlp[6] == "S") {
1553 fullPath = hlp[0].replace(0,2,"");
1554 }
1555 QString ntripVersion = "2";
1556 if (hlp.size() >= 7) {
1557 ntripVersion = (hlp[6]);
1558 }
1559
1560 QTableWidgetItem* it;
1561 it = new QTableWidgetItem(url.userInfo());
1562 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1563 _mountPointsTable->setItem(iRow, 0, it);
1564
1565 it = new QTableWidgetItem(fullPath);
1566 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1567 _mountPointsTable->setItem(iRow, 1, it);
1568
1569 it = new QTableWidgetItem(format);
1570 _mountPointsTable->setItem(iRow, 2, it);
1571
1572 it = new QTableWidgetItem(country);
1573 _mountPointsTable->setItem(iRow, 3, it);
1574
1575 if (nmea == "yes") {
1576 it = new QTableWidgetItem(latitude);
1577 _mountPointsTable->setItem(iRow, 4, it);
1578 it = new QTableWidgetItem(longitude);
1579 _mountPointsTable->setItem(iRow, 5, it);
1580 } else {
1581 it = new QTableWidgetItem(latitude);
1582 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1583 _mountPointsTable->setItem(iRow, 4, it);
1584
1585 it = new QTableWidgetItem(longitude);
1586 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1587 _mountPointsTable->setItem(iRow, 5, it);
1588 }
1589
1590 it = new QTableWidgetItem(nmea);
1591 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1592 _mountPointsTable->setItem(iRow, 6, it);
1593
1594 it = new QTableWidgetItem(ntripVersion);
1595 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1596 _mountPointsTable->setItem(iRow, 7, it);
1597
1598 bncTableItem* bncIt = new bncTableItem();
1599 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1600 _mountPointsTable->setItem(iRow, 8, bncIt);
1601
1602 iRow++;
1603 }
1604
1605 _mountPointsTable->sortItems(1);
1606
1607 enableStartStop();
1608}
1609
1610// Retrieve Table
1611////////////////////////////////////////////////////////////////////////////
1612void bncWindow::slotAddMountPoints() {
1613
1614 bncSettings settings;
1615 QString proxyHost = settings.value("proxyHost").toString();
1616 int proxyPort = settings.value("proxyPort").toInt();
1617 if (proxyHost != _proxyHostLineEdit->text() ||
1618 proxyPort != _proxyPortLineEdit->text().toInt()) {
1619 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1620 "changed. Use the new ones?",
1621 QMessageBox::Yes, QMessageBox::No,
1622 QMessageBox::NoButton);
1623 if (iRet == QMessageBox::Yes) {
1624 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1625 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1626 }
1627 }
1628
1629 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1630 settings.setValue("sslIgnoreErrors", _sslIgnoreErrorsCheckBox->checkState());
1631
1632 QMessageBox msgBox;
1633 msgBox.setIcon(QMessageBox::Question);
1634 msgBox.setWindowTitle("Add Stream");
1635 msgBox.setText("Add stream(s) coming from:");
1636
1637 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1638 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1639 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1640 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1641 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1642
1643 msgBox.exec();
1644
1645 if (msgBox.clickedButton() == buttonNtrip) {
1646 bncTableDlg* dlg = new bncTableDlg(this);
1647 dlg->move(this->pos().x()+50, this->pos().y()+50);
1648 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1649 this, SLOT(slotNewMountPoints(QStringList*)));
1650 dlg->exec();
1651 delete dlg;
1652 } else if (msgBox.clickedButton() == buttonIP) {
1653 bncIpPort* ipp = new bncIpPort(this);
1654 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1655 this, SLOT(slotNewMountPoints(QStringList*)));
1656 ipp->exec();
1657 delete ipp;
1658 } else if (msgBox.clickedButton() == buttonUDP) {
1659 bncUdpPort* udp = new bncUdpPort(this);
1660 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1661 this, SLOT(slotNewMountPoints(QStringList*)));
1662 udp->exec();
1663 delete udp;
1664 } else if (msgBox.clickedButton() == buttonSerial) {
1665 bncSerialPort* sep = new bncSerialPort(this);
1666 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1667 this, SLOT(slotNewMountPoints(QStringList*)));
1668 sep->exec();
1669 delete sep;
1670 } else if (msgBox.clickedButton() == buttonCancel) {
1671 // Cancel
1672 }
1673
1674 enableStartStop();
1675}
1676
1677// Delete Selected Mount Points
1678////////////////////////////////////////////////////////////////////////////
1679void bncWindow::slotDeleteMountPoints() {
1680
1681 int nRows = _mountPointsTable->rowCount();
1682 bool flg[nRows];
1683 for (int iRow = 0; iRow < nRows; iRow++) {
1684 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1685 flg[iRow] = true;
1686 }
1687 else {
1688 flg[iRow] = false;
1689 }
1690 }
1691 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1692 if (flg[iRow]) {
1693 _mountPointsTable->removeRow(iRow);
1694 }
1695 }
1696 _actDeleteMountPoints->setEnabled(false);
1697
1698 enableStartStop();
1699}
1700
1701// New Mount Points Selected
1702////////////////////////////////////////////////////////////////////////////
1703void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1704 int iRow = 0;
1705 QListIterator<QString> it(*mountPoints);
1706 while (it.hasNext()) {
1707 QStringList hlp = it.next().split(" ");
1708 QUrl url(hlp[0]);
1709 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1710 QString format(hlp[1]); QString country(hlp[2]); QString latitude(hlp[3]); QString longitude(hlp[4]);
1711 QString nmea(hlp[5]);
1712 if (hlp[6] == "S") {
1713 fullPath = hlp[0].replace(0,2,"");
1714 }
1715 QString ntripVersion = "2";
1716 if (hlp.size() >= 7) {
1717 ntripVersion = (hlp[6]);
1718 }
1719
1720 _mountPointsTable->insertRow(iRow);
1721
1722 QTableWidgetItem* it;
1723 it = new QTableWidgetItem(url.userInfo());
1724 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1725 _mountPointsTable->setItem(iRow, 0, it);
1726
1727 it = new QTableWidgetItem(fullPath);
1728 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1729 _mountPointsTable->setItem(iRow, 1, it);
1730
1731 it = new QTableWidgetItem(format);
1732 _mountPointsTable->setItem(iRow, 2, it);
1733
1734 it = new QTableWidgetItem(country);
1735 _mountPointsTable->setItem(iRow, 3, it);
1736
1737 if (nmea == "yes") {
1738 it = new QTableWidgetItem(latitude);
1739 _mountPointsTable->setItem(iRow, 4, it);
1740 it = new QTableWidgetItem(longitude);
1741 _mountPointsTable->setItem(iRow, 5, it);
1742 } else {
1743 it = new QTableWidgetItem(latitude);
1744 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1745 _mountPointsTable->setItem(iRow, 4, it);
1746 it = new QTableWidgetItem(longitude);
1747 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1748 _mountPointsTable->setItem(iRow, 5, it);
1749 }
1750
1751 it = new QTableWidgetItem(nmea);
1752 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1753 _mountPointsTable->setItem(iRow, 6, it);
1754
1755 it = new QTableWidgetItem(ntripVersion);
1756 ////it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1757 _mountPointsTable->setItem(iRow, 7, it);
1758
1759 bncTableItem* bncIt = new bncTableItem();
1760 _mountPointsTable->setItem(iRow, 8, bncIt);
1761
1762 iRow++;
1763 }
1764 _mountPointsTable->hideColumn(0);
1765 _mountPointsTable->hideColumn(3);
1766 _mountPointsTable->sortItems(1);
1767 delete mountPoints;
1768
1769 enableStartStop();
1770}
1771
1772// Save Options (serialize)
1773////////////////////////////////////////////////////////////////////////////
1774void bncWindow::slotSaveOptions() {
1775 saveOptions();
1776 bncSettings settings;
1777 settings.sync();
1778}
1779
1780// Save Options (memory only)
1781////////////////////////////////////////////////////////////////////////////
1782void bncWindow::saveOptions() {
1783
1784 QStringList mountPoints;
1785 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1786
1787 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1788 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1789 "@" + _mountPointsTable->item(iRow, 1)->text() );
1790
1791 mountPoints.append(url.toString() + " " +
1792 _mountPointsTable->item(iRow, 2)->text()
1793 + " " + _mountPointsTable->item(iRow, 3)->text()
1794 + " " + _mountPointsTable->item(iRow, 4)->text()
1795 + " " + _mountPointsTable->item(iRow, 5)->text()
1796 + " " + _mountPointsTable->item(iRow, 6)->text()
1797 + " " + _mountPointsTable->item(iRow, 7)->text());
1798 } else {
1799 mountPoints.append(
1800 "//" + _mountPointsTable->item(iRow, 1)->text()
1801 + " " + _mountPointsTable->item(iRow, 2)->text()
1802 + " " + _mountPointsTable->item(iRow, 3)->text()
1803 + " " + _mountPointsTable->item(iRow, 4)->text()
1804 + " " + _mountPointsTable->item(iRow, 5)->text()
1805 + " " + _mountPointsTable->item(iRow, 6)->text()
1806 + " " + _mountPointsTable->item(iRow, 7)->text());
1807 }
1808 }
1809
1810 QStringList cmbStreams;
1811 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1812 QString hlp;
1813 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1814 if (_cmbTable->item(iRow, iCol)) {
1815 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1816 }
1817 }
1818 if (!hlp.isEmpty()) {
1819 cmbStreams << hlp;
1820 }
1821 }
1822
1823 QStringList uploadMountpointsOut;
1824 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1825 QString hlp;
1826 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1827 if (_uploadTable->cellWidget(iRow, iCol) &&
1828 (iCol == 3 || iCol == 4 || iCol == 5)) {
1829 if (iCol == 3) {
1830 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1831 hlp += passwd->text() + ",";
1832 }
1833 else if (iCol == 4) {
1834 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1835 hlp += system->currentText() + ",";
1836 }
1837 else if (iCol == 5) {
1838 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1839 QString state; state.setNum(com->checkState());
1840 hlp += state + ",";
1841 }
1842 }
1843 else if (_uploadTable->item(iRow, iCol)) {
1844 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1845 }
1846 }
1847 if (!hlp.isEmpty()) {
1848 uploadMountpointsOut << hlp;
1849 }
1850 }
1851
1852 bncSettings settings;
1853
1854 settings.setValue("startTab", _aogroup->currentIndex());
1855 settings.setValue("statusTab", _loggroup->currentIndex());
1856 settings.setValue("mountPoints", mountPoints);
1857// Network
1858 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1859 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1860 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1861 settings.setValue("sslIgnoreErrors", _sslIgnoreErrorsCheckBox->checkState());
1862// General
1863 settings.setValue("logFile", _logFileLineEdit->text());
1864 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1865 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1866 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1867 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1868// RINEX Observations
1869 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1870 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1871 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1872 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1873 settings.setValue("rnxOnlyWithSKL",_rnxFileCheckBox->checkState());
1874 settings.setValue("rnxV3filenames",_rnxV3filenameCheckBox->checkState());
1875 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1876 (_rnxV3filenameCheckBox->checkState()) ?
1877 settings.setValue("rnxV3", _rnxV3filenameCheckBox->checkState()) :
1878 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1879 settings.setValue("rnxV2Priority",_rnxV2Priority->text());
1880// RINEX Ephemeris
1881 settings.setValue("ephPath", _ephPathLineEdit->text());
1882 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1883 settings.setValue("ephOutPort", _ephOutPortLineEdit->text());
1884 settings.setValue("ephV3filenames", _ephV3filenameCheckBox->checkState());
1885 (_ephV3filenameCheckBox->checkState()) ?
1886 settings.setValue("ephV3", _ephV3filenameCheckBox->checkState()) :
1887 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1888// Broadcast Corrections
1889 settings.setValue("corrPath", _corrPathLineEdit->text());
1890 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1891 settings.setValue("corrPort", _corrPortLineEdit->text());
1892// Feed Engine
1893 settings.setValue("outPort", _outPortLineEdit->text());
1894 settings.setValue("outWait", _outWaitSpinBox->value());
1895 settings.setValue("outSampl", _outSamplSpinBox->value());
1896 settings.setValue("outFile", _outFileLineEdit->text());
1897 settings.setValue("outUPort", _outUPortLineEdit->text());
1898// Serial Output
1899 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1900 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1901 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1902 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1903 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1904 settings.setValue("serialParity", _serialParityComboBox->currentText());
1905 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1906 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1907 settings.setValue("serialFileNMEA", _serialFileNMEALineEdit->text());
1908 settings.setValue("serialHeightNMEA", _serialHeightNMEALineEdit->text());
1909 settings.setValue("serialManualNMEASampling", _serialManualNMEASamplingSpinBox->value());
1910// Outages
1911 settings.setValue("adviseObsRate", _adviseObsRateComboBox->currentText());
1912 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1913 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1914 settings.setValue("adviseScript", _adviseScriptLineEdit->text());
1915// Miscellaneous
1916 settings.setValue("miscMount", _miscMountLineEdit->text());
1917 settings.setValue("miscPort", _miscPortLineEdit->text());
1918 settings.setValue("miscIntr", _miscIntrComboBox->currentText());
1919 settings.setValue("miscScanRTCM", _miscScanRTCMCheckBox->checkState());
1920// Reqc
1921 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1922 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1923 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1924 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1925 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1926 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
1927 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
1928 settings.setValue("reqcSkyPlotSignals", _reqcSkyPlotSignals->text());
1929 settings.setValue("reqcLogSummaryOnly", _reqcLogSummaryOnly->checkState());
1930// SP3 Comparison
1931 settings.setValue("sp3CompFile", _sp3CompFileChooser->fileName());
1932 settings.setValue("sp3CompExclude", _sp3CompExclude->text());
1933 settings.setValue("sp3CompOutLogFile", _sp3CompLogLineEdit->text());
1934// Combine Corrections
1935 if (!cmbStreams.isEmpty()) {
1936 settings.setValue("cmbStreams", cmbStreams);
1937 }
1938 else {
1939 settings.setValue("cmbStreams", "");
1940 }
1941 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1942 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1943 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1944 settings.setValue("cmbUseGlonass", _cmbUseGlonass->checkState());
1945// Upload Corrections
1946 if (!uploadMountpointsOut.isEmpty()) {
1947 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1948 }
1949 else {
1950 settings.setValue("uploadMountpointsOut", "");
1951 }
1952 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1953 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1954 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1955 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
1956 settings.setValue("uploadAntexFile", _uploadAntexFile->fileName());
1957// Upload Ephemeris
1958 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1959 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
1960 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
1961 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1962 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
1963
1964 if (_caster) {
1965 _caster->readMountPoints();
1966 }
1967
1968 _pppWidgets.saveOptions();
1969}
1970
1971// All get slots terminated
1972////////////////////////////////////////////////////////////////////////////
1973void bncWindow::slotGetThreadsFinished() {
1974 BNC_CORE->slotMessage("All Get Threads Terminated", true);
1975 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
1976 delete _casterEph; _casterEph = 0;
1977 _runningRealTime = false;
1978}
1979
1980// Start It!
1981////////////////////////////////////////////////////////////////////////////
1982void bncWindow::slotStart() {
1983 saveOptions();
1984 if ( _pppWidgets._dataSource->currentText() == "RINEX Files") {
1985 _runningPPP = true;
1986 enableStartStop();
1987 _caster = new bncCaster(); BNC_CORE->setCaster(_caster);
1988 BNC_CORE->startPPP();
1989 _bncFigurePPP->reset();
1990 }
1991 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
1992 if (_reqcActionComboBox->currentText() == "Analyze") {
1993 _runningQC = true;
1994 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
1995 connect(reqcAnalyze, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1996 reqcAnalyze->start();
1997 }
1998 else {
1999 _runningEdit = true;
2000 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
2001 connect(reqcEdit, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
2002 reqcEdit->start();
2003 }
2004 enableStartStop();
2005 }
2006 else if (!_sp3CompFileChooser->fileName().isEmpty()) {
2007 _runningSp3Comp = true;
2008 t_sp3Comp* sp3Comp = new t_sp3Comp(this);
2009 connect(sp3Comp, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
2010 sp3Comp->start();
2011 enableStartStop();
2012 }
2013 else {
2014 startRealTime();
2015 BNC_CORE->startPPP();
2016 }
2017}
2018
2019// Start Real-Time (Retrieve Data etc.)
2020////////////////////////////////////////////////////////////////////////////
2021void bncWindow::startRealTime() {
2022
2023 _runningRealTime = true;
2024
2025 _bncFigurePPP->reset();
2026
2027 _actDeleteMountPoints->setEnabled(false);
2028
2029 enableStartStop();
2030
2031 _caster = new bncCaster();
2032
2033 BNC_CORE->setCaster(_caster);
2034 BNC_CORE->setPortEph(_ephOutPortLineEdit->text().toInt());
2035 BNC_CORE->setPortCorr(_corrPortLineEdit->text().toInt());
2036 BNC_CORE->initCombination();
2037
2038 connect(_caster, SIGNAL(getThreadsFinished()),
2039 this, SLOT(slotGetThreadsFinished()));
2040
2041 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
2042 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
2043
2044 BNC_CORE->slotMessage("========== Start BNC v" BNCVERSION" ("BNC_OS") ==========", true);
2045
2046 bncSettings settings;
2047
2048 // Active panels
2049 // -------------
2050 if (!_rnxPathLineEdit->text().isEmpty())
2051 BNC_CORE->slotMessage("Panel 'RINEX Observations' active", true);
2052 if (!_ephPathLineEdit->text().isEmpty())
2053 BNC_CORE->slotMessage("Panel 'RINEX Ephemeris' active", true);
2054 if (!_corrPathLineEdit->text().isEmpty())
2055 BNC_CORE->slotMessage("Panel 'Broadcast Corrections' active", true);
2056 if (!_outPortLineEdit->text().isEmpty())
2057 BNC_CORE->slotMessage("Panel 'Feed Engine' active", true);
2058 if (!_serialMountPointLineEdit->text().isEmpty())
2059 BNC_CORE->slotMessage("Panel 'Serial Output' active", true);
2060 if (!_adviseObsRateComboBox->currentText().isEmpty())
2061 BNC_CORE->slotMessage("Panel 'Outages' active", true);
2062 if (!_miscMountLineEdit->text().isEmpty())
2063 BNC_CORE->slotMessage("Panel 'Miscellaneous' active", true);
2064 if (_pppWidgets._dataSource->currentText() == "Real-Time Streams")
2065 BNC_CORE->slotMessage("Panel 'PPP' active", true);
2066 if (_cmbTable->rowCount() > 0)
2067 BNC_CORE->slotMessage("Panel 'Combine Corrections' active", true);
2068 if (_uploadTable->rowCount() > 0)
2069 BNC_CORE->slotMessage("Panel 'Upload Corrections' active", true);
2070 if (!_uploadEphHostLineEdit->text().isEmpty())
2071 BNC_CORE->slotMessage("Panel 'UploadEphemeris' active", true);
2072
2073 QDir rnxdir(settings.value("rnxPath").toString());
2074 if (!rnxdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations directory", true);
2075
2076 QString rnx_file = settings.value("rnxScript").toString();
2077 if ( !rnx_file.isEmpty() ) {
2078 QFile rnxfile(settings.value("rnxScript").toString());
2079 if (!rnxfile.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations script", true);
2080 }
2081
2082 QDir ephdir(settings.value("ephPath").toString());
2083 if (!ephdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Ephemeris directory", true);
2084
2085 QDir corrdir(settings.value("corrPath").toString());
2086 if (!corrdir.exists()) BNC_CORE->slotMessage("Cannot find Broadcast Corrections directory", true);
2087
2088 QString advise_file = settings.value("adviseScript").toString();
2089 if ( !advise_file.isEmpty() ) {
2090 QFile advisefile(settings.value("adviseScript").toString());
2091 if (!advisefile.exists()) BNC_CORE->slotMessage("Cannot find Outages script", true);
2092 }
2093
2094 _caster->readMountPoints();
2095
2096 _casterEph = new bncEphUploadCaster();
2097 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
2098 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
2099}
2100
2101// Retrieve Data
2102////////////////////////////////////////////////////////////////////////////
2103void bncWindow::slotStop() {
2104 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving/processing data?",
2105 QMessageBox::Yes, QMessageBox::No,
2106 QMessageBox::NoButton);
2107 if (iRet == QMessageBox::Yes) {
2108 BNC_CORE->stopPPP();
2109 BNC_CORE->stopCombination();
2110 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
2111 delete _casterEph; _casterEph = 0;
2112 _runningRealTime = false;
2113 _runningPPP = false;
2114 enableStartStop();
2115 }
2116}
2117
2118// Close Application gracefully
2119////////////////////////////////////////////////////////////////////////////
2120void bncWindow::closeEvent(QCloseEvent* event) {
2121
2122 int iRet = QMessageBox::question(this, "Close", "Save Options?",
2123 QMessageBox::Yes, QMessageBox::No,
2124 QMessageBox::Cancel);
2125
2126 if (iRet == QMessageBox::Cancel) {
2127 event->ignore();
2128 return;
2129 }
2130 else if (iRet == QMessageBox::Yes) {
2131 slotSaveOptions();
2132 }
2133
2134 BNC_CORE->stopPPP();
2135
2136 QMainWindow::closeEvent(event);
2137}
2138
2139// User changed the selection of mountPoints
2140////////////////////////////////////////////////////////////////////////////
2141void bncWindow::slotSelectionChanged() {
2142 if (_mountPointsTable->selectedItems().isEmpty()) {
2143 _actDeleteMountPoints->setEnabled(false);
2144 }
2145 else {
2146 _actDeleteMountPoints->setEnabled(true);
2147 }
2148}
2149
2150// Display Program Messages
2151////////////////////////////////////////////////////////////////////////////
2152void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
2153 if (showOnScreen ) {
2154 _log->append(QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg);
2155 }
2156}
2157
2158// About Message
2159////////////////////////////////////////////////////////////////////////////
2160void bncWindow::slotAbout() {
2161 new bncAboutDlg(0);
2162}
2163
2164//Flowchart
2165////////////////////////////////////////////////////////////////////////////
2166void bncWindow::slotFlowchart() {
2167 new bncFlowchartDlg(0);
2168}
2169
2170// Help Window
2171////////////////////////////////////////////////////////////////////////////
2172void bncWindow::slotHelp() {
2173 QUrl url;
2174 url.setPath(":bnchelp.html");
2175 new bncHlpDlg(0, url);
2176}
2177
2178// Select Fonts
2179////////////////////////////////////////////////////////////////////////////
2180void bncWindow::slotFontSel() {
2181 bool ok;
2182 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
2183 if (ok) {
2184 bncSettings settings;
2185 settings.setValue("font", newFont.toString());
2186 QApplication::setFont(newFont);
2187 int ww = QFontMetrics(newFont).width('w');
2188 setMinimumSize(60*ww, 80*ww);
2189 resize(60*ww, 80*ww);
2190 }
2191}
2192
2193// Whats This Help
2194void bncWindow::slotWhatsThis() {
2195 QWhatsThis::enterWhatsThisMode();
2196}
2197
2198//
2199////////////////////////////////////////////////////////////////////////////
2200void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
2201 _threads = threads;
2202
2203 _bncFigure->updateMountPoints();
2204 _bncFigureLate->updateMountPoints();
2205
2206 populateMountPointsTable();
2207 bncSettings settings;
2208 _outSamplSpinBox->setValue(settings.value("outSampl").toInt());
2209 _outWaitSpinBox->setValue(settings.value("outWait").toInt());
2210 QListIterator<bncGetThread*> iTh(threads);
2211 while (iTh.hasNext()) {
2212 bncGetThread* thread = iTh.next();
2213 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
2214 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
2215 "@" + _mountPointsTable->item(iRow, 1)->text() );
2216 if (url == thread->mountPoint() &&
2217 _mountPointsTable->item(iRow, 4)->text() == thread->latitude() &&
2218 _mountPointsTable->item(iRow, 5)->text() == thread->longitude() ) {
2219 ((bncTableItem*) _mountPointsTable->item(iRow, 8))->setGetThread(thread);
2220 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
2221 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2222 connect(thread, SIGNAL(newBytes(QByteArray, double)),
2223 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2224 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
2225 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2226 connect(thread, SIGNAL(newLatency(QByteArray, double)),
2227 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2228 break;
2229 }
2230 }
2231 }
2232}
2233
2234//
2235////////////////////////////////////////////////////////////////////////////
2236void bncWindow::CreateMenu() {
2237 // Create Menus
2238 // ------------
2239 _menuFile = menuBar()->addMenu(tr("&File"));
2240 _menuFile->addAction(_actFontSel);
2241 _menuFile->addSeparator();
2242 _menuFile->addAction(_actSaveOpt);
2243 _menuFile->addSeparator();
2244 _menuFile->addAction(_actQuit);
2245
2246 _menuHlp = menuBar()->addMenu(tr("&Help"));
2247 _menuHlp->addAction(_actHelp);
2248 _menuHlp->addAction(_actFlowchart);
2249 _menuHlp->addAction(_actAbout);
2250}
2251
2252// Toolbar
2253////////////////////////////////////////////////////////////////////////////
2254void bncWindow::AddToolbar() {
2255 QToolBar* toolBar = new QToolBar;
2256 addToolBar(Qt::BottomToolBarArea, toolBar);
2257 toolBar->setMovable(false);
2258 toolBar->addAction(_actAddMountPoints);
2259 toolBar->addAction(_actDeleteMountPoints);
2260 toolBar->addAction(_actMapMountPoints);
2261 toolBar->addAction(_actStart);
2262 toolBar->addAction(_actStop);
2263 toolBar->addWidget(new QLabel(" "));
2264 toolBar->addAction(_actwhatsthis);
2265}
2266
2267// About
2268////////////////////////////////////////////////////////////////////////////
2269bncAboutDlg::bncAboutDlg(QWidget* parent) :
2270 QDialog(parent) {
2271
2272 QTextBrowser* tb = new QTextBrowser;
2273 QUrl url; url.setPath(":bncabout.html");
2274 tb->setSource(url);
2275 tb->setReadOnly(true);
2276
2277 int ww = QFontMetrics(font()).width('w');
2278 QPushButton* _closeButton = new QPushButton("Close");
2279 _closeButton->setMaximumWidth(10*ww);
2280 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2281
2282 QGridLayout* dlgLayout = new QGridLayout();
2283 QLabel* img = new QLabel();
2284 img->setPixmap(QPixmap(":ntrip-logo.png"));
2285 dlgLayout->addWidget(img, 0,0);
2286 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
2287 dlgLayout->addWidget(tb,1,0,1,2);
2288 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2289
2290 setLayout(dlgLayout);
2291 resize(60*ww, 60*ww);
2292 setWindowTitle("About BNC");
2293 show();
2294}
2295
2296//
2297////////////////////////////////////////////////////////////////////////////
2298bncAboutDlg::~bncAboutDlg() {
2299
2300};
2301
2302// Flowchart
2303////////////////////////////////////////////////////////////////////////////
2304bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2305 QDialog(parent) {
2306
2307 int ww = QFontMetrics(font()).width('w');
2308 QPushButton* _closeButton = new QPushButton("Close");
2309 _closeButton->setMaximumWidth(10*ww);
2310 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2311
2312 QGridLayout* dlgLayout = new QGridLayout();
2313 QLabel* img = new QLabel();
2314 img->setPixmap(QPixmap(":bncflowchart.png"));
2315 dlgLayout->addWidget(img, 0,0);
2316 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2317
2318 setLayout(dlgLayout);
2319 setWindowTitle("Flow Chart");
2320 show();
2321}
2322
2323//
2324////////////////////////////////////////////////////////////////////////////
2325bncFlowchartDlg::~bncFlowchartDlg() {
2326};
2327
2328// Enable/Disable Widget (and change its color)
2329////////////////////////////////////////////////////////////////////////////
2330void bncWindow::enableWidget(bool enable, QWidget* widget) {
2331
2332 const static QPalette paletteWhite(QColor(255, 255, 255));
2333 const static QPalette paletteGray(QColor(230, 230, 230));
2334
2335 widget->setEnabled(enable);
2336 if (enable) {
2337 widget->setPalette(paletteWhite);
2338 }
2339 else {
2340 widget->setPalette(paletteGray);
2341 }
2342}
2343
2344// Bnc Text
2345////////////////////////////////////////////////////////////////////////////
2346void bncWindow::slotBncTextChanged(){
2347
2348 const static QPalette paletteWhite(QColor(255, 255, 255));
2349 const static QPalette paletteGray(QColor(230, 230, 230));
2350
2351 bool enable = true;
2352
2353 // Proxy
2354 //------
2355 if (sender() == 0 || sender() == _proxyHostLineEdit) {
2356 enable = !_proxyHostLineEdit->text().isEmpty();
2357 enableWidget(enable, _proxyPortLineEdit);
2358 }
2359
2360 // RINEX Observations
2361 // ------------------
2362 if (sender() == 0 || sender() == _rnxPathLineEdit) {
2363 enable = !_rnxPathLineEdit->text().isEmpty();
2364 enableWidget(enable, _rnxIntrComboBox);
2365 enableWidget(enable, _rnxSamplSpinBox);
2366 enableWidget(enable, _rnxSkelLineEdit);
2367 enableWidget(enable, _rnxFileCheckBox);
2368 enableWidget(enable, _rnxScrpLineEdit);
2369 enableWidget(enable, _rnxV2Priority);
2370 enableWidget(enable, _rnxV3CheckBox);
2371
2372 bool enable1 = true;
2373 enable1 = _rnxV3CheckBox->isChecked();
2374 if (enable && enable1) {
2375 enableWidget(false, _rnxV2Priority);
2376 }
2377 if (enable && !enable1) {
2378 enableWidget(true, _rnxV2Priority);
2379 }
2380 }
2381
2382 // RINEX Observations, Signal Priority
2383 // -----------------------------------
2384 if (sender() == 0 || sender() == _rnxV3CheckBox) {
2385 if (!_rnxPathLineEdit->text().isEmpty()) {
2386 enableWidget(enable, _rnxIntrComboBox);
2387 enable = !_rnxV3CheckBox->isChecked();
2388 enableWidget(enable, _rnxV2Priority);
2389 }
2390 }
2391
2392 // RINEX Ephemeris
2393 // ---------------
2394 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _ephOutPortLineEdit) {
2395 enable = !_ephPathLineEdit->text().isEmpty() || !_ephOutPortLineEdit->text().isEmpty();
2396 enableWidget(enable, _ephIntrComboBox);
2397 enableWidget(enable, _ephV3CheckBox);
2398 enableWidget(enable, _ephV3filenameCheckBox);
2399 }
2400
2401 // Broadcast Corrections
2402 // ---------------------
2403 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2404 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2405 enableWidget(enable, _corrIntrComboBox);
2406 }
2407
2408 // Feed Engine
2409 // -----------
2410 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2411 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2412 enableWidget(enable, _outWaitSpinBox);
2413 enableWidget(enable, _outSamplSpinBox);
2414 }
2415
2416 // Serial Output
2417 // -------------
2418 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
2419 sender() == _serialAutoNMEAComboBox) {
2420 enable = !_serialMountPointLineEdit->text().isEmpty();
2421 enableWidget(enable, _serialPortNameLineEdit);
2422 enableWidget(enable, _serialBaudRateComboBox);
2423 enableWidget(enable, _serialParityComboBox);
2424 enableWidget(enable, _serialDataBitsComboBox);
2425 enableWidget(enable, _serialStopBitsComboBox);
2426 enableWidget(enable, _serialFlowControlComboBox);
2427 enableWidget(enable, _serialAutoNMEAComboBox);
2428 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() == "Auto";
2429 enableWidget(enable2, _serialFileNMEALineEdit);
2430 bool enable3 = enable && _serialAutoNMEAComboBox->currentText().contains("Manual");
2431 enableWidget(enable3, _serialHeightNMEALineEdit);
2432 enableWidget(enable3, _serialManualNMEASamplingSpinBox);
2433 }
2434
2435 // Outages
2436 // -------
2437 if (sender() == 0 || sender() == _adviseObsRateComboBox) {
2438 enable = !_adviseObsRateComboBox->currentText().isEmpty();
2439 enableWidget(enable, _adviseFailSpinBox);
2440 enableWidget(enable, _adviseRecoSpinBox);
2441 enableWidget(enable, _adviseScriptLineEdit);
2442 }
2443
2444 // Miscellaneous
2445 // -------------
2446 if (sender() == 0 || sender() == _miscMountLineEdit) {
2447 enable = !_miscMountLineEdit->text().isEmpty();
2448 enableWidget(enable, _miscIntrComboBox);
2449 enableWidget(enable, _miscScanRTCMCheckBox);
2450 enableWidget(enable, _miscPortLineEdit);
2451 }
2452
2453 // Enable/disable Broadcast Ephemerides
2454 // ------------------------------------
2455 if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2456 enable = !_uploadEphHostLineEdit->text().isEmpty();
2457 enableWidget(enable, _uploadEphPortLineEdit);
2458 enableWidget(enable, _uploadEphMountpointLineEdit);
2459 enableWidget(enable, _uploadEphPasswordLineEdit);
2460 enableWidget(enable, _uploadEphSampleSpinBox);
2461 }
2462
2463 // Combine Corrections
2464 // -------------------
2465 if (sender() == 0 || sender() == _cmbTable) {
2466 int iRow = _cmbTable->rowCount();
2467 if (iRow > 0) {
2468 enableWidget(true, _cmbMethodComboBox);
2469 enableWidget(true, _cmbMaxresLineEdit);
2470 enableWidget(true, _cmbSamplSpinBox);
2471 enableWidget(true, _cmbUseGlonass);
2472 }
2473 else {
2474 enableWidget(false, _cmbMethodComboBox);
2475 enableWidget(false, _cmbMaxresLineEdit);
2476 enableWidget(false, _cmbSamplSpinBox);
2477 enableWidget(false, _cmbUseGlonass);
2478 }
2479 }
2480
2481 // Upload(clk)
2482 // -----------
2483 int iRow = _uploadTable->rowCount();
2484 if (iRow > 0) {
2485 enableWidget(true, _uploadIntrComboBox);
2486 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2487 enableWidget(true, _uploadSamplClkRnxSpinBox);
2488 enableWidget(true, _uploadSamplSp3SpinBox);
2489 enableWidget(true, _uploadAntexFile);
2490 }
2491 else {
2492 enableWidget(false, _uploadIntrComboBox);
2493 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2494 enableWidget(false, _uploadSamplClkRnxSpinBox);
2495 enableWidget(false, _uploadSamplSp3SpinBox);
2496 enableWidget(false, _uploadAntexFile);
2497 }
2498
2499 // QC
2500 // --
2501 if (sender() == 0 || sender() == _reqcActionComboBox || sender() == _reqcSkyPlotSignals) {
2502 enable = !_reqcActionComboBox->currentText().isEmpty();
2503 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2504// bool enablePlot = !_reqcSkyPlotSignals->text().isEmpty();
2505 enableWidget(enable, _reqcObsFileChooser);
2506 enableWidget(enable, _reqcNavFileChooser);
2507 enableWidget(enable, _reqcOutLogLineEdit);
2508 enableWidget(enable && enable10, _reqcEditOptionButton);
2509 enableWidget(enable && enable10, _reqcOutObsLineEdit);
2510 enableWidget(enable && enable10, _reqcOutNavLineEdit);
2511 enableWidget(enable && !enable10, _reqcLogSummaryOnly);
2512 enableWidget(enable && !enable10, _reqcSkyPlotSignals);
2513// enableWidget(enable && !enable10 && enablePlot, _reqcPlotDirLineEdit);
2514 enableWidget(enable && !enable10, _reqcPlotDirLineEdit);
2515 }
2516
2517 // SP3 File Comparison
2518 // -------------------
2519 if (sender() == 0 || sender() == _sp3CompFileChooser) {
2520 enable = !_sp3CompFileChooser->fileName().isEmpty();
2521 enableWidget(enable, _sp3CompLogLineEdit);
2522 enableWidget(enable, _sp3CompExclude);
2523 }
2524
2525 enableStartStop();
2526}
2527
2528//
2529////////////////////////////////////////////////////////////////////////////
2530void bncWindow::slotAddCmbRow() {
2531 int iRow = _cmbTable->rowCount();
2532 _cmbTable->insertRow(iRow);
2533 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2534 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2535 }
2536}
2537
2538//
2539////////////////////////////////////////////////////////////////////////////
2540void bncWindow::slotDelCmbRow() {
2541
2542 const static QPalette paletteWhite(QColor(255, 255, 255));
2543 const static QPalette paletteGray(QColor(230, 230, 230));
2544
2545 int nRows = _cmbTable->rowCount();
2546 bool flg[nRows];
2547 for (int iRow = 0; iRow < nRows; iRow++) {
2548 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2549 flg[iRow] = true;
2550 }
2551 else {
2552 flg[iRow] = false;
2553 }
2554 }
2555 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2556 if (flg[iRow]) {
2557 _cmbTable->removeRow(iRow);
2558 }
2559 }
2560 nRows = _cmbTable->rowCount();
2561 if (nRows < 1) {
2562 enableWidget(false, _cmbMethodComboBox);
2563 enableWidget(false, _cmbMaxresLineEdit);
2564 enableWidget(false, _cmbSamplSpinBox);
2565 enableWidget(false, _cmbUseGlonass);
2566 }
2567}
2568
2569//
2570////////////////////////////////////////////////////////////////////////////
2571void bncWindow::populateCmbTable() {
2572
2573 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2574 _cmbTable->removeRow(iRow);
2575 }
2576
2577 bncSettings settings;
2578
2579 int iRow = -1;
2580 QListIterator<QString> it(settings.value("cmbStreams").toStringList());
2581 while (it.hasNext()) {
2582 QStringList hlp = it.next().split(" ");
2583 if (hlp.size() > 2) {
2584 ++iRow;
2585 _cmbTable->insertRow(iRow);
2586 }
2587 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2588 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2589 }
2590 }
2591}
2592
2593//
2594////////////////////////////////////////////////////////////////////////////
2595void bncWindow::slotAddUploadRow() {
2596 int iRow = _uploadTable->rowCount();
2597 _uploadTable->insertRow(iRow);
2598 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2599 if (iCol == 3) {
2600 QLineEdit* passwd = new QLineEdit();
2601 passwd->setFrame(false);
2602 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2603 _uploadTable->setCellWidget(iRow, iCol, passwd);
2604 }
2605 else if (iCol == 4) {
2606 QComboBox* system = new QComboBox();
2607 system->setEditable(false);
2608 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2609 system->setFrame(false);
2610 _uploadTable->setCellWidget(iRow, iCol, system);
2611 }
2612 else if (iCol == 5) {
2613 QCheckBox* com = new QCheckBox();
2614 _uploadTable->setCellWidget(iRow, iCol, com);
2615 }
2616 else if (iCol == 11) {
2617 bncTableItem* bncIt = new bncTableItem();
2618 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2619 _uploadTable->setItem(iRow, iCol, bncIt);
2620 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2621 }
2622 else {
2623 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2624 }
2625 }
2626}
2627
2628//
2629////////////////////////////////////////////////////////////////////////////
2630void bncWindow::slotDelUploadRow() {
2631 BNC_CORE->_uploadTableItems.clear();
2632 int nRows = _uploadTable->rowCount();
2633 bool flg[nRows];
2634 for (int iRow = 0; iRow < nRows; iRow++) {
2635 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2636 flg[iRow] = true;
2637 }
2638 else {
2639 flg[iRow] = false;
2640 }
2641 }
2642 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2643 if (flg[iRow]) {
2644 _uploadTable->removeRow(iRow);
2645 }
2646 }
2647 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2648 BNC_CORE->_uploadTableItems[iRow] =
2649 (bncTableItem*) _uploadTable->item(iRow, 11);
2650 }
2651 nRows = _uploadTable->rowCount();
2652 if (nRows < 1) {
2653 enableWidget(false, _uploadIntrComboBox);
2654 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2655 enableWidget(false, _uploadSamplSp3SpinBox);
2656 enableWidget(false, _uploadSamplClkRnxSpinBox);
2657 enableWidget(false, _uploadAntexFile);
2658 }
2659}
2660
2661//
2662////////////////////////////////////////////////////////////////////////////
2663void bncWindow::populateUploadTable() {
2664 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2665 _uploadTable->removeRow(iRow);
2666 }
2667
2668 bncSettings settings;
2669
2670 int iRow = -1;
2671 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2672 while (it.hasNext()) {
2673 QStringList hlp = it.next().split(",");
2674 if (hlp.size() > 6) {
2675 ++iRow;
2676 _uploadTable->insertRow(iRow);
2677 }
2678 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2679 if (iCol == 3) {
2680 QLineEdit* passwd = new QLineEdit();
2681 passwd->setFrame(false);
2682 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2683 passwd->setText(hlp[iCol]);
2684 _uploadTable->setCellWidget(iRow, iCol, passwd);
2685 }
2686 else if (iCol == 4) {
2687 QComboBox* system = new QComboBox();
2688 system->setEditable(false);
2689 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2690 system->setFrame(false);
2691 system->setCurrentIndex(system->findText(hlp[iCol]));
2692 _uploadTable->setCellWidget(iRow, iCol, system);
2693 }
2694 else if (iCol == 5) {
2695 QCheckBox* com = new QCheckBox();
2696 if (hlp[iCol].toInt() == Qt::Checked) {
2697 com->setCheckState(Qt::Checked);
2698 }
2699 _uploadTable->setCellWidget(iRow, iCol, com);
2700 }
2701 else if (iCol == 11) {
2702 bncTableItem* bncIt = new bncTableItem();
2703 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2704 _uploadTable->setItem(iRow, iCol, bncIt);
2705 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2706 }
2707 else {
2708 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2709 }
2710 }
2711 }
2712}
2713
2714//
2715////////////////////////////////////////////////////////////////////////////
2716void bncWindow::slotSetUploadTrafo() {
2717 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2718 dlg->exec();
2719 delete dlg;
2720}
2721
2722// Progress Bar Change
2723////////////////////////////////////////////////////////////////////////////
2724void bncWindow::slotPostProcessingProgress(int nEpo) {
2725 _actStart->setText(QString("%1 Epochs").arg(nEpo));
2726}
2727
2728// Post-Processing Reqc Finished
2729////////////////////////////////////////////////////////////////////////////
2730void bncWindow::slotPostProcessingFinished() {
2731 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
2732 _runningPPP = false;
2733 _runningEdit = false;
2734 _runningQC = false;
2735 _runningSp3Comp = false;
2736 _actStart->setText(tr("Sta&rt"));
2737 enableStartStop();
2738}
2739
2740// Edit teqc-like editing options
2741////////////////////////////////////////////////////////////////////////////
2742void bncWindow::slotReqcEditOption() {
2743 saveOptions();
2744 reqcDlg* dlg = new reqcDlg(this);
2745 dlg->move(this->pos().x()+50, this->pos().y()+50);
2746 dlg->exec();
2747 delete dlg;
2748}
2749
2750// Enable/Disable Start and Stop Buttons
2751////////////////////////////////////////////////////////////////////////////
2752void bncWindow::enableStartStop() {
2753 if ( running() ) {
2754 _actStart->setEnabled(false);
2755 if (_runningRealTime || _runningPPP) {
2756 _actStop->setEnabled(true);
2757 }
2758 }
2759 else {
2760 _actStart->setEnabled(true);
2761 _actStop->setEnabled(false);
2762 }
2763}
2764
2765// Show Map
2766////////////////////////////////////////////////////////////////////////////
2767void bncWindow::slotMapMountPoints() {
2768 saveOptions();
2769 t_bncMap* bncMap = new t_bncMap(this);
2770 bncMap->setMinimumSize(800, 600);
2771 bncMap->setWindowTitle("Selected Mountpoints");
2772
2773 bncSettings settings;
2774 QListIterator<QString> it(settings.value("mountPoints").toStringList());
2775 while (it.hasNext()) {
2776 QStringList hlp = it.next().split(" ");
2777 if (hlp.size() < 5) continue;
2778 QUrl url(hlp[0]);
2779 double latDeg = hlp[2].toDouble();
2780 double lonDeg = hlp[3].toDouble();
2781 bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
2782 }
2783
2784 bncMap->show();
2785}
2786
2787// Show Map
2788////////////////////////////////////////////////////////////////////////////
2789void bncWindow::slotMapPPP() {
2790#ifdef QT_WEBKIT
2791 saveOptions();
2792 enableWidget(false, _pppWidgets._mapWinButton);
2793 enableWidget(false, _pppWidgets._useGoogleMap);
2794 enableWidget(false, _pppWidgets._useOpenStreetMap);
2795 enableWidget(false, _pppWidgets._mapWinDotSize);
2796 enableWidget(false, _pppWidgets._mapWinDotColor);
2797
2798 if (!_mapWin) {
2799 _mapWin = new bncMapWin(this);
2800 connect(_mapWin, SIGNAL(mapClosed()), this, SLOT(slotMapPPPClosed()));
2801 connect(BNC_CORE, SIGNAL(newPosition(QByteArray, bncTime, QVector<double>)),
2802 _mapWin, SLOT(slotNewPosition(QByteArray, bncTime, QVector<double>)));
2803 }
2804 _mapWin->show();
2805#else
2806 QMessageBox::information(this, "Information",
2807 "Qt Library compiled without QtWebKit");
2808#endif
2809}
2810
2811// Show Map
2812////////////////////////////////////////////////////////////////////////////
2813void bncWindow::slotMapPPPClosed() {
2814#ifdef QT_WEBKIT
2815 enableWidget(true, _pppWidgets._mapWinButton);
2816 enableWidget(true, _pppWidgets._useGoogleMap);
2817 enableWidget(true, _pppWidgets._useOpenStreetMap);
2818 enableWidget(true, _pppWidgets._mapWinDotSize);
2819 enableWidget(true, _pppWidgets._mapWinDotColor);
2820 if (_mapWin) {
2821 QListIterator<bncGetThread*> it(_threads);
2822 while (it.hasNext()) {
2823 bncGetThread* thread = it.next();
2824 thread->disconnect(_mapWin);
2825 }
2826 _mapWin->deleteLater();
2827 _mapWin = 0;
2828 }
2829#endif
2830}
Note: See TracBrowser for help on using the repository browser.