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

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

System and frequency specific signal priorities are added for RINEX3 to RINEX2 conversion and the default 'Signal priority' list is improved

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