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

Last change on this file since 4646 was 4646, checked in by mervart, 12 years ago
File size: 138.8 KB
Line 
1// Part of BNC, a utility for retrieving decoding and
2// converting GNSS data streams from NTRIP broadcasters.
3//
4// Copyright (C) 2007
5// German Federal Agency for Cartography and Geodesy (BKG)
6// http://www.bkg.bund.de
7// Czech Technical University Prague, Department of Geodesy
8// http://www.fsv.cvut.cz
9//
10// Email: euref-ip@bkg.bund.de
11//
12// This program is free software; you can redistribute it and/or
13// modify it under the terms of the GNU General Public License
14// as published by the Free Software Foundation, version 2.
15//
16// This program is distributed in the hope that it will be useful,
17// but WITHOUT ANY WARRANTY; without even the implied warranty of
18// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19// GNU General Public License for more details.
20//
21// You should have received a copy of the GNU General Public License
22// along with this program; if not, write to the Free Software
23// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24
25/* -------------------------------------------------------------------------
26 * BKG NTRIP Client
27 * -------------------------------------------------------------------------
28 *
29 * Class: bncWindow
30 *
31 * Purpose: This class implements the main application window.
32 *
33 * Author: L. Mervart
34 *
35 * Created: 24-Dec-2005
36 *
37 * Changes:
38 *
39 * -----------------------------------------------------------------------*/
40
41#include <iostream>
42
43#include <unistd.h>
44#include "bncwindow.h"
45#include "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 // Enable/Disable all Widgets
1318 // --------------------------
1319 slotBncTextChanged();
1320 enableStartStop();
1321
1322 // Auto start
1323 // ----------
1324 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1325 slotStart();
1326 }
1327}
1328
1329// Destructor
1330////////////////////////////////////////////////////////////////////////////
1331bncWindow::~bncWindow() {
1332 delete _caster;
1333 delete _casterEph;
1334}
1335
1336//
1337////////////////////////////////////////////////////////////////////////////
1338void bncWindow::populateMountPointsTable() {
1339
1340 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1341 _mountPointsTable->removeRow(iRow);
1342 }
1343
1344 bncSettings settings;
1345
1346 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1347 int iRow = 0;
1348 while (it.hasNext()) {
1349 QStringList hlp = it.next().split(" ");
1350 if (hlp.size() < 5) continue;
1351 _mountPointsTable->insertRow(iRow);
1352
1353 QUrl url(hlp[0]);
1354
1355 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1356 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1357 QString nmea(hlp[4]);
1358 if (hlp[5] == "S") {
1359 fullPath = hlp[0].replace(0,2,"");
1360 }
1361 QString ntripVersion = "2";
1362 if (hlp.size() >= 6) {
1363 ntripVersion = (hlp[5]);
1364 }
1365
1366 QTableWidgetItem* it;
1367 it = new QTableWidgetItem(url.userInfo());
1368 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1369 _mountPointsTable->setItem(iRow, 0, it);
1370
1371 it = new QTableWidgetItem(fullPath);
1372 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1373 _mountPointsTable->setItem(iRow, 1, it);
1374
1375 it = new QTableWidgetItem(format);
1376 _mountPointsTable->setItem(iRow, 2, it);
1377
1378 if (nmea == "yes") {
1379 it = new QTableWidgetItem(latitude);
1380 _mountPointsTable->setItem(iRow, 3, it);
1381 it = new QTableWidgetItem(longitude);
1382 _mountPointsTable->setItem(iRow, 4, it);
1383 } else {
1384 it = new QTableWidgetItem(latitude);
1385 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1386 _mountPointsTable->setItem(iRow, 3, it);
1387 it = new QTableWidgetItem(longitude);
1388 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1389 _mountPointsTable->setItem(iRow, 4, it);
1390 }
1391
1392 it = new QTableWidgetItem(nmea);
1393 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1394 _mountPointsTable->setItem(iRow, 5, it);
1395
1396 it = new QTableWidgetItem(ntripVersion);
1397 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1398 _mountPointsTable->setItem(iRow, 6, it);
1399
1400 bncTableItem* bncIt = new bncTableItem();
1401 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1402 _mountPointsTable->setItem(iRow, 7, bncIt);
1403
1404 iRow++;
1405 }
1406
1407 _mountPointsTable->sortItems(1);
1408
1409 enableStartStop();
1410}
1411
1412// Retrieve Table
1413////////////////////////////////////////////////////////////////////////////
1414void bncWindow::slotAddMountPoints() {
1415
1416 bncSettings settings;
1417 QString proxyHost = settings.value("proxyHost").toString();
1418 int proxyPort = settings.value("proxyPort").toInt();
1419 if (proxyHost != _proxyHostLineEdit->text() ||
1420 proxyPort != _proxyPortLineEdit->text().toInt()) {
1421 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1422 "changed. Use the new ones?",
1423 QMessageBox::Yes, QMessageBox::No,
1424 QMessageBox::NoButton);
1425 if (iRet == QMessageBox::Yes) {
1426 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1427 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1428 }
1429 }
1430
1431 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1432 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1433
1434 QMessageBox msgBox;
1435 msgBox.setIcon(QMessageBox::Question);
1436 msgBox.setWindowTitle("Add Stream");
1437 msgBox.setText("Add stream(s) coming from:");
1438
1439 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1440 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1441 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1442 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1443 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1444
1445 msgBox.exec();
1446
1447 if (msgBox.clickedButton() == buttonNtrip) {
1448 bncTableDlg* dlg = new bncTableDlg(this);
1449 dlg->move(this->pos().x()+50, this->pos().y()+50);
1450 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1451 this, SLOT(slotNewMountPoints(QStringList*)));
1452 dlg->exec();
1453 delete dlg;
1454 } else if (msgBox.clickedButton() == buttonIP) {
1455 bncIpPort* ipp = new bncIpPort(this);
1456 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1457 this, SLOT(slotNewMountPoints(QStringList*)));
1458 ipp->exec();
1459 delete ipp;
1460 } else if (msgBox.clickedButton() == buttonUDP) {
1461 bncUdpPort* udp = new bncUdpPort(this);
1462 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1463 this, SLOT(slotNewMountPoints(QStringList*)));
1464 udp->exec();
1465 delete udp;
1466 } else if (msgBox.clickedButton() == buttonSerial) {
1467 bncSerialPort* sep = new bncSerialPort(this);
1468 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1469 this, SLOT(slotNewMountPoints(QStringList*)));
1470 sep->exec();
1471 delete sep;
1472 } else if (msgBox.clickedButton() == buttonCancel) {
1473 // Cancel
1474 }
1475
1476 enableStartStop();
1477}
1478
1479// Delete Selected Mount Points
1480////////////////////////////////////////////////////////////////////////////
1481void bncWindow::slotDeleteMountPoints() {
1482
1483 int nRows = _mountPointsTable->rowCount();
1484 bool flg[nRows];
1485 for (int iRow = 0; iRow < nRows; iRow++) {
1486 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1487 flg[iRow] = true;
1488 }
1489 else {
1490 flg[iRow] = false;
1491 }
1492 }
1493 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1494 if (flg[iRow]) {
1495 _mountPointsTable->removeRow(iRow);
1496 }
1497 }
1498 _actDeleteMountPoints->setEnabled(false);
1499
1500 enableStartStop();
1501}
1502
1503// New Mount Points Selected
1504////////////////////////////////////////////////////////////////////////////
1505void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1506 int iRow = 0;
1507 QListIterator<QString> it(*mountPoints);
1508 while (it.hasNext()) {
1509 QStringList hlp = it.next().split(" ");
1510 QUrl url(hlp[0]);
1511 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1512 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1513 QString nmea(hlp[4]);
1514 if (hlp[5] == "S") {
1515 fullPath = hlp[0].replace(0,2,"");
1516 }
1517 QString ntripVersion = "2";
1518 if (hlp.size() >= 6) {
1519 ntripVersion = (hlp[5]);
1520 }
1521
1522 _mountPointsTable->insertRow(iRow);
1523
1524 QTableWidgetItem* it;
1525 it = new QTableWidgetItem(url.userInfo());
1526 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1527 _mountPointsTable->setItem(iRow, 0, it);
1528
1529 it = new QTableWidgetItem(fullPath);
1530 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1531 _mountPointsTable->setItem(iRow, 1, it);
1532
1533 it = new QTableWidgetItem(format);
1534 _mountPointsTable->setItem(iRow, 2, it);
1535
1536 if (nmea == "yes") {
1537 it = new QTableWidgetItem(latitude);
1538 _mountPointsTable->setItem(iRow, 3, it);
1539 it = new QTableWidgetItem(longitude);
1540 _mountPointsTable->setItem(iRow, 4, it);
1541 } else {
1542 it = new QTableWidgetItem(latitude);
1543 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1544 _mountPointsTable->setItem(iRow, 3, it);
1545 it = new QTableWidgetItem(longitude);
1546 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1547 _mountPointsTable->setItem(iRow, 4, it);
1548 }
1549
1550 it = new QTableWidgetItem(nmea);
1551 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1552 _mountPointsTable->setItem(iRow, 5, it);
1553
1554 it = new QTableWidgetItem(ntripVersion);
1555 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1556 _mountPointsTable->setItem(iRow, 6, it);
1557
1558 bncTableItem* bncIt = new bncTableItem();
1559 _mountPointsTable->setItem(iRow, 7, bncIt);
1560
1561 iRow++;
1562 }
1563 _mountPointsTable->hideColumn(0);
1564 _mountPointsTable->sortItems(1);
1565 delete mountPoints;
1566
1567 enableStartStop();
1568}
1569
1570// Save Options (serialize)
1571////////////////////////////////////////////////////////////////////////////
1572void bncWindow::slotSaveOptions() {
1573 saveOptions();
1574 bncSettings settings;
1575 settings.sync();
1576}
1577
1578// Save Options (memory only)
1579////////////////////////////////////////////////////////////////////////////
1580void bncWindow::saveOptions() {
1581
1582 QStringList mountPoints;
1583 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1584
1585 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1586 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1587 "@" + _mountPointsTable->item(iRow, 1)->text() );
1588
1589 mountPoints.append(url.toString() + " " +
1590 _mountPointsTable->item(iRow, 2)->text()
1591 + " " + _mountPointsTable->item(iRow, 3)->text()
1592 + " " + _mountPointsTable->item(iRow, 4)->text()
1593 + " " + _mountPointsTable->item(iRow, 5)->text()
1594 + " " + _mountPointsTable->item(iRow, 6)->text());
1595 } else {
1596 mountPoints.append(
1597 "//" + _mountPointsTable->item(iRow, 1)->text()
1598 + " " + _mountPointsTable->item(iRow, 2)->text()
1599 + " " + _mountPointsTable->item(iRow, 3)->text()
1600 + " " + _mountPointsTable->item(iRow, 4)->text()
1601 + " " + _mountPointsTable->item(iRow, 5)->text()
1602 + " " + _mountPointsTable->item(iRow, 6)->text());
1603 }
1604 }
1605
1606 QStringList combineStreams;
1607 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1608 QString hlp;
1609 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1610 if (_cmbTable->item(iRow, iCol)) {
1611 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1612 }
1613 }
1614 if (!hlp.isEmpty()) {
1615 combineStreams << hlp;
1616 }
1617 }
1618
1619 QStringList uploadMountpointsOut;
1620 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1621 QString hlp;
1622 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1623 if (_uploadTable->cellWidget(iRow, iCol) &&
1624 (iCol == 3 || iCol == 4 || iCol == 5)) {
1625 if (iCol == 3) {
1626 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1627 hlp += passwd->text() + ",";
1628 }
1629 else if (iCol == 4) {
1630 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1631 hlp += system->currentText() + ",";
1632 }
1633 else if (iCol == 5) {
1634 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1635 QString state; state.setNum(com->checkState());
1636 hlp += state + ",";
1637 }
1638 }
1639 else if (_uploadTable->item(iRow, iCol)) {
1640 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1641 }
1642 }
1643 if (!hlp.isEmpty()) {
1644 uploadMountpointsOut << hlp;
1645 }
1646 }
1647
1648 bncSettings settings;
1649
1650 settings.setValue("startTab", _aogroup->currentIndex());
1651 settings.setValue("statusTab", _loggroup->currentIndex());
1652 settings.setValue("mountPoints", mountPoints);
1653// Network
1654 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1655 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1656 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1657 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1658// General
1659 settings.setValue("logFile", _logFileLineEdit->text());
1660 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1661 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1662 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1663 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1664// RINEX Observations
1665 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1666 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1667 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1668 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1669 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1670 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1671// RINEX Ephemeris
1672 settings.setValue("ephPath", _ephPathLineEdit->text());
1673 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1674 settings.setValue("outEphPort", _outEphPortLineEdit->text());
1675 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1676// Broadcast Corrections
1677 settings.setValue("corrPath", _corrPathLineEdit->text());
1678 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1679 settings.setValue("corrPort", _corrPortLineEdit->text());
1680 settings.setValue("corrTime", _corrTimeSpinBox->value());
1681// Feed Engine
1682 settings.setValue("outPort", _outPortLineEdit->text());
1683 settings.setValue("waitTime", _waitTimeSpinBox->value());
1684 settings.setValue("binSampl", _binSamplSpinBox->value());
1685 settings.setValue("outFile", _outFileLineEdit->text());
1686 settings.setValue("outUPort", _outUPortLineEdit->text());
1687// Serial Output
1688 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1689 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1690 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1691 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1692 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1693 settings.setValue("serialParity", _serialParityComboBox->currentText());
1694 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1695 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1696 settings.setValue("serialFileNMEA",_serialFileNMEALineEdit->text());
1697 settings.setValue("serialHeightNMEA",_serialHeightNMEALineEdit->text());
1698// Outages
1699 settings.setValue("obsRate", _obsRateComboBox->currentText());
1700 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1701 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1702 settings.setValue("adviseScript",_adviseScriptLineEdit->text());
1703// Miscellaneous
1704 settings.setValue("miscMount", _miscMountLineEdit->text());
1705 settings.setValue("perfIntr", _perfIntrComboBox->currentText());
1706 settings.setValue("scanRTCM", _scanRTCMCheckBox->checkState());
1707// PPPP
1708 settings.setValue("pppSPP", _pppSPPComboBox->currentText());
1709 settings.setValue("pppMount", _pppMountLineEdit->text());
1710 settings.setValue("pppCorrMount",_pppCorrMountLineEdit->text());
1711 settings.setValue("pppRefCrdX", _pppRefCrdXLineEdit->text());
1712 settings.setValue("pppRefCrdY", _pppRefCrdYLineEdit->text());
1713 settings.setValue("pppRefCrdZ", _pppRefCrdZLineEdit->text());
1714 settings.setValue("pppRefdN", _pppRefdNLineEdit->text());
1715 settings.setValue("pppRefdE", _pppRefdELineEdit->text());
1716 settings.setValue("pppRefdU", _pppRefdULineEdit->text());
1717 settings.setValue("nmeaFile", _pppNMEALineEdit->text());
1718 settings.setValue("nmeaPort", _pppNMEAPortLineEdit->text());
1719 settings.setValue("pppPlotCoordinates", _pppPlotCoordinates->checkState());
1720 settings.setValue("postObsFile", _postObsFileChooser->fileName());
1721 settings.setValue("postNavFile", _postNavFileChooser->fileName());
1722 settings.setValue("postCorrFile", _postCorrFileChooser->fileName());
1723 settings.setValue("postOutFile", _postOutLineEdit->text());
1724 settings.setValue("pppAntenna", _pppAntennaLineEdit->text());
1725 settings.setValue("pppAntex", _pppAntexFileChooser->fileName());
1726 settings.setValue("pppUsePhase", _pppUsePhaseCheckBox->checkState());
1727 settings.setValue("pppEstTropo", _pppEstTropoCheckBox->checkState());
1728 settings.setValue("pppGLONASS", _pppGLONASSCheckBox->checkState());
1729 settings.setValue("pppGalileo", _pppGalileoCheckBox->checkState());
1730 settings.setValue("pppSync", _pppSync->text());
1731 settings.setValue("pppAverage", _pppAverageLineEdit->text());
1732 settings.setValue("pppQuickStart", _pppQuickStartLineEdit->text());
1733 settings.setValue("pppMaxSolGap", _pppMaxSolGapLineEdit->text());
1734 settings.setValue("pppAudioResponse", _pppAudioResponseLineEdit->text());
1735 settings.setValue("pppSigmaCode",_pppSigCLineEdit->text());
1736 settings.setValue("pppSigmaPhase",_pppSigPLineEdit->text());
1737 settings.setValue("pppSigCrd0",_pppSigCrd0->text());
1738 settings.setValue("pppSigCrdP",_pppSigCrdP->text());
1739 settings.setValue("pppSigTrp0",_pppSigTrp0->text());
1740 settings.setValue("pppSigTrpP",_pppSigTrpP->text());
1741// Reqc
1742 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1743 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1744 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1745 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1746 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1747 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
1748 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
1749// Combine Corrections
1750 if (!combineStreams.isEmpty()) {
1751 settings.setValue("combineStreams", combineStreams);
1752 }
1753 else {
1754 settings.setValue("combineStreams", "");
1755 }
1756 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1757 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1758 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1759// Upload Corrections
1760 if (!uploadMountpointsOut.isEmpty()) {
1761 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1762 }
1763 else {
1764 settings.setValue("uploadMountpointsOut", "");
1765 }
1766 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1767 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1768 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1769 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
1770// Upload Ephemeris
1771 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1772 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
1773 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
1774 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1775 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
1776 if (_caster) {
1777 _caster->readMountPoints();
1778 }
1779}
1780
1781// All get slots terminated
1782////////////////////////////////////////////////////////////////////////////
1783void bncWindow::slotGetThreadsFinished() {
1784 ((bncApp*)qApp)->slotMessage("All Get Threads Terminated", true);
1785 delete _caster; _caster = 0;
1786 delete _casterEph; _casterEph = 0;
1787 _runningRealTime = false;
1788}
1789
1790// Start It!
1791////////////////////////////////////////////////////////////////////////////
1792void bncWindow::slotStart() {
1793 saveOptions();
1794 if ( _pppSPPComboBox->currentText() == "Post-Processing" ) {
1795 startPostProcessingPPP();
1796 }
1797 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
1798 startPostProcessingReqc();
1799 }
1800 else {
1801 startRealTime();
1802 }
1803}
1804
1805// Start Real-Time (Retrieve Data etc.)
1806////////////////////////////////////////////////////////////////////////////
1807void bncWindow::startRealTime() {
1808
1809 _runningRealTime = true;
1810
1811 _bncFigurePPP->reset();
1812
1813 _actDeleteMountPoints->setEnabled(false);
1814
1815 enableStartStop();
1816
1817 _caster = new bncCaster(_outFileLineEdit->text(),
1818 _outPortLineEdit->text().toInt());
1819
1820 ((bncApp*)qApp)->setPort(_outEphPortLineEdit->text().toInt());
1821 ((bncApp*)qApp)->setPortCorr(_corrPortLineEdit->text().toInt());
1822 ((bncApp*)qApp)->initCombination();
1823
1824 connect(_caster, SIGNAL(getThreadsFinished()),
1825 this, SLOT(slotGetThreadsFinished()));
1826
1827 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
1828 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
1829
1830 ((bncApp*)qApp)->slotMessage("========== Start BNC v" BNCVERSION " =========", true);
1831
1832 bncSettings settings;
1833
1834 QDir rnxdir(settings.value("rnxPath").toString());
1835 if (!rnxdir.exists()) ((bncApp*)qApp)->slotMessage("Cannot find RINEX Observations directory", true);
1836
1837 QString rnx_file = settings.value("rnxScript").toString();
1838 if ( !rnx_file.isEmpty() ) {
1839 QFile rnxfile(settings.value("rnxScript").toString());
1840 if (!rnxfile.exists()) ((bncApp*)qApp)->slotMessage("Cannot find RINEX Observations script", true);
1841 }
1842
1843 QDir ephdir(settings.value("ephPath").toString());
1844 if (!ephdir.exists()) ((bncApp*)qApp)->slotMessage("Cannot find RINEX Ephemeris directory", true);
1845
1846 QDir corrdir(settings.value("corrPath").toString());
1847 if (!corrdir.exists()) ((bncApp*)qApp)->slotMessage("Cannot find Broadcast Corrections directory", true);
1848
1849 QString advise_file = settings.value("adviseScript").toString();
1850 if ( !advise_file.isEmpty() ) {
1851 QFile advisefile(settings.value("adviseScript").toString());
1852 if (!advisefile.exists()) ((bncApp*)qApp)->slotMessage("Cannot find Outages script", true);
1853 }
1854
1855 QString ant_file = settings.value("pppAntex").toString();
1856 if ( !ant_file.isEmpty() ) {
1857 QFile anxfile(settings.value("pppAntex").toString());
1858 if (!anxfile.exists()) ((bncApp*)qApp)->slotMessage("Cannot find IGS ANTEX file", true);
1859 }
1860
1861 _caster->readMountPoints();
1862
1863 _casterEph = new bncEphUploadCaster();
1864 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
1865 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
1866}
1867
1868// Retrieve Data
1869////////////////////////////////////////////////////////////////////////////
1870void bncWindow::slotStop() {
1871 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving data?",
1872 QMessageBox::Yes, QMessageBox::No,
1873 QMessageBox::NoButton);
1874 if (iRet == QMessageBox::Yes) {
1875 ((bncApp*)qApp)->stopCombination();
1876 delete _caster; _caster = 0;
1877 delete _casterEph; _casterEph = 0;
1878 _runningRealTime = false;
1879 enableStartStop();
1880 }
1881}
1882
1883// Close Application gracefully
1884////////////////////////////////////////////////////////////////////////////
1885void bncWindow::closeEvent(QCloseEvent* event) {
1886
1887 int iRet = QMessageBox::question(this, "Close", "Save Options?",
1888 QMessageBox::Yes, QMessageBox::No,
1889 QMessageBox::Cancel);
1890
1891 if (iRet == QMessageBox::Cancel) {
1892 event->ignore();
1893 return;
1894 }
1895 else if (iRet == QMessageBox::Yes) {
1896 slotSaveOptions();
1897 }
1898
1899 QMainWindow::closeEvent(event);
1900}
1901
1902// User changed the selection of mountPoints
1903////////////////////////////////////////////////////////////////////////////
1904void bncWindow::slotSelectionChanged() {
1905 if (_mountPointsTable->selectedItems().isEmpty()) {
1906 _actDeleteMountPoints->setEnabled(false);
1907 }
1908 else {
1909 _actDeleteMountPoints->setEnabled(true);
1910 }
1911}
1912
1913// Display Program Messages
1914////////////////////////////////////////////////////////////////////////////
1915void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
1916
1917#ifdef DEBUG_RTCM2_2021
1918 const int maxBufferSize = 1000;
1919#else
1920 const int maxBufferSize = 10000;
1921#endif
1922
1923 if (! showOnScreen ) {
1924 return;
1925 }
1926
1927 QString txt = _log->toPlainText() + "\n" +
1928 QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg;
1929 _log->clear();
1930 _log->append(txt.right(maxBufferSize));
1931}
1932
1933// About Message
1934////////////////////////////////////////////////////////////////////////////
1935void bncWindow::slotAbout() {
1936 new bncAboutDlg(0);
1937}
1938
1939//Flowchart
1940////////////////////////////////////////////////////////////////////////////
1941void bncWindow::slotFlowchart() {
1942 new bncFlowchartDlg(0);
1943}
1944
1945// Help Window
1946////////////////////////////////////////////////////////////////////////////
1947void bncWindow::slotHelp() {
1948 QUrl url;
1949 url.setPath(":bnchelp.html");
1950 new bncHlpDlg(0, url);
1951}
1952
1953// Select Fonts
1954////////////////////////////////////////////////////////////////////////////
1955void bncWindow::slotFontSel() {
1956 bool ok;
1957 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
1958 if (ok) {
1959 bncSettings settings;
1960 settings.setValue("font", newFont.toString());
1961 QApplication::setFont(newFont);
1962 int ww = QFontMetrics(newFont).width('w');
1963 setMinimumSize(60*ww, 80*ww);
1964 resize(60*ww, 80*ww);
1965 }
1966}
1967
1968// Whats This Help
1969void bncWindow::slotWhatsThis() {
1970 QWhatsThis::enterWhatsThisMode();
1971}
1972
1973//
1974////////////////////////////////////////////////////////////////////////////
1975void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
1976 _bncFigure->updateMountPoints();
1977 _bncFigureLate->updateMountPoints();
1978
1979 populateMountPointsTable();
1980 bncSettings settings;
1981 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
1982 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
1983 QListIterator<bncGetThread*> iTh(threads);
1984 while (iTh.hasNext()) {
1985 bncGetThread* thread = iTh.next();
1986 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1987 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1988 "@" + _mountPointsTable->item(iRow, 1)->text() );
1989 if (url == thread->mountPoint() &&
1990 _mountPointsTable->item(iRow, 3)->text() == thread->latitude() &&
1991 _mountPointsTable->item(iRow, 4)->text() == thread->longitude() ) {
1992 ((bncTableItem*) _mountPointsTable->item(iRow, 7))->setGetThread(thread);
1993 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
1994 _bncFigure, SLOT(slotNewData(QByteArray, double)));
1995 connect(thread, SIGNAL(newBytes(QByteArray, double)),
1996 _bncFigure, SLOT(slotNewData(QByteArray, double)));
1997 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
1998 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
1999 connect(thread, SIGNAL(newLatency(QByteArray, double)),
2000 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2001 if ( Qt::CheckState(settings.value("pppPlotCoordinates").toInt()) == Qt::Checked) {
2002 disconnect(thread,
2003 SIGNAL(newPosition(bncTime, double, double, double)),
2004 _bncFigurePPP,
2005 SLOT(slotNewPosition(bncTime, double, double, double)));
2006 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2007 _bncFigurePPP,
2008 SLOT(slotNewPosition(bncTime, double, double, double)));
2009 }
2010 break;
2011 }
2012 }
2013 }
2014}
2015
2016//
2017////////////////////////////////////////////////////////////////////////////
2018void bncWindow::CreateMenu() {
2019 // Create Menus
2020 // ------------
2021 _menuFile = menuBar()->addMenu(tr("&File"));
2022 _menuFile->addAction(_actFontSel);
2023 _menuFile->addSeparator();
2024 _menuFile->addAction(_actSaveOpt);
2025 _menuFile->addSeparator();
2026 _menuFile->addAction(_actQuit);
2027
2028 _menuHlp = menuBar()->addMenu(tr("&Help"));
2029 _menuHlp->addAction(_actHelp);
2030 _menuHlp->addAction(_actFlowchart);
2031 _menuHlp->addAction(_actAbout);
2032}
2033
2034// Toolbar
2035////////////////////////////////////////////////////////////////////////////
2036void bncWindow::AddToolbar() {
2037 QToolBar* toolBar = new QToolBar;
2038 addToolBar(Qt::BottomToolBarArea, toolBar);
2039 toolBar->setMovable(false);
2040 toolBar->addAction(_actAddMountPoints);
2041 toolBar->addAction(_actDeleteMountPoints);
2042 toolBar->addAction(_actMap);
2043 toolBar->addAction(_actStart);
2044 toolBar->addAction(_actStop);
2045 toolBar->addWidget(new QLabel(" "));
2046 toolBar->addAction(_actwhatsthis);
2047}
2048
2049// About
2050////////////////////////////////////////////////////////////////////////////
2051bncAboutDlg::bncAboutDlg(QWidget* parent) :
2052 QDialog(parent) {
2053
2054 QTextBrowser* tb = new QTextBrowser;
2055 QUrl url; url.setPath(":bncabout.html");
2056 tb->setSource(url);
2057 tb->setReadOnly(true);
2058
2059 int ww = QFontMetrics(font()).width('w');
2060 QPushButton* _closeButton = new QPushButton("Close");
2061 _closeButton->setMaximumWidth(10*ww);
2062 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2063
2064 QGridLayout* dlgLayout = new QGridLayout();
2065 QLabel* img = new QLabel();
2066 img->setPixmap(QPixmap(":ntrip-logo.png"));
2067 dlgLayout->addWidget(img, 0,0);
2068 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
2069 dlgLayout->addWidget(tb,1,0,1,2);
2070 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2071
2072 setLayout(dlgLayout);
2073 resize(60*ww, 60*ww);
2074 setWindowTitle("About BNC");
2075 show();
2076}
2077
2078//
2079////////////////////////////////////////////////////////////////////////////
2080bncAboutDlg::~bncAboutDlg() {
2081};
2082
2083// Flowchart
2084////////////////////////////////////////////////////////////////////////////
2085bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2086 QDialog(parent) {
2087
2088 int ww = QFontMetrics(font()).width('w');
2089 QPushButton* _closeButton = new QPushButton("Close");
2090 _closeButton->setMaximumWidth(10*ww);
2091 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2092
2093 QGridLayout* dlgLayout = new QGridLayout();
2094 QLabel* img = new QLabel();
2095 img->setPixmap(QPixmap(":bncflowchart.png"));
2096 dlgLayout->addWidget(img, 0,0);
2097 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2098
2099 setLayout(dlgLayout);
2100 setWindowTitle("Flow Chart");
2101 show();
2102}
2103
2104//
2105////////////////////////////////////////////////////////////////////////////
2106bncFlowchartDlg::~bncFlowchartDlg() {
2107};
2108
2109// Enable/Disable Widget (and change its color)
2110////////////////////////////////////////////////////////////////////////////
2111void bncWindow::enableWidget(bool enable, QWidget* widget) {
2112 const static QPalette paletteWhite(QColor(255, 255, 255));
2113 const static QPalette paletteGray(QColor(230, 230, 230));
2114
2115 widget->setEnabled(enable);
2116 if (enable) {
2117 widget->setPalette(paletteWhite);
2118 }
2119 else {
2120 widget->setPalette(paletteGray);
2121 }
2122}
2123
2124// Bnc Text
2125////////////////////////////////////////////////////////////////////////////
2126void bncWindow::slotBncTextChanged(){
2127
2128 bool enable = true;
2129
2130 // Proxy
2131 //------
2132 if (sender() == 0 || sender() == _proxyHostLineEdit) {
2133 enable = !_proxyHostLineEdit->text().isEmpty();
2134 enableWidget(enable, _proxyPortLineEdit);
2135 }
2136
2137 // RINEX Observations
2138 // ------------------
2139 if (sender() == 0 || sender() == _rnxPathLineEdit) {
2140 enable = !_rnxPathLineEdit->text().isEmpty();
2141 enableWidget(enable, _rnxSamplSpinBox);
2142 enableWidget(enable, _rnxSkelLineEdit);
2143 enableWidget(enable, _rnxScrpLineEdit);
2144 enableWidget(enable, _rnxV3CheckBox);
2145 enableWidget(enable, _rnxIntrComboBox);
2146 }
2147
2148 // RINEX Ephemeris
2149 // ---------------
2150 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _outEphPortLineEdit) {
2151 enable = !_ephPathLineEdit->text().isEmpty() || !_outEphPortLineEdit->text().isEmpty();
2152 enableWidget(enable, _ephIntrComboBox);
2153 enableWidget(enable, _ephV3CheckBox);
2154 }
2155
2156 // Broadcast Corrections
2157 // ---------------------
2158 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2159 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2160 enableWidget(enable, _corrIntrComboBox);
2161 }
2162
2163 // Feed Engine
2164 // -----------
2165 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2166 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2167 enableWidget(enable, _waitTimeSpinBox);
2168 enableWidget(enable, _binSamplSpinBox);
2169 }
2170
2171 // Serial Output
2172 // -------------
2173 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
2174 sender() == _serialAutoNMEAComboBox) {
2175 enable = !_serialMountPointLineEdit->text().isEmpty();
2176 enableWidget(enable, _serialPortNameLineEdit);
2177 enableWidget(enable, _serialBaudRateComboBox);
2178 enableWidget(enable, _serialParityComboBox);
2179 enableWidget(enable, _serialDataBitsComboBox);
2180 enableWidget(enable, _serialStopBitsComboBox);
2181 enableWidget(enable, _serialFlowControlComboBox);
2182 enableWidget(enable, _serialAutoNMEAComboBox);
2183
2184 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() != "Auto";
2185 enableWidget(enable2, _serialFileNMEALineEdit);
2186 }
2187
2188 // Outages
2189 // -------
2190 if (sender() == 0 || sender() == _obsRateComboBox) {
2191 enable = !_obsRateComboBox->currentText().isEmpty();
2192 enableWidget(enable, _adviseFailSpinBox);
2193 enableWidget(enable, _adviseRecoSpinBox);
2194 enableWidget(enable, _adviseScriptLineEdit);
2195 }
2196
2197 // Miscellaneous
2198 // -------------
2199 if (sender() == 0 || sender() == _miscMountLineEdit) {
2200 enable = !_miscMountLineEdit->text().isEmpty();
2201 enableWidget(enable, _perfIntrComboBox);
2202 enableWidget(enable, _scanRTCMCheckBox);
2203 }
2204
2205 // Enable/disable Broadcast Ephemerides
2206 // ------------------------------------
2207 if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2208 if (!_uploadEphHostLineEdit->text().isEmpty()) {
2209 _uploadEphPortLineEdit->setStyleSheet("background-color: white");
2210 _uploadEphMountpointLineEdit->setStyleSheet("background-color: white");
2211 _uploadEphPasswordLineEdit->setStyleSheet("background-color: white");
2212 _uploadEphSampleSpinBox->setStyleSheet("background-color: white");
2213 _uploadEphPortLineEdit->setEnabled(true);
2214 _uploadEphMountpointLineEdit->setEnabled(true);
2215 _uploadEphPasswordLineEdit->setEnabled(true);
2216 _uploadEphSampleSpinBox->setEnabled(true);
2217 }
2218 else {
2219 _uploadEphPortLineEdit->setStyleSheet("background-color: lightGray");
2220 _uploadEphMountpointLineEdit->setStyleSheet("background-color: lightGray");
2221 _uploadEphPasswordLineEdit->setStyleSheet("background-color: lightGray");
2222 _uploadEphSampleSpinBox->setStyleSheet("background-color: lightGray");
2223 _uploadEphPortLineEdit->setEnabled(false);
2224 _uploadEphMountpointLineEdit->setEnabled(false);
2225 _uploadEphPasswordLineEdit->setEnabled(false);
2226 _uploadEphSampleSpinBox->setEnabled(false);
2227 }
2228 }
2229
2230 // Combine Corrections
2231 // -------------------
2232 if (sender() == 0 || sender() == _cmbTable) {
2233 int iRow = _cmbTable->rowCount();
2234 if (iRow > 0) {
2235 enableWidget(true, _cmbMethodComboBox);
2236 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
2237 _cmbMaxresLineEdit->setEnabled(true);
2238 _cmbSamplSpinBox->setEnabled(true);
2239 }
2240 else {
2241 enableWidget(false, _cmbMethodComboBox);
2242 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2243 _cmbMaxresLineEdit->setEnabled(false);
2244 _cmbSamplSpinBox->setEnabled(false);
2245 }
2246 }
2247
2248 // Upload(clk)
2249 // -----------
2250 int iRow = _uploadTable->rowCount();
2251 if (iRow > 0) {
2252 enableWidget(true, _uploadIntrComboBox);
2253 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2254 enableWidget(true, _uploadSamplClkRnxSpinBox);
2255 enableWidget(true, _uploadSamplSp3SpinBox);
2256 }
2257 else {
2258 enableWidget(false, _uploadIntrComboBox);
2259 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2260 enableWidget(false, _uploadSamplClkRnxSpinBox);
2261 enableWidget(false, _uploadSamplSp3SpinBox);
2262 }
2263
2264 // PPP Client
2265 // ----------
2266 if (sender() == 0
2267 || sender() == _pppMountLineEdit
2268 || sender() == _pppCorrMountLineEdit
2269 || sender() == _pppRefCrdXLineEdit
2270 || sender() == _pppRefCrdYLineEdit
2271 || sender() == _pppRefCrdZLineEdit
2272 || sender() == _pppRefdNLineEdit
2273 || sender() == _pppRefdELineEdit
2274 || sender() == _pppRefdULineEdit
2275 || sender() == _pppSync
2276 || sender() == _pppSPPComboBox
2277 || sender() == _pppQuickStartLineEdit
2278 || sender() == _pppEstTropoCheckBox
2279 || sender() == _pppUsePhaseCheckBox
2280 || sender() == _pppAntexFileChooser ) {
2281
2282 enable = !_pppSPPComboBox->currentText().isEmpty();
2283 if (enable) {
2284 enable = (!_pppMountLineEdit->text().isEmpty() && !_pppCorrMountLineEdit->text().isEmpty()) ||
2285 (!_pppMountLineEdit->text().isEmpty() && _pppSPPComboBox->currentText() == "Realtime-SPP") ||
2286 (_pppSPPComboBox->currentText() == "Post-Processing");
2287 }
2288
2289 enableWidget(enable, _pppNMEALineEdit);
2290 enableWidget(enable, _pppNMEAPortLineEdit);
2291 enableWidget(enable, _pppRefCrdXLineEdit);
2292 enableWidget(enable, _pppRefCrdYLineEdit);
2293 enableWidget(enable, _pppRefCrdZLineEdit);
2294 enableWidget(enable, _pppRefdNLineEdit);
2295 enableWidget(enable, _pppRefdELineEdit);
2296 enableWidget(enable, _pppRefdULineEdit);
2297 enableWidget(enable, _pppUsePhaseCheckBox);
2298 enableWidget(enable, _pppPlotCoordinates);
2299 enableWidget(enable, _pppEstTropoCheckBox);
2300// enableWidget(enable, _pppGLONASSCheckBox);
2301 enableWidget(enable, _pppGalileoCheckBox);
2302// enableWidget(enable, _pppAntexFileChooser);
2303 enableWidget(enable, _pppSigCLineEdit);
2304 enableWidget(enable, _pppSigCrd0);
2305 enableWidget(enable, _pppSigCrdP);
2306
2307 bool enable2 = enable && !_pppRefCrdXLineEdit->text().isEmpty() &&
2308 !_pppRefCrdYLineEdit->text().isEmpty() &&
2309 !_pppRefCrdZLineEdit->text().isEmpty();
2310
2311 enableWidget(enable2, _pppAverageLineEdit);
2312 enableWidget(enable2, _pppQuickStartLineEdit);
2313
2314 bool enable3 = enable2 && !_pppQuickStartLineEdit->text().isEmpty();
2315 enableWidget(enable3, _pppMaxSolGapLineEdit);
2316 enableWidget(enable3, _pppAudioResponseLineEdit);
2317
2318 bool enable4 = enable && !_pppAntexFileChooser->fileName().isEmpty();
2319 enableWidget(enable4, _pppAntennaLineEdit);
2320
2321 bool enable5 = enable && _pppEstTropoCheckBox->isChecked();
2322 enableWidget(enable5, _pppSigTrp0);
2323 enableWidget(enable5, _pppSigTrpP);
2324
2325 bool enable6 = enable && _pppUsePhaseCheckBox->isChecked();
2326 enableWidget(enable6, _pppSigPLineEdit);
2327
2328 bool enable7 = enable && _pppSPPComboBox->currentText() == "Realtime-PPP";
2329 enableWidget(enable7, _pppSync);
2330
2331 bool enable8 = _pppSPPComboBox->currentText() == "Realtime-PPP";
2332 enableWidget(enable8, _pppCorrMountLineEdit);
2333
2334 bool enable9 = _pppSPPComboBox->currentText() == "Post-Processing";
2335 enableWidget(enable9, _postObsFileChooser);
2336 enableWidget(enable9, _postNavFileChooser);
2337 enableWidget(enable9, _postCorrFileChooser);
2338 enableWidget(enable9, _postOutLineEdit);
2339
2340 bool enable10 = !_pppSPPComboBox->currentText().isEmpty() && !enable9;
2341 enableWidget(enable10, _pppMountLineEdit);
2342 }
2343
2344 if (sender() == 0 || sender() == _reqcActionComboBox) {
2345 enable = !_reqcActionComboBox->currentText().isEmpty();
2346 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2347 enableWidget(enable && enable10, _reqcEditOptionButton);
2348 enableWidget(enable, _reqcObsFileChooser);
2349 enableWidget(enable, _reqcNavFileChooser);
2350 enableWidget(enable && enable10, _reqcOutObsLineEdit);
2351 enableWidget(enable && enable10, _reqcOutNavLineEdit);
2352 enableWidget(enable, _reqcOutLogLineEdit);
2353 enableWidget(enable && !enable10, _reqcPlotDirLineEdit);
2354 }
2355
2356 enableStartStop();
2357}
2358
2359//
2360////////////////////////////////////////////////////////////////////////////
2361void bncWindow::slotAddCmbRow() {
2362 int iRow = _cmbTable->rowCount();
2363 _cmbTable->insertRow(iRow);
2364 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2365 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2366 }
2367}
2368
2369//
2370////////////////////////////////////////////////////////////////////////////
2371void bncWindow::slotDelCmbRow() {
2372 int nRows = _cmbTable->rowCount();
2373 bool flg[nRows];
2374 for (int iRow = 0; iRow < nRows; iRow++) {
2375 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2376 flg[iRow] = true;
2377 }
2378 else {
2379 flg[iRow] = false;
2380 }
2381 }
2382 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2383 if (flg[iRow]) {
2384 _cmbTable->removeRow(iRow);
2385 }
2386 }
2387 nRows = _cmbTable->rowCount();
2388 if (nRows < 1) {
2389 enableWidget(false, _cmbMethodComboBox);
2390 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2391 _cmbMaxresLineEdit->setEnabled(false);
2392 _cmbSamplSpinBox->setEnabled(false);
2393 }
2394}
2395
2396//
2397////////////////////////////////////////////////////////////////////////////
2398void bncWindow::populateCmbTable() {
2399
2400 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2401 _cmbTable->removeRow(iRow);
2402 }
2403
2404 bncSettings settings;
2405
2406 int iRow = -1;
2407 QListIterator<QString> it(settings.value("combineStreams").toStringList());
2408 while (it.hasNext()) {
2409 QStringList hlp = it.next().split(" ");
2410 if (hlp.size() > 2) {
2411 ++iRow;
2412 _cmbTable->insertRow(iRow);
2413 }
2414 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2415 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2416 }
2417 }
2418}
2419
2420//
2421////////////////////////////////////////////////////////////////////////////
2422void bncWindow::slotAddUploadRow() {
2423 int iRow = _uploadTable->rowCount();
2424 _uploadTable->insertRow(iRow);
2425 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2426 if (iCol == 3) {
2427 QLineEdit* passwd = new QLineEdit();
2428 passwd->setFrame(false);
2429 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2430 _uploadTable->setCellWidget(iRow, iCol, passwd);
2431 }
2432 else if (iCol == 4) {
2433 QComboBox* system = new QComboBox();
2434 system->setEditable(false);
2435 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,Custom").split(","));
2436 system->setFrame(false);
2437 _uploadTable->setCellWidget(iRow, iCol, system);
2438 }
2439 else if (iCol == 5) {
2440 QCheckBox* com = new QCheckBox();
2441 _uploadTable->setCellWidget(iRow, iCol, com);
2442 }
2443 else if (iCol == 11) {
2444 bncTableItem* bncIt = new bncTableItem();
2445 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2446 _uploadTable->setItem(iRow, iCol, bncIt);
2447 ((bncApp*)qApp)->_uploadTableItems[iRow] = bncIt;
2448 }
2449 else {
2450 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2451 }
2452 }
2453}
2454
2455//
2456////////////////////////////////////////////////////////////////////////////
2457void bncWindow::slotDelUploadRow() {
2458 ((bncApp*)qApp)->_uploadTableItems.clear();
2459 int nRows = _uploadTable->rowCount();
2460 bool flg[nRows];
2461 for (int iRow = 0; iRow < nRows; iRow++) {
2462 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2463 flg[iRow] = true;
2464 }
2465 else {
2466 flg[iRow] = false;
2467 }
2468 }
2469 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2470 if (flg[iRow]) {
2471 _uploadTable->removeRow(iRow);
2472 }
2473 }
2474 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2475 ((bncApp*)qApp)->_uploadTableItems[iRow] =
2476 (bncTableItem*) _uploadTable->item(iRow, 11);
2477 }
2478 nRows = _uploadTable->rowCount();
2479 if (nRows < 1) {
2480 enableWidget(false, _uploadIntrComboBox);
2481 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2482 enableWidget(false, _uploadSamplSp3SpinBox);
2483 enableWidget(false, _uploadSamplClkRnxSpinBox);
2484 }
2485}
2486
2487//
2488////////////////////////////////////////////////////////////////////////////
2489void bncWindow::populateUploadTable() {
2490 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2491 _uploadTable->removeRow(iRow);
2492 }
2493
2494 bncSettings settings;
2495
2496 int iRow = -1;
2497 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2498 while (it.hasNext()) {
2499 QStringList hlp = it.next().split(",");
2500 if (hlp.size() > 6) {
2501 ++iRow;
2502 _uploadTable->insertRow(iRow);
2503 }
2504 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2505 if (iCol == 3) {
2506 QLineEdit* passwd = new QLineEdit();
2507 passwd->setFrame(false);
2508 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2509 passwd->setText(hlp[iCol]);
2510 _uploadTable->setCellWidget(iRow, iCol, passwd);
2511 }
2512 else if (iCol == 4) {
2513 QComboBox* system = new QComboBox();
2514 system->setEditable(false);
2515 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,Custom").split(","));
2516 system->setFrame(false);
2517 system->setCurrentIndex(system->findText(hlp[iCol]));
2518 _uploadTable->setCellWidget(iRow, iCol, system);
2519 }
2520 else if (iCol == 5) {
2521 QCheckBox* com = new QCheckBox();
2522 if (hlp[iCol].toInt() == Qt::Checked) {
2523 com->setCheckState(Qt::Checked);
2524 }
2525 _uploadTable->setCellWidget(iRow, iCol, com);
2526 }
2527 else if (iCol == 11) {
2528 bncTableItem* bncIt = new bncTableItem();
2529 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2530 _uploadTable->setItem(iRow, iCol, bncIt);
2531 ((bncApp*)qApp)->_uploadTableItems[iRow] = bncIt;
2532 }
2533 else {
2534 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2535 }
2536 }
2537 }
2538}
2539
2540//
2541////////////////////////////////////////////////////////////////////////////
2542void bncWindow::slotSetUploadTrafo() {
2543 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2544 dlg->exec();
2545 delete dlg;
2546}
2547
2548// Start Post-Processing PPP
2549////////////////////////////////////////////////////////////////////////////
2550void bncWindow::startPostProcessingPPP() {
2551#ifdef USE_POSTPROCESSING
2552 _runningPostProcessingPPP = true;
2553 _actStart->setText("0 Epochs");
2554 enableStartStop();
2555
2556 t_postProcessing* postProcessing = new t_postProcessing(this);
2557 connect(postProcessing, SIGNAL(finished()), this, SLOT(slotFinishedPostProcessingPPP()));
2558 connect(postProcessing, SIGNAL(progress(int)), this, SLOT(slotPostProgress(int)));
2559
2560 postProcessing->start();
2561#else
2562 QMessageBox::information(this, "Information",
2563 "Post-Processing Not Permitted");
2564#endif
2565}
2566
2567// Post-Processing PPP Finished
2568////////////////////////////////////////////////////////////////////////////
2569void bncWindow::slotFinishedPostProcessingPPP() {
2570 _runningPostProcessingPPP = false;
2571 QMessageBox::information(this, "Information",
2572 "Post-Processing Thread Finished");
2573 _actStart->setText("Start");
2574 enableStartStop();
2575}
2576
2577// Progress Bar Change
2578////////////////////////////////////////////////////////////////////////////
2579void bncWindow::slotPostProgress(int nEpo) {
2580 if (_actStart) {
2581 _actStart->setText(QString("%1 Epochs").arg(nEpo));
2582 }
2583}
2584
2585// Start Post-Processing Reqc
2586////////////////////////////////////////////////////////////////////////////
2587void bncWindow::startPostProcessingReqc() {
2588#ifdef USE_POSTPROCESSING
2589 _runningPostProcessingReqc = true;
2590 enableStartStop();
2591 if (_reqcActionComboBox->currentText() == "Analyze") {
2592 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
2593 connect(reqcAnalyze, SIGNAL(finished()),
2594 this, SLOT(slotFinishedPostProcessingReqc()));
2595 reqcAnalyze->start();
2596 }
2597 else {
2598 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
2599 connect(reqcEdit, SIGNAL(finished()),
2600 this, SLOT(slotFinishedPostProcessingReqc()));
2601 reqcEdit->start();
2602 }
2603#else
2604 QMessageBox::information(this, "Information",
2605 "Post-Processing Not Permitted");
2606#endif
2607}
2608
2609// Post-Processing Reqc Finished
2610////////////////////////////////////////////////////////////////////////////
2611void bncWindow::slotFinishedPostProcessingReqc() {
2612 _runningPostProcessingReqc = false;
2613 if (_reqcActionComboBox->currentText() != "Analyze") {
2614 QMessageBox::information(this, "Information",
2615 "RINEX Processing Thread Finished");
2616 }
2617 enableStartStop();
2618}
2619
2620// Edit teqc-like editing options
2621////////////////////////////////////////////////////////////////////////////
2622void bncWindow::slotReqcEditOption() {
2623 reqcDlg* dlg = new reqcDlg(this);
2624 dlg->move(this->pos().x()+50, this->pos().y()+50);
2625 dlg->exec();
2626 delete dlg;
2627}
2628
2629// Enable/Disable Start and Stop Buttons
2630////////////////////////////////////////////////////////////////////////////
2631void bncWindow::enableStartStop() {
2632
2633 if ( _pppSPPComboBox && _pppSPPComboBox->currentText() == "Post-Processing" ) {
2634 if (_runningPostProcessingPPP) {
2635 _actStart->setEnabled(false);
2636 }
2637 else {
2638 _actStart->setEnabled(true);
2639 }
2640 _actStop->setEnabled(false);
2641 }
2642 else if ( _reqcActionComboBox && !_reqcActionComboBox->currentText().isEmpty() ) {
2643 if (_runningPostProcessingReqc) {
2644 _actStart->setEnabled(false);
2645 }
2646 else {
2647 _actStart->setEnabled(true);
2648 }
2649 _actStop->setEnabled(false);
2650 }
2651 else {
2652 if (_runningRealTime) {
2653 _actStart->setEnabled(false);
2654 _actStop->setEnabled(true);
2655 }
2656 else {
2657 _actStop->setEnabled(false);
2658 if (_mountPointsTable->rowCount() == 0) {
2659 _actStart->setEnabled(false);
2660 }
2661 else {
2662 _actStart->setEnabled(true);
2663 }
2664 }
2665 }
2666}
2667
2668// Show Map
2669////////////////////////////////////////////////////////////////////////////
2670void bncWindow::slotMap() {
2671 saveOptions();
2672 t_bncMap* bncMap = new t_bncMap(this);
2673 bncMap->setGeometry( x(), int(y()+height()*1.3), 800, 600 );
2674 bncMap->show();
2675}
Note: See TracBrowser for help on using the repository browser.