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

Last change on this file since 4720 was 4714, checked in by mervart, 12 years ago
File size: 139.7 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 "bncapp.h"
46#include "bncgetthread.h"
47#include "bnctabledlg.h"
48#include "bncipport.h"
49#include "bncudpport.h"
50#include "bncserialport.h"
51#include "bnchlpdlg.h"
52#include "bnchtml.h"
53#include "bnctableitem.h"
54#include "bncsettings.h"
55#include "bncfigure.h"
56#include "bncfigurelate.h"
57#include "bncfigureppp.h"
58#include "bncversion.h"
59#include "bncbytescounter.h"
60#include "bncsslconfig.h"
61#include "upload/bnccustomtrafo.h"
62#include "upload/bncephuploadcaster.h"
63#include "qtfilechooser.h"
64#include "reqcdlg.h"
65#include "bncmap.h"
66#ifdef USE_POSTPROCESSING
67# include "rinex/bncpostprocess.h"
68# include "rinex/reqcedit.h"
69# include "rinex/reqcanalyze.h"
70#endif
71
72using namespace std;
73
74// Constructor
75////////////////////////////////////////////////////////////////////////////
76bncWindow::bncWindow() {
77
78 _caster = 0;
79 _casterEph = 0;
80
81 _bncFigure = new bncFigure(this);
82 _bncFigureLate = new bncFigureLate(this);
83 _bncFigurePPP = new bncFigurePPP(this);
84 _runningRealTime = false;
85 _runningPostProcessingPPP = false;
86 _runningPostProcessingReqc = false;
87
88 _pppSPPComboBox = 0; // necessary for enableStartStop()
89 _reqcActionComboBox = 0; // necessary for enableStartStop()
90
91 int ww = QFontMetrics(this->font()).width('w');
92
93 static const QStringList labels = QString("account, Streams: resource loader / mountpoint, decoder, lat, long, nmea, ntrip, bytes").split(",");
94
95 setMinimumSize(85*ww, 65*ww);
96
97 setWindowTitle(tr("BKG Ntrip Client (BNC) Version " BNCVERSION));
98
99 connect((bncApp*)qApp, SIGNAL(newMessage(QByteArray,bool)),
100 this, SLOT(slotWindowMessage(QByteArray,bool)));
101
102 // Create Actions
103 // --------------
104 _actHelp = new QAction(tr("&Help Contents"),this);
105 connect(_actHelp, SIGNAL(triggered()), SLOT(slotHelp()));
106
107 _actAbout = new QAction(tr("&About BNC"),this);
108 connect(_actAbout, SIGNAL(triggered()), SLOT(slotAbout()));
109
110 _actFlowchart = new QAction(tr("&Flow Chart"),this);
111 connect(_actFlowchart, SIGNAL(triggered()), SLOT(slotFlowchart()));
112
113 _actFontSel = new QAction(tr("Select &Font"),this);
114 connect(_actFontSel, SIGNAL(triggered()), SLOT(slotFontSel()));
115
116 _actSaveOpt = new QAction(tr("&Save && Reread Configuration"),this);
117 connect(_actSaveOpt, SIGNAL(triggered()), SLOT(slotSaveOptions()));
118
119 _actQuit = new QAction(tr("&Quit"),this);
120 connect(_actQuit, SIGNAL(triggered()), SLOT(close()));
121
122 _actAddMountPoints = new QAction(tr("Add &Stream"),this);
123 connect(_actAddMountPoints, SIGNAL(triggered()), SLOT(slotAddMountPoints()));
124
125 _actDeleteMountPoints = new QAction(tr("&Delete Stream"),this);
126 connect(_actDeleteMountPoints, SIGNAL(triggered()), SLOT(slotDeleteMountPoints()));
127 _actDeleteMountPoints->setEnabled(false);
128
129 _actMap = new QAction(tr("&Map"),this);
130 connect(_actMap, SIGNAL(triggered()), SLOT(slotMap()));
131
132 _actStart = new QAction(tr("Sta&rt"),this);
133 connect(_actStart, SIGNAL(triggered()), SLOT(slotStart()));
134
135 _actStop = new QAction(tr("Sto&p"),this);
136 connect(_actStop, SIGNAL(triggered()), SLOT(slotStop()));
137
138 _actwhatsthis= new QAction(tr("Help ?=Shift+F1"),this);
139 connect(_actwhatsthis, SIGNAL(triggered()), SLOT(slotWhatsThis()));
140
141 CreateMenu();
142 AddToolbar();
143
144 bncSettings settings;
145
146 // Network Options
147 // ---------------
148 _proxyHostLineEdit = new QLineEdit(settings.value("proxyHost").toString());
149 _proxyPortLineEdit = new QLineEdit(settings.value("proxyPort").toString());
150
151 connect(_proxyHostLineEdit, SIGNAL(textChanged(const QString &)),
152 this, SLOT(slotBncTextChanged()));
153
154 _sslCaCertPathLineEdit = new QLineEdit(settings.value("sslCaCertPath").toString());
155 _ignoreSslErrorsCheckBox = new QCheckBox();
156 _ignoreSslErrorsCheckBox->setCheckState(Qt::CheckState(
157 settings.value("ignoreSslErrors").toInt()));
158
159 // General Options
160 // ---------------
161 _logFileLineEdit = new QLineEdit(settings.value("logFile").toString());
162 _rawOutFileLineEdit = new QLineEdit(settings.value("rawOutFile").toString());
163 _rnxAppendCheckBox = new QCheckBox();
164 _rnxAppendCheckBox->setCheckState(Qt::CheckState(
165 settings.value("rnxAppend").toInt()));
166 _onTheFlyComboBox = new QComboBox();
167 _onTheFlyComboBox->setEditable(false);
168 _onTheFlyComboBox->addItems(QString("1 day,1 hour,5 min,1 min").split(","));
169 int ii = _onTheFlyComboBox->findText(settings.value("onTheFlyInterval").toString());
170 if (ii != -1) {
171 _onTheFlyComboBox->setCurrentIndex(ii);
172 }
173 _autoStartCheckBox = new QCheckBox();
174 _autoStartCheckBox->setCheckState(Qt::CheckState(
175 settings.value("autoStart").toInt()));
176
177 // RINEX Observations Options
178 // --------------------------
179 _rnxPathLineEdit = new QLineEdit(settings.value("rnxPath").toString());
180 _rnxIntrComboBox = new QComboBox();
181 _rnxIntrComboBox->setEditable(false);
182 _rnxIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
183 ii = _rnxIntrComboBox->findText(settings.value("rnxIntr").toString());
184 if (ii != -1) {
185 _rnxIntrComboBox->setCurrentIndex(ii);
186 }
187 _rnxSamplSpinBox = new QSpinBox();
188 _rnxSamplSpinBox->setMinimum(0);
189 _rnxSamplSpinBox->setMaximum(60);
190 _rnxSamplSpinBox->setSingleStep(5);
191 _rnxSamplSpinBox->setValue(settings.value("rnxSampl").toInt());
192 _rnxSamplSpinBox->setSuffix(" sec");
193 _rnxSkelLineEdit = new QLineEdit(settings.value("rnxSkel").toString());
194 _rnxSkelLineEdit->setMaximumWidth(5*ww);
195 _rnxScrpLineEdit = new QLineEdit(settings.value("rnxScript").toString());
196 _rnxV3CheckBox = new QCheckBox();
197 _rnxV3CheckBox->setCheckState(Qt::CheckState(settings.value("rnxV3").toInt()));
198
199 connect(_rnxPathLineEdit, SIGNAL(textChanged(const QString &)),
200 this, SLOT(slotBncTextChanged()));
201
202 // RINEX Ephemeris Options
203 // -----------------------
204 _ephPathLineEdit = new QLineEdit(settings.value("ephPath").toString());
205 _ephIntrComboBox = new QComboBox();
206 _ephIntrComboBox->setEditable(false);
207 _ephIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
208 int jj = _ephIntrComboBox->findText(settings.value("ephIntr").toString());
209 if (jj != -1) {
210 _ephIntrComboBox->setCurrentIndex(jj);
211 }
212 _outEphPortLineEdit = new QLineEdit(settings.value("outEphPort").toString());
213 _ephV3CheckBox = new QCheckBox();
214 _ephV3CheckBox->setCheckState(Qt::CheckState(settings.value("ephV3").toInt()));
215
216 connect(_outEphPortLineEdit, SIGNAL(textChanged(const QString &)),
217 this, SLOT(slotBncTextChanged()));
218
219 connect(_ephPathLineEdit, SIGNAL(textChanged(const QString &)),
220 this, SLOT(slotBncTextChanged()));
221
222 // Broadcast Corrections Options
223 // -----------------------------
224 _corrPathLineEdit = new QLineEdit(settings.value("corrPath").toString());
225 _corrIntrComboBox = new QComboBox();
226 _corrIntrComboBox->setEditable(false);
227 _corrIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
228 int mm = _corrIntrComboBox->findText(settings.value("corrIntr").toString());
229 if (mm != -1) {
230 _corrIntrComboBox->setCurrentIndex(mm);
231 }
232 _corrPortLineEdit = new QLineEdit(settings.value("corrPort").toString());
233 _corrTimeSpinBox = new QSpinBox();
234 _corrTimeSpinBox->setMinimum(0);
235 _corrTimeSpinBox->setMaximum(60);
236 _corrTimeSpinBox->setSingleStep(1);
237 _corrTimeSpinBox->setSuffix(" sec");
238 _corrTimeSpinBox->setValue(settings.value("corrTime").toInt());
239
240 connect(_corrPathLineEdit, SIGNAL(textChanged(const QString &)),
241 this, SLOT(slotBncTextChanged()));
242
243 connect(_corrPortLineEdit, SIGNAL(textChanged(const QString &)),
244 this, SLOT(slotBncTextChanged()));
245
246 // Feed Engine Options
247 // -------------------
248 _outPortLineEdit = new QLineEdit(settings.value("outPort").toString());
249 _waitTimeSpinBox = new QSpinBox();
250 _waitTimeSpinBox->setMinimum(1);
251 _waitTimeSpinBox->setMaximum(30);
252 _waitTimeSpinBox->setSingleStep(1);
253 _waitTimeSpinBox->setSuffix(" sec");
254 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
255 _binSamplSpinBox = new QSpinBox();
256 _binSamplSpinBox->setMinimum(0);
257 _binSamplSpinBox->setMaximum(60);
258 _binSamplSpinBox->setSingleStep(5);
259 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
260 _binSamplSpinBox->setSuffix(" sec");
261 _outFileLineEdit = new QLineEdit(settings.value("outFile").toString());
262 _outUPortLineEdit = new QLineEdit(settings.value("outUPort").toString());
263
264 connect(_outPortLineEdit, SIGNAL(textChanged(const QString &)),
265 this, SLOT(slotBncTextChanged()));
266
267 connect(_outFileLineEdit, SIGNAL(textChanged(const QString &)),
268 this, SLOT(slotBncTextChanged()));
269
270 // Serial Output Options
271 // ---------------------
272 _serialMountPointLineEdit = new QLineEdit(settings.value("serialMountPoint").toString());
273 _serialPortNameLineEdit = new QLineEdit(settings.value("serialPortName").toString());
274 _serialBaudRateComboBox = new QComboBox();
275 _serialBaudRateComboBox->addItems(QString("110,300,600,"
276 "1200,2400,4800,9600,19200,38400,57600,115200").split(","));
277 int kk = _serialBaudRateComboBox->findText(settings.value("serialBaudRate").toString());
278 if (kk != -1) {
279 _serialBaudRateComboBox->setCurrentIndex(kk);
280 }
281 _serialFlowControlComboBox = new QComboBox();
282 _serialFlowControlComboBox->addItems(QString("OFF,XONXOFF,HARDWARE").split(","));
283 kk = _serialFlowControlComboBox->findText(settings.value("serialFlowControl").toString());
284 if (kk != -1) {
285 _serialFlowControlComboBox->setCurrentIndex(kk);
286 }
287 _serialDataBitsComboBox = new QComboBox();
288 _serialDataBitsComboBox->addItems(QString("5,6,7,8").split(","));
289 kk = _serialDataBitsComboBox->findText(settings.value("serialDataBits").toString());
290 if (kk != -1) {
291 _serialDataBitsComboBox->setCurrentIndex(kk);
292 }
293 _serialParityComboBox = new QComboBox();
294 _serialParityComboBox->addItems(QString("NONE,ODD,EVEN,SPACE").split(","));
295 kk = _serialParityComboBox->findText(settings.value("serialParity").toString());
296 if (kk != -1) {
297 _serialParityComboBox->setCurrentIndex(kk);
298 }
299 _serialStopBitsComboBox = new QComboBox();
300 _serialStopBitsComboBox->addItems(QString("1,2").split(","));
301 kk = _serialStopBitsComboBox->findText(settings.value("serialStopBits").toString());
302 if (kk != -1) {
303 _serialStopBitsComboBox->setCurrentIndex(kk);
304 }
305 _serialAutoNMEAComboBox = new QComboBox();
306 _serialAutoNMEAComboBox->addItems(QString("Auto,Manual").split(","));
307 kk = _serialAutoNMEAComboBox->findText(settings.value("serialAutoNMEA").toString());
308 if (kk != -1) {
309 _serialAutoNMEAComboBox->setCurrentIndex(kk);
310 }
311 _serialFileNMEALineEdit = new QLineEdit(settings.value("serialFileNMEA").toString());
312 _serialHeightNMEALineEdit = new QLineEdit(settings.value("serialHeightNMEA").toString());
313
314 connect(_serialMountPointLineEdit, SIGNAL(textChanged(const QString &)),
315 this, SLOT(slotBncTextChanged()));
316
317 connect(_serialAutoNMEAComboBox, SIGNAL(currentIndexChanged(const QString &)),
318 this, SLOT(slotBncTextChanged()));
319
320 // Outages Options
321 // ---------------
322 _obsRateComboBox = new QComboBox();
323 _obsRateComboBox->setEditable(false);
324 _obsRateComboBox->addItems(QString(",0.1 Hz,0.2 Hz,0.5 Hz,1 Hz,5 Hz").split(","));
325 kk = _obsRateComboBox->findText(settings.value("obsRate").toString());
326 if (kk != -1) {
327 _obsRateComboBox->setCurrentIndex(kk);
328 }
329 _adviseFailSpinBox = new QSpinBox();
330 _adviseFailSpinBox->setMinimum(0);
331 _adviseFailSpinBox->setMaximum(60);
332 _adviseFailSpinBox->setSingleStep(1);
333 _adviseFailSpinBox->setSuffix(" min");
334 _adviseFailSpinBox->setValue(settings.value("adviseFail").toInt());
335 _adviseRecoSpinBox = new QSpinBox();
336 _adviseRecoSpinBox->setMinimum(0);
337 _adviseRecoSpinBox->setMaximum(60);
338 _adviseRecoSpinBox->setSingleStep(1);
339 _adviseRecoSpinBox->setSuffix(" min");
340 _adviseRecoSpinBox->setValue(settings.value("adviseReco").toInt());
341 _adviseScriptLineEdit = new QLineEdit(settings.value("adviseScript").toString());
342
343 connect(_obsRateComboBox, SIGNAL(currentIndexChanged(const QString &)),
344 this, SLOT(slotBncTextChanged()));
345
346 // Miscellaneous Options
347 // ---------------------
348 _miscMountLineEdit = new QLineEdit(settings.value("miscMount").toString());
349 _perfIntrComboBox = new QComboBox();
350 _perfIntrComboBox->setEditable(false);
351 _perfIntrComboBox->addItems(QString(",2 sec, 10 sec,1 min,5 min,15 min,1 hour,6 hours,1 day").split(","));
352 int ll = _perfIntrComboBox->findText(settings.value("perfIntr").toString());
353 if (ll != -1) {
354 _perfIntrComboBox->setCurrentIndex(ll);
355 }
356 _scanRTCMCheckBox = new QCheckBox();
357 _scanRTCMCheckBox->setCheckState(Qt::CheckState(
358 settings.value("scanRTCM").toInt()));
359
360 connect(_miscMountLineEdit, SIGNAL(textChanged(const QString &)),
361 this, SLOT(slotBncTextChanged()));
362
363 // PPP Options
364 // -----------
365 _pppMountLineEdit = new QLineEdit(settings.value("pppMount").toString());
366 _pppMountLineEdit->setMaximumWidth(8*ww);
367 _pppCorrMountLineEdit = new QLineEdit(settings.value("pppCorrMount").toString());
368 _pppMountLineEdit->setMinimumWidth(8*ww);
369 _pppCorrMountLineEdit->setMinimumWidth(8*ww);
370 _pppCorrMountLineEdit->setMaximumWidth(8*ww);
371 _pppNMEALineEdit = new QLineEdit(settings.value("nmeaFile").toString());
372 _pppNMEALineEdit->setMinimumWidth(15*ww);
373 _pppNMEAPortLineEdit = new QLineEdit(settings.value("nmeaPort").toString());
374 _pppNMEAPortLineEdit->setMaximumWidth(8*ww);
375 _pppNMEAPortLineEdit->setMinimumWidth(8*ww);
376 _pppSigCLineEdit = new QLineEdit(settings.value("pppSigmaCode").toString());
377 _pppSigPLineEdit = new QLineEdit(settings.value("pppSigmaPhase").toString());
378 _pppSigCrd0 = new QLineEdit(settings.value("pppSigCrd0").toString());
379 _pppSigCrdP = new QLineEdit(settings.value("pppSigCrdP").toString());
380 _pppSigTrp0 = new QLineEdit(settings.value("pppSigTrp0").toString());
381 _pppSigTrpP = new QLineEdit(settings.value("pppSigTrpP").toString());
382 _pppAverageLineEdit = new QLineEdit(settings.value("pppAverage").toString());
383 _pppQuickStartLineEdit = new QLineEdit(settings.value("pppQuickStart").toString());
384 _pppMaxSolGapLineEdit = new QLineEdit(settings.value("pppMaxSolGap").toString());
385 _pppAudioResponseLineEdit = new QLineEdit(settings.value("pppAudioResponse").toString());
386 _pppRefCrdXLineEdit = new QLineEdit(settings.value("pppRefCrdX").toString());
387 _pppRefCrdYLineEdit = new QLineEdit(settings.value("pppRefCrdY").toString());
388 _pppRefCrdZLineEdit = new QLineEdit(settings.value("pppRefCrdZ").toString());
389 _pppRefdNLineEdit = new QLineEdit(settings.value("pppRefdN").toString());
390 _pppRefdELineEdit = new QLineEdit(settings.value("pppRefdE").toString());
391 _pppRefdULineEdit = new QLineEdit(settings.value("pppRefdU").toString());
392 _pppSync = new QLineEdit(settings.value("pppSync").toString());
393 _pppAntexFileChooser = new qtFileChooser;
394 _pppAntexFileChooser->setMinimumWidth(12*ww);
395 _pppAntennaLineEdit = new QLineEdit(settings.value("pppAntenna").toString());
396 _pppAntexFileChooser->setFileName(settings.value("pppAntex").toString());
397
398 _pppSPPComboBox = new QComboBox();
399 _pppSPPComboBox->setEditable(false);
400 _pppSPPComboBox->addItems(QString(",Realtime-PPP,Realtime-SPP,Post-Processing").split(","));
401 int ik = _pppSPPComboBox->findText(settings.value("pppSPP").toString());
402 if (ik != -1) {
403 _pppSPPComboBox->setCurrentIndex(ik);
404 }
405 _pppUsePhaseCheckBox = new QCheckBox();
406 _pppUsePhaseCheckBox->setCheckState(Qt::CheckState(
407 settings.value("pppUsePhase").toInt()));
408 _pppEstTropoCheckBox = new QCheckBox();
409 _pppEstTropoCheckBox->setCheckState(Qt::CheckState(
410 settings.value("pppEstTropo").toInt()));
411 _pppGLONASSCheckBox = new QCheckBox();
412 _pppGLONASSCheckBox->setCheckState(Qt::CheckState(
413 settings.value("pppGLONASS").toInt()));
414 _pppGalileoCheckBox = new QCheckBox();
415 _pppGalileoCheckBox->setCheckState(Qt::CheckState(
416 settings.value("pppGalileo").toInt()));
417
418 _pppPlotCoordinates = new QCheckBox();
419 _pppPlotCoordinates->setCheckState(Qt::CheckState(
420 settings.value("pppPlotCoordinates").toInt()));
421
422 connect(_pppMountLineEdit, SIGNAL(textChanged(const QString &)),
423 this, SLOT(slotBncTextChanged()));
424
425 connect(_pppCorrMountLineEdit, SIGNAL(textChanged(const QString &)),
426 this, SLOT(slotBncTextChanged()));
427
428 connect(_pppUsePhaseCheckBox, SIGNAL(stateChanged(int)),
429 this, SLOT(slotBncTextChanged()));
430
431 connect(_pppRefCrdXLineEdit, SIGNAL(textChanged(const QString &)),
432 this, SLOT(slotBncTextChanged()));
433 connect(_pppRefCrdYLineEdit, SIGNAL(textChanged(const QString &)),
434 this, SLOT(slotBncTextChanged()));
435 connect(_pppRefCrdZLineEdit, SIGNAL(textChanged(const QString &)),
436 this, SLOT(slotBncTextChanged()));
437 connect(_pppRefdNLineEdit, SIGNAL(textChanged(const QString &)),
438 this, SLOT(slotBncTextChanged()));
439 connect(_pppRefdELineEdit, SIGNAL(textChanged(const QString &)),
440 this, SLOT(slotBncTextChanged()));
441 connect(_pppRefdULineEdit, SIGNAL(textChanged(const QString &)),
442 this, SLOT(slotBncTextChanged()));
443
444 connect(_pppEstTropoCheckBox, SIGNAL(stateChanged(int)),
445 this, SLOT(slotBncTextChanged()));
446
447 connect(_pppSync, SIGNAL(textChanged(const QString &)),
448 this, SLOT(slotBncTextChanged()));
449
450 connect(_pppSPPComboBox, SIGNAL(currentIndexChanged(const QString &)),
451 this, SLOT(slotBncTextChanged()));
452
453 connect(_pppAntexFileChooser, SIGNAL(fileNameChanged(const QString &)),
454 this, SLOT(slotBncTextChanged()));
455
456 connect(_pppQuickStartLineEdit, SIGNAL(textChanged(const QString &)),
457 this, SLOT(slotBncTextChanged()));
458
459 // Streams
460 // -------
461 _mountPointsTable = new QTableWidget(0,8);
462
463 _mountPointsTable->horizontalHeader()->resizeSection(1,34*ww);
464 _mountPointsTable->horizontalHeader()->resizeSection(2,9*ww);
465 _mountPointsTable->horizontalHeader()->resizeSection(3,7*ww);
466 _mountPointsTable->horizontalHeader()->resizeSection(4,7*ww);
467 _mountPointsTable->horizontalHeader()->resizeSection(5,5*ww);
468 _mountPointsTable->horizontalHeader()->resizeSection(6,5*ww);
469 _mountPointsTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
470 _mountPointsTable->horizontalHeader()->setStretchLastSection(true);
471 _mountPointsTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
472_mountPointsTable->setHorizontalHeaderLabels(labels);
473 _mountPointsTable->setGridStyle(Qt::NoPen);
474 _mountPointsTable->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
475 _mountPointsTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
476 _mountPointsTable->setSelectionBehavior(QAbstractItemView::SelectRows);
477 _mountPointsTable->hideColumn(0);
478 connect(_mountPointsTable, SIGNAL(itemSelectionChanged()),
479 SLOT(slotSelectionChanged()));
480 populateMountPointsTable();
481
482 _log = new QTextBrowser();
483 _log->setReadOnly(true);
484
485 // Combine Corrections
486 // -------------------
487 _cmbTable = new QTableWidget(0,3);
488 _cmbTable->setHorizontalHeaderLabels(QString("Mountpoint, AC Name, Weight").split(","));
489 _cmbTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
490 _cmbTable->setSelectionBehavior(QAbstractItemView::SelectRows);
491 _cmbTable->setMaximumWidth(30*ww);
492 _cmbTable->horizontalHeader()->resizeSection(0,10*ww);
493 _cmbTable->horizontalHeader()->resizeSection(1,8*ww);
494 _cmbTable->horizontalHeader()->resizeSection(2,8*ww);
495 _cmbTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
496 _cmbTable->horizontalHeader()->setStretchLastSection(true);
497 _cmbTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
498
499 _cmbMaxresLineEdit = new QLineEdit(settings.value("cmbMaxres").toString());
500
501 _cmbSamplSpinBox = new QSpinBox;
502 _cmbSamplSpinBox->setMinimum(10);
503 _cmbSamplSpinBox->setMaximum(60);
504 _cmbSamplSpinBox->setSingleStep(10);
505 _cmbSamplSpinBox->setMaximumWidth(9*ww);
506 _cmbSamplSpinBox->setValue(settings.value("cmbSampl").toInt());
507 _cmbSamplSpinBox->setSuffix(" sec");
508
509 QPushButton* addCmbRowButton = new QPushButton("Add Row");
510 QPushButton* delCmbRowButton = new QPushButton("Delete");
511
512 connect(_cmbTable, SIGNAL(itemSelectionChanged()),
513 SLOT(slotBncTextChanged()));
514
515 _cmbMethodComboBox = new QComboBox();
516 _cmbMethodComboBox->setEditable(false);
517 _cmbMethodComboBox->addItems(QString("Filter,Single-Epoch").split(","));
518 int im = _cmbMethodComboBox->findText(settings.value("cmbMethod").toString());
519 if (im != -1) {
520 _cmbMethodComboBox->setCurrentIndex(im);
521 }
522
523 int iRow = _cmbTable->rowCount();
524 if (iRow > 0) {
525 enableWidget(true, _cmbMethodComboBox);
526 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
527 _cmbMaxresLineEdit->setEnabled(true);
528 _cmbSamplSpinBox->setEnabled(true);
529 }
530 else {
531 enableWidget(false, _cmbMethodComboBox);
532 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
533 _cmbMaxresLineEdit->setEnabled(false);
534 _cmbSamplSpinBox->setEnabled(false);
535 }
536
537 // Upload Results
538 // -------------
539 _uploadTable = new QTableWidget(0,12);
540 _uploadTable->setHorizontalHeaderLabels(QString("Host, Port, Mount, Password, System, CoM, SP3 File, RNX File, PID, SID, IOD, bytes").split(","));
541 _uploadTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
542 _uploadTable->setSelectionBehavior(QAbstractItemView::SelectRows);
543 _uploadTable->horizontalHeader()->resizeSection( 0,13*ww);
544 _uploadTable->horizontalHeader()->resizeSection( 1, 5*ww);
545 _uploadTable->horizontalHeader()->resizeSection( 2, 6*ww);
546 _uploadTable->horizontalHeader()->resizeSection( 3, 8*ww);
547 _uploadTable->horizontalHeader()->resizeSection( 4,11*ww);
548 _uploadTable->horizontalHeader()->resizeSection( 5, 4*ww);
549 _uploadTable->horizontalHeader()->resizeSection( 6,15*ww);
550 _uploadTable->horizontalHeader()->resizeSection( 7,15*ww);
551 _uploadTable->horizontalHeader()->resizeSection( 8, 4*ww);
552 _uploadTable->horizontalHeader()->resizeSection( 9, 4*ww);
553 _uploadTable->horizontalHeader()->resizeSection(10, 4*ww);
554 _uploadTable->horizontalHeader()->resizeSection(11,12*ww);
555 _uploadTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
556 _uploadTable->horizontalHeader()->setStretchLastSection(true);
557 _uploadTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
558
559 connect(_uploadTable, SIGNAL(itemSelectionChanged()),
560 SLOT(slotBncTextChanged()));
561
562 QPushButton* addUploadRowButton = new QPushButton("Add Row");
563 QPushButton* delUploadRowButton = new QPushButton("Del Row");
564 QPushButton* setUploadTrafoButton = new QPushButton("Custom Trafo");
565 _uploadIntrComboBox = new QComboBox;
566 _uploadIntrComboBox->setEditable(false);
567 _uploadIntrComboBox->addItems(QString("1 day,1 hour, 30 min,15 min,10 min,5 min,2 min,1 min").split(","));
568 ii = _uploadIntrComboBox->findText(settings.value("uploadIntr").toString());
569 if (ii != -1) {
570 _uploadIntrComboBox->setCurrentIndex(ii);
571 }
572
573 _uploadSamplRtcmEphCorrSpinBox = new QSpinBox;
574 _uploadSamplRtcmEphCorrSpinBox->setMinimum(0);
575 _uploadSamplRtcmEphCorrSpinBox->setMaximum(60);
576 _uploadSamplRtcmEphCorrSpinBox->setSingleStep(5);
577 _uploadSamplRtcmEphCorrSpinBox->setMaximumWidth(9*ww);
578 _uploadSamplRtcmEphCorrSpinBox->setValue(settings.value("uploadSamplRtcmEphCorr").toInt());
579 _uploadSamplRtcmEphCorrSpinBox->setSuffix(" sec");
580
581 _uploadSamplSp3SpinBox = new QSpinBox;
582 _uploadSamplSp3SpinBox->setMinimum(0);
583 _uploadSamplSp3SpinBox->setMaximum(15);
584 _uploadSamplSp3SpinBox->setSingleStep(1);
585 _uploadSamplSp3SpinBox->setMaximumWidth(9*ww);
586 _uploadSamplSp3SpinBox->setValue(settings.value("uploadSamplSp3").toInt());
587 _uploadSamplSp3SpinBox->setSuffix(" min");
588
589 _uploadSamplClkRnxSpinBox = new QSpinBox;
590 _uploadSamplClkRnxSpinBox->setMinimum(0);
591 _uploadSamplClkRnxSpinBox->setMaximum(60);
592 _uploadSamplClkRnxSpinBox->setSingleStep(5);
593 _uploadSamplClkRnxSpinBox->setMaximumWidth(9*ww);
594 _uploadSamplClkRnxSpinBox->setValue(settings.value("uploadSamplClkRnx").toInt());
595 _uploadSamplClkRnxSpinBox->setSuffix(" sec");
596
597 int iRowT = _uploadTable->rowCount();
598 if (iRowT > 0) {
599 enableWidget(true, _uploadIntrComboBox);
600 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
601 enableWidget(true, _uploadSamplSp3SpinBox);
602 enableWidget(true, _uploadSamplClkRnxSpinBox);
603 }
604 else {
605 enableWidget(false, _uploadIntrComboBox);
606 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
607 enableWidget(false, _uploadSamplSp3SpinBox);
608 enableWidget(false, _uploadSamplClkRnxSpinBox);
609 }
610
611 // Upload RTCM3 Ephemeris
612 // ----------------------
613 _uploadEphHostLineEdit = new QLineEdit(settings.value("uploadEphHost").toString());
614 _uploadEphPortLineEdit = new QLineEdit(settings.value("uploadEphPort").toString());
615 _uploadEphPasswordLineEdit = new QLineEdit(settings.value("uploadEphPassword").toString());
616 _uploadEphPasswordLineEdit->setEchoMode(QLineEdit::PasswordEchoOnEdit);
617 _uploadEphMountpointLineEdit = new QLineEdit(settings.value("uploadEphMountpoint").toString());
618 _uploadEphSampleSpinBox = new QSpinBox;
619 _uploadEphSampleSpinBox->setMinimum(5);
620 _uploadEphSampleSpinBox->setMaximum(60);
621 _uploadEphSampleSpinBox->setSingleStep(5);
622 _uploadEphSampleSpinBox->setMaximumWidth(9*ww);
623 _uploadEphSampleSpinBox->setValue(settings.value("uploadEphSample").toInt());
624 _uploadEphSampleSpinBox->setSuffix(" sec");
625 _uploadEphBytesCounter = new bncBytesCounter;
626
627 // Canvas with Editable Fields
628 // ---------------------------
629 _canvas = new QWidget;
630 setCentralWidget(_canvas);
631
632 _aogroup = new QTabWidget();
633 QWidget* pgroup = new QWidget();
634 QWidget* ggroup = new QWidget();
635 QWidget* sgroup = new QWidget();
636 QWidget* egroup = new QWidget();
637 QWidget* agroup = new QWidget();
638 QWidget* cgroup = new QWidget();
639 QWidget* ogroup = new QWidget();
640 QWidget* rgroup = new QWidget();
641 QWidget* sergroup = new QWidget();
642 QWidget* pppgroup = new QWidget();
643 QWidget* ppp2group = new QWidget();
644 QWidget* reqcgroup = new QWidget();
645 QWidget* cmbgroup = new QWidget();
646 QWidget* uploadgroup = new QWidget();
647 QWidget* uploadEphgroup = new QWidget();
648 _aogroup->addTab(pgroup,tr("Network"));
649 _aogroup->addTab(ggroup,tr("General"));
650 _aogroup->addTab(ogroup,tr("RINEX Observations"));
651 _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
652 _aogroup->addTab(reqcgroup,tr("RINEX Editing && QC"));
653 _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
654 _aogroup->addTab(sgroup,tr("Feed Engine"));
655 _aogroup->addTab(sergroup,tr("Serial Output"));
656 _aogroup->addTab(agroup,tr("Outages"));
657 _aogroup->addTab(rgroup,tr("Miscellaneous"));
658 _aogroup->addTab(pppgroup,tr("PPP (1)"));
659 _aogroup->addTab(ppp2group,tr("PPP (2)"));
660#ifdef USE_COMBINATION
661 _aogroup->addTab(cmbgroup,tr("Combine Corrections"));
662#endif
663 _aogroup->addTab(uploadgroup,tr("Upload Corrections"));
664 _aogroup->addTab(uploadEphgroup,tr("Upload Ephemeris"));
665
666 // Log Tab
667 // -------
668 _loggroup = new QTabWidget();
669 _loggroup->addTab(_log,tr("Log"));
670 _loggroup->addTab(_bncFigure,tr("Throughput"));
671 _loggroup->addTab(_bncFigureLate,tr("Latency"));
672 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
673
674 // Netowork (Proxy and SSL) Tab
675 // ----------------------------
676 QGridLayout* pLayout = new QGridLayout;
677 pLayout->setColumnMinimumWidth(0,13*ww);
678 _proxyPortLineEdit->setMaximumWidth(9*ww);
679
680 pLayout->addWidget(new QLabel("Settings for proxy in protected networks and for SSL authorization, leave boxes blank if none."),0, 0, 1, 50);
681 pLayout->addWidget(new QLabel("Proxy host"), 1, 0);
682 pLayout->addWidget(_proxyHostLineEdit, 1, 1, 1,10);
683 pLayout->addWidget(new QLabel("Proxy port"), 2, 0);
684 pLayout->addWidget(_proxyPortLineEdit, 2, 1);
685 pLayout->addWidget(new QLabel("Path to SSL Certificates"), 3, 0);
686 pLayout->addWidget(_sslCaCertPathLineEdit, 3, 1, 1,10);
687 pLayout->addWidget(new QLabel("Default: " + bncSslConfig::defaultPath()), 3,11, 1,20);
688 pLayout->addWidget(new QLabel("Ignore SSL Authorization Errors"), 4, 0);
689 pLayout->addWidget(_ignoreSslErrorsCheckBox, 4, 1, 1,10);
690 pLayout->addWidget(new QLabel(" "), 4, 0);
691 pLayout->addWidget(new QLabel(" "), 5, 0);
692 pLayout->addWidget(new QLabel(" "), 6, 0);
693 pgroup->setLayout(pLayout);
694
695 // General Tab
696 // -----------
697 QGridLayout* gLayout = new QGridLayout;
698 gLayout->setColumnMinimumWidth(0,14*ww);
699 _onTheFlyComboBox->setMaximumWidth(9*ww);
700
701 gLayout->addWidget(new QLabel("General settings for logfile, file handling, configuration on-the-fly, and auto-start."),0, 0, 1, 50);
702 gLayout->addWidget(new QLabel("Logfile (full path)"), 1, 0);
703 gLayout->addWidget(_logFileLineEdit, 1, 1, 1,30);
704 gLayout->addWidget(new QLabel("Append files"), 2, 0);
705 gLayout->addWidget(_rnxAppendCheckBox, 2, 1);
706 gLayout->addWidget(new QLabel("Reread configuration"), 3, 0);
707 gLayout->addWidget(_onTheFlyComboBox, 3, 1);
708 gLayout->addWidget(new QLabel("Auto start"), 4, 0);
709 gLayout->addWidget(_autoStartCheckBox, 4, 1);
710 gLayout->addWidget(new QLabel("Raw output file (full path)"), 5, 0);
711 gLayout->addWidget(_rawOutFileLineEdit, 5, 1, 1,30);
712 gLayout->addWidget(new QLabel(" "), 6, 0);
713 ggroup->setLayout(gLayout);
714
715 // RINEX Observations
716 // ------------------
717 QGridLayout* oLayout = new QGridLayout;
718 oLayout->setColumnMinimumWidth(0,14*ww);
719 _rnxIntrComboBox->setMaximumWidth(9*ww);
720 _rnxSamplSpinBox->setMaximumWidth(9*ww);
721
722 oLayout->addWidget(new QLabel("Saving RINEX observation files."),0, 0, 1,50);
723 oLayout->addWidget(new QLabel("Directory"), 1, 0);
724 oLayout->addWidget(_rnxPathLineEdit, 1, 1, 1,24);
725 oLayout->addWidget(new QLabel("Interval"), 2, 0);
726 oLayout->addWidget(_rnxIntrComboBox, 2, 1);
727 oLayout->addWidget(new QLabel(" Sampling"), 2, 2, Qt::AlignRight);
728 oLayout->addWidget(_rnxSamplSpinBox, 2, 3, Qt::AlignLeft);
729 oLayout->addWidget(new QLabel("Skeleton extension"), 3, 0);
730 oLayout->addWidget(_rnxSkelLineEdit, 3, 1, 1, 1, Qt::AlignLeft);
731 oLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
732 oLayout->addWidget(_rnxScrpLineEdit, 4, 1, 1,24);
733 oLayout->addWidget(new QLabel("Version 3"), 5, 0);
734 oLayout->addWidget(_rnxV3CheckBox, 5, 1);
735 oLayout->addWidget(new QLabel(" "), 6, 0);
736 ogroup->setLayout(oLayout);
737
738 // RINEX Ephemeris
739 // ---------------
740 QGridLayout* eLayout = new QGridLayout;
741 eLayout->setColumnMinimumWidth(0,14*ww);
742 _ephIntrComboBox->setMaximumWidth(9*ww);
743 _outEphPortLineEdit->setMaximumWidth(9*ww);
744
745 eLayout->addWidget(new QLabel("Saving RINEX ephemeris files and ephemeris output through IP port."),0,0,1,50);
746 eLayout->addWidget(new QLabel("Directory"), 1, 0);
747 eLayout->addWidget(_ephPathLineEdit, 1, 1, 1,30);
748 eLayout->addWidget(new QLabel("Interval"), 2, 0);
749 eLayout->addWidget(_ephIntrComboBox, 2, 1);
750 eLayout->addWidget(new QLabel("Port"), 3, 0);
751 eLayout->addWidget(_outEphPortLineEdit, 3, 1);
752 eLayout->addWidget(new QLabel("Version 3"), 4, 0);
753 eLayout->addWidget(_ephV3CheckBox, 4, 1);
754 eLayout->addWidget(new QLabel(" "), 5, 0);
755 eLayout->addWidget(new QLabel(" "), 6, 0);
756 egroup->setLayout(eLayout);
757
758
759 // Broadcast Corrections
760 // ---------------------
761 QGridLayout* cLayout = new QGridLayout;
762 cLayout->setColumnMinimumWidth(0,14*ww);
763 _corrIntrComboBox->setMaximumWidth(9*ww);
764 _corrPortLineEdit->setMaximumWidth(9*ww);
765 _corrTimeSpinBox->setMaximumWidth(9*ww);
766
767 cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port."),0,0,1,50);
768 cLayout->addWidget(new QLabel("Directory, ASCII"), 1, 0);
769 cLayout->addWidget(_corrPathLineEdit, 1, 1, 1,20);
770 cLayout->addWidget(new QLabel("Interval"), 2, 0);
771 cLayout->addWidget(_corrIntrComboBox, 2, 1);
772 cLayout->addWidget(new QLabel("Port"), 3, 0);
773 cLayout->addWidget(_corrPortLineEdit, 3, 1);
774 cLayout->addWidget(new QLabel(" Wait for full corr epoch"), 3, 2, Qt::AlignRight);
775 cLayout->addWidget(_corrTimeSpinBox, 3, 3, Qt::AlignLeft);
776 cLayout->addWidget(new QLabel(" "), 4, 0);
777 cLayout->addWidget(new QLabel(" "), 5, 0);
778 cLayout->addWidget(new QLabel(" "), 6, 0);
779 cgroup->setLayout(cLayout);
780
781 // Feed Engine
782 // -----------
783 QGridLayout* sLayout = new QGridLayout;
784 sLayout->setColumnMinimumWidth(0,14*ww);
785 _outPortLineEdit->setMaximumWidth(9*ww);
786 _waitTimeSpinBox->setMaximumWidth(9*ww);
787 _binSamplSpinBox->setMaximumWidth(9*ww);
788 _outUPortLineEdit->setMaximumWidth(9*ww);
789
790 sLayout->addWidget(new QLabel("Output decoded observations in ASCII format to feed a real-time GNSS network engine."),0,0,1,50);
791 sLayout->addWidget(new QLabel("Port"), 1, 0);
792 sLayout->addWidget(_outPortLineEdit, 1, 1);
793 sLayout->addWidget(new QLabel("Wait for full obs epoch"), 1, 2, Qt::AlignRight);
794 sLayout->addWidget(_waitTimeSpinBox, 1, 3, Qt::AlignLeft);
795 sLayout->addWidget(new QLabel("Sampling"), 2, 0);
796 sLayout->addWidget(_binSamplSpinBox, 2, 1, Qt::AlignLeft);
797 sLayout->addWidget(new QLabel("File (full path)"), 3, 0);
798 sLayout->addWidget(_outFileLineEdit, 3, 1, 1, 20);
799 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 4, 0);
800 sLayout->addWidget(_outUPortLineEdit, 4, 1);
801 sLayout->addWidget(new QLabel(" "), 5, 0);
802 sLayout->addWidget(new QLabel(" "), 6, 0);
803 sgroup->setLayout(sLayout);
804
805 // Serial Output
806 // -------------
807 QGridLayout* serLayout = new QGridLayout;
808 serLayout->setColumnMinimumWidth(0,14*ww);
809 _serialBaudRateComboBox->setMaximumWidth(9*ww);
810 _serialFlowControlComboBox->setMaximumWidth(11*ww);
811 _serialDataBitsComboBox->setMaximumWidth(5*ww);
812 _serialParityComboBox->setMaximumWidth(9*ww);
813 _serialStopBitsComboBox->setMaximumWidth(5*ww);
814 _serialAutoNMEAComboBox->setMaximumWidth(9*ww);
815 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
816
817 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver."),0,0,1,30);
818 serLayout->addWidget(new QLabel("Mountpoint"), 1, 0, Qt::AlignLeft);
819 serLayout->addWidget(_serialMountPointLineEdit, 1, 1, 1, 2);
820 serLayout->addWidget(new QLabel("Port name"), 2, 0, Qt::AlignLeft);
821 serLayout->addWidget(_serialPortNameLineEdit, 2, 1, 1, 2);
822 serLayout->addWidget(new QLabel("Baud rate"), 3, 0, Qt::AlignLeft);
823 serLayout->addWidget(_serialBaudRateComboBox, 3, 1);
824 serLayout->addWidget(new QLabel("Flow control"), 3, 2, Qt::AlignRight);
825 serLayout->addWidget(_serialFlowControlComboBox, 3, 3);
826 serLayout->addWidget(new QLabel("Data bits"), 4, 0, Qt::AlignLeft);
827 serLayout->addWidget(_serialDataBitsComboBox, 4, 1);
828 serLayout->addWidget(new QLabel("Parity"), 4, 2, Qt::AlignRight);
829 serLayout->addWidget(_serialParityComboBox, 4, 3);
830 serLayout->addWidget(new QLabel(" Stop bits"), 4, 4, Qt::AlignRight);
831 serLayout->addWidget(_serialStopBitsComboBox, 4, 5);
832 serLayout->addWidget(new QLabel("NMEA"), 5, 0);
833 serLayout->addWidget(_serialAutoNMEAComboBox, 5, 1);
834 serLayout->addWidget(new QLabel(" File (full path)"), 5, 2, Qt::AlignRight);
835 serLayout->addWidget(_serialFileNMEALineEdit, 5, 3, 1,15);
836 serLayout->addWidget(new QLabel("Height"), 5,20, Qt::AlignRight);
837 serLayout->addWidget(_serialHeightNMEALineEdit, 5,21, 1,11);
838 serLayout->addWidget(new QLabel(" "), 6, 0);
839
840 sergroup->setLayout(serLayout);
841
842 // Outages
843 // -------
844 QGridLayout* aLayout = new QGridLayout;
845 aLayout->setColumnMinimumWidth(0,14*ww);
846 _obsRateComboBox->setMaximumWidth(9*ww);
847 _adviseFailSpinBox->setMaximumWidth(9*ww);
848 _adviseRecoSpinBox->setMaximumWidth(9*ww);
849
850 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes."),0,0,1,50,Qt::AlignLeft);
851 aLayout->addWidget(new QLabel("Observation rate"), 1, 0);
852 aLayout->addWidget(_obsRateComboBox, 1, 1);
853 aLayout->addWidget(new QLabel("Failure threshold"), 2, 0);
854 aLayout->addWidget(_adviseFailSpinBox, 2, 1);
855 aLayout->addWidget(new QLabel("Recovery threshold"), 3, 0);
856 aLayout->addWidget(_adviseRecoSpinBox, 3, 1);
857 aLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
858 aLayout->addWidget(_adviseScriptLineEdit, 4, 1, 1,30);
859 aLayout->addWidget(new QLabel(" "), 5, 0);
860 aLayout->addWidget(new QLabel(" "), 6, 0);
861 agroup->setLayout(aLayout);
862
863 // Miscellaneous
864 // -------------
865 QGridLayout* rLayout = new QGridLayout;
866 rLayout->setColumnMinimumWidth(0,14*ww);
867 _perfIntrComboBox->setMaximumWidth(9*ww);
868
869 rLayout->addWidget(new QLabel("Log latencies or scan RTCM streams for numbers of message types and antenna information."),0, 0,1,30);
870 rLayout->addWidget(new QLabel("Mountpoint"), 1, 0);
871 rLayout->addWidget(_miscMountLineEdit, 1, 1, 1,7);
872 rLayout->addWidget(new QLabel("Log latency"), 2, 0);
873 rLayout->addWidget(_perfIntrComboBox, 2, 1);
874 rLayout->addWidget(new QLabel("Scan RTCM"), 3, 0);
875 rLayout->addWidget(_scanRTCMCheckBox, 3, 1);
876 rLayout->addWidget(new QLabel(" "), 4, 0);
877 rLayout->addWidget(new QLabel(" "), 5, 0);
878 rLayout->addWidget(new QLabel(" "), 6, 0);
879 rgroup->setLayout(rLayout);
880
881 // PPP Client
882 // ----------
883 QGridLayout* pppLayout = new QGridLayout;
884 pppLayout->setColumnMinimumWidth(0,14*ww);
885 _pppSigCLineEdit->setMaximumWidth(6*ww);
886 _pppSigPLineEdit->setMaximumWidth(6*ww);
887 _pppSigCrd0->setMaximumWidth(6*ww);
888 _pppSigCrdP->setMaximumWidth(6*ww);
889 _pppSigTrp0->setMaximumWidth(6*ww);
890 _pppSigTrpP->setMaximumWidth(6*ww);
891 _pppAverageLineEdit->setMaximumWidth(6*ww);
892 _pppQuickStartLineEdit->setMaximumWidth(6*ww);
893 _pppMaxSolGapLineEdit->setMaximumWidth(6*ww);
894 _pppAudioResponseLineEdit->setMaximumWidth(6*ww);
895 _pppRefCrdXLineEdit->setMaximumWidth(10*ww);
896 _pppRefCrdYLineEdit->setMaximumWidth(10*ww);
897 _pppRefCrdZLineEdit->setMaximumWidth(10*ww);
898 _pppRefdNLineEdit->setMaximumWidth(6*ww);
899 _pppRefdELineEdit->setMaximumWidth(6*ww);
900 _pppRefdULineEdit->setMaximumWidth(6*ww);
901 _pppSync->setMaximumWidth(6*ww);
902 _pppSPPComboBox->setMinimumWidth(15*ww);
903
904 _postObsFileChooser = new qtFileChooser;
905 _postObsFileChooser->setFileName(settings.value("postObsFile").toString());
906 _postObsFileChooser->setMinimumWidth(15*ww);
907 _postNavFileChooser = new qtFileChooser;
908 _postNavFileChooser->setFileName(settings.value("postNavFile").toString());
909 _postNavFileChooser->setMinimumWidth(15*ww);
910 _postCorrFileChooser = new qtFileChooser;
911 _postCorrFileChooser->setFileName(settings.value("postCorrFile").toString());
912 _postCorrFileChooser->setMinimumWidth(15*ww);
913 _postOutLineEdit = new QLineEdit(settings.value("postOutFile").toString());
914 _postOutLineEdit->setMinimumWidth(15*ww);
915
916 int ir = 0;
917 pppLayout->addWidget(new QLabel("Precise Point Positioning, Panel 1."), ir, 0, 1, 2, Qt::AlignLeft);
918 ++ir;
919 pppLayout->addWidget(new QLabel("Mode & mountpoints"),ir, 0, Qt::AlignLeft);
920 pppLayout->addWidget(_pppSPPComboBox, ir, 1, Qt::AlignRight);
921 pppLayout->addWidget(_pppMountLineEdit, ir, 3, Qt::AlignRight);
922 pppLayout->addWidget(new QLabel("Obs."), ir, 4, Qt::AlignLeft);
923 pppLayout->addWidget(_pppCorrMountLineEdit, ir, 5, Qt::AlignRight);
924 pppLayout->addWidget(new QLabel("Corr."), ir, 6, Qt::AlignLeft);
925 ++ir;
926 pppLayout->addWidget(new QLabel("Marker coordinates"), ir, 0, Qt::AlignLeft);
927 pppLayout->addWidget(_pppRefCrdXLineEdit, ir, 1, Qt::AlignRight);
928 pppLayout->addWidget(new QLabel("X "), ir, 2, Qt::AlignLeft);
929 pppLayout->addWidget(_pppRefCrdYLineEdit, ir, 3, Qt::AlignRight);
930 pppLayout->addWidget(new QLabel("Y"), ir, 4, Qt::AlignLeft);
931 pppLayout->addWidget(_pppRefCrdZLineEdit, ir, 5, Qt::AlignRight);
932 pppLayout->addWidget(new QLabel("Z"), ir, 6, Qt::AlignLeft);
933 ++ir;
934 pppLayout->addWidget(new QLabel("Antenna excentricity"), ir, 0, Qt::AlignLeft);
935 pppLayout->addWidget(_pppRefdNLineEdit, ir, 1, Qt::AlignRight);
936 pppLayout->addWidget(new QLabel("dN"), ir, 2, Qt::AlignLeft);
937 pppLayout->addWidget(_pppRefdELineEdit, ir, 3, Qt::AlignRight);
938 pppLayout->addWidget(new QLabel("dE"), ir, 4, Qt::AlignLeft);
939 pppLayout->addWidget(_pppRefdULineEdit, ir, 5, Qt::AlignRight);
940 pppLayout->addWidget(new QLabel("dU"), ir, 6, Qt::AlignLeft);
941 ++ir;
942 pppLayout->addWidget(new QLabel("NMEA & plot output"),ir, 0, Qt::AlignLeft);
943 pppLayout->addWidget(_pppNMEALineEdit, ir, 1, Qt::AlignRight);
944 pppLayout->addWidget(new QLabel("NMEA File"), ir, 2, Qt::AlignLeft);
945 pppLayout->addWidget(_pppNMEAPortLineEdit, ir, 3, Qt::AlignRight);
946 pppLayout->addWidget(new QLabel("NMEA Port"), ir, 4, Qt::AlignLeft);
947 pppLayout->addWidget(_pppPlotCoordinates, ir, 5, Qt::AlignRight);
948 pppLayout->addWidget(new QLabel("PPP Plot"), ir, 6, Qt::AlignLeft);
949 ++ir;
950 pppLayout->addWidget(new QLabel("Post-processing"), ir, 0, Qt::AlignLeft);
951 pppLayout->addWidget(_postObsFileChooser, ir, 1, Qt::AlignRight);
952 pppLayout->addWidget(new QLabel("Obs "), ir, 2, Qt::AlignLeft);
953 pppLayout->addWidget(_postNavFileChooser, ir, 3, Qt::AlignRight);
954 pppLayout->addWidget(new QLabel("Nav "), ir, 4, Qt::AlignLeft);
955 ++ir;
956 pppLayout->addWidget(_postCorrFileChooser, ir, 1, Qt::AlignRight);
957 pppLayout->addWidget(new QLabel("Corr"), ir, 2, Qt::AlignLeft);
958 pppLayout->addWidget(_postOutLineEdit, ir, 3, Qt::AlignRight);
959 pppLayout->addWidget(new QLabel("Log (full path)"), ir, 4, Qt::AlignLeft);
960
961 pppgroup->setLayout(pppLayout);
962
963 // PPP Client (second panel)
964 // -------------------------
965 QGridLayout* ppp2Layout = new QGridLayout;
966 ppp2Layout->setColumnMinimumWidth(0,14*ww);
967 ir = 0;
968 ppp2Layout->addWidget(new QLabel("Precise Point Positioning, Panel 2."), ir, 0, 1, 10);
969 ++ir;
970 ppp2Layout->addWidget(new QLabel("Antennas"), ir, 0);
971 ppp2Layout->addWidget(_pppAntexFileChooser, ir, 1,1,3);
972 ppp2Layout->addWidget(new QLabel("ANTEX File"), ir, 4);
973 ppp2Layout->addWidget(_pppAntennaLineEdit, ir, 5,1,3);
974 ppp2Layout->addWidget(new QLabel("Antenna Name"), ir, 8);
975 ++ir;
976 ppp2Layout->addWidget(new QLabel("Basics"), ir, 0, 1, 5);
977 ppp2Layout->addWidget(_pppUsePhaseCheckBox, ir, 1, Qt::AlignRight);
978 ppp2Layout->addWidget(new QLabel("Use phase obs"), ir, 2);
979 ppp2Layout->addWidget(_pppEstTropoCheckBox, ir, 3, Qt::AlignRight);
980 ppp2Layout->addWidget(new QLabel("Estimate tropo"), ir, 4);
981 ppp2Layout->addWidget(_pppGLONASSCheckBox, ir, 5, Qt::AlignRight);
982 ppp2Layout->addWidget(new QLabel("Use GLONASS"), ir, 6);
983 ppp2Layout->addWidget(_pppGalileoCheckBox, ir, 7, Qt::AlignRight);
984 ppp2Layout->addWidget(new QLabel("Use Galileo "), ir, 8);
985 ++ir;
986 ppp2Layout->addWidget(new QLabel("Basics cont'd"), ir, 0);
987 ppp2Layout->addWidget(_pppSync, ir, 1);
988 ppp2Layout->addWidget(new QLabel("Sync Corr (sec) "), ir, 2);
989 ppp2Layout->addWidget(_pppAverageLineEdit, ir, 3, Qt::AlignRight);
990 ppp2Layout->addWidget(new QLabel("Averaging (min)") , ir, 4);
991 ppp2Layout->addWidget(_pppQuickStartLineEdit, ir, 5, Qt::AlignRight);
992 ppp2Layout->addWidget(new QLabel("Quick-Start (sec) "), ir, 6);
993 ppp2Layout->addWidget(_pppMaxSolGapLineEdit, ir, 7, Qt::AlignRight);
994 ppp2Layout->addWidget(new QLabel("Max Sol. Gap (sec)"), ir, 8);
995 ++ir;
996 ppp2Layout->addWidget(new QLabel("Basics cont'd"), ir, 0);
997 ppp2Layout->addWidget(_pppAudioResponseLineEdit, ir, 1, Qt::AlignRight);
998 ppp2Layout->addWidget(new QLabel("Audio response (m)"), ir, 2);
999 ++ir;
1000 ppp2Layout->addWidget(new QLabel("Sigmas"), ir, 0);
1001 ppp2Layout->addWidget(_pppSigCLineEdit, ir, 1, Qt::AlignRight);
1002 ppp2Layout->addWidget(new QLabel("Code"), ir, 2);
1003 ppp2Layout->addWidget(_pppSigPLineEdit, ir, 3);
1004 ppp2Layout->addWidget(new QLabel("Phase"), ir, 4);
1005 ++ir;
1006 ppp2Layout->addWidget(new QLabel("Sigmas cont'd"), ir, 0);
1007 ppp2Layout->addWidget(_pppSigCrd0, ir, 1, Qt::AlignRight);
1008 ppp2Layout->addWidget(new QLabel("XYZ Init "), ir, 2);
1009 ppp2Layout->addWidget(_pppSigCrdP, ir, 3, Qt::AlignRight);
1010 ppp2Layout->addWidget(new QLabel("XYZ White Noise "), ir, 4);
1011 ppp2Layout->addWidget(_pppSigTrp0, ir, 5, Qt::AlignRight);
1012 ppp2Layout->addWidget(new QLabel("Tropo Init "), ir, 6);
1013 ppp2Layout->addWidget(_pppSigTrpP, ir, 7);
1014 ppp2Layout->addWidget(new QLabel("Tropo White Noise"), ir, 8);
1015 ++ir;
1016 ppp2Layout->addWidget(new QLabel(""), ir, 0);
1017
1018 ppp2group->setLayout(ppp2Layout);
1019
1020 // Reqc Processing
1021 // ---------------
1022 _reqcActionComboBox = new QComboBox();
1023 _reqcActionComboBox->setEditable(false);
1024 _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
1025 ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
1026 if (ik != -1) {
1027 _reqcActionComboBox->setCurrentIndex(ik);
1028 }
1029 connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
1030 this, SLOT(slotBncTextChanged()));
1031
1032 QGridLayout* reqcLayout = new QGridLayout;
1033 _reqcActionComboBox->setMinimumWidth(15*ww);
1034 _reqcActionComboBox->setMaximumWidth(15*ww);
1035
1036 _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1037 _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
1038 _reqcObsFileChooser->setWhatsThis(tr("Specify the full path to an observation file in RINEX v2 or v3 format."));
1039 _reqcObsFileChooser->setMinimumWidth(15*ww);
1040 _reqcObsFileChooser->setMaximumWidth(15*ww);
1041
1042 _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1043 _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
1044 _reqcNavFileChooser->setWhatsThis(tr("Specify the full path to a RINEX v2 or v3 navigation file."));
1045 _reqcNavFileChooser->setMinimumWidth(15*ww);
1046 _reqcNavFileChooser->setMaximumWidth(15*ww);
1047
1048 _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
1049 _reqcOutObsLineEdit->setWhatsThis(tr("Specify the full path to a RINEX observation output file."));
1050 _reqcOutObsLineEdit->setMinimumWidth(15*ww);
1051 _reqcOutObsLineEdit->setMaximumWidth(15*ww);
1052
1053 _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
1054 _reqcOutNavLineEdit->setWhatsThis(tr("Specify the full path to a RINEX navigation output file."));
1055 _reqcOutNavLineEdit->setMinimumWidth(15*ww);
1056 _reqcOutNavLineEdit->setMaximumWidth(15*ww);
1057
1058 _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
1059 _reqcOutLogLineEdit->setWhatsThis(tr("Specify the full path to a logfile."));
1060 _reqcOutLogLineEdit->setMinimumWidth(15*ww);
1061 _reqcOutLogLineEdit->setMaximumWidth(15*ww);
1062
1063 _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
1064 _reqcPlotDirLineEdit->setWhatsThis(tr("Specify the directory name for saving plots."));
1065 _reqcPlotDirLineEdit->setMinimumWidth(15*ww);
1066 _reqcPlotDirLineEdit->setMaximumWidth(15*ww);
1067
1068 ir = 0;
1069 reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check."),ir, 0, 1, 20);
1070 ++ir;
1071 reqcLayout->addWidget(new QLabel("Action"), ir, 0, Qt::AlignLeft);
1072 reqcLayout->addWidget(_reqcActionComboBox, ir, 1, Qt::AlignLeft);
1073 _reqcEditOptionButton = new QPushButton("Set Edit Options");
1074 reqcLayout->addWidget(_reqcEditOptionButton, ir, 3, Qt::AlignRight);
1075 ++ir;
1076 reqcLayout->addWidget(new QLabel("Input files (full path)"), ir, 0, Qt::AlignLeft);
1077 reqcLayout->addWidget(_reqcObsFileChooser, ir, 1, Qt::AlignRight);
1078 reqcLayout->addWidget(new QLabel("Obs"), ir, 2, Qt::AlignLeft);
1079 reqcLayout->addWidget(_reqcNavFileChooser, ir, 3, Qt::AlignRight);
1080 reqcLayout->addWidget(new QLabel("Nav"), ir, 4, Qt::AlignLeft);
1081 ++ir;
1082 reqcLayout->addWidget(new QLabel("Output files (full path)"), ir, 0, Qt::AlignLeft);
1083 reqcLayout->addWidget(_reqcOutObsLineEdit, ir, 1, Qt::AlignRight);
1084 reqcLayout->addWidget(new QLabel("Obs"), ir, 2, Qt::AlignLeft);
1085 reqcLayout->addWidget(_reqcOutNavLineEdit, ir, 3, Qt::AlignRight);
1086 reqcLayout->addWidget(new QLabel("Nav"), ir, 4, Qt::AlignLeft);
1087 ++ir;
1088 reqcLayout->addWidget(_reqcOutLogLineEdit, ir, 1, Qt::AlignRight);
1089 reqcLayout->addWidget(new QLabel("Log"), ir, 2, Qt::AlignLeft);
1090 ++ir;
1091 reqcLayout->addWidget(new QLabel("Directory for plots"), ir, 0, Qt::AlignLeft);
1092 reqcLayout->addWidget(_reqcPlotDirLineEdit, ir, 1, Qt::AlignRight);
1093 ++ir;
1094 reqcLayout->addWidget(new QLabel(""), ir, 1);
1095 reqcLayout->setRowStretch(ir, 999);
1096
1097 reqcLayout->setColumnMinimumWidth(2, 8*ww);
1098 reqcLayout->setColumnMinimumWidth(4, 8*ww);
1099
1100 reqcgroup->setLayout(reqcLayout);
1101
1102 connect(_reqcEditOptionButton, SIGNAL(clicked()),
1103 this, SLOT(slotReqcEditOption()));
1104
1105 // Combine Corrections
1106 // -------------------
1107 QGridLayout* cmbLayout = new QGridLayout;
1108
1109 populateCmbTable();
1110 cmbLayout->addWidget(_cmbTable, 0, 0, 6, 3);
1111 cmbLayout->addWidget(new QLabel(" "), 0, 5);
1112 cmbLayout->addWidget(new QLabel("Combine Broadcast Correction streams."), 0, 6, 1, 50);
1113 cmbLayout->addWidget(new QLabel(" "), 1, 5);
1114 cmbLayout->addWidget(addCmbRowButton, 1, 6);
1115 cmbLayout->addWidget(delCmbRowButton, 1, 7);
1116 cmbLayout->addWidget(new QLabel(" "), 2, 5);
1117 cmbLayout->addWidget(new QLabel("Method"), 2, 6, Qt::AlignRight);
1118 cmbLayout->addWidget(_cmbMethodComboBox, 2, 7, Qt::AlignRight);
1119 cmbLayout->addWidget(new QLabel(" "), 3, 5);
1120 cmbLayout->addWidget(new QLabel("Maximal Residuum"), 3, 6, Qt::AlignRight);
1121 cmbLayout->addWidget(_cmbMaxresLineEdit, 3, 7, Qt::AlignRight);
1122 cmbLayout->addWidget(new QLabel(" "), 4, 5);
1123 cmbLayout->addWidget(new QLabel("Sampling"), 4, 6, Qt::AlignRight);
1124 cmbLayout->addWidget(_cmbSamplSpinBox, 4, 7, Qt::AlignRight);
1125 cmbLayout->addWidget(new QLabel(" "), 5, 0);
1126
1127 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1128 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
1129
1130 cmbgroup->setLayout(cmbLayout);
1131
1132 // Upload Layout (Clocks)
1133 // ----------------------
1134 QGridLayout* uploadHlpLayout = new QGridLayout();
1135
1136 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1137 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1138 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
1139
1140 uploadHlpLayout->addWidget(addUploadRowButton, 0, 0);
1141 uploadHlpLayout->addWidget(delUploadRowButton, 0, 1);
1142 uploadHlpLayout->addWidget(new QLabel("Interval"), 0, 2, Qt::AlignRight);
1143 uploadHlpLayout->addWidget(_uploadIntrComboBox, 0, 3);
1144 uploadHlpLayout->addWidget(new QLabel(" Sampling: Orb"), 0, 4, Qt::AlignRight);
1145 uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox, 0, 5);
1146 uploadHlpLayout->addWidget(new QLabel("SP3"), 0, 6, Qt::AlignRight);
1147 uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox, 0, 7);
1148 uploadHlpLayout->addWidget(new QLabel("RNX"), 0, 8, Qt::AlignRight);
1149 uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox, 0, 9);
1150 uploadHlpLayout->addWidget(setUploadTrafoButton, 0,10);
1151
1152 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1153 populateUploadTable();
1154
1155 uploadLayout->addWidget(new QLabel("Upload RTCMv3 Broadcast Corrections to caster."));
1156 uploadLayout->addWidget(_uploadTable);
1157 uploadLayout->addLayout(uploadHlpLayout);
1158
1159 uploadgroup->setLayout(uploadLayout);
1160
1161 // Upload Layout (Ephemeris)
1162 // -------------------------
1163 QGridLayout* uploadLayoutEph = new QGridLayout;
1164
1165 uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1166 _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1167 _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1168 _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1169
1170 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster."), 0, 0, 1, 50);
1171 uploadLayoutEph->addWidget(new QLabel("Host"), 1, 0);
1172 uploadLayoutEph->addWidget(_uploadEphHostLineEdit, 1, 1, 1, 3);
1173 uploadLayoutEph->addWidget(new QLabel(" Port"), 1, 4, Qt::AlignRight);
1174 uploadLayoutEph->addWidget(_uploadEphPortLineEdit, 1, 5, 1, 1);
1175 uploadLayoutEph->addWidget(new QLabel("Mountpoint "), 2, 0);
1176 uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit, 2, 1);
1177 uploadLayoutEph->addWidget(new QLabel(" Password"), 2, 2, Qt::AlignRight);
1178 uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit, 2, 3);
1179 uploadLayoutEph->addWidget(new QLabel("Sampling"), 3, 0);
1180 uploadLayoutEph->addWidget(_uploadEphSampleSpinBox, 3, 1);
1181 uploadLayoutEph->addWidget(new QLabel("Uploaded"), 4, 0);
1182 uploadLayoutEph->addWidget(_uploadEphBytesCounter, 4, 1);
1183 uploadLayoutEph->addWidget(new QLabel(" "), 5, 0);
1184 uploadLayoutEph->addWidget(new QLabel(" "), 6, 0);
1185
1186 uploadEphgroup->setLayout(uploadLayoutEph);
1187
1188 connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1189 this, SLOT(slotBncTextChanged()));
1190
1191 // Main Layout
1192 // -----------
1193 QGridLayout* mLayout = new QGridLayout;
1194 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
1195 mLayout->addWidget(_aogroup, 0,0);
1196 mLayout->addWidget(_mountPointsTable, 1,0);
1197 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
1198 mLayout->addWidget(_loggroup, 2,0);
1199
1200 _canvas->setLayout(mLayout);
1201
1202 // WhatsThis
1203 // ---------
1204 _proxyHostLineEdit->setWhatsThis(tr("<p>If you are running BNC within a protected Local Area Network (LAN), you might need to use a proxy server to access the Internet. Enter your proxy server IP and port number in case one is operated in front of BNC. If you do not know the IP and port of your proxy server, check the proxy server settings in your Internet browser or ask your network administrator.</p><p>Note that IP streaming is sometimes not allowed in a LAN. In this case you need to ask your network administrator for an appropriate modification of the local security policy or for the installation of a TCP relay to the NTRIP broadcasters. If these are not possible, you might need to run BNC outside your LAN on a network that has unobstructed connection to the Internet.</p>"));
1205 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1206 _sslCaCertPathLineEdit->setWhatsThis(tr("<p>Communication with an NTRIP broadcaster over SSL requires the exchange of client and/or server certificates. Specify the path to a directory where you save certificates on your system. Don't try communication via SSL if you are not sure wheter this is supported by the involved NTRIP broadcaster. Note that SSL communication is usually done over port 443.</p>"));
1207 _ignoreSslErrorsCheckBox->setWhatsThis(tr("<p>SSL communication may involve queries coming from the NTRIP broadcaster. Tick 'Ignore SSL authorization erros' if you don't want to be bothered with this.</p>"));
1208 _waitTimeSpinBox->setWhatsThis(tr("<p>When feeding a real-time GNSS network engine waiting for synchronized input epoch by epoch, BNC drops whatever is received later than 'Wait for full obs epoch' seconds. A value of 3 to 5 seconds is recommended, depending on the latency of the incoming streams and the delay acceptable to your real-time GNSS network engine or products.</p>"));
1209 _outFileLineEdit->setWhatsThis(tr("Specify the full path to a file where synchronized observations are saved in plain ASCII format. Beware that the size of this file can rapidly increase depending on the number of incoming streams."));
1210 _outPortLineEdit->setWhatsThis(tr("BNC can produce synchronized observations in a plain ASCII format on your local host through an IP port. Specify a port number here to activate this function."));
1211 _outUPortLineEdit->setWhatsThis(tr("BNC can produce unsynchronized observations in a plain ASCII format on your local host through an IP port. Specify a port number here to activate this function."));
1212 _outEphPortLineEdit->setWhatsThis(tr("BNC can produce ephemeris data in RINEX ASCII format on your local host through an IP port. Specify a port number here to activate this function."));
1213 _corrPortLineEdit->setWhatsThis(tr("BNC can produce Broadcast Ephemeris Corrections on your local host through an IP port. Specify a port number here to activate this function."));
1214 _corrTimeSpinBox->setWhatsThis(tr("<p>Concerning output through IP port, BNC drops Broadcast Ephemeris Corrections received later than 'Wait for full corr epoch' seconds. A value of 2 to 5 seconds is recommended, depending on the latency of the incoming correction stream(s) and the delay acceptable to your real-time application.</p><p>Specifying a value of '0' means that BNC immediately outputs all incoming Broadcast Epemeris Corrections and does not drop any of them for latency reasons.</p>"));
1215 _rnxPathLineEdit->setWhatsThis(tr("Here you specify the path to where the RINEX Observation files will be stored. If the specified directory does not exist, BNC will not create RINEX Observation files."));
1216 _ephPathLineEdit->setWhatsThis(tr("Specify the path for saving Broadcast Ephemeris data as RINEX Navigation files. If the specified directory does not exist, BNC will not create RINEX Navigation files."));
1217 _corrPathLineEdit->setWhatsThis(tr("Specify a directory for saving Broadcast Ephemeris Correction files. If the specified directory does not exist, BNC will not create the files."));
1218 _rnxScrpLineEdit->setWhatsThis(tr("<p>Whenever a RINEX Observation file is saved, you might want to compress, copy or upload it immediately via FTP. BNC allows you to execute a script/batch file to carry out these operations. To do that specify the full path of the script/batch file here. BNC will pass the full RINEX Observation file path to the script as a command line parameter (%1 on Windows systems, $1 onUnix/Linux systems).</p>"));
1219 _rnxSkelLineEdit->setWhatsThis(tr("<p>BNC allows using personal skeleton files that contain the header records you would like to include. You can derive a personal RINEX header skeleton file from the information given in an up to date sitelog.</p><p>A file in the RINEX Observations 'Directory' with a 'Skeleton extension' suffix is interpreted by BNC as a personal RINEX header skeleton file for the corresponding stream.</p>"));
1220 _rnxAppendCheckBox->setWhatsThis(tr("<p>When BNC is started, new files are created by default and any existing files with the same name will be overwritten. However, users might want to append already existing files following a restart of BNC, a system crash or when BNC crashed. Tick 'Append files' to continue with existing files and keep what has been recorded so far.</p>"));
1221 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1222 _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p>"));
1223
1224 _onTheFlyComboBox->setWhatsThis(tr("<p>When operating BNC online in 'no window' mode, some configuration parameters can be changed on-the-fly without interrupting the running process. For that BNC rereads parts of its configuration in pre-defined intervals.<p></p>Select '1 min', '5 min', '1 hour', or '1 day' to force BNC to reread its configuration every full minute, hour, or day and let in between edited configuration options become effective on-the-fly without terminating uninvolved threads.</p><p>Note that when operating BNC in window mode, on-the-fly changeable configuration options become effective immediately through 'Save & Reread Configuration'.</p>"));
1225 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1226 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1227 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of the Broadcast Ephemeris Correction files.</p>"));
1228 _rnxSamplSpinBox->setWhatsThis(tr("<p>Select the RINEX Observation sampling interval in seconds. A value of zero '0' tells BNC to store all received epochs into RINEX.</p>"));
1229 _binSamplSpinBox->setWhatsThis(tr("<p>Select the synchronized observation sampling interval in seconds. A value of zero '0' tells BNC to send/store all received epochs.</p>"));
1230 _obsRateComboBox->setWhatsThis(tr("<p>BNC can collect all returns (success or failure) coming from a decoder within a certain short time span to then decide whether a stream has an outage or its content is corrupted. The procedure needs a rough estimate of the expected 'Observation rate' of the incoming streams. When a continuous problem is detected, BNC can inform its operator about this event through an advisory note.</p>"));
1231 _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>"));
1232 _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>"));
1233 _logFileLineEdit->setWhatsThis(tr("<p>Records of BNC's activities are shown in the 'Log' tab on the bottom of this window. They can be saved into a file when a valid path is specified in the 'Logfile (full path)' field.</p><p>The logfile name will automatically be extended by a string '_YYMMDD' carrying the current date."));
1234 _adviseScriptLineEdit->setWhatsThis(tr("<p>Specify the full path to a script or batch file to handle advisory notes generated in the event of corrupted streams or stream outages. The affected mountpoint and one of the comments 'Begin_Outage', 'End_Outage', 'Begin_Corrupted', or 'End_Corrupted' are passed on to the script as command line parameters.</p><p>The script may have the task to send the advisory notes by email to BNC's operator and/or to the affected stream provider. An empty option field (default) or invalid path means that you don't want to use this option.</p>"));
1235 _perfIntrComboBox->setWhatsThis(tr("<p>BNC can average latencies per stream over a certain period of GPS time. The resulting mean latencies are recorded in the 'Log' tab at the end of each 'Log latency' interval together with results of a statistical evaluation (approximate number of covered epochs, data gaps).</p><p>Select a 'Log latency' interval or select the empty option field if you do not want BNC to log latencies and statistical information.</p>"));
1236 _mountPointsTable->setWhatsThis(tr("<p>Streams selected for retrieval are listed in the 'Streams' section. Clicking on 'Add Stream' button will open a window that allows the user to select data streams from an NTRIP broadcaster according to their mountpoints. To remove a stream from the 'Streams' list, highlight it by clicking on it and hit the 'Delete Stream' button. You can also remove multiple streams by highlighting them using +Shift and +Ctrl.</p><p>BNC automatically allocates one of its internal decoders to a stream based on the stream's 'format' as given in the sourcetable. BNC allows users to change this selection by editing the decoder string. Double click on the 'decoder' field, enter your preferred decoder and then hit Enter. The accepted decoder strings are 'RTCM_2.x', 'RTCM_3.x' and 'RTNET'.</p><p>In case you need to log the raw data as is, BNC allows users to by-pass its decoders and directly save the input in daily log files. To do this specify the decoder string as 'ZERO'.</p><p>BNC can also retrieve streams from virtual reference stations (VRS). VRS streams are indicated by a 'yes' in the 'nmea' column. To initiate these streams, the approximate latitude/longitude rover position is sent to the NTRIP broadcaster. The default values can be change according to your requirement. Double click on 'lat' and 'long' fields, enter the values you wish to send and then hit Enter.</p>"));
1237 _log->setWhatsThis(tr("Records of BNC's activities are shown in the 'Log' tab. The message log covers the communication status between BNC and the NTRIP broadcaster as well as any problems that occur in the communication link, stream availability, stream delay, stream conversion etc."));
1238 _bncFigure->setWhatsThis(tr("The bandwidth consumtion per stream is shown in the 'Throughput' tab in bits per second (bps) or kilo bits per second (kbps)."));
1239 _bncFigureLate->setWhatsThis(tr("The individual latency of observations in each incoming stream is shown in the 'Latency' tab. Streams not carrying observations (i.e. those providing only broadcast ephemeris messages) are not considered here. Note that the calculation of correct latencies requires the clock of the host computer to be properly synchronized."));
1240 _ephV3CheckBox->setWhatsThis(tr("The default format for output of RINEX Navigation data containing Broadcast Ephemeris is RINEX Version 2.11. Select 'Version 3' if you want to output the ephemeris in RINEX Version 3 format."));
1241 _rnxV3CheckBox->setWhatsThis(tr("The default format for RINEX Observation files is RINEX Version 2.11. Select 'Version 3' if you want to save the observations in RINEX Version 3 format."));
1242 _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>"));
1243 _scanRTCMCheckBox->setWhatsThis(tr("<p>Tick 'Scan RTCM' to log the numbers of incomming message types as well as contained antenna coordinates, antenna heigt, and antenna descriptor.</p><p>In case of RTCM Version 3 MSM streams, BNC will also log contained RINEX Version 3 observation types.</p>."));
1244 _serialMountPointLineEdit->setWhatsThis(tr("<p>Enter a 'Mountpoint' to forward the corresponding stream to a serial connected receiver.</p>"));
1245 _serialPortNameLineEdit->setWhatsThis(tr("<p>Enter the serial 'Port name' selected for communication with your serial connected receiver. Valid port names are</p><pre>Windows: COM1, COM2<br>Linux: /dev/ttyS0, /dev/ttyS1<br>FreeBSD: /dev/ttyd0, /dev/ttyd1<br>Digital Unix: /dev/tty01, /dev/tty02<br>HP-UX: /dev/tty1p0, /dev/tty2p0<br>SGI/IRIX: /dev/ttyf1, /dev/ttyf2<br>SunOS/Solaris: /dev/ttya, /dev/ttyb</pre><p>Note that you must plug a serial cable in the port defined here before you start BNC.</p>"));
1246 _serialBaudRateComboBox->setWhatsThis(tr("<p>Select a 'Baud rate' for the serial output link.</p><p>Note that your selection must equal the baud rate configured to the serial connected receiver. Note further that using a high baud rate is recommended.</p>"));
1247 _serialParityComboBox->setWhatsThis(tr("<p>Select the 'Parity' for the serial output link.</p><p>Note that your selection must equal the parity selection configured to the serial connected receiver. Note further that parity is often set to 'NONE'.</p>"));
1248 _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>"));
1249 _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>"));
1250 _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>"));
1251 _serialAutoNMEAComboBox->setWhatsThis(tr("<p>Select 'Auto' to automatically forward NMEA-GGA messages coming from your serial connected receiver to the NTRIP broadcaster and/or save them in a file.</p><p>Select 'Manual' only when handling a VRS stream and your serial connected receiver doesn't generate NMEA-GGA messages.</p>"));
1252 _serialFileNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where NMEA messages coming from your serial connected receiver are saved.</p>"));
1253 _serialHeightNMEALineEdit->setWhatsThis(tr("<p>Specify an approximate 'Height' above mean sea level in meter for your VRS to simulate an inital NMEA-GGA message.</p><p>The setting of this option is ignored in case of streams coming from physical reference stations.</p>"));
1254 _pppMountLineEdit->setWhatsThis(tr("<p>Specify an observations stream by its mountpoint from the 'Streams' list compiled below if you want BNC to estimate coordinates for the affected receiver position through a PPP solution. Example: 'FFMJ1'</p><p>Note that PPP in BNC requires to also pull a stream carrying RTCM Version 3 satellite orbit and clock corrections to Broadcast Ephemeris referring to the satellites' Antenna Phase Centers (APC). Stream CLK11 on NTRIP broadcaster products.igs-ip.net is an example.</p><p>Pulling in addition a third stream carrying Broadcast Ephemeris messages in high repetition rate is suggested if such messages are comeing from the receiver in low repetition rate or don't come at all from there.</p>"));
1255 _pppCorrMountLineEdit->setWhatsThis(tr("<p>You must specify an orbit/clock Broadcast Ephemeris corrections stream by its mountpoint from the 'Streams' list below. Example: 'CLK10'</p><p>Note that BNC can produce an internal PPP solution from combined Broadcast Ephemeris corrections as specified under 'Combine Corrections' if you introduce keyword 'INTERNAL' as the corrections mountpoint.</p>"));
1256 _pppSPPComboBox->setWhatsThis(tr("<p>Choose between plain Single Point Positioning (SPP) and Precise Point Positioning (PPP) in 'Realtime' or 'Post-Processing' mode.</p><p>When in 'Post-Processing mode:<ul><li>Specifying a RINEX Observation, a RINEX Navigation and a Broadcast Correction file leads to a PPP solution.</li><li>Specifying only a RINEX Observation and a RINEX Navigation file and no Broadcast Correction file leads to a SPP solution.</ul></p>"));
1257 _reqcActionComboBox->setWhatsThis(tr("<p>BNC allows to edit or concatenate RINEX v2 or v3 files or to perform a quality check following UNAVCO's famous 'teqc' program.</p>"));
1258 _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX v2 or v3 files.</p>"));
1259 _pppUsePhaseCheckBox->setWhatsThis(tr("<p>By default BNC applies a PPP solution using an ionosphere free P3 linear combination of code observations.</p><p>Tick 'Use phase obs' for an ionosphere free L3 linear combination of phase observations.</p>"));
1260 _pppEstTropoCheckBox->setWhatsThis(tr("<p>By default BNC does not introduce troposphere parameters when estimating coordinates.</p><p>Tick 'Estimate tropo' to introduce troposphere parameters when estimating coordinates.</p>"));
1261 _pppGLONASSCheckBox->setWhatsThis(tr("<p>By default BNC does not use GLONASS observations in PPP mode.</p><p>Tick 'Use GLONASS' for adding GLONASS observations to GPS and Galileo (optional) in a PPP solution.</p>"));
1262 _pppGalileoCheckBox->setWhatsThis(tr("<p>By default BNC does not use Galileo observations in PPP mode.</p><p>Tick 'Use Galileo' for adding Galileo observations to GPS and GLONASS (optional) in a PPP solution.</p>"));
1263 _pppPlotCoordinates->setWhatsThis(tr("<p>BNC will plot PPP results in the 'PPP Plot' tab as North (red), East (green) and Up (blue) displacements when this option is selected. Values will be either referred to an XYZ reference coordinate (if specified) or referred to the first estimated coordinate. The sliding PPP time series window will cover the period of the latest 5 minutes.</p><p>Note that a PPP time series makes only sense for a stationary operated receiver."));
1264 _pppNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where PPP results are saved as NMEA messages.</p>"));
1265 _pppNMEAPortLineEdit->setWhatsThis(tr("<p>Specify an IP port number to output PPP results as NMEA messages through an IP port.</p>"));
1266 _pppSigCLineEdit->setWhatsThis(tr("<p>Enter a sigma for your code observations in meters.</p><p>The higher the sigma you enter, the less the contribution of code observations to a PPP solution based on a combination of code and phase data. 5.0 (default) is likely to be an appropriate choice.</p>"));
1267 _pppQuickStartLineEdit->setWhatsThis(tr("<p>Enter the lenght of a startup period in seconds for which you want to fix the PPP solution to a known XYZ coordinate as introduced above and adjust a sigma 'XYZ Ini' according to the coordinate's precision. Fixing the coordinate is done in BNC through setting the 'Sigma XYZ Noise' you define below temporarily to zero.</p><p>This so-called Quick-Start option allows the PPP solution to rapidly converge. It requires that the antenna remains unmoved on the know position throughout the startup period.</p><p>A value of 120 is likely to be an appropriate choice for 'Quick-Start'. Default is an empty option field, meaning that you don't want BNC to operate in Quick-Start mode.</p>"));
1268 _pppMaxSolGapLineEdit->setWhatsThis(tr("<p>Specify a 'Maximum Solution Gap' in seconds. Should the time span between two consecutive solutions exceed this limit, the algorithm returns into Quick-Start mode and fixes the introduced reference coordinate for the specified period. A value of '60' seconds could be an appropriate choice.</p><p>This option makes only sense for a stationary operated receiver where solution convergence can be enforced because a good approximation for the rover position is known. Default is an empty option field, meaning that you don't want BNC to return into the Quick-Start mode after failures caused i.e. by longer lasting outages.</p>"));
1269 _pppAudioResponseLineEdit->setWhatsThis(tr("<p>Specify an 'Audio response' threshold in meters. A beep is produced by BNC whenever a horizontal PPP coordinate component differs by more than the threshold value from the marker coordinate.</p><p>Default is an empty option field, meaning that you don't want BNC to produce alarm signals.</p>"));
1270 _pppSigPLineEdit->setWhatsThis(tr("<p>Enter a sigma for your phase observations in meters.</p><p>The higher the sigma you enter, the less the contribution of phase observations to a PPP solutions based on a combination of code and phase data. 0.02 (default) is likely to be an appropriate choice.</p>"));
1271 _pppAverageLineEdit->setWhatsThis(tr("<p>Enter the length of a sliding time window in minutes. BNC will continuously output moving average positions computed from those individual positions obtained most recently throughout this period.</p><p>An empty option field (default) means that you don't want BNC to output moving average positions.</p>"));
1272 _pppSigCrd0->setWhatsThis(tr("<p>Enter a sigma in meters for the initial XYZ coordinate componentes. A value of 100.0 (default) may be an appropriate choice. However, this value may be significantly smaller (i.e. 0.01) when starting for example from a station with known XZY position in Quick-Start mode."));
1273 _pppSigCrdP->setWhatsThis(tr("<p>Enter a sigma in meters for the white noise of estimated XYZ coordinate components. A value of 100.0 (default) may be appropriate considering the potential movement of a rover position.</p>"));
1274 _pppSigTrp0->setWhatsThis(tr("<p>Enter a sigma in meters for the a-priory model based tropospheric delay estimation. A value of 0.1 (default) may be an appropriate choice.</p>"));
1275 _pppSigTrpP->setWhatsThis(tr("<p>Enter a sigma in meters per second to describe the expected variation of the tropospheric effect.</p><p>Supposing 1Hz observation data, a value of 3e-6 (default) would mean that the tropospheric effect may vary for 3600 * 3e-6 = 0.01 meters per hour.</p>"));
1276 _pppRefCrdXLineEdit->setWhatsThis(tr("<p>Enter reference coordinate X of the receiver's position.</p><p>This option only makes sense in static observation conditions.</p>"));
1277 _pppRefCrdYLineEdit->setWhatsThis(tr("<p>Enter reference coordinate Y of the receiver's position.</p><p>This option only makes sens in static observation conditions.</p>"));
1278 _pppRefCrdZLineEdit->setWhatsThis(tr("<p>Enter reference coordinate Z of the receiver's position.</p><p>This option only makes sens in static observation conditions.</p>"));
1279 _pppRefdNLineEdit->setWhatsThis(tr("<p>Enter north antenna excentricity.</p>"));
1280 _pppRefdELineEdit->setWhatsThis(tr("<p>Enter east antenna excentricity.</p>"));
1281 _pppRefdULineEdit->setWhatsThis(tr("<p>Enter up antenna excentricity.</p>"));
1282 _bncFigurePPP->setWhatsThis(tr("PPP time series of North (red), East (green) and Up (blue) coordinate components are shown in the 'PPP Plot' tab when the corresponting option is selected above. Values are either referred to an XYZ reference coordinate (if specified) or referred to the first estimated set of coordinate compoments. The sliding PPP time series window covers the period of the latest 5 minutes."));
1283 _pppSync->setWhatsThis(tr(
1284 "<p> Zero value (or empty field, default) means that BNC processes each epoch of data "
1285 "immediately after its arrival using satellite clock corrections available at "
1286 "that time.</p><p> Non-zero value 'Sync Corr' (i.e. 5) means that the epochs of data "
1287 "are buffered and the processing of each epoch is postponed till the satellite clock "
1288 "corrections not older than 'Sync Corr' seconds are available.<p>"));
1289 _pppAntexFileChooser->setWhatsThis(tr("<p>IGS provides a file containing absolute phase center corrections for GNSS satellite and receiver antennas in ANTEX format. Entering the full path to such an ANTEX file is required for correcting observations for antenna phase center offsets and variations. It allows you to specify the name of your receiver's antenna (as contained in the ANTEX file) to apply such corrections.</p><p>Default is an empty option field meaning that you don't want to correct observations for antenna phase center offsets and variations.</p>"));
1290 _pppAntennaLineEdit->setWhatsThis(tr("<p>Specify the receiver's antenna name as defined in your ANTEX file. Observations will be corrected for the antenna phase center's offset which may result in a reduction of a few centimeters at max. Corrections for phase center variations are not yet applied by BNC. The specified name must consist of 20 characters. Add trailing blanks if the antenna name has less then 20 characters.</p><p>Default is an empty option field meaning that you don't want to correct observations for antenna phase center offsets.</p>"));
1291 _cmbTable->setWhatsThis(tr("<p>BNC allows to process several orbit and clock corrections streams in real-time to produce, encode, upload and save a combination of correctors coming from various providers. Hit the 'Add Row' button, double click on the 'Mountpoint' field to enter a Broadcast Ephemeris corrections mountpoint from the 'Streams' section below and hit Enter. Then double click on the 'AC Name' field to enter your choice of an abbreviation for the Analysis Center (AC) providing the stream. Finally, double click on the 'Weight' field to enter the weight to be applied for this stream in the combination.<ul><li>Note that an appropriate 'Wait for full corr epoch' value needs to be specified for the combination under the 'Broadcast Corrections' tab. A value of 15 seconds would make sense there if the update rate of incoming clock corrections is i.e. 10 seconds.</li><li>Note also that you need to tick 'Use GLONASS' which is part ot the 'PPP (2)' panel in case you want to produce an GPS plus GLONASS combination.</li></ul></p><p>Note further that the orbit information in the final combination stream is just copied from one of the incoming streams. The stream used for providing the orbits may vary over time: if the orbit providing stream has an outage then BNC switches to the next remaining stream for getting hold of the orbit information.</p><p>The combination process requires Broadcast Ephemeris. Besides the orbit and clock corrections stream(s) BNC should therefore pull a stream carrying Broadcast Ephemeris in the form of RTCM Version 3 messages.</p><p>It is possible to specify only one Broadcast Ephemeris corrections stream in the combination table. Instead of combining corrections BNC will then merge them with Broadcast Ephemeris to save results in SP3 and/or Clock RINEX format."));
1292 _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>"));
1293 _cmbSamplSpinBox->setWhatsThis(tr("<p>Specify a combination sampling interval. Clock and orbit corrections will be produced following that interval. A value of 10 sec may be an appropriate choice.</p>"));
1294 _cmbMethodComboBox->setWhatsThis(tr("<p>Select a clock combination approach. Options are 'Single-Epoch' and Kalman 'Filter'. It is suggested to use the Kalman filter approach for the purpose of Precise Point Positioning.</p>"));
1295 _uploadTable->setWhatsThis(tr("<p>BNC can upload clock and orbit corrections to broadcast ephemeris (Broadcast Corrections) in RTCM Version 3 SSR format. You may have a situation where clocks and orbits come from an external Real-time Network Engine (1) or a situation where clock and orbit corrections are combined within BNC (2).</p><p>(1) BNC identifies a stream as coming from a Real-time Network Engine if its format is specified as 'RTNET' and hence its decoder string in the 'Streams' canvas is 'RTNET'. It encodes and uploads that stream to the specified NTRIP broadcaster</p><p>(2) BNC understands that it is expected to encode and upload combined Broadcast Ephemeris corrections if you specify correction streams in the 'Combine Corrections' stream table.</p><p>Hit the 'Add Row' button, double click on the 'Host' field to enter the IP or URL of an NTRIP broadcaster and hit Enter. Then double click on the 'Port', 'Mount' and 'Password' fields to enter the NTRIP broadcaster IP port (default is 80), the mountpoint and the stream upload password. An empty 'Host' option field means that you don't want to upload corrections.</p><p>Select a target coordinate reference system (e.g. IGS08) for outgoing clock and orbit corrections.</p><p>By default orbit and clock corrections refer to Antenna Phase Center (APC). Tick 'CoM' to refer uploaded corrections to Center of Mass instead of APC.</p><p>Specify a path for saving the generated Broadcast Corrections plus Broadcast Ephemeris as SP3 orbit files. If the specified directory does not exist, BNC will not create SP3 orbit files. The following is a path example for a Linux system:<br>/home/user/BNC${GPSWD}.sp3<br>Note that '${GPSWD}' produces the GPS Week and Day number in the file name.</p><ul><li>As an SP3 file contents should be referred to the satellites Center of Mass (CoM) while correctors are referred to the satellites Antenna Phase Center (APC), an offset has to be applied which is available from an IGS ANTEX file. You should therefore specify the 'ANTEX File' path under tab 'PPP (2)' if you want to save the stream contents in SP3 format. If you don't specify an 'ANTEX File' path there, the SP3 file contents will be referred to the satellites APCs.</li></ul></p><p>Specify a path for saving the generated Broadcast Correction clocks plus Broadcast Ephemeris clocks as Clock RINEX files. If the specified directory does not exist, BNC will not create Clock RINEX files. The following is a path example for a Linux system:<br>/home/user/BNC${GPSWD}.clk<br>Note that '${GPSWD}' produces the GPS Week and Day number in the file name.</p><p>Specify finally an SSR Provider ID number, an SSR Solution ID number and an Issue of Data SSR number.</p><p>In case the 'Combine Corrections' table contains only one Broadcast Corrections stream, BNC will merge that stream with Broadcast Ephemeris to save results in files specified here through SP3 and/or Clock RINEX file path. In such a case you should define only the SP3 and Clock RINEX file path and no further options in the 'Upload Corrections' table.</p>"));
1296 _postObsFileChooser->setWhatsThis(tr("Full path to RINEX v2/v3 Observation file."));
1297 _postNavFileChooser->setWhatsThis(tr("Full path to RINEX v2/v3 Navigation file."));
1298 _postCorrFileChooser->setWhatsThis(tr("Full path to Broadcast Corrections file as previously saved with BNC in plain ASCII format."));
1299 _postOutLineEdit->setWhatsThis(tr("Full path to file with post processing PPP results. "));
1300 addCmbRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the mountpoints table."));
1301 delCmbRowButton->setWhatsThis(tr("Hit 'Delete' button to delete the highlighted line from the mountpoints table."));
1302 addUploadRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the stream upload table."));
1303 delUploadRowButton->setWhatsThis(tr("Hit 'Del Row' button to delete the highlighted line from the stream upload table."));
1304 _uploadIntrComboBox->setWhatsThis(tr("Select the length of the SP3 and Clock RINEX files."));
1305 _uploadSamplRtcmEphCorrSpinBox->setWhatsThis(tr("Select the stream's orbit correction sampling interval in seconds. A value of zero '0' tells BNC to upload all available orbit and clock correction samples together in combined messages."));
1306 _uploadSamplClkRnxSpinBox->setWhatsThis(tr("Select the Clock RINEX file sampling interval in seconds. A value of zero '0' tells BNC to store all available samples into Clock RINEX files."));
1307 _uploadSamplSp3SpinBox->setWhatsThis(tr("Select the SP3 orbit file sampling interval in minutes. A value of zero '0' tells BNC to store all available samples into SP3 orbit files."));
1308 setUploadTrafoButton->setWhatsThis(tr("Hit 'Custom Trafo' to specify your own 14 parameter Helmert Transformation instead of selecting a predefined transformation through 'System' button."));
1309
1310 _uploadEphHostLineEdit->setWhatsThis(tr("BNC can upload a Broadcast Ephemeris stream in RTCM Version 3 format. Specify the host IP of an NTRIP Broadcaster to upload the stream. An empty option field means that you don't want to upload Broadcast Ephemeris."));
1311 _uploadEphPortLineEdit->setWhatsThis(tr("Specify the IP port of an NTRIP Broadcaster to upload the stream. Default is port 80."));
1312 _uploadEphMountpointLineEdit->setWhatsThis(tr("Specify the mounpoint for stream upload to an NTRIP Broadcaster."));
1313 _uploadEphPasswordLineEdit->setWhatsThis(tr("Specify the stream upload password protecting the mounpoint on an NTRIP Broadcaster."));
1314 _uploadEphSampleSpinBox->setWhatsThis(tr("Select the Broadcast Ephemeris sampling interval in seconds. Defaut is '5' meaning that a complete set of Broadcast Ephemeris is uploaded every 5 seconds."));
1315 _uploadEphBytesCounter->setWhatsThis(tr("BNC shows the amount of data uploaded through this stream."));
1316
1317 _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1318 _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
1319 _actMap->setWhatsThis(tr("<p> Draw distribution map of stream selection presented in the 'Streams' canvas.</p>"));
1320 _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1321 _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1322// Weber
1323
1324 // Enable/Disable all Widgets
1325 // --------------------------
1326 slotBncTextChanged();
1327 enableStartStop();
1328
1329 // Auto start
1330 // ----------
1331 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1332 slotStart();
1333 }
1334}
1335
1336// Destructor
1337////////////////////////////////////////////////////////////////////////////
1338bncWindow::~bncWindow() {
1339 delete _caster;
1340 delete _casterEph;
1341}
1342
1343//
1344////////////////////////////////////////////////////////////////////////////
1345void bncWindow::populateMountPointsTable() {
1346
1347 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1348 _mountPointsTable->removeRow(iRow);
1349 }
1350
1351 bncSettings settings;
1352
1353 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1354 int iRow = 0;
1355 while (it.hasNext()) {
1356 QStringList hlp = it.next().split(" ");
1357 if (hlp.size() < 5) continue;
1358 _mountPointsTable->insertRow(iRow);
1359
1360 QUrl url(hlp[0]);
1361
1362 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1363 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1364 QString nmea(hlp[4]);
1365 if (hlp[5] == "S") {
1366 fullPath = hlp[0].replace(0,2,"");
1367 }
1368 QString ntripVersion = "2";
1369 if (hlp.size() >= 6) {
1370 ntripVersion = (hlp[5]);
1371 }
1372
1373 QTableWidgetItem* it;
1374 it = new QTableWidgetItem(url.userInfo());
1375 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1376 _mountPointsTable->setItem(iRow, 0, it);
1377
1378 it = new QTableWidgetItem(fullPath);
1379 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1380 _mountPointsTable->setItem(iRow, 1, it);
1381
1382 it = new QTableWidgetItem(format);
1383 _mountPointsTable->setItem(iRow, 2, it);
1384
1385 if (nmea == "yes") {
1386 it = new QTableWidgetItem(latitude);
1387 _mountPointsTable->setItem(iRow, 3, it);
1388 it = new QTableWidgetItem(longitude);
1389 _mountPointsTable->setItem(iRow, 4, it);
1390 } else {
1391 it = new QTableWidgetItem(latitude);
1392 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1393 _mountPointsTable->setItem(iRow, 3, it);
1394 it = new QTableWidgetItem(longitude);
1395 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1396 _mountPointsTable->setItem(iRow, 4, it);
1397 }
1398
1399 it = new QTableWidgetItem(nmea);
1400 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1401 _mountPointsTable->setItem(iRow, 5, it);
1402
1403 it = new QTableWidgetItem(ntripVersion);
1404 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1405 _mountPointsTable->setItem(iRow, 6, it);
1406
1407 bncTableItem* bncIt = new bncTableItem();
1408 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1409 _mountPointsTable->setItem(iRow, 7, bncIt);
1410
1411 iRow++;
1412 }
1413
1414 _mountPointsTable->sortItems(1);
1415
1416 enableStartStop();
1417}
1418
1419// Retrieve Table
1420////////////////////////////////////////////////////////////////////////////
1421void bncWindow::slotAddMountPoints() {
1422
1423 bncSettings settings;
1424 QString proxyHost = settings.value("proxyHost").toString();
1425 int proxyPort = settings.value("proxyPort").toInt();
1426 if (proxyHost != _proxyHostLineEdit->text() ||
1427 proxyPort != _proxyPortLineEdit->text().toInt()) {
1428 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1429 "changed. Use the new ones?",
1430 QMessageBox::Yes, QMessageBox::No,
1431 QMessageBox::NoButton);
1432 if (iRet == QMessageBox::Yes) {
1433 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1434 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1435 }
1436 }
1437
1438 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1439 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1440
1441 QMessageBox msgBox;
1442 msgBox.setIcon(QMessageBox::Question);
1443 msgBox.setWindowTitle("Add Stream");
1444 msgBox.setText("Add stream(s) coming from:");
1445
1446 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1447 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1448 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1449 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1450 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1451
1452 msgBox.exec();
1453
1454 if (msgBox.clickedButton() == buttonNtrip) {
1455 bncTableDlg* dlg = new bncTableDlg(this);
1456 dlg->move(this->pos().x()+50, this->pos().y()+50);
1457 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1458 this, SLOT(slotNewMountPoints(QStringList*)));
1459 dlg->exec();
1460 delete dlg;
1461 } else if (msgBox.clickedButton() == buttonIP) {
1462 bncIpPort* ipp = new bncIpPort(this);
1463 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1464 this, SLOT(slotNewMountPoints(QStringList*)));
1465 ipp->exec();
1466 delete ipp;
1467 } else if (msgBox.clickedButton() == buttonUDP) {
1468 bncUdpPort* udp = new bncUdpPort(this);
1469 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1470 this, SLOT(slotNewMountPoints(QStringList*)));
1471 udp->exec();
1472 delete udp;
1473 } else if (msgBox.clickedButton() == buttonSerial) {
1474 bncSerialPort* sep = new bncSerialPort(this);
1475 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1476 this, SLOT(slotNewMountPoints(QStringList*)));
1477 sep->exec();
1478 delete sep;
1479 } else if (msgBox.clickedButton() == buttonCancel) {
1480 // Cancel
1481 }
1482
1483 enableStartStop();
1484}
1485
1486// Delete Selected Mount Points
1487////////////////////////////////////////////////////////////////////////////
1488void bncWindow::slotDeleteMountPoints() {
1489
1490 int nRows = _mountPointsTable->rowCount();
1491 bool flg[nRows];
1492 for (int iRow = 0; iRow < nRows; iRow++) {
1493 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1494 flg[iRow] = true;
1495 }
1496 else {
1497 flg[iRow] = false;
1498 }
1499 }
1500 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1501 if (flg[iRow]) {
1502 _mountPointsTable->removeRow(iRow);
1503 }
1504 }
1505 _actDeleteMountPoints->setEnabled(false);
1506
1507 enableStartStop();
1508}
1509
1510// New Mount Points Selected
1511////////////////////////////////////////////////////////////////////////////
1512void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1513 int iRow = 0;
1514 QListIterator<QString> it(*mountPoints);
1515 while (it.hasNext()) {
1516 QStringList hlp = it.next().split(" ");
1517 QUrl url(hlp[0]);
1518 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1519 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1520 QString nmea(hlp[4]);
1521 if (hlp[5] == "S") {
1522 fullPath = hlp[0].replace(0,2,"");
1523 }
1524 QString ntripVersion = "2";
1525 if (hlp.size() >= 6) {
1526 ntripVersion = (hlp[5]);
1527 }
1528
1529 _mountPointsTable->insertRow(iRow);
1530
1531 QTableWidgetItem* it;
1532 it = new QTableWidgetItem(url.userInfo());
1533 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1534 _mountPointsTable->setItem(iRow, 0, it);
1535
1536 it = new QTableWidgetItem(fullPath);
1537 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1538 _mountPointsTable->setItem(iRow, 1, it);
1539
1540 it = new QTableWidgetItem(format);
1541 _mountPointsTable->setItem(iRow, 2, it);
1542
1543 if (nmea == "yes") {
1544 it = new QTableWidgetItem(latitude);
1545 _mountPointsTable->setItem(iRow, 3, it);
1546 it = new QTableWidgetItem(longitude);
1547 _mountPointsTable->setItem(iRow, 4, it);
1548 } else {
1549 it = new QTableWidgetItem(latitude);
1550 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1551 _mountPointsTable->setItem(iRow, 3, it);
1552 it = new QTableWidgetItem(longitude);
1553 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1554 _mountPointsTable->setItem(iRow, 4, it);
1555 }
1556
1557 it = new QTableWidgetItem(nmea);
1558 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1559 _mountPointsTable->setItem(iRow, 5, it);
1560
1561 it = new QTableWidgetItem(ntripVersion);
1562 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1563 _mountPointsTable->setItem(iRow, 6, it);
1564
1565 bncTableItem* bncIt = new bncTableItem();
1566 _mountPointsTable->setItem(iRow, 7, bncIt);
1567
1568 iRow++;
1569 }
1570 _mountPointsTable->hideColumn(0);
1571 _mountPointsTable->sortItems(1);
1572 delete mountPoints;
1573
1574 enableStartStop();
1575}
1576
1577// Save Options (serialize)
1578////////////////////////////////////////////////////////////////////////////
1579void bncWindow::slotSaveOptions() {
1580 saveOptions();
1581 bncSettings settings;
1582 settings.sync();
1583}
1584
1585// Save Options (memory only)
1586////////////////////////////////////////////////////////////////////////////
1587void bncWindow::saveOptions() {
1588
1589 QStringList mountPoints;
1590 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1591
1592 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1593 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1594 "@" + _mountPointsTable->item(iRow, 1)->text() );
1595
1596 mountPoints.append(url.toString() + " " +
1597 _mountPointsTable->item(iRow, 2)->text()
1598 + " " + _mountPointsTable->item(iRow, 3)->text()
1599 + " " + _mountPointsTable->item(iRow, 4)->text()
1600 + " " + _mountPointsTable->item(iRow, 5)->text()
1601 + " " + _mountPointsTable->item(iRow, 6)->text());
1602 } else {
1603 mountPoints.append(
1604 "//" + _mountPointsTable->item(iRow, 1)->text()
1605 + " " + _mountPointsTable->item(iRow, 2)->text()
1606 + " " + _mountPointsTable->item(iRow, 3)->text()
1607 + " " + _mountPointsTable->item(iRow, 4)->text()
1608 + " " + _mountPointsTable->item(iRow, 5)->text()
1609 + " " + _mountPointsTable->item(iRow, 6)->text());
1610 }
1611 }
1612
1613 QStringList combineStreams;
1614 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1615 QString hlp;
1616 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1617 if (_cmbTable->item(iRow, iCol)) {
1618 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1619 }
1620 }
1621 if (!hlp.isEmpty()) {
1622 combineStreams << hlp;
1623 }
1624 }
1625
1626 QStringList uploadMountpointsOut;
1627 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1628 QString hlp;
1629 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1630 if (_uploadTable->cellWidget(iRow, iCol) &&
1631 (iCol == 3 || iCol == 4 || iCol == 5)) {
1632 if (iCol == 3) {
1633 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1634 hlp += passwd->text() + ",";
1635 }
1636 else if (iCol == 4) {
1637 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1638 hlp += system->currentText() + ",";
1639 }
1640 else if (iCol == 5) {
1641 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1642 QString state; state.setNum(com->checkState());
1643 hlp += state + ",";
1644 }
1645 }
1646 else if (_uploadTable->item(iRow, iCol)) {
1647 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1648 }
1649 }
1650 if (!hlp.isEmpty()) {
1651 uploadMountpointsOut << hlp;
1652 }
1653 }
1654
1655 bncSettings settings;
1656
1657 settings.setValue("startTab", _aogroup->currentIndex());
1658 settings.setValue("statusTab", _loggroup->currentIndex());
1659 settings.setValue("mountPoints", mountPoints);
1660// Network
1661 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1662 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1663 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1664 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1665// General
1666 settings.setValue("logFile", _logFileLineEdit->text());
1667 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1668 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1669 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1670 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1671// RINEX Observations
1672 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1673 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1674 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1675 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1676 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1677 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1678// RINEX Ephemeris
1679 settings.setValue("ephPath", _ephPathLineEdit->text());
1680 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1681 settings.setValue("outEphPort", _outEphPortLineEdit->text());
1682 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1683// Broadcast Corrections
1684 settings.setValue("corrPath", _corrPathLineEdit->text());
1685 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1686 settings.setValue("corrPort", _corrPortLineEdit->text());
1687 settings.setValue("corrTime", _corrTimeSpinBox->value());
1688// Feed Engine
1689 settings.setValue("outPort", _outPortLineEdit->text());
1690 settings.setValue("waitTime", _waitTimeSpinBox->value());
1691 settings.setValue("binSampl", _binSamplSpinBox->value());
1692 settings.setValue("outFile", _outFileLineEdit->text());
1693 settings.setValue("outUPort", _outUPortLineEdit->text());
1694// Serial Output
1695 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1696 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1697 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1698 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1699 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1700 settings.setValue("serialParity", _serialParityComboBox->currentText());
1701 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1702 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1703 settings.setValue("serialFileNMEA",_serialFileNMEALineEdit->text());
1704 settings.setValue("serialHeightNMEA",_serialHeightNMEALineEdit->text());
1705// Outages
1706 settings.setValue("obsRate", _obsRateComboBox->currentText());
1707 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1708 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1709 settings.setValue("adviseScript",_adviseScriptLineEdit->text());
1710// Miscellaneous
1711 settings.setValue("miscMount", _miscMountLineEdit->text());
1712 settings.setValue("perfIntr", _perfIntrComboBox->currentText());
1713 settings.setValue("scanRTCM", _scanRTCMCheckBox->checkState());
1714// PPPP
1715 settings.setValue("pppSPP", _pppSPPComboBox->currentText());
1716 settings.setValue("pppMount", _pppMountLineEdit->text());
1717 settings.setValue("pppCorrMount",_pppCorrMountLineEdit->text());
1718 settings.setValue("pppRefCrdX", _pppRefCrdXLineEdit->text());
1719 settings.setValue("pppRefCrdY", _pppRefCrdYLineEdit->text());
1720 settings.setValue("pppRefCrdZ", _pppRefCrdZLineEdit->text());
1721 settings.setValue("pppRefdN", _pppRefdNLineEdit->text());
1722 settings.setValue("pppRefdE", _pppRefdELineEdit->text());
1723 settings.setValue("pppRefdU", _pppRefdULineEdit->text());
1724 settings.setValue("nmeaFile", _pppNMEALineEdit->text());
1725 settings.setValue("nmeaPort", _pppNMEAPortLineEdit->text());
1726 settings.setValue("pppPlotCoordinates", _pppPlotCoordinates->checkState());
1727 settings.setValue("postObsFile", _postObsFileChooser->fileName());
1728 settings.setValue("postNavFile", _postNavFileChooser->fileName());
1729 settings.setValue("postCorrFile", _postCorrFileChooser->fileName());
1730 settings.setValue("postOutFile", _postOutLineEdit->text());
1731 settings.setValue("pppAntenna", _pppAntennaLineEdit->text());
1732 settings.setValue("pppAntex", _pppAntexFileChooser->fileName());
1733 settings.setValue("pppUsePhase", _pppUsePhaseCheckBox->checkState());
1734 settings.setValue("pppEstTropo", _pppEstTropoCheckBox->checkState());
1735 settings.setValue("pppGLONASS", _pppGLONASSCheckBox->checkState());
1736 settings.setValue("pppGalileo", _pppGalileoCheckBox->checkState());
1737 settings.setValue("pppSync", _pppSync->text());
1738 settings.setValue("pppAverage", _pppAverageLineEdit->text());
1739 settings.setValue("pppQuickStart", _pppQuickStartLineEdit->text());
1740 settings.setValue("pppMaxSolGap", _pppMaxSolGapLineEdit->text());
1741 settings.setValue("pppAudioResponse", _pppAudioResponseLineEdit->text());
1742 settings.setValue("pppSigmaCode",_pppSigCLineEdit->text());
1743 settings.setValue("pppSigmaPhase",_pppSigPLineEdit->text());
1744 settings.setValue("pppSigCrd0",_pppSigCrd0->text());
1745 settings.setValue("pppSigCrdP",_pppSigCrdP->text());
1746 settings.setValue("pppSigTrp0",_pppSigTrp0->text());
1747 settings.setValue("pppSigTrpP",_pppSigTrpP->text());
1748// Reqc
1749 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1750 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1751 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1752 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1753 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1754 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
1755 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
1756// Combine Corrections
1757 if (!combineStreams.isEmpty()) {
1758 settings.setValue("combineStreams", combineStreams);
1759 }
1760 else {
1761 settings.setValue("combineStreams", "");
1762 }
1763 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1764 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1765 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1766// Upload Corrections
1767 if (!uploadMountpointsOut.isEmpty()) {
1768 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1769 }
1770 else {
1771 settings.setValue("uploadMountpointsOut", "");
1772 }
1773 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1774 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1775 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1776 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
1777// Upload Ephemeris
1778 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1779 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
1780 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
1781 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1782 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
1783 if (_caster) {
1784 _caster->readMountPoints();
1785 }
1786}
1787
1788// All get slots terminated
1789////////////////////////////////////////////////////////////////////////////
1790void bncWindow::slotGetThreadsFinished() {
1791 ((bncApp*)qApp)->slotMessage("All Get Threads Terminated", true);
1792 delete _caster; _caster = 0;
1793 delete _casterEph; _casterEph = 0;
1794 _runningRealTime = false;
1795}
1796
1797// Start It!
1798////////////////////////////////////////////////////////////////////////////
1799void bncWindow::slotStart() {
1800 saveOptions();
1801 if ( _pppSPPComboBox->currentText() == "Post-Processing" ) {
1802 startPostProcessingPPP();
1803 }
1804 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
1805 startPostProcessingReqc();
1806 }
1807 else {
1808 startRealTime();
1809 }
1810}
1811
1812// Start Real-Time (Retrieve Data etc.)
1813////////////////////////////////////////////////////////////////////////////
1814void bncWindow::startRealTime() {
1815
1816 _runningRealTime = true;
1817
1818 _bncFigurePPP->reset();
1819
1820 _actDeleteMountPoints->setEnabled(false);
1821
1822 enableStartStop();
1823
1824 _caster = new bncCaster(_outFileLineEdit->text(),
1825 _outPortLineEdit->text().toInt());
1826
1827 ((bncApp*)qApp)->setPort(_outEphPortLineEdit->text().toInt());
1828 ((bncApp*)qApp)->setPortCorr(_corrPortLineEdit->text().toInt());
1829 ((bncApp*)qApp)->initCombination();
1830
1831 connect(_caster, SIGNAL(getThreadsFinished()),
1832 this, SLOT(slotGetThreadsFinished()));
1833
1834 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
1835 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
1836
1837 ((bncApp*)qApp)->slotMessage("========== Start BNC v" BNCVERSION " =========", true);
1838
1839 bncSettings settings;
1840
1841 QDir rnxdir(settings.value("rnxPath").toString());
1842 if (!rnxdir.exists()) ((bncApp*)qApp)->slotMessage("Cannot find RINEX Observations directory", true);
1843
1844 QString rnx_file = settings.value("rnxScript").toString();
1845 if ( !rnx_file.isEmpty() ) {
1846 QFile rnxfile(settings.value("rnxScript").toString());
1847 if (!rnxfile.exists()) ((bncApp*)qApp)->slotMessage("Cannot find RINEX Observations script", true);
1848 }
1849
1850 QDir ephdir(settings.value("ephPath").toString());
1851 if (!ephdir.exists()) ((bncApp*)qApp)->slotMessage("Cannot find RINEX Ephemeris directory", true);
1852
1853 QDir corrdir(settings.value("corrPath").toString());
1854 if (!corrdir.exists()) ((bncApp*)qApp)->slotMessage("Cannot find Broadcast Corrections directory", true);
1855
1856 QString advise_file = settings.value("adviseScript").toString();
1857 if ( !advise_file.isEmpty() ) {
1858 QFile advisefile(settings.value("adviseScript").toString());
1859 if (!advisefile.exists()) ((bncApp*)qApp)->slotMessage("Cannot find Outages script", true);
1860 }
1861
1862 QString ant_file = settings.value("pppAntex").toString();
1863 if ( !ant_file.isEmpty() ) {
1864 QFile anxfile(settings.value("pppAntex").toString());
1865 if (!anxfile.exists()) ((bncApp*)qApp)->slotMessage("Cannot find IGS ANTEX file", true);
1866 }
1867
1868 _caster->readMountPoints();
1869
1870 _casterEph = new bncEphUploadCaster();
1871 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
1872 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
1873}
1874
1875// Retrieve Data
1876////////////////////////////////////////////////////////////////////////////
1877void bncWindow::slotStop() {
1878 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving data?",
1879 QMessageBox::Yes, QMessageBox::No,
1880 QMessageBox::NoButton);
1881 if (iRet == QMessageBox::Yes) {
1882 ((bncApp*)qApp)->stopCombination();
1883 delete _caster; _caster = 0;
1884 delete _casterEph; _casterEph = 0;
1885 _runningRealTime = false;
1886 enableStartStop();
1887 }
1888}
1889
1890// Close Application gracefully
1891////////////////////////////////////////////////////////////////////////////
1892void bncWindow::closeEvent(QCloseEvent* event) {
1893
1894 int iRet = QMessageBox::question(this, "Close", "Save Options?",
1895 QMessageBox::Yes, QMessageBox::No,
1896 QMessageBox::Cancel);
1897
1898 if (iRet == QMessageBox::Cancel) {
1899 event->ignore();
1900 return;
1901 }
1902 else if (iRet == QMessageBox::Yes) {
1903 slotSaveOptions();
1904 }
1905
1906 QMainWindow::closeEvent(event);
1907}
1908
1909// User changed the selection of mountPoints
1910////////////////////////////////////////////////////////////////////////////
1911void bncWindow::slotSelectionChanged() {
1912 if (_mountPointsTable->selectedItems().isEmpty()) {
1913 _actDeleteMountPoints->setEnabled(false);
1914 }
1915 else {
1916 _actDeleteMountPoints->setEnabled(true);
1917 }
1918}
1919
1920// Display Program Messages
1921////////////////////////////////////////////////////////////////////////////
1922void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
1923
1924#ifdef DEBUG_RTCM2_2021
1925 const int maxBufferSize = 1000;
1926#else
1927 const int maxBufferSize = 10000;
1928#endif
1929
1930 if (! showOnScreen ) {
1931 return;
1932 }
1933
1934 QString txt = _log->toPlainText() + "\n" +
1935 QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg;
1936 _log->clear();
1937 _log->append(txt.right(maxBufferSize));
1938}
1939
1940// About Message
1941////////////////////////////////////////////////////////////////////////////
1942void bncWindow::slotAbout() {
1943 new bncAboutDlg(0);
1944}
1945
1946//Flowchart
1947////////////////////////////////////////////////////////////////////////////
1948void bncWindow::slotFlowchart() {
1949 new bncFlowchartDlg(0);
1950}
1951
1952// Help Window
1953////////////////////////////////////////////////////////////////////////////
1954void bncWindow::slotHelp() {
1955 QUrl url;
1956 url.setPath(":bnchelp.html");
1957 new bncHlpDlg(0, url);
1958}
1959
1960// Select Fonts
1961////////////////////////////////////////////////////////////////////////////
1962void bncWindow::slotFontSel() {
1963 bool ok;
1964 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
1965 if (ok) {
1966 bncSettings settings;
1967 settings.setValue("font", newFont.toString());
1968 QApplication::setFont(newFont);
1969 int ww = QFontMetrics(newFont).width('w');
1970 setMinimumSize(60*ww, 80*ww);
1971 resize(60*ww, 80*ww);
1972 }
1973}
1974
1975// Whats This Help
1976void bncWindow::slotWhatsThis() {
1977 QWhatsThis::enterWhatsThisMode();
1978}
1979
1980//
1981////////////////////////////////////////////////////////////////////////////
1982void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
1983 _bncFigure->updateMountPoints();
1984 _bncFigureLate->updateMountPoints();
1985
1986 populateMountPointsTable();
1987 bncSettings settings;
1988 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
1989 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
1990 QListIterator<bncGetThread*> iTh(threads);
1991 while (iTh.hasNext()) {
1992 bncGetThread* thread = iTh.next();
1993 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1994 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1995 "@" + _mountPointsTable->item(iRow, 1)->text() );
1996 if (url == thread->mountPoint() &&
1997 _mountPointsTable->item(iRow, 3)->text() == thread->latitude() &&
1998 _mountPointsTable->item(iRow, 4)->text() == thread->longitude() ) {
1999 ((bncTableItem*) _mountPointsTable->item(iRow, 7))->setGetThread(thread);
2000 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
2001 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2002 connect(thread, SIGNAL(newBytes(QByteArray, double)),
2003 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2004 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
2005 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2006 connect(thread, SIGNAL(newLatency(QByteArray, double)),
2007 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2008 if ( Qt::CheckState(settings.value("pppPlotCoordinates").toInt()) == Qt::Checked) {
2009 disconnect(thread,
2010 SIGNAL(newPosition(bncTime, double, double, double)),
2011 _bncFigurePPP,
2012 SLOT(slotNewPosition(bncTime, double, double, double)));
2013 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2014 _bncFigurePPP,
2015 SLOT(slotNewPosition(bncTime, double, double, double)));
2016 }
2017 break;
2018 }
2019 }
2020 }
2021}
2022
2023//
2024////////////////////////////////////////////////////////////////////////////
2025void bncWindow::CreateMenu() {
2026 // Create Menus
2027 // ------------
2028 _menuFile = menuBar()->addMenu(tr("&File"));
2029 _menuFile->addAction(_actFontSel);
2030 _menuFile->addSeparator();
2031 _menuFile->addAction(_actSaveOpt);
2032 _menuFile->addSeparator();
2033 _menuFile->addAction(_actQuit);
2034
2035 _menuHlp = menuBar()->addMenu(tr("&Help"));
2036 _menuHlp->addAction(_actHelp);
2037 _menuHlp->addAction(_actFlowchart);
2038 _menuHlp->addAction(_actAbout);
2039}
2040
2041// Toolbar
2042////////////////////////////////////////////////////////////////////////////
2043void bncWindow::AddToolbar() {
2044 QToolBar* toolBar = new QToolBar;
2045 addToolBar(Qt::BottomToolBarArea, toolBar);
2046 toolBar->setMovable(false);
2047 toolBar->addAction(_actAddMountPoints);
2048 toolBar->addAction(_actDeleteMountPoints);
2049 toolBar->addAction(_actMap);
2050 toolBar->addAction(_actStart);
2051 toolBar->addAction(_actStop);
2052 toolBar->addWidget(new QLabel(" "));
2053 toolBar->addAction(_actwhatsthis);
2054}
2055
2056// About
2057////////////////////////////////////////////////////////////////////////////
2058bncAboutDlg::bncAboutDlg(QWidget* parent) :
2059 QDialog(parent) {
2060
2061 QTextBrowser* tb = new QTextBrowser;
2062 QUrl url; url.setPath(":bncabout.html");
2063 tb->setSource(url);
2064 tb->setReadOnly(true);
2065
2066 int ww = QFontMetrics(font()).width('w');
2067 QPushButton* _closeButton = new QPushButton("Close");
2068 _closeButton->setMaximumWidth(10*ww);
2069 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2070
2071 QGridLayout* dlgLayout = new QGridLayout();
2072 QLabel* img = new QLabel();
2073 img->setPixmap(QPixmap(":ntrip-logo.png"));
2074 dlgLayout->addWidget(img, 0,0);
2075 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
2076 dlgLayout->addWidget(tb,1,0,1,2);
2077 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2078
2079 setLayout(dlgLayout);
2080 resize(60*ww, 60*ww);
2081 setWindowTitle("About BNC");
2082 show();
2083}
2084
2085//
2086////////////////////////////////////////////////////////////////////////////
2087bncAboutDlg::~bncAboutDlg() {
2088};
2089
2090// Flowchart
2091////////////////////////////////////////////////////////////////////////////
2092bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2093 QDialog(parent) {
2094
2095 int ww = QFontMetrics(font()).width('w');
2096 QPushButton* _closeButton = new QPushButton("Close");
2097 _closeButton->setMaximumWidth(10*ww);
2098 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2099
2100 QGridLayout* dlgLayout = new QGridLayout();
2101 QLabel* img = new QLabel();
2102 img->setPixmap(QPixmap(":bncflowchart.png"));
2103 dlgLayout->addWidget(img, 0,0);
2104 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2105
2106 setLayout(dlgLayout);
2107 setWindowTitle("Flow Chart");
2108 show();
2109}
2110
2111//
2112////////////////////////////////////////////////////////////////////////////
2113bncFlowchartDlg::~bncFlowchartDlg() {
2114};
2115
2116// Enable/Disable Widget (and change its color)
2117////////////////////////////////////////////////////////////////////////////
2118void bncWindow::enableWidget(bool enable, QWidget* widget) {
2119 const static QPalette paletteWhite(QColor(255, 255, 255));
2120 const static QPalette paletteGray(QColor(230, 230, 230));
2121
2122 widget->setEnabled(enable);
2123 if (enable) {
2124 widget->setPalette(paletteWhite);
2125 }
2126 else {
2127 widget->setPalette(paletteGray);
2128 }
2129}
2130
2131// Bnc Text
2132////////////////////////////////////////////////////////////////////////////
2133void bncWindow::slotBncTextChanged(){
2134
2135 bool enable = true;
2136
2137 // Proxy
2138 //------
2139 if (sender() == 0 || sender() == _proxyHostLineEdit) {
2140 enable = !_proxyHostLineEdit->text().isEmpty();
2141 enableWidget(enable, _proxyPortLineEdit);
2142 }
2143
2144 // RINEX Observations
2145 // ------------------
2146 if (sender() == 0 || sender() == _rnxPathLineEdit) {
2147 enable = !_rnxPathLineEdit->text().isEmpty();
2148 enableWidget(enable, _rnxSamplSpinBox);
2149 enableWidget(enable, _rnxSkelLineEdit);
2150 enableWidget(enable, _rnxScrpLineEdit);
2151 enableWidget(enable, _rnxV3CheckBox);
2152 enableWidget(enable, _rnxIntrComboBox);
2153 }
2154
2155 // RINEX Ephemeris
2156 // ---------------
2157 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _outEphPortLineEdit) {
2158 enable = !_ephPathLineEdit->text().isEmpty() || !_outEphPortLineEdit->text().isEmpty();
2159 enableWidget(enable, _ephIntrComboBox);
2160 enableWidget(enable, _ephV3CheckBox);
2161 }
2162
2163 // Broadcast Corrections
2164 // ---------------------
2165 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2166 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2167 enableWidget(enable, _corrIntrComboBox);
2168 }
2169
2170 // Feed Engine
2171 // -----------
2172 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2173 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2174 enableWidget(enable, _waitTimeSpinBox);
2175 enableWidget(enable, _binSamplSpinBox);
2176 }
2177
2178 // Serial Output
2179 // -------------
2180 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
2181 sender() == _serialAutoNMEAComboBox) {
2182 enable = !_serialMountPointLineEdit->text().isEmpty();
2183 enableWidget(enable, _serialPortNameLineEdit);
2184 enableWidget(enable, _serialBaudRateComboBox);
2185 enableWidget(enable, _serialParityComboBox);
2186 enableWidget(enable, _serialDataBitsComboBox);
2187 enableWidget(enable, _serialStopBitsComboBox);
2188 enableWidget(enable, _serialFlowControlComboBox);
2189 enableWidget(enable, _serialAutoNMEAComboBox);
2190
2191 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() != "Auto";
2192 enableWidget(enable2, _serialFileNMEALineEdit);
2193 }
2194
2195 // Outages
2196 // -------
2197 if (sender() == 0 || sender() == _obsRateComboBox) {
2198 enable = !_obsRateComboBox->currentText().isEmpty();
2199 enableWidget(enable, _adviseFailSpinBox);
2200 enableWidget(enable, _adviseRecoSpinBox);
2201 enableWidget(enable, _adviseScriptLineEdit);
2202 }
2203
2204 // Miscellaneous
2205 // -------------
2206 if (sender() == 0 || sender() == _miscMountLineEdit) {
2207 enable = !_miscMountLineEdit->text().isEmpty();
2208 enableWidget(enable, _perfIntrComboBox);
2209 enableWidget(enable, _scanRTCMCheckBox);
2210 }
2211
2212 // Enable/disable Broadcast Ephemerides
2213 // ------------------------------------
2214 if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2215 if (!_uploadEphHostLineEdit->text().isEmpty()) {
2216 _uploadEphPortLineEdit->setStyleSheet("background-color: white");
2217 _uploadEphMountpointLineEdit->setStyleSheet("background-color: white");
2218 _uploadEphPasswordLineEdit->setStyleSheet("background-color: white");
2219 _uploadEphSampleSpinBox->setStyleSheet("background-color: white");
2220 _uploadEphPortLineEdit->setEnabled(true);
2221 _uploadEphMountpointLineEdit->setEnabled(true);
2222 _uploadEphPasswordLineEdit->setEnabled(true);
2223 _uploadEphSampleSpinBox->setEnabled(true);
2224 }
2225 else {
2226 _uploadEphPortLineEdit->setStyleSheet("background-color: lightGray");
2227 _uploadEphMountpointLineEdit->setStyleSheet("background-color: lightGray");
2228 _uploadEphPasswordLineEdit->setStyleSheet("background-color: lightGray");
2229 _uploadEphSampleSpinBox->setStyleSheet("background-color: lightGray");
2230 _uploadEphPortLineEdit->setEnabled(false);
2231 _uploadEphMountpointLineEdit->setEnabled(false);
2232 _uploadEphPasswordLineEdit->setEnabled(false);
2233 _uploadEphSampleSpinBox->setEnabled(false);
2234 }
2235 }
2236
2237 // Combine Corrections
2238 // -------------------
2239 if (sender() == 0 || sender() == _cmbTable) {
2240 int iRow = _cmbTable->rowCount();
2241 if (iRow > 0) {
2242 enableWidget(true, _cmbMethodComboBox);
2243 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
2244 _cmbMaxresLineEdit->setEnabled(true);
2245 _cmbSamplSpinBox->setEnabled(true);
2246 }
2247 else {
2248 enableWidget(false, _cmbMethodComboBox);
2249 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2250 _cmbMaxresLineEdit->setEnabled(false);
2251 _cmbSamplSpinBox->setEnabled(false);
2252 }
2253 }
2254
2255 // Upload(clk)
2256 // -----------
2257 int iRow = _uploadTable->rowCount();
2258 if (iRow > 0) {
2259 enableWidget(true, _uploadIntrComboBox);
2260 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2261 enableWidget(true, _uploadSamplClkRnxSpinBox);
2262 enableWidget(true, _uploadSamplSp3SpinBox);
2263 }
2264 else {
2265 enableWidget(false, _uploadIntrComboBox);
2266 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2267 enableWidget(false, _uploadSamplClkRnxSpinBox);
2268 enableWidget(false, _uploadSamplSp3SpinBox);
2269 }
2270
2271 // PPP Client
2272 // ----------
2273 if (sender() == 0
2274 || sender() == _pppMountLineEdit
2275 || sender() == _pppCorrMountLineEdit
2276 || sender() == _pppRefCrdXLineEdit
2277 || sender() == _pppRefCrdYLineEdit
2278 || sender() == _pppRefCrdZLineEdit
2279 || sender() == _pppRefdNLineEdit
2280 || sender() == _pppRefdELineEdit
2281 || sender() == _pppRefdULineEdit
2282 || sender() == _pppSync
2283 || sender() == _pppSPPComboBox
2284 || sender() == _pppQuickStartLineEdit
2285 || sender() == _pppEstTropoCheckBox
2286 || sender() == _pppUsePhaseCheckBox
2287 || sender() == _pppAntexFileChooser ) {
2288
2289 enable = !_pppSPPComboBox->currentText().isEmpty();
2290 if (enable) {
2291 enable = (!_pppMountLineEdit->text().isEmpty() && !_pppCorrMountLineEdit->text().isEmpty()) ||
2292 (!_pppMountLineEdit->text().isEmpty() && _pppSPPComboBox->currentText() == "Realtime-SPP") ||
2293 (_pppSPPComboBox->currentText() == "Post-Processing");
2294 }
2295
2296 enableWidget(enable, _pppNMEALineEdit);
2297 enableWidget(enable, _pppNMEAPortLineEdit);
2298 enableWidget(enable, _pppRefCrdXLineEdit);
2299 enableWidget(enable, _pppRefCrdYLineEdit);
2300 enableWidget(enable, _pppRefCrdZLineEdit);
2301 enableWidget(enable, _pppRefdNLineEdit);
2302 enableWidget(enable, _pppRefdELineEdit);
2303 enableWidget(enable, _pppRefdULineEdit);
2304 enableWidget(enable, _pppUsePhaseCheckBox);
2305 enableWidget(enable, _pppPlotCoordinates);
2306 enableWidget(enable, _pppEstTropoCheckBox);
2307// enableWidget(enable, _pppGLONASSCheckBox);
2308 enableWidget(enable, _pppGalileoCheckBox);
2309// enableWidget(enable, _pppAntexFileChooser);
2310 enableWidget(enable, _pppSigCLineEdit);
2311 enableWidget(enable, _pppSigCrd0);
2312 enableWidget(enable, _pppSigCrdP);
2313
2314 bool enable2 = enable && !_pppRefCrdXLineEdit->text().isEmpty() &&
2315 !_pppRefCrdYLineEdit->text().isEmpty() &&
2316 !_pppRefCrdZLineEdit->text().isEmpty();
2317
2318 enableWidget(enable2, _pppAverageLineEdit);
2319 enableWidget(enable2, _pppQuickStartLineEdit);
2320
2321 bool enable3 = enable2 && !_pppQuickStartLineEdit->text().isEmpty();
2322 enableWidget(enable3, _pppMaxSolGapLineEdit);
2323 enableWidget(enable3, _pppAudioResponseLineEdit);
2324
2325 bool enable4 = enable && !_pppAntexFileChooser->fileName().isEmpty();
2326 enableWidget(enable4, _pppAntennaLineEdit);
2327
2328 bool enable5 = enable && _pppEstTropoCheckBox->isChecked();
2329 enableWidget(enable5, _pppSigTrp0);
2330 enableWidget(enable5, _pppSigTrpP);
2331
2332 bool enable6 = enable && _pppUsePhaseCheckBox->isChecked();
2333 enableWidget(enable6, _pppSigPLineEdit);
2334
2335 bool enable7 = enable && _pppSPPComboBox->currentText() == "Realtime-PPP";
2336 enableWidget(enable7, _pppSync);
2337
2338 bool enable8 = _pppSPPComboBox->currentText() == "Realtime-PPP";
2339 enableWidget(enable8, _pppCorrMountLineEdit);
2340
2341 bool enable9 = _pppSPPComboBox->currentText() == "Post-Processing";
2342 enableWidget(enable9, _postObsFileChooser);
2343 enableWidget(enable9, _postNavFileChooser);
2344 enableWidget(enable9, _postCorrFileChooser);
2345 enableWidget(enable9, _postOutLineEdit);
2346
2347 bool enable10 = !_pppSPPComboBox->currentText().isEmpty() && !enable9;
2348 enableWidget(enable10, _pppMountLineEdit);
2349 }
2350
2351 if (sender() == 0 || sender() == _reqcActionComboBox) {
2352 enable = !_reqcActionComboBox->currentText().isEmpty();
2353 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2354 enableWidget(enable && enable10, _reqcEditOptionButton);
2355 enableWidget(enable, _reqcObsFileChooser);
2356 enableWidget(enable, _reqcNavFileChooser);
2357 enableWidget(enable && enable10, _reqcOutObsLineEdit);
2358 enableWidget(enable && enable10, _reqcOutNavLineEdit);
2359 enableWidget(enable, _reqcOutLogLineEdit);
2360 enableWidget(enable && !enable10, _reqcPlotDirLineEdit);
2361 }
2362
2363 enableStartStop();
2364}
2365
2366//
2367////////////////////////////////////////////////////////////////////////////
2368void bncWindow::slotAddCmbRow() {
2369 int iRow = _cmbTable->rowCount();
2370 _cmbTable->insertRow(iRow);
2371 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2372 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2373 }
2374}
2375
2376//
2377////////////////////////////////////////////////////////////////////////////
2378void bncWindow::slotDelCmbRow() {
2379 int nRows = _cmbTable->rowCount();
2380 bool flg[nRows];
2381 for (int iRow = 0; iRow < nRows; iRow++) {
2382 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2383 flg[iRow] = true;
2384 }
2385 else {
2386 flg[iRow] = false;
2387 }
2388 }
2389 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2390 if (flg[iRow]) {
2391 _cmbTable->removeRow(iRow);
2392 }
2393 }
2394 nRows = _cmbTable->rowCount();
2395 if (nRows < 1) {
2396 enableWidget(false, _cmbMethodComboBox);
2397 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2398 _cmbMaxresLineEdit->setEnabled(false);
2399 _cmbSamplSpinBox->setEnabled(false);
2400 }
2401}
2402
2403//
2404////////////////////////////////////////////////////////////////////////////
2405void bncWindow::populateCmbTable() {
2406
2407 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2408 _cmbTable->removeRow(iRow);
2409 }
2410
2411 bncSettings settings;
2412
2413 int iRow = -1;
2414 QListIterator<QString> it(settings.value("combineStreams").toStringList());
2415 while (it.hasNext()) {
2416 QStringList hlp = it.next().split(" ");
2417 if (hlp.size() > 2) {
2418 ++iRow;
2419 _cmbTable->insertRow(iRow);
2420 }
2421 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2422 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2423 }
2424 }
2425}
2426
2427//
2428////////////////////////////////////////////////////////////////////////////
2429void bncWindow::slotAddUploadRow() {
2430 int iRow = _uploadTable->rowCount();
2431 _uploadTable->insertRow(iRow);
2432 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2433 if (iCol == 3) {
2434 QLineEdit* passwd = new QLineEdit();
2435 passwd->setFrame(false);
2436 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2437 _uploadTable->setCellWidget(iRow, iCol, passwd);
2438 }
2439 else if (iCol == 4) {
2440 QComboBox* system = new QComboBox();
2441 system->setEditable(false);
2442 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,Custom").split(","));
2443 system->setFrame(false);
2444 _uploadTable->setCellWidget(iRow, iCol, system);
2445 }
2446 else if (iCol == 5) {
2447 QCheckBox* com = new QCheckBox();
2448 _uploadTable->setCellWidget(iRow, iCol, com);
2449 }
2450 else if (iCol == 11) {
2451 bncTableItem* bncIt = new bncTableItem();
2452 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2453 _uploadTable->setItem(iRow, iCol, bncIt);
2454 ((bncApp*)qApp)->_uploadTableItems[iRow] = bncIt;
2455 }
2456 else {
2457 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2458 }
2459 }
2460}
2461
2462//
2463////////////////////////////////////////////////////////////////////////////
2464void bncWindow::slotDelUploadRow() {
2465 ((bncApp*)qApp)->_uploadTableItems.clear();
2466 int nRows = _uploadTable->rowCount();
2467 bool flg[nRows];
2468 for (int iRow = 0; iRow < nRows; iRow++) {
2469 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2470 flg[iRow] = true;
2471 }
2472 else {
2473 flg[iRow] = false;
2474 }
2475 }
2476 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2477 if (flg[iRow]) {
2478 _uploadTable->removeRow(iRow);
2479 }
2480 }
2481 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2482 ((bncApp*)qApp)->_uploadTableItems[iRow] =
2483 (bncTableItem*) _uploadTable->item(iRow, 11);
2484 }
2485 nRows = _uploadTable->rowCount();
2486 if (nRows < 1) {
2487 enableWidget(false, _uploadIntrComboBox);
2488 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2489 enableWidget(false, _uploadSamplSp3SpinBox);
2490 enableWidget(false, _uploadSamplClkRnxSpinBox);
2491 }
2492}
2493
2494//
2495////////////////////////////////////////////////////////////////////////////
2496void bncWindow::populateUploadTable() {
2497 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2498 _uploadTable->removeRow(iRow);
2499 }
2500
2501 bncSettings settings;
2502
2503 int iRow = -1;
2504 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2505 while (it.hasNext()) {
2506 QStringList hlp = it.next().split(",");
2507 if (hlp.size() > 6) {
2508 ++iRow;
2509 _uploadTable->insertRow(iRow);
2510 }
2511 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2512 if (iCol == 3) {
2513 QLineEdit* passwd = new QLineEdit();
2514 passwd->setFrame(false);
2515 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2516 passwd->setText(hlp[iCol]);
2517 _uploadTable->setCellWidget(iRow, iCol, passwd);
2518 }
2519 else if (iCol == 4) {
2520 QComboBox* system = new QComboBox();
2521 system->setEditable(false);
2522 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,Custom").split(","));
2523 system->setFrame(false);
2524 system->setCurrentIndex(system->findText(hlp[iCol]));
2525 _uploadTable->setCellWidget(iRow, iCol, system);
2526 }
2527 else if (iCol == 5) {
2528 QCheckBox* com = new QCheckBox();
2529 if (hlp[iCol].toInt() == Qt::Checked) {
2530 com->setCheckState(Qt::Checked);
2531 }
2532 _uploadTable->setCellWidget(iRow, iCol, com);
2533 }
2534 else if (iCol == 11) {
2535 bncTableItem* bncIt = new bncTableItem();
2536 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2537 _uploadTable->setItem(iRow, iCol, bncIt);
2538 ((bncApp*)qApp)->_uploadTableItems[iRow] = bncIt;
2539 }
2540 else {
2541 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2542 }
2543 }
2544 }
2545}
2546
2547//
2548////////////////////////////////////////////////////////////////////////////
2549void bncWindow::slotSetUploadTrafo() {
2550 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2551 dlg->exec();
2552 delete dlg;
2553}
2554
2555// Start Post-Processing PPP
2556////////////////////////////////////////////////////////////////////////////
2557void bncWindow::startPostProcessingPPP() {
2558#ifdef USE_POSTPROCESSING
2559 _runningPostProcessingPPP = true;
2560 _actStart->setText("0 Epochs");
2561 enableStartStop();
2562
2563 t_postProcessing* postProcessing = new t_postProcessing(this);
2564 connect(postProcessing, SIGNAL(finished()), this, SLOT(slotFinishedPostProcessingPPP()));
2565 connect(postProcessing, SIGNAL(progress(int)), this, SLOT(slotPostProgress(int)));
2566
2567 postProcessing->start();
2568#else
2569 QMessageBox::information(this, "Information",
2570 "Post-Processing Not Permitted");
2571#endif
2572}
2573
2574// Post-Processing PPP Finished
2575////////////////////////////////////////////////////////////////////////////
2576void bncWindow::slotFinishedPostProcessingPPP() {
2577 _runningPostProcessingPPP = false;
2578 QMessageBox::information(this, "Information",
2579 "Post-Processing Thread Finished");
2580 _actStart->setText("Start");
2581 enableStartStop();
2582}
2583
2584// Progress Bar Change
2585////////////////////////////////////////////////////////////////////////////
2586void bncWindow::slotPostProgress(int nEpo) {
2587 if (_actStart) {
2588 _actStart->setText(QString("%1 Epochs").arg(nEpo));
2589 }
2590}
2591
2592// Start Post-Processing Reqc
2593////////////////////////////////////////////////////////////////////////////
2594void bncWindow::startPostProcessingReqc() {
2595#ifdef USE_POSTPROCESSING
2596 _runningPostProcessingReqc = true;
2597 enableStartStop();
2598 if (_reqcActionComboBox->currentText() == "Analyze") {
2599 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
2600 connect(reqcAnalyze, SIGNAL(finished()),
2601 this, SLOT(slotFinishedPostProcessingReqc()));
2602 reqcAnalyze->start();
2603 }
2604 else {
2605 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
2606 connect(reqcEdit, SIGNAL(finished()),
2607 this, SLOT(slotFinishedPostProcessingReqc()));
2608 reqcEdit->start();
2609 }
2610#else
2611 QMessageBox::information(this, "Information",
2612 "Post-Processing Not Permitted");
2613#endif
2614}
2615
2616// Post-Processing Reqc Finished
2617////////////////////////////////////////////////////////////////////////////
2618void bncWindow::slotFinishedPostProcessingReqc() {
2619 _runningPostProcessingReqc = false;
2620 if (_reqcActionComboBox->currentText() != "Analyze") {
2621 QMessageBox::information(this, "Information",
2622 "RINEX Processing Thread Finished");
2623 }
2624 enableStartStop();
2625}
2626
2627// Edit teqc-like editing options
2628////////////////////////////////////////////////////////////////////////////
2629void bncWindow::slotReqcEditOption() {
2630 reqcDlg* dlg = new reqcDlg(this);
2631 dlg->move(this->pos().x()+50, this->pos().y()+50);
2632 dlg->exec();
2633 delete dlg;
2634}
2635
2636// Enable/Disable Start and Stop Buttons
2637////////////////////////////////////////////////////////////////////////////
2638void bncWindow::enableStartStop() {
2639
2640 if ( _pppSPPComboBox && _pppSPPComboBox->currentText() == "Post-Processing" ) {
2641 if (_runningPostProcessingPPP) {
2642 _actStart->setEnabled(false);
2643 }
2644 else {
2645 _actStart->setEnabled(true);
2646 }
2647 _actStop->setEnabled(false);
2648 }
2649 else if ( _reqcActionComboBox && !_reqcActionComboBox->currentText().isEmpty() ) {
2650 if (_runningPostProcessingReqc) {
2651 _actStart->setEnabled(false);
2652 }
2653 else {
2654 _actStart->setEnabled(true);
2655 }
2656 _actStop->setEnabled(false);
2657 }
2658 else {
2659 if (_runningRealTime) {
2660 _actStart->setEnabled(false);
2661 _actStop->setEnabled(true);
2662 }
2663 else {
2664 _actStop->setEnabled(false);
2665 if (_mountPointsTable->rowCount() == 0) {
2666 _actStart->setEnabled(false);
2667 }
2668 else {
2669 _actStart->setEnabled(true);
2670 }
2671 }
2672 }
2673}
2674
2675// Show Map
2676////////////////////////////////////////////////////////////////////////////
2677void bncWindow::slotMap() {
2678 saveOptions();
2679 t_bncMap* bncMap = new t_bncMap(this);
2680 bncMap->setMinimumSize(800, 600);
2681 bncMap->setWindowTitle("Selected Mountpoints");
2682
2683 bncSettings settings;
2684 QListIterator<QString> it(settings.value("mountPoints").toStringList());
2685 while (it.hasNext()) {
2686 QStringList hlp = it.next().split(" ");
2687 if (hlp.size() < 5) continue;
2688 QUrl url(hlp[0]);
2689 double latDeg = hlp[2].toDouble();
2690 double lonDeg = hlp[3].toDouble();
2691 bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
2692 }
2693
2694 bncMap->show();
2695}
Note: See TracBrowser for help on using the repository browser.