source: ntrip/trunk/BNC/bncwindow.cpp@ 3600

Last change on this file since 3600 was 3600, checked in by mervart, 12 years ago
File size: 120.4 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
64using namespace std;
65
66// Constructor
67////////////////////////////////////////////////////////////////////////////
68bncWindow::bncWindow() {
69
70 _caster = 0;
71 _casterEph = 0;
72
73 _bncFigure = new bncFigure(this);
74 _bncFigureLate = new bncFigureLate(this);
75 _bncFigurePPP = new bncFigurePPP(this);
76
77 int ww = QFontMetrics(this->font()).width('w');
78
79 static const QStringList labels = QString("account, Streams: resource loader / mountpoint, decoder, lat, long, nmea, ntrip, bytes").split(",");
80
81 setMinimumSize(85*ww, 65*ww);
82
83 setWindowTitle(tr("BKG Ntrip Client (BNC) Version " BNCVERSION));
84
85 connect((bncApp*)qApp, SIGNAL(newMessage(QByteArray,bool)),
86 this, SLOT(slotWindowMessage(QByteArray,bool)));
87
88 // Create Actions
89 // --------------
90 _actHelp = new QAction(tr("&Help Contents"),this);
91 connect(_actHelp, SIGNAL(triggered()), SLOT(slotHelp()));
92
93 _actAbout = new QAction(tr("&About BNC"),this);
94 connect(_actAbout, SIGNAL(triggered()), SLOT(slotAbout()));
95
96 _actFlowchart = new QAction(tr("&Flow Chart"),this);
97 connect(_actFlowchart, SIGNAL(triggered()), SLOT(slotFlowchart()));
98
99 _actFontSel = new QAction(tr("Select &Font"),this);
100 connect(_actFontSel, SIGNAL(triggered()), SLOT(slotFontSel()));
101
102 _actSaveOpt = new QAction(tr("&Save && Reread Configuration"),this);
103 connect(_actSaveOpt, SIGNAL(triggered()), SLOT(slotSaveOptions()));
104
105 _actQuit = new QAction(tr("&Quit"),this);
106 connect(_actQuit, SIGNAL(triggered()), SLOT(close()));
107
108 _actAddMountPoints = new QAction(tr("Add &Stream"),this);
109 connect(_actAddMountPoints, SIGNAL(triggered()), SLOT(slotAddMountPoints()));
110
111 _actDeleteMountPoints = new QAction(tr("&Delete Stream"),this);
112 connect(_actDeleteMountPoints, SIGNAL(triggered()), SLOT(slotDeleteMountPoints()));
113 _actDeleteMountPoints->setEnabled(false);
114
115 _actGetData = new QAction(tr("Sta&rt"),this);
116 connect(_actGetData, SIGNAL(triggered()), SLOT(slotGetData()));
117
118 _actStop = new QAction(tr("Sto&p"),this);
119 connect(_actStop, SIGNAL(triggered()), SLOT(slotStop()));
120 _actStop->setEnabled(false);
121
122 _actwhatsthis= new QAction(tr("Help ?=Shift+F1"),this);
123 connect(_actwhatsthis, SIGNAL(triggered()), SLOT(slotWhatsThis()));
124
125 CreateMenu();
126 AddToolbar();
127
128 bncSettings settings;
129
130 // Netowrk Options
131 // ---------------
132 _proxyHostLineEdit = new QLineEdit(settings.value("proxyHost").toString());
133 _proxyPortLineEdit = new QLineEdit(settings.value("proxyPort").toString());
134
135 connect(_proxyHostLineEdit, SIGNAL(textChanged(const QString &)),
136 this, SLOT(slotBncTextChanged()));
137
138 _sslCaCertPathLineEdit = new QLineEdit(settings.value("sslCaCertPath").toString());
139 _ignoreSslErrorsCheckBox = new QCheckBox();
140 _ignoreSslErrorsCheckBox->setCheckState(Qt::CheckState(
141 settings.value("ignoreSslErrors").toInt()));
142
143 // General Options
144 // ---------------
145 _logFileLineEdit = new QLineEdit(settings.value("logFile").toString());
146 _rawOutFileLineEdit = new QLineEdit(settings.value("rawOutFile").toString());
147 _rnxAppendCheckBox = new QCheckBox();
148 _rnxAppendCheckBox->setCheckState(Qt::CheckState(
149 settings.value("rnxAppend").toInt()));
150 _onTheFlyComboBox = new QComboBox();
151 _onTheFlyComboBox->setEditable(false);
152 _onTheFlyComboBox->addItems(QString("1 day,1 hour,1 min").split(","));
153 int ii = _onTheFlyComboBox->findText(settings.value("onTheFlyInterval").toString());
154 if (ii != -1) {
155 _onTheFlyComboBox->setCurrentIndex(ii);
156 }
157 _autoStartCheckBox = new QCheckBox();
158 _autoStartCheckBox->setCheckState(Qt::CheckState(
159 settings.value("autoStart").toInt()));
160
161 // RINEX Observations Options
162 // --------------------------
163 _rnxPathLineEdit = new QLineEdit(settings.value("rnxPath").toString());
164 _rnxIntrComboBox = new QComboBox();
165 _rnxIntrComboBox->setEditable(false);
166 _rnxIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
167 ii = _rnxIntrComboBox->findText(settings.value("rnxIntr").toString());
168 if (ii != -1) {
169 _rnxIntrComboBox->setCurrentIndex(ii);
170 }
171 _rnxSamplSpinBox = new QSpinBox();
172 _rnxSamplSpinBox->setMinimum(0);
173 _rnxSamplSpinBox->setMaximum(60);
174 _rnxSamplSpinBox->setSingleStep(5);
175 _rnxSamplSpinBox->setValue(settings.value("rnxSampl").toInt());
176 _rnxSamplSpinBox->setSuffix(" sec");
177 _rnxSkelLineEdit = new QLineEdit(settings.value("rnxSkel").toString());
178 _rnxSkelLineEdit->setMaximumWidth(5*ww);
179 _rnxScrpLineEdit = new QLineEdit(settings.value("rnxScript").toString());
180 _rnxV3CheckBox = new QCheckBox();
181 _rnxV3CheckBox->setCheckState(Qt::CheckState(settings.value("rnxV3").toInt()));
182
183 connect(_rnxPathLineEdit, SIGNAL(textChanged(const QString &)),
184 this, SLOT(slotBncTextChanged()));
185
186 // RINEX Ephemeris Options
187 // -----------------------
188 _ephPathLineEdit = new QLineEdit(settings.value("ephPath").toString());
189 _ephIntrComboBox = new QComboBox();
190 _ephIntrComboBox->setEditable(false);
191 _ephIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
192 int jj = _ephIntrComboBox->findText(settings.value("ephIntr").toString());
193 if (jj != -1) {
194 _ephIntrComboBox->setCurrentIndex(jj);
195 }
196 _outEphPortLineEdit = new QLineEdit(settings.value("outEphPort").toString());
197 _ephV3CheckBox = new QCheckBox();
198 _ephV3CheckBox->setCheckState(Qt::CheckState(settings.value("ephV3").toInt()));
199
200 connect(_outEphPortLineEdit, SIGNAL(textChanged(const QString &)),
201 this, SLOT(slotBncTextChanged()));
202
203 connect(_ephPathLineEdit, SIGNAL(textChanged(const QString &)),
204 this, SLOT(slotBncTextChanged()));
205
206 // Broadcast Corrections Options
207 // -----------------------------
208 _corrPathLineEdit = new QLineEdit(settings.value("corrPath").toString());
209 _corrIntrComboBox = new QComboBox();
210 _corrIntrComboBox->setEditable(false);
211 _corrIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
212 int mm = _corrIntrComboBox->findText(settings.value("corrIntr").toString());
213 if (mm != -1) {
214 _corrIntrComboBox->setCurrentIndex(mm);
215 }
216 _corrPortLineEdit = new QLineEdit(settings.value("corrPort").toString());
217 _corrTimeSpinBox = new QSpinBox();
218 _corrTimeSpinBox->setMinimum(0);
219 _corrTimeSpinBox->setMaximum(60);
220 _corrTimeSpinBox->setSingleStep(1);
221 _corrTimeSpinBox->setSuffix(" sec");
222 _corrTimeSpinBox->setValue(settings.value("corrTime").toInt());
223
224 connect(_corrPathLineEdit, SIGNAL(textChanged(const QString &)),
225 this, SLOT(slotBncTextChanged()));
226
227 connect(_corrPortLineEdit, SIGNAL(textChanged(const QString &)),
228 this, SLOT(slotBncTextChanged()));
229
230 // Feed Engine Options
231 // -------------------
232 _outPortLineEdit = new QLineEdit(settings.value("outPort").toString());
233 _waitTimeSpinBox = new QSpinBox();
234 _waitTimeSpinBox->setMinimum(1);
235 _waitTimeSpinBox->setMaximum(30);
236 _waitTimeSpinBox->setSingleStep(1);
237 _waitTimeSpinBox->setSuffix(" sec");
238 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
239 _binSamplSpinBox = new QSpinBox();
240 _binSamplSpinBox->setMinimum(0);
241 _binSamplSpinBox->setMaximum(60);
242 _binSamplSpinBox->setSingleStep(5);
243 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
244 _binSamplSpinBox->setSuffix(" sec");
245 _outFileLineEdit = new QLineEdit(settings.value("outFile").toString());
246 _outUPortLineEdit = new QLineEdit(settings.value("outUPort").toString());
247
248 connect(_outPortLineEdit, SIGNAL(textChanged(const QString &)),
249 this, SLOT(slotBncTextChanged()));
250
251 connect(_outFileLineEdit, SIGNAL(textChanged(const QString &)),
252 this, SLOT(slotBncTextChanged()));
253
254 // Serial Output Options
255 // ---------------------
256 _serialMountPointLineEdit = new QLineEdit(settings.value("serialMountPoint").toString());
257 _serialPortNameLineEdit = new QLineEdit(settings.value("serialPortName").toString());
258 _serialBaudRateComboBox = new QComboBox();
259 _serialBaudRateComboBox->addItems(QString("110,300,600,"
260 "1200,2400,4800,9600,19200,38400,57600,115200").split(","));
261 int kk = _serialBaudRateComboBox->findText(settings.value("serialBaudRate").toString());
262 if (kk != -1) {
263 _serialBaudRateComboBox->setCurrentIndex(kk);
264 }
265 _serialFlowControlComboBox = new QComboBox();
266 _serialFlowControlComboBox->addItems(QString("OFF,XONXOFF,HARDWARE").split(","));
267 kk = _serialFlowControlComboBox->findText(settings.value("serialFlowControl").toString());
268 if (kk != -1) {
269 _serialFlowControlComboBox->setCurrentIndex(kk);
270 }
271 _serialDataBitsComboBox = new QComboBox();
272 _serialDataBitsComboBox->addItems(QString("5,6,7,8").split(","));
273 kk = _serialDataBitsComboBox->findText(settings.value("serialDataBits").toString());
274 if (kk != -1) {
275 _serialDataBitsComboBox->setCurrentIndex(kk);
276 }
277 _serialParityComboBox = new QComboBox();
278 _serialParityComboBox->addItems(QString("NONE,ODD,EVEN,SPACE").split(","));
279 kk = _serialParityComboBox->findText(settings.value("serialParity").toString());
280 if (kk != -1) {
281 _serialParityComboBox->setCurrentIndex(kk);
282 }
283 _serialStopBitsComboBox = new QComboBox();
284 _serialStopBitsComboBox->addItems(QString("1,2").split(","));
285 kk = _serialStopBitsComboBox->findText(settings.value("serialStopBits").toString());
286 if (kk != -1) {
287 _serialStopBitsComboBox->setCurrentIndex(kk);
288 }
289 _serialAutoNMEAComboBox = new QComboBox();
290 _serialAutoNMEAComboBox->addItems(QString("Auto,Manual").split(","));
291 kk = _serialAutoNMEAComboBox->findText(settings.value("serialAutoNMEA").toString());
292 if (kk != -1) {
293 _serialAutoNMEAComboBox->setCurrentIndex(kk);
294 }
295 _serialFileNMEALineEdit = new QLineEdit(settings.value("serialFileNMEA").toString());
296 _serialHeightNMEALineEdit = new QLineEdit(settings.value("serialHeightNMEA").toString());
297
298 connect(_serialMountPointLineEdit, SIGNAL(textChanged(const QString &)),
299 this, SLOT(slotBncTextChanged()));
300
301 connect(_serialAutoNMEAComboBox, SIGNAL(currentIndexChanged(const QString &)),
302 this, SLOT(slotBncTextChanged()));
303
304 // Outages Options
305 // ---------------
306 _obsRateComboBox = new QComboBox();
307 _obsRateComboBox->setEditable(false);
308 _obsRateComboBox->addItems(QString(",0.1 Hz,0.2 Hz,0.5 Hz,1 Hz,5 Hz").split(","));
309 kk = _obsRateComboBox->findText(settings.value("obsRate").toString());
310 if (kk != -1) {
311 _obsRateComboBox->setCurrentIndex(kk);
312 }
313 _adviseFailSpinBox = new QSpinBox();
314 _adviseFailSpinBox->setMinimum(0);
315 _adviseFailSpinBox->setMaximum(60);
316 _adviseFailSpinBox->setSingleStep(1);
317 _adviseFailSpinBox->setSuffix(" min");
318 _adviseFailSpinBox->setValue(settings.value("adviseFail").toInt());
319 _adviseRecoSpinBox = new QSpinBox();
320 _adviseRecoSpinBox->setMinimum(0);
321 _adviseRecoSpinBox->setMaximum(60);
322 _adviseRecoSpinBox->setSingleStep(1);
323 _adviseRecoSpinBox->setSuffix(" min");
324 _adviseRecoSpinBox->setValue(settings.value("adviseReco").toInt());
325 _adviseScriptLineEdit = new QLineEdit(settings.value("adviseScript").toString());
326
327 connect(_obsRateComboBox, SIGNAL(currentIndexChanged(const QString &)),
328 this, SLOT(slotBncTextChanged()));
329
330 // Miscellaneous Options
331 // ---------------------
332 _miscMountLineEdit = new QLineEdit(settings.value("miscMount").toString());
333 _perfIntrComboBox = new QComboBox();
334 _perfIntrComboBox->setEditable(false);
335 _perfIntrComboBox->addItems(QString(",2 sec, 10 sec,1 min,5 min,15 min,1 hour,6 hours,1 day").split(","));
336 int ll = _perfIntrComboBox->findText(settings.value("perfIntr").toString());
337 if (ll != -1) {
338 _perfIntrComboBox->setCurrentIndex(ll);
339 }
340 _scanRTCMCheckBox = new QCheckBox();
341 _scanRTCMCheckBox->setCheckState(Qt::CheckState(
342 settings.value("scanRTCM").toInt()));
343
344 connect(_miscMountLineEdit, SIGNAL(textChanged(const QString &)),
345 this, SLOT(slotBncTextChanged()));
346
347 // PPP Options
348 // -----------
349 _pppMountLineEdit = new QLineEdit(settings.value("pppMount").toString());
350 _pppCorrMountLineEdit = new QLineEdit(settings.value("pppCorrMount").toString());
351 _pppNMEALineEdit = new QLineEdit(settings.value("nmeaFile").toString());
352 _pppNMEAPortLineEdit = new QLineEdit(settings.value("nmeaPort").toString());
353 _pppSigCLineEdit = new QLineEdit(settings.value("pppSigmaCode").toString());
354 _pppSigPLineEdit = new QLineEdit(settings.value("pppSigmaPhase").toString());
355 _pppSigCrd0 = new QLineEdit(settings.value("pppSigCrd0").toString());
356 _pppSigCrdP = new QLineEdit(settings.value("pppSigCrdP").toString());
357 _pppSigTrp0 = new QLineEdit(settings.value("pppSigTrp0").toString());
358 _pppSigTrpP = new QLineEdit(settings.value("pppSigTrpP").toString());
359 _pppAverageLineEdit = new QLineEdit(settings.value("pppAverage").toString());
360 _pppQuickStartLineEdit = new QLineEdit(settings.value("pppQuickStart").toString());
361 _pppMaxSolGapLineEdit = new QLineEdit(settings.value("pppMaxSolGap").toString());
362 _pppRefCrdXLineEdit = new QLineEdit(settings.value("pppRefCrdX").toString());
363 _pppRefCrdYLineEdit = new QLineEdit(settings.value("pppRefCrdY").toString());
364 _pppRefCrdZLineEdit = new QLineEdit(settings.value("pppRefCrdZ").toString());
365 _pppRefdNLineEdit = new QLineEdit(settings.value("pppRefdN").toString());
366 _pppRefdELineEdit = new QLineEdit(settings.value("pppRefdE").toString());
367 _pppRefdULineEdit = new QLineEdit(settings.value("pppRefdU").toString());
368 _pppSync = new QLineEdit(settings.value("pppSync").toString());
369 _pppAntennaLineEdit = new QLineEdit(settings.value("pppAntenna").toString());
370 _pppAntexLineEdit = new QLineEdit(settings.value("pppAntex").toString());
371
372
373 _pppSPPComboBox = new QComboBox();
374 _pppSPPComboBox->setEditable(false);
375 _pppSPPComboBox->addItems(QString("PPP,SPP").split(","));
376 int ik = _pppSPPComboBox->findText(settings.value("pppSPP").toString());
377 if (ik != -1) {
378 _pppSPPComboBox->setCurrentIndex(ik);
379 }
380 _pppUsePhaseCheckBox = new QCheckBox();
381 _pppUsePhaseCheckBox->setCheckState(Qt::CheckState(
382 settings.value("pppUsePhase").toInt()));
383 _pppEstTropoCheckBox = new QCheckBox();
384 _pppEstTropoCheckBox->setCheckState(Qt::CheckState(
385 settings.value("pppEstTropo").toInt()));
386 _pppGLONASSCheckBox = new QCheckBox();
387 _pppGLONASSCheckBox->setCheckState(Qt::CheckState(
388 settings.value("pppGLONASS").toInt()));
389 _pppGalileoCheckBox = new QCheckBox();
390 _pppGalileoCheckBox->setCheckState(Qt::CheckState(
391 settings.value("pppGalileo").toInt()));
392
393 _pppPlotCoordinates = new QCheckBox();
394 _pppPlotCoordinates->setCheckState(Qt::CheckState(
395 settings.value("pppPlotCoordinates").toInt()));
396
397 _pppApplySatAntCheckBox = new QCheckBox();
398 _pppApplySatAntCheckBox->setCheckState(Qt::CheckState(
399 settings.value("pppApplySatAnt").toInt()));
400
401 connect(_pppMountLineEdit, SIGNAL(textChanged(const QString &)),
402 this, SLOT(slotBncTextChanged()));
403
404 connect(_pppCorrMountLineEdit, SIGNAL(textChanged(const QString &)),
405 this, SLOT(slotBncTextChanged()));
406
407 connect(_pppUsePhaseCheckBox, SIGNAL(stateChanged(int)),
408 this, SLOT(slotBncTextChanged()));
409
410 connect(_pppRefCrdXLineEdit, SIGNAL(textChanged(const QString &)),
411 this, SLOT(slotBncTextChanged()));
412 connect(_pppRefCrdYLineEdit, SIGNAL(textChanged(const QString &)),
413 this, SLOT(slotBncTextChanged()));
414 connect(_pppRefCrdZLineEdit, SIGNAL(textChanged(const QString &)),
415 this, SLOT(slotBncTextChanged()));
416 connect(_pppRefdNLineEdit, SIGNAL(textChanged(const QString &)),
417 this, SLOT(slotBncTextChanged()));
418 connect(_pppRefdELineEdit, SIGNAL(textChanged(const QString &)),
419 this, SLOT(slotBncTextChanged()));
420 connect(_pppRefdULineEdit, SIGNAL(textChanged(const QString &)),
421 this, SLOT(slotBncTextChanged()));
422
423 connect(_pppEstTropoCheckBox, SIGNAL(stateChanged(int)),
424 this, SLOT(slotBncTextChanged()));
425
426 connect(_pppSync, SIGNAL(textChanged(const QString &)),
427 this, SLOT(slotBncTextChanged()));
428
429 connect(_pppSPPComboBox, SIGNAL(currentIndexChanged(const QString &)),
430 this, SLOT(slotBncTextChanged()));
431
432 connect(_pppAntexLineEdit, SIGNAL(textChanged(const QString &)),
433 this, SLOT(slotBncTextChanged()));
434
435 connect(_pppQuickStartLineEdit, SIGNAL(textChanged(const QString &)),
436 this, SLOT(slotBncTextChanged()));
437
438 // Streams
439 // -------
440 _mountPointsTable = new QTableWidget(0,8);
441
442 _mountPointsTable->horizontalHeader()->resizeSection(1,34*ww);
443 _mountPointsTable->horizontalHeader()->resizeSection(2,9*ww);
444 _mountPointsTable->horizontalHeader()->resizeSection(3,7*ww);
445 _mountPointsTable->horizontalHeader()->resizeSection(4,7*ww);
446 _mountPointsTable->horizontalHeader()->resizeSection(5,5*ww);
447 _mountPointsTable->horizontalHeader()->resizeSection(6,5*ww);
448 _mountPointsTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
449 _mountPointsTable->horizontalHeader()->setStretchLastSection(true);
450 _mountPointsTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
451 _mountPointsTable->setHorizontalHeaderLabels(labels);
452 _mountPointsTable->setGridStyle(Qt::NoPen);
453 _mountPointsTable->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
454 _mountPointsTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
455 _mountPointsTable->setSelectionBehavior(QAbstractItemView::SelectRows);
456 _mountPointsTable->hideColumn(0);
457 connect(_mountPointsTable, SIGNAL(itemSelectionChanged()),
458 SLOT(slotSelectionChanged()));
459 populateMountPointsTable();
460
461 _log = new QTextBrowser();
462 _log->setReadOnly(true);
463
464 // Combination
465 // -----------
466 _cmbTable = new QTableWidget(0,3);
467 _cmbTable->setHorizontalHeaderLabels(QString("Mountpoint, AC Name, Weight").split(","));
468 _cmbTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
469 _cmbTable->setSelectionBehavior(QAbstractItemView::SelectRows);
470 _cmbTable->setMaximumWidth(30*ww);
471 _cmbTable->horizontalHeader()->resizeSection(0,10*ww);
472 _cmbTable->horizontalHeader()->resizeSection(1,8*ww);
473 _cmbTable->horizontalHeader()->resizeSection(2,8*ww);
474 _cmbTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
475 _cmbTable->horizontalHeader()->setStretchLastSection(true);
476 _cmbTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
477
478 _cmbMaxresLineEdit = new QLineEdit(settings.value("cmbMaxres").toString());
479
480 QPushButton* addCmbRowButton = new QPushButton("Add Row");
481 QPushButton* delCmbRowButton = new QPushButton("Delete");
482
483 connect(_cmbTable, SIGNAL(itemSelectionChanged()),
484 SLOT(slotBncTextChanged()));
485
486 _cmbMethodComboBox = new QComboBox();
487 _cmbMethodComboBox->setEditable(false);
488 _cmbMethodComboBox->addItems(QString("Filter,Single-Epoch").split(","));
489 int im = _cmbMethodComboBox->findText(settings.value("cmbMethod").toString());
490 if (im != -1) {
491 _cmbMethodComboBox->setCurrentIndex(im);
492 }
493
494 // Upload Results
495 // -------------
496 _uploadTable = new QTableWidget(0,9);
497 _uploadTable->setHorizontalHeaderLabels(QString("Host, Port, Mount, Password, System, CoM, SP3 File, RNX File, bytes").split(","));
498 _uploadTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
499 _uploadTable->setSelectionBehavior(QAbstractItemView::SelectRows);
500 _uploadTable->horizontalHeader()->resizeSection(0,13*ww);
501 _uploadTable->horizontalHeader()->resizeSection(1,5*ww);
502 _uploadTable->horizontalHeader()->resizeSection(2,6*ww);
503 _uploadTable->horizontalHeader()->resizeSection(3,8*ww);
504 _uploadTable->horizontalHeader()->resizeSection(4,11*ww);
505 _uploadTable->horizontalHeader()->resizeSection(5,4*ww);
506 _uploadTable->horizontalHeader()->resizeSection(6,15*ww);
507 _uploadTable->horizontalHeader()->resizeSection(7,15*ww);
508 _uploadTable->horizontalHeader()->resizeSection(8,10*ww);
509 _uploadTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
510 _uploadTable->horizontalHeader()->setStretchLastSection(true);
511 _uploadTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
512
513 connect(_uploadTable, SIGNAL(itemSelectionChanged()),
514 SLOT(slotBncTextChanged()));
515
516 QPushButton* addUploadRowButton = new QPushButton("Add Row");
517 QPushButton* delUploadRowButton = new QPushButton("Del Row");
518 QPushButton* setUploadTrafoButton = new QPushButton("Custom Trafo");
519 _uploadIntrComboBox = new QComboBox;
520 _uploadIntrComboBox->setEditable(false);
521 _uploadIntrComboBox->addItems(QString("1 day,1 hour, 30 min,15 min,10 min,5 min,2 min,1 min").split(","));
522 ii = _uploadIntrComboBox->findText(settings.value("uploadIntr").toString());
523 if (ii != -1) {
524 _uploadIntrComboBox->setCurrentIndex(ii);
525 }
526 _uploadSamplSpinBox = new QSpinBox;
527 _uploadSamplSpinBox->setMinimum(5);
528 _uploadSamplSpinBox->setMaximum(60);
529 _uploadSamplSpinBox->setSingleStep(5);
530 _uploadSamplSpinBox->setMaximumWidth(9*ww);
531 _uploadSamplSpinBox->setValue(settings.value("uploadSampl").toInt());
532 _uploadSamplSpinBox->setSuffix(" sec");
533
534 _uploadSamplOrbSpinBox = new QSpinBox;
535 _uploadSamplOrbSpinBox->setMinimum(0);
536 _uploadSamplOrbSpinBox->setMaximum(60);
537 _uploadSamplOrbSpinBox->setSingleStep(5);
538 _uploadSamplOrbSpinBox->setMaximumWidth(9*ww);
539 _uploadSamplOrbSpinBox->setValue(settings.value("uploadSamplOrb").toInt());
540 _uploadSamplOrbSpinBox->setSuffix(" sec");
541
542 // Upload RTCM3 Ephemeris
543 // ----------------------
544 _uploadEphHostLineEdit = new QLineEdit(settings.value("uploadEphHost").toString());
545 _uploadEphPortLineEdit = new QLineEdit(settings.value("uploadEphPort").toString());
546 _uploadEphPasswordLineEdit = new QLineEdit(settings.value("uploadEphPassword").toString());
547 _uploadEphPasswordLineEdit->setEchoMode(QLineEdit::PasswordEchoOnEdit);
548 _uploadEphMountpointLineEdit = new QLineEdit(settings.value("uploadEphMountpoint").toString());
549 _uploadEphSampleSpinBox = new QSpinBox;
550 _uploadEphSampleSpinBox->setMinimum(5);
551 _uploadEphSampleSpinBox->setMaximum(60);
552 _uploadEphSampleSpinBox->setSingleStep(5);
553 _uploadEphSampleSpinBox->setMaximumWidth(9*ww);
554 _uploadEphSampleSpinBox->setValue(settings.value("uploadEphSample").toInt());
555 _uploadEphSampleSpinBox->setSuffix(" sec");
556 _uploadEphBytesCounter = new bncBytesCounter;
557
558 // WhatsThis
559 // ---------
560 _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>"));
561 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
562 _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 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>"));
563 _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."));
564 _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."));
565 _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."));
566 _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."));
567 _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."));
568 _corrTimeSpinBox->setWhatsThis(tr("<p>Concerning output through IP port, BNC drops Broadcast Ephemeris Corrections received later than 'Wait for full 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>"));
569 _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."));
570 _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."));
571 _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."));
572 _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>"));
573 _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>"));
574 _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>"));
575 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
576 _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p>"));
577
578 _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', '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>"));
579 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
580 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
581 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of the Broadcast Ephemeris Correction files.</p>"));
582 _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>"));
583 _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>"));
584 _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>"));
585 _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>"));
586 _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>"));
587 _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."));
588 _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>"));
589 _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>"));
590 _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' and 'RTCM_3.x'.</p><p>In case you need to log the raw data as is, BNC allows users to by-pass its decoders and 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>"));
591 _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."));
592 _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)."));
593 _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."));
594 _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."));
595 _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."));
596 _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>"));
597 _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>"));
598 _serialMountPointLineEdit->setWhatsThis(tr("<p>Enter a 'Mountpoint' to forward the corresponding stream to a serial connected receiver.</p>"));
599 _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>"));
600 _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>"));
601 _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>"));
602 _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>"));
603 _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>"));
604 _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>"));
605 _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>"));
606 _serialFileNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where NMEA messages coming from your serial connected receiver are saved.</p>"));
607 _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>"));
608 _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>"));
609 _pppCorrMountLineEdit->setWhatsThis(tr("<p>You must specify an orbit/clock corrections stream by its mountpoint from the 'Streams' list compiled below. Example: 'CLK10'</p>"));
610 _pppSPPComboBox->setWhatsThis(tr("<p>Choose between plain Single Point Positioning (SPP) and Precise Point Positioning (PPP).</p>"));
611 _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>"));
612 _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>"));
613 _pppGLONASSCheckBox->setWhatsThis(tr("<p>By default BNC does not use GLONASS observations in PPP mode.</p><p>Tick 'Use GLONASS' for a combined processing of both, GPS and GLONASS observations in PPP mode.</p>"));
614 _pppGalileoCheckBox->setWhatsThis(tr("<p>By default BNC does not use Galileo observations in PPP mode.</p><p>Tick 'Use Galileo' for a combined processing of both, GPS and Galileo observations in PPP mode.</p>"));
615 _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."));
616 _pppNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where PPP results are saved as NMEA messages.</p>"));
617 _pppNMEAPortLineEdit->setWhatsThis(tr("<p>Specify an IP port number to output PPP results as NMEA messages through an IP port.</p>"));
618 _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>"));
619 _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>"));
620 _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 the Quick-Start mode and fixes the introduced reference coordinate for the specified Quick-Start period. A value of '120' 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>"));
621 _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>"));
622 _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>"));
623 _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."));
624 _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>"));
625 _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>"));
626 _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 1e-6 (default) would mean that the tropospheric effect may vary for 3600 * 1e-6 = 0.0036 meters per hour.</p>"));
627 _pppRefCrdXLineEdit->setWhatsThis(tr("<p>Enter reference coordinate X of the receiver's position.</p>"));
628 _pppRefCrdYLineEdit->setWhatsThis(tr("<p>Enter reference coordinate Y of the receiver's position.</p>"));
629 _pppRefCrdZLineEdit->setWhatsThis(tr("<p>Enter reference coordinate Z of the receiver's position.</p>"));
630 _pppRefdNLineEdit->setWhatsThis(tr("<p>Enter north antenna excentricity.</p>"));
631 _pppRefdELineEdit->setWhatsThis(tr("<p>Enter east antenna excentricity.</p>"));
632 _pppRefdULineEdit->setWhatsThis(tr("<p>Enter up antenna excentricity.</p>"));
633 _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."));
634 _pppSync->setWhatsThis(tr(
635 "<p> Zero value (or empty field, default) means that BNC processes each epoch of data "
636 "immediately after its arrival using satellite clock corrections available at "
637 "that time.</p><p> Non-zero value 'Sync Corr' (i.e. 5) means that the epochs of data "
638 "are buffered and the processing of each epoch is postponed till the satellite clock "
639 "corrections not older than 'Sync Corr' seconds are available.<p>"));
640 _pppAntexLineEdit->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>"));
641 _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>"));
642 _pppApplySatAntCheckBox->setWhatsThis(tr("<p>This option is not yet working.</p><p>Satellite orbit and clock corrections refer to the satellite's antenna phase centers and hence observations are actually <u>not</u> to be corrected for satellite antenna phase center offsets. However, you may like to tick 'Apply Offsets' to force BNC to correct observations for satellite antenna phase center offsets.</p><p>Default is to <u>not</u> correct observations for satellite antenna phase center offsets."));
643 _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 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.</p><p>Note that an appropriate 'Wait for full 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.</p><p>Note further that the sequence of rows in the 'Combination Table' is of importance because the orbit information in the final combination stream is just copied from the stream listed in the first row. Hence the first line in the 'Combination Table' defines a kind of 'Master AC'. The update rate of the combination product follows the 'Master AC's update rate.</p><p>The combination process requires Broadcast Ephemeris. Besides the orbit and clock corrections stream(s) BNC must therefore pull a stream carrying Broadcast Ephemeris in the form of RTCM Version 3 messages.</p>"));
644 addCmbRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the mountpoints table."));
645 delCmbRowButton->setWhatsThis(tr("Hit 'Delete' button to delete the highlighted line from the mountpoints table."));
646
647 // Canvas with Editable Fields
648 // ---------------------------
649 _canvas = new QWidget;
650 setCentralWidget(_canvas);
651
652 _aogroup = new QTabWidget();
653 QWidget* pgroup = new QWidget();
654 QWidget* ggroup = new QWidget();
655 QWidget* sgroup = new QWidget();
656 QWidget* egroup = new QWidget();
657 QWidget* agroup = new QWidget();
658 QWidget* cgroup = new QWidget();
659 QWidget* ogroup = new QWidget();
660 QWidget* rgroup = new QWidget();
661 QWidget* sergroup = new QWidget();
662 QWidget* pppgroup = new QWidget();
663 QWidget* ppp2group = new QWidget();
664 QWidget* cmbgroup = new QWidget();
665 QWidget* uploadgroup = new QWidget();
666 QWidget* uploadEphgroup = new QWidget();
667 _aogroup->addTab(pgroup,tr("Network"));
668 _aogroup->addTab(ggroup,tr("General"));
669 _aogroup->addTab(ogroup,tr("RINEX Observations"));
670 _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
671 _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
672 _aogroup->addTab(sgroup,tr("Feed Engine"));
673 _aogroup->addTab(sergroup,tr("Serial Output"));
674 _aogroup->addTab(agroup,tr("Outages"));
675 _aogroup->addTab(rgroup,tr("Miscellaneous"));
676 _aogroup->addTab(pppgroup,tr("PPP (1)"));
677 _aogroup->addTab(ppp2group,tr("PPP (2)"));
678#ifdef USE_COMBINATION
679 _aogroup->addTab(cmbgroup,tr("Combination"));
680#endif
681 _aogroup->addTab(uploadgroup,tr("Upload (clk)"));
682 _aogroup->addTab(uploadEphgroup,tr("Upload (eph)"));
683
684 // Log Tab
685 // -------
686 _loggroup = new QTabWidget();
687 _loggroup->addTab(_log,tr("Log"));
688 _loggroup->addTab(_bncFigure,tr("Throughput"));
689 _loggroup->addTab(_bncFigureLate,tr("Latency"));
690 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
691
692 // Netowork (Proxy and SSL) Tab
693 // ----------------------------
694 QGridLayout* pLayout = new QGridLayout;
695 pLayout->setColumnMinimumWidth(0,13*ww);
696 _proxyPortLineEdit->setMaximumWidth(9*ww);
697
698 pLayout->addWidget(new QLabel("Proxy host"), 0, 0);
699 pLayout->addWidget(_proxyHostLineEdit, 0, 1, 1,10);
700 pLayout->addWidget(new QLabel("Proxy port"), 1, 0);
701 pLayout->addWidget(_proxyPortLineEdit, 1, 1);
702 pLayout->addWidget(new QLabel("Settings for proxy in protected networks, leave boxes blank if none."),2, 0, 1, 50, Qt::AlignLeft);
703 pLayout->addWidget(new QLabel(" "),3,0);
704 pLayout->addWidget(new QLabel(" "),4,0);
705 pLayout->addWidget(new QLabel("Path to SSL Certificates"), 5, 0);
706 pLayout->addWidget(_sslCaCertPathLineEdit, 5, 1, 1,10);
707 pLayout->addWidget(new QLabel("default: " + bncSslConfig::defaultPath()), 5, 12, 1,20);
708 pLayout->addWidget(new QLabel("Ignore SSL Authorization Errors"), 6,0);
709 pLayout->addWidget(_ignoreSslErrorsCheckBox, 6, 1, 1,10);
710 pLayout->addWidget(new QLabel("Settings for SSL Authorization."),7, 0, 1, 50, Qt::AlignLeft);
711 pgroup->setLayout(pLayout);
712
713 // General Tab
714 // -----------
715 QGridLayout* gLayout = new QGridLayout;
716 gLayout->setColumnMinimumWidth(0,14*ww);
717 _onTheFlyComboBox->setMaximumWidth(9*ww);
718
719 gLayout->addWidget(new QLabel("Logfile (full path)"), 0, 0);
720 gLayout->addWidget(_logFileLineEdit, 0, 1, 1,30); // 1
721 gLayout->addWidget(new QLabel("Append files"), 1, 0);
722 gLayout->addWidget(_rnxAppendCheckBox, 1, 1);
723 gLayout->addWidget(new QLabel("Reread configuration"), 2, 0);
724 gLayout->addWidget(_onTheFlyComboBox, 2, 1);
725 gLayout->addWidget(new QLabel("Auto start"), 3, 0);
726 gLayout->addWidget(_autoStartCheckBox, 3, 1);
727 gLayout->addWidget(new QLabel("Raw output file (full path)"), 4, 0);
728 gLayout->addWidget(_rawOutFileLineEdit, 4, 1, 1,30);
729 gLayout->addWidget(new QLabel("General settings for logfile, file handling, configuration on-the-fly, and auto-start."),5, 0, 1, 50, Qt::AlignLeft);
730 ggroup->setLayout(gLayout);
731
732 // RINEX Observations
733 // ------------------
734 QGridLayout* oLayout = new QGridLayout;
735 oLayout->setColumnMinimumWidth(0,14*ww);
736 _rnxIntrComboBox->setMaximumWidth(9*ww);
737 _rnxSamplSpinBox->setMaximumWidth(9*ww);
738
739 oLayout->addWidget(new QLabel("Directory"), 0, 0);
740 oLayout->addWidget(_rnxPathLineEdit, 0, 1,1,24);
741 oLayout->addWidget(new QLabel("Interval"), 1, 0);
742 oLayout->addWidget(_rnxIntrComboBox, 1, 1);
743 oLayout->addWidget(new QLabel(" Sampling"), 1, 2, Qt::AlignRight);
744 oLayout->addWidget(_rnxSamplSpinBox, 1, 3, Qt::AlignLeft);
745 oLayout->addWidget(new QLabel("Skeleton extension"), 2, 0);
746 oLayout->addWidget(_rnxSkelLineEdit, 2, 1,1,1, Qt::AlignLeft);
747 oLayout->addWidget(new QLabel("Script (full path)"), 3, 0);
748 oLayout->addWidget(_rnxScrpLineEdit, 3, 1,1,24);
749 oLayout->addWidget(new QLabel("Version 3"), 4, 0);
750 oLayout->addWidget(_rnxV3CheckBox, 4, 1);
751 oLayout->addWidget(new QLabel("Saving RINEX observation files."),5,0,1,50, Qt::AlignLeft);
752 ogroup->setLayout(oLayout);
753
754 // RINEX Ephemeris
755 // ---------------
756 QGridLayout* eLayout = new QGridLayout;
757 eLayout->setColumnMinimumWidth(0,14*ww);
758 _ephIntrComboBox->setMaximumWidth(9*ww);
759 _outEphPortLineEdit->setMaximumWidth(9*ww);
760
761 eLayout->addWidget(new QLabel("Directory"), 0, 0);
762 eLayout->addWidget(_ephPathLineEdit, 0, 1, 1,30);
763 eLayout->addWidget(new QLabel("Interval"), 1, 0);
764 eLayout->addWidget(_ephIntrComboBox, 1, 1);
765 eLayout->addWidget(new QLabel("Port"), 2, 0);
766 eLayout->addWidget(_outEphPortLineEdit, 2, 1);
767 eLayout->addWidget(new QLabel("Version 3"), 3, 0);
768 eLayout->addWidget(_ephV3CheckBox, 3, 1);
769 eLayout->addWidget(new QLabel("Saving RINEX ephemeris files and ephemeris output through IP port."),4,0,1,50,Qt::AlignLeft);
770 eLayout->addWidget(new QLabel(" "),5,0);
771 egroup->setLayout(eLayout);
772
773
774 // Broadcast Corrections
775 // ---------------------
776 QGridLayout* cLayout = new QGridLayout;
777 cLayout->setColumnMinimumWidth(0,14*ww);
778 _corrIntrComboBox->setMaximumWidth(9*ww);
779 _corrPortLineEdit->setMaximumWidth(9*ww);
780 _corrTimeSpinBox->setMaximumWidth(9*ww);
781
782 cLayout->addWidget(new QLabel("Directory, ASCII"), 0, 0);
783 cLayout->addWidget(_corrPathLineEdit, 0, 1,1,20);
784 cLayout->addWidget(new QLabel("Interval"), 1, 0);
785 cLayout->addWidget(_corrIntrComboBox, 1, 1);
786 cLayout->addWidget(new QLabel("Port"), 2, 0);
787 cLayout->addWidget(_corrPortLineEdit, 2, 1);
788 cLayout->addWidget(new QLabel(" Wait for full epoch"), 2, 2, Qt::AlignRight);
789 cLayout->addWidget(_corrTimeSpinBox, 2, 3, Qt::AlignLeft);
790 cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port."),3,0,1,50);
791 cLayout->addWidget(new QLabel(" "),4,0);
792 cLayout->addWidget(new QLabel(" "),5,0);
793 cgroup->setLayout(cLayout);
794
795 // Feed Engine
796 // -----------
797 QGridLayout* sLayout = new QGridLayout;
798 sLayout->setColumnMinimumWidth(0,14*ww);
799 _outPortLineEdit->setMaximumWidth(9*ww);
800 _waitTimeSpinBox->setMaximumWidth(9*ww);
801 _binSamplSpinBox->setMaximumWidth(9*ww);
802 _outUPortLineEdit->setMaximumWidth(9*ww);
803
804 sLayout->addWidget(new QLabel("Port"), 0, 0);
805 sLayout->addWidget(_outPortLineEdit, 0, 1);
806 sLayout->addWidget(new QLabel("Wait for full epoch"), 0, 2, Qt::AlignRight);
807 sLayout->addWidget(_waitTimeSpinBox, 0, 3, Qt::AlignLeft);
808 sLayout->addWidget(new QLabel("Sampling"), 1, 0);
809 sLayout->addWidget(_binSamplSpinBox, 1, 1, Qt::AlignLeft);
810 sLayout->addWidget(new QLabel("File (full path)"), 2, 0);
811 sLayout->addWidget(_outFileLineEdit, 2, 1, 1, 20);
812 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 3, 0);
813 sLayout->addWidget(_outUPortLineEdit, 3, 1);
814 sLayout->addWidget(new QLabel("Output decoded observations in a binary format to feed a real-time GNSS network engine."),4,0,1,50);
815 sLayout->addWidget(new QLabel(" "),5,0);
816 sgroup->setLayout(sLayout);
817
818 // Serial Output
819 // -------------
820 QGridLayout* serLayout = new QGridLayout;
821 serLayout->setColumnMinimumWidth(0,14*ww);
822 _serialBaudRateComboBox->setMaximumWidth(9*ww);
823 _serialFlowControlComboBox->setMaximumWidth(11*ww);
824 _serialDataBitsComboBox->setMaximumWidth(5*ww);
825 _serialParityComboBox->setMaximumWidth(9*ww);
826 _serialStopBitsComboBox->setMaximumWidth(5*ww);
827 _serialAutoNMEAComboBox->setMaximumWidth(9*ww);
828 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
829
830 serLayout->addWidget(new QLabel("Mountpoint"), 0,0, Qt::AlignLeft);
831 serLayout->addWidget(_serialMountPointLineEdit, 0,1,1,2);
832 serLayout->addWidget(new QLabel("Port name"), 1,0, Qt::AlignLeft);
833 serLayout->addWidget(_serialPortNameLineEdit, 1,1,1,2);
834 serLayout->addWidget(new QLabel("Baud rate"), 2,0, Qt::AlignLeft);
835 serLayout->addWidget(_serialBaudRateComboBox, 2,1);
836 serLayout->addWidget(new QLabel("Flow control"), 2,2, Qt::AlignRight);
837 serLayout->addWidget(_serialFlowControlComboBox, 2,3);
838 serLayout->addWidget(new QLabel("Data bits"), 3,0, Qt::AlignLeft);
839 serLayout->addWidget(_serialDataBitsComboBox, 3,1);
840 serLayout->addWidget(new QLabel("Parity"), 3,2, Qt::AlignRight);
841 serLayout->addWidget(_serialParityComboBox, 3,3);
842 serLayout->addWidget(new QLabel(" Stop bits"), 3,4, Qt::AlignRight);
843 serLayout->addWidget(_serialStopBitsComboBox, 3,5);
844 serLayout->addWidget(new QLabel("NMEA"), 4,0);
845 serLayout->addWidget(_serialAutoNMEAComboBox, 4,1);
846 serLayout->addWidget(new QLabel(" File (full path)"), 4,2, Qt::AlignRight);
847 serLayout->addWidget(_serialFileNMEALineEdit, 4,3,1,15);
848 serLayout->addWidget(new QLabel("Height"), 4,20, Qt::AlignRight);
849 serLayout->addWidget(_serialHeightNMEALineEdit, 4,21,1,11);
850 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver."),5,0,1,30);
851
852 sergroup->setLayout(serLayout);
853
854 // Outages
855 // -------
856 QGridLayout* aLayout = new QGridLayout;
857 aLayout->setColumnMinimumWidth(0,14*ww);
858 _obsRateComboBox->setMaximumWidth(9*ww);
859 _adviseFailSpinBox->setMaximumWidth(9*ww);
860 _adviseRecoSpinBox->setMaximumWidth(9*ww);
861
862 aLayout->addWidget(new QLabel("Observation rate"), 0, 0);
863 aLayout->addWidget(_obsRateComboBox, 0, 1);
864 aLayout->addWidget(new QLabel("Failure threshold"), 1, 0);
865 aLayout->addWidget(_adviseFailSpinBox, 1, 1);
866 aLayout->addWidget(new QLabel("Recovery threshold"), 2, 0);
867 aLayout->addWidget(_adviseRecoSpinBox, 2, 1);
868 aLayout->addWidget(new QLabel("Script (full path)"), 3, 0);
869 aLayout->addWidget(_adviseScriptLineEdit, 3, 1,1,30);
870 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes."),4,0,1,50,Qt::AlignLeft);
871 aLayout->addWidget(new QLabel(" "), 5, 0);
872 agroup->setLayout(aLayout);
873
874 // Miscellaneous
875 // -------------
876 QGridLayout* rLayout = new QGridLayout;
877 rLayout->setColumnMinimumWidth(0,14*ww);
878 _perfIntrComboBox->setMaximumWidth(9*ww);
879
880 rLayout->addWidget(new QLabel("Mountpoint"), 0, 0);
881 rLayout->addWidget(_miscMountLineEdit, 0, 1, 1,7);
882 rLayout->addWidget(new QLabel("Log latency"), 1, 0);
883 rLayout->addWidget(_perfIntrComboBox, 1, 1);
884 rLayout->addWidget(new QLabel("Scan RTCM"), 2, 0);
885 rLayout->addWidget(_scanRTCMCheckBox, 2, 1);
886 rLayout->addWidget(new QLabel("Log latencies or scan RTCM streams for numbers of message types and antenna information."),3, 0,1,30);
887 rLayout->addWidget(new QLabel(" "), 4, 0);
888 rLayout->addWidget(new QLabel(" "), 5, 0);
889 rgroup->setLayout(rLayout);
890
891 // PPP Client
892 // ----------
893 QGridLayout* pppLayout = new QGridLayout;
894 _pppSigCLineEdit->setMaximumWidth(6*ww);
895 _pppSigPLineEdit->setMaximumWidth(6*ww);
896 _pppSigCrd0->setMaximumWidth(6*ww);
897 _pppSigCrdP->setMaximumWidth(6*ww);
898 _pppSigTrp0->setMaximumWidth(6*ww);
899 _pppSigTrpP->setMaximumWidth(6*ww);
900 _pppAverageLineEdit->setMaximumWidth(6*ww);
901 _pppQuickStartLineEdit->setMaximumWidth(6*ww);
902 _pppMaxSolGapLineEdit->setMaximumWidth(6*ww);
903 _pppRefCrdXLineEdit->setMaximumWidth(10*ww);
904 _pppRefCrdYLineEdit->setMaximumWidth(10*ww);
905 _pppRefCrdZLineEdit->setMaximumWidth(10*ww);
906 _pppRefdNLineEdit->setMaximumWidth(5*ww);
907 _pppRefdELineEdit->setMaximumWidth(5*ww);
908 _pppRefdULineEdit->setMaximumWidth(5*ww);
909 _pppSync->setMaximumWidth(6*ww);
910 _pppSPPComboBox->setMaximumWidth(8*ww);
911 _pppNMEAPortLineEdit->setMaximumWidth(6*ww);
912 int ir = 0;
913 pppLayout->addWidget(new QLabel("<b>Precise Point Positioning (Panel 1)</b>"), ir, 0, 1, 8);
914 ++ir;
915 pppLayout->addWidget(new QLabel("Obs Mountpoint"), ir, 0);
916 pppLayout->addWidget(_pppMountLineEdit, ir, 1);
917 pppLayout->addWidget(_pppSPPComboBox, ir, 2);
918 pppLayout->addWidget(new QLabel(" X "), ir, 3, Qt::AlignRight);
919 pppLayout->addWidget(_pppRefCrdXLineEdit, ir, 4);
920 pppLayout->addWidget(new QLabel(" Y "), ir, 5, Qt::AlignRight);
921 pppLayout->addWidget(_pppRefCrdYLineEdit, ir, 6);
922 pppLayout->addWidget(new QLabel(" Z "), ir, 7, Qt::AlignRight);
923 pppLayout->addWidget(_pppRefCrdZLineEdit, ir, 8);
924 ++ir;
925 pppLayout->addWidget(new QLabel("Corr Mountpoint "), ir, 0);
926 pppLayout->addWidget(_pppCorrMountLineEdit, ir, 1);
927 pppLayout->addWidget(new QLabel(" dN "), ir, 3, Qt::AlignRight);
928 pppLayout->addWidget(_pppRefdNLineEdit, ir, 4);
929 pppLayout->addWidget(new QLabel(" dE "), ir, 5, Qt::AlignRight);
930 pppLayout->addWidget(_pppRefdELineEdit, ir, 6);
931 pppLayout->addWidget(new QLabel(" dU "), ir, 7, Qt::AlignRight);
932 pppLayout->addWidget(_pppRefdULineEdit, ir, 8);
933 ++ir;
934 pppLayout->addWidget(new QLabel("Options"), ir, 0, 1, 5);
935 pppLayout->addWidget(_pppUsePhaseCheckBox, ir, 1, Qt::AlignRight);
936 pppLayout->addWidget(new QLabel("Use phase obs"), ir, 2);
937 pppLayout->addWidget(_pppEstTropoCheckBox, ir, 3, Qt::AlignRight);
938 pppLayout->addWidget(new QLabel("Estimate tropo"), ir, 4);
939 pppLayout->addWidget(_pppGLONASSCheckBox, ir, 5, Qt::AlignRight);
940 pppLayout->addWidget(new QLabel("Use GLONASS"), ir, 6);
941 pppLayout->addWidget(_pppGalileoCheckBox, ir, 7, Qt::AlignRight);
942 pppLayout->addWidget(new QLabel("Use Galileo "), ir, 8);
943 ++ir;
944 pppLayout->addWidget(new QLabel("Output"), ir, 0);
945 pppLayout->addWidget(_pppNMEALineEdit, ir, 1, 1, 3);
946 pppLayout->addWidget(new QLabel("NMEA File"), ir, 4);
947 pppLayout->addWidget(_pppNMEAPortLineEdit, ir, 5, Qt::AlignRight);
948 pppLayout->addWidget(new QLabel("NMEA Port"), ir, 6);
949 pppLayout->addWidget(_pppPlotCoordinates, ir, 7, Qt::AlignRight);
950 pppLayout->addWidget(new QLabel("PPP Plot"), ir, 8);
951 ++ir;
952 pppLayout->addWidget(new QLabel("<b>Post-Processing</b>"), ir, 0);
953 ++ir;
954 pppLayout->addWidget(new QLabel(" "), ir, 0);
955 pppLayout->setRowStretch(ir, 99);
956
957 pppgroup->setLayout(pppLayout);
958
959 // PPP Client (second panel)
960 // -------------------------
961 QGridLayout* ppp2Layout = new QGridLayout;
962 ir = 0;
963 ppp2Layout->addWidget(new QLabel("<b>Precise Point Positioning (Panel 2)</b>"), ir, 0, 1, 8);
964 ++ir;
965 ppp2Layout->addWidget(new QLabel("Antennas"), ir, 0);
966 ppp2Layout->addWidget(_pppAntexLineEdit, ir, 1, 1, 3);
967 ppp2Layout->addWidget(new QLabel("ANTEX File "), ir, 4);
968 ppp2Layout->addWidget(_pppAntennaLineEdit, ir, 5, 1, 3);
969 ppp2Layout->addWidget(new QLabel("Rec. Ant. Name"), ir, 8);
970 ++ir;
971 ppp2Layout->addWidget(new QLabel("Satellite Antenna "), ir, 0);
972 ppp2Layout->addWidget(_pppApplySatAntCheckBox, ir, 1, Qt::AlignRight);
973 ppp2Layout->addWidget(new QLabel("Apply Offsets"), ir, 2, Qt::AlignLeft);
974 ++ir;
975 ppp2Layout->addWidget(new QLabel("Sigmas"), ir, 0);
976 ppp2Layout->addWidget(_pppSigCLineEdit, ir, 1, Qt::AlignRight);
977 ppp2Layout->addWidget(new QLabel("Code"), ir, 2);
978 ppp2Layout->addWidget(_pppSigPLineEdit, ir, 3);
979 ppp2Layout->addWidget(new QLabel("Phase"), ir, 4);
980 ppp2Layout->addWidget(_pppSigTrp0, ir, 5, Qt::AlignRight);
981 ppp2Layout->addWidget(new QLabel("Tropo Init "), ir, 6);
982 ppp2Layout->addWidget(_pppSigTrpP, ir, 7);
983 ppp2Layout->addWidget(new QLabel("Tropo White Noise"), ir, 8);
984 ++ir;
985 ppp2Layout->addWidget(new QLabel("Options cont'd"), ir, 0);
986 ppp2Layout->addWidget(_pppSigCrd0, ir, 1, Qt::AlignRight);
987 ppp2Layout->addWidget(new QLabel("Sigma XYZ Init "), ir, 2);
988 ppp2Layout->addWidget(_pppSigCrdP, ir, 3, Qt::AlignRight);
989 ppp2Layout->addWidget(new QLabel("Sigma XYZ Noise "), ir, 4);
990 ppp2Layout->addWidget(_pppQuickStartLineEdit, ir, 5, Qt::AlignRight);
991 ppp2Layout->addWidget(new QLabel("Quick-Start (sec) "), ir, 6);
992 ppp2Layout->addWidget(_pppMaxSolGapLineEdit, ir, 7, Qt::AlignRight);
993 ppp2Layout->addWidget(new QLabel("Max Sol. Gap (sec)"), ir, 8);
994 ++ir;
995 ppp2Layout->addWidget(new QLabel("Options cont'd"), ir, 0);
996 ppp2Layout->addWidget(_pppSync, ir, 1);
997 ppp2Layout->addWidget(new QLabel("Sync Corr (sec) "), ir, 2);
998 ppp2Layout->addWidget(_pppAverageLineEdit, ir, 3, Qt::AlignRight);
999 ppp2Layout->addWidget(new QLabel("Averaging (min)") , ir, 4);
1000 ++ir;
1001 ppp2Layout->addWidget(new QLabel(" "), ir, 0);
1002 ppp2Layout->setRowStretch(ir, 99);
1003
1004 ppp2group->setLayout(ppp2Layout);
1005
1006 // Combination
1007 // -----------
1008 QGridLayout* cmbLayout = new QGridLayout;
1009
1010 populateCmbTable();
1011 cmbLayout->addWidget(_cmbTable,0,0,6,3);
1012
1013 cmbLayout->addWidget(addCmbRowButton,1,3);
1014 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1015 cmbLayout->addWidget(delCmbRowButton,2,3);
1016 cmbLayout->addWidget(new QLabel("Method"), 3, 3);
1017 cmbLayout->addWidget(_cmbMethodComboBox, 3, 4, Qt::AlignRight);
1018 cmbLayout->addWidget(new QLabel("Maximal Residuum"), 4, 3);
1019 cmbLayout->addWidget(_cmbMaxresLineEdit, 4, 4, Qt::AlignRight);
1020 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
1021
1022 cmbLayout->addWidget(new QLabel(" Combine Broadcast Ephemeris corrections streams."),5,3,1,3);
1023
1024 cmbgroup->setLayout(cmbLayout);
1025
1026 // Upload Layout (Clocks)
1027 // ----------------------
1028 QGridLayout* uploadHlpLayout = new QGridLayout();
1029
1030 uploadHlpLayout->addWidget(new QLabel("Upload RTNet or Combination Results"),0,0);
1031
1032 uploadHlpLayout->addWidget(addUploadRowButton,0,1);
1033 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1034
1035 uploadHlpLayout->addWidget(delUploadRowButton,0,2);
1036 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1037
1038 uploadHlpLayout->addWidget(setUploadTrafoButton,1,1);
1039 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
1040
1041 uploadHlpLayout->addWidget(new QLabel("Interval"),0,3, Qt::AlignRight);
1042 uploadHlpLayout->addWidget(_uploadIntrComboBox,0,4);
1043
1044 uploadHlpLayout->addWidget(new QLabel("Sampling"),1,3, Qt::AlignRight);
1045 uploadHlpLayout->addWidget(_uploadSamplSpinBox,1,4);
1046
1047 uploadHlpLayout->addWidget(new QLabel("Sampling (Orb)"),1,5, Qt::AlignRight);
1048 uploadHlpLayout->addWidget(_uploadSamplOrbSpinBox,1,6);
1049
1050 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1051 populateUploadTable();
1052 uploadLayout->addWidget(_uploadTable);
1053 uploadLayout->addLayout(uploadHlpLayout);
1054
1055 uploadgroup->setLayout(uploadLayout);
1056
1057 // Upload Layout (Ephemeris)
1058 // -------------------------
1059 QGridLayout* uploadLayoutEph = new QGridLayout;
1060
1061 uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1062 _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1063 _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1064 _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1065
1066 uploadLayoutEph->addWidget(new QLabel("Host"), 0, 0);
1067 uploadLayoutEph->addWidget(_uploadEphHostLineEdit, 0, 1, 1, 3);
1068 uploadLayoutEph->addWidget(new QLabel(" Port"), 0, 4, Qt::AlignRight);
1069 uploadLayoutEph->addWidget(_uploadEphPortLineEdit, 0, 5, 1, 1);
1070 uploadLayoutEph->addWidget(new QLabel("Mountpoint "), 1, 0);
1071 uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit, 1, 1);
1072 uploadLayoutEph->addWidget(new QLabel(" Password"), 1, 2, Qt::AlignRight);
1073 uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit, 1, 3);
1074 uploadLayoutEph->addWidget(new QLabel("Sampling"), 2, 0);
1075 uploadLayoutEph->addWidget(_uploadEphSampleSpinBox, 2, 1);
1076 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster."), 3, 0, 1, 5);
1077 uploadLayoutEph->addWidget(_uploadEphBytesCounter, 3, 5);
1078
1079 uploadEphgroup->setLayout(uploadLayoutEph);
1080
1081 connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1082 this, SLOT(slotBncTextChanged()));
1083
1084 // Main Layout
1085 // -----------
1086 QGridLayout* mLayout = new QGridLayout;
1087 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
1088 mLayout->addWidget(_aogroup, 0,0);
1089 mLayout->addWidget(_mountPointsTable, 1,0);
1090 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
1091 mLayout->addWidget(_loggroup, 2,0);
1092
1093 _canvas->setLayout(mLayout);
1094
1095 // Enable/Disable all Widgets
1096 // --------------------------
1097 slotBncTextChanged();
1098
1099 // Auto start
1100 // ----------
1101 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1102 slotGetData();
1103 }
1104}
1105
1106// Destructor
1107////////////////////////////////////////////////////////////////////////////
1108bncWindow::~bncWindow() {
1109 delete _caster;
1110 delete _casterEph;
1111}
1112
1113//
1114////////////////////////////////////////////////////////////////////////////
1115void bncWindow::populateMountPointsTable() {
1116
1117 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1118 _mountPointsTable->removeRow(iRow);
1119 }
1120
1121 bncSettings settings;
1122
1123 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1124 if (!it.hasNext()) {
1125 _actGetData->setEnabled(false);
1126 }
1127 int iRow = 0;
1128 while (it.hasNext()) {
1129 QStringList hlp = it.next().split(" ");
1130 if (hlp.size() < 5) continue;
1131 _mountPointsTable->insertRow(iRow);
1132
1133 QUrl url(hlp[0]);
1134
1135 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1136 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1137 QString nmea(hlp[4]);
1138 if (hlp[5] == "S") {
1139 fullPath = hlp[0].replace(0,2,"");
1140 }
1141 QString ntripVersion = "2";
1142 if (hlp.size() >= 6) {
1143 ntripVersion = (hlp[5]);
1144 }
1145
1146 QTableWidgetItem* it;
1147 it = new QTableWidgetItem(url.userInfo());
1148 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1149 _mountPointsTable->setItem(iRow, 0, it);
1150
1151 it = new QTableWidgetItem(fullPath);
1152 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1153 _mountPointsTable->setItem(iRow, 1, it);
1154
1155 it = new QTableWidgetItem(format);
1156 _mountPointsTable->setItem(iRow, 2, it);
1157
1158 if (nmea == "yes") {
1159 it = new QTableWidgetItem(latitude);
1160 _mountPointsTable->setItem(iRow, 3, it);
1161 it = new QTableWidgetItem(longitude);
1162 _mountPointsTable->setItem(iRow, 4, it);
1163 } else {
1164 it = new QTableWidgetItem(latitude);
1165 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1166 _mountPointsTable->setItem(iRow, 3, it);
1167 it = new QTableWidgetItem(longitude);
1168 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1169 _mountPointsTable->setItem(iRow, 4, it);
1170 }
1171
1172 it = new QTableWidgetItem(nmea);
1173 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1174 _mountPointsTable->setItem(iRow, 5, it);
1175
1176 it = new QTableWidgetItem(ntripVersion);
1177 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1178 _mountPointsTable->setItem(iRow, 6, it);
1179
1180 bncTableItem* bncIt = new bncTableItem();
1181 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1182 _mountPointsTable->setItem(iRow, 7, bncIt);
1183
1184 iRow++;
1185 }
1186
1187 _mountPointsTable->sortItems(1);
1188}
1189
1190// Retrieve Table
1191////////////////////////////////////////////////////////////////////////////
1192void bncWindow::slotAddMountPoints() {
1193
1194 bncSettings settings;
1195 QString proxyHost = settings.value("proxyHost").toString();
1196 int proxyPort = settings.value("proxyPort").toInt();
1197 if (proxyHost != _proxyHostLineEdit->text() ||
1198 proxyPort != _proxyPortLineEdit->text().toInt()) {
1199 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1200 "changed. Use the new ones?",
1201 QMessageBox::Yes, QMessageBox::No,
1202 QMessageBox::NoButton);
1203 if (iRet == QMessageBox::Yes) {
1204 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1205 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1206 settings.sync();
1207 }
1208 }
1209
1210 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1211 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1212 settings.sync();
1213
1214 QMessageBox msgBox;
1215 msgBox.setIcon(QMessageBox::Question);
1216 msgBox.setWindowTitle("Add Stream");
1217 msgBox.setText("Add stream(s) coming from:");
1218
1219 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1220 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1221 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1222 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1223 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1224
1225 msgBox.exec();
1226
1227 if (msgBox.clickedButton() == buttonNtrip) {
1228 bncTableDlg* dlg = new bncTableDlg(this);
1229 dlg->move(this->pos().x()+50, this->pos().y()+50);
1230 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1231 this, SLOT(slotNewMountPoints(QStringList*)));
1232 dlg->exec();
1233 delete dlg;
1234 } else if (msgBox.clickedButton() == buttonIP) {
1235 bncIpPort* ipp = new bncIpPort(this);
1236 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1237 this, SLOT(slotNewMountPoints(QStringList*)));
1238 ipp->exec();
1239 delete ipp;
1240 } else if (msgBox.clickedButton() == buttonUDP) {
1241 bncUdpPort* udp = new bncUdpPort(this);
1242 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1243 this, SLOT(slotNewMountPoints(QStringList*)));
1244 udp->exec();
1245 delete udp;
1246 } else if (msgBox.clickedButton() == buttonSerial) {
1247 bncSerialPort* sep = new bncSerialPort(this);
1248 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1249 this, SLOT(slotNewMountPoints(QStringList*)));
1250 sep->exec();
1251 delete sep;
1252 } else if (msgBox.clickedButton() == buttonCancel) {
1253 // Cancel
1254 }
1255}
1256
1257// Delete Selected Mount Points
1258////////////////////////////////////////////////////////////////////////////
1259void bncWindow::slotDeleteMountPoints() {
1260
1261 int nRows = _mountPointsTable->rowCount();
1262 bool flg[nRows];
1263 for (int iRow = 0; iRow < nRows; iRow++) {
1264 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1265 flg[iRow] = true;
1266 }
1267 else {
1268 flg[iRow] = false;
1269 }
1270 }
1271 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1272 if (flg[iRow]) {
1273 _mountPointsTable->removeRow(iRow);
1274 }
1275 }
1276 _actDeleteMountPoints->setEnabled(false);
1277
1278 if (_mountPointsTable->rowCount() == 0) {
1279 _actGetData->setEnabled(false);
1280 }
1281}
1282
1283// New Mount Points Selected
1284////////////////////////////////////////////////////////////////////////////
1285void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1286 int iRow = 0;
1287 QListIterator<QString> it(*mountPoints);
1288 while (it.hasNext()) {
1289 QStringList hlp = it.next().split(" ");
1290 QUrl url(hlp[0]);
1291 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1292 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1293 QString nmea(hlp[4]);
1294 if (hlp[5] == "S") {
1295 fullPath = hlp[0].replace(0,2,"");
1296 }
1297 QString ntripVersion = "2";
1298 if (hlp.size() >= 6) {
1299 ntripVersion = (hlp[5]);
1300 }
1301
1302 _mountPointsTable->insertRow(iRow);
1303
1304 QTableWidgetItem* it;
1305 it = new QTableWidgetItem(url.userInfo());
1306 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1307 _mountPointsTable->setItem(iRow, 0, it);
1308
1309 it = new QTableWidgetItem(fullPath);
1310 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1311 _mountPointsTable->setItem(iRow, 1, it);
1312
1313 it = new QTableWidgetItem(format);
1314 _mountPointsTable->setItem(iRow, 2, it);
1315
1316 if (nmea == "yes") {
1317 it = new QTableWidgetItem(latitude);
1318 _mountPointsTable->setItem(iRow, 3, it);
1319 it = new QTableWidgetItem(longitude);
1320 _mountPointsTable->setItem(iRow, 4, it);
1321 } else {
1322 it = new QTableWidgetItem(latitude);
1323 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1324 _mountPointsTable->setItem(iRow, 3, it);
1325 it = new QTableWidgetItem(longitude);
1326 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1327 _mountPointsTable->setItem(iRow, 4, it);
1328 }
1329
1330 it = new QTableWidgetItem(nmea);
1331 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1332 _mountPointsTable->setItem(iRow, 5, it);
1333
1334 it = new QTableWidgetItem(ntripVersion);
1335 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1336 _mountPointsTable->setItem(iRow, 6, it);
1337
1338 bncTableItem* bncIt = new bncTableItem();
1339 _mountPointsTable->setItem(iRow, 7, bncIt);
1340
1341 iRow++;
1342 }
1343 _mountPointsTable->hideColumn(0);
1344 _mountPointsTable->sortItems(1);
1345 if (mountPoints->count() > 0 && !_actStop->isEnabled()) {
1346 _actGetData->setEnabled(true);
1347 }
1348 delete mountPoints;
1349}
1350
1351// Save Options
1352////////////////////////////////////////////////////////////////////////////
1353void bncWindow::slotSaveOptions() {
1354
1355 QStringList mountPoints;
1356 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1357
1358 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1359 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1360 "@" + _mountPointsTable->item(iRow, 1)->text() );
1361
1362 mountPoints.append(url.toString() + " " +
1363 _mountPointsTable->item(iRow, 2)->text()
1364 + " " + _mountPointsTable->item(iRow, 3)->text()
1365 + " " + _mountPointsTable->item(iRow, 4)->text()
1366 + " " + _mountPointsTable->item(iRow, 5)->text()
1367 + " " + _mountPointsTable->item(iRow, 6)->text());
1368 } else {
1369 mountPoints.append(
1370 "//" + _mountPointsTable->item(iRow, 1)->text()
1371 + " " + _mountPointsTable->item(iRow, 2)->text()
1372 + " " + _mountPointsTable->item(iRow, 3)->text()
1373 + " " + _mountPointsTable->item(iRow, 4)->text()
1374 + " " + _mountPointsTable->item(iRow, 5)->text()
1375 + " " + _mountPointsTable->item(iRow, 6)->text());
1376 }
1377 }
1378
1379 QStringList combineStreams;
1380 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1381 QString hlp;
1382 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1383 if (_cmbTable->item(iRow, iCol)) {
1384 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1385 }
1386 }
1387 if (!hlp.isEmpty()) {
1388 combineStreams << hlp;
1389 }
1390 }
1391
1392 QStringList uploadMountpointsOut;
1393 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1394 QString hlp;
1395 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1396 if (_uploadTable->cellWidget(iRow, iCol) &&
1397 (iCol == 3 || iCol == 4 || iCol == 5)) {
1398 if (iCol == 3) {
1399 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1400 hlp += passwd->text() + ",";
1401 }
1402 else if (iCol == 4) {
1403 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1404 hlp += system->currentText() + ",";
1405 }
1406 else if (iCol == 5) {
1407 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1408 QString state; state.setNum(com->checkState());
1409 hlp += state + ",";
1410 }
1411 }
1412 else if (_uploadTable->item(iRow, iCol)) {
1413 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1414 }
1415 }
1416 if (!hlp.isEmpty()) {
1417 uploadMountpointsOut << hlp;
1418 }
1419 }
1420
1421 bncSettings settings;
1422
1423 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1424 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1425 settings.setValue("adviseScript",_adviseScriptLineEdit->text());
1426 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1427 settings.setValue("binSampl", _binSamplSpinBox->value());
1428 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1429 settings.setValue("corrPath", _corrPathLineEdit->text());
1430 settings.setValue("corrPort", _corrPortLineEdit->text());
1431 settings.setValue("corrTime", _corrTimeSpinBox->value());
1432 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1433 settings.setValue("ephPath", _ephPathLineEdit->text());
1434 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1435 settings.setValue("logFile", _logFileLineEdit->text());
1436 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1437 settings.setValue("miscMount", _miscMountLineEdit->text());
1438 settings.setValue("pppMount", _pppMountLineEdit->text());
1439 settings.setValue("pppCorrMount",_pppCorrMountLineEdit->text());
1440 settings.setValue("pppSPP", _pppSPPComboBox->currentText());
1441 settings.setValue("nmeaFile", _pppNMEALineEdit->text());
1442 settings.setValue("nmeaPort", _pppNMEAPortLineEdit->text());
1443 settings.setValue("pppSigmaCode",_pppSigCLineEdit->text());
1444 settings.setValue("pppSigmaPhase",_pppSigPLineEdit->text());
1445 settings.setValue("pppSigCrd0",_pppSigCrd0->text());
1446 settings.setValue("pppSigCrdP",_pppSigCrdP->text());
1447 settings.setValue("pppSigTrp0",_pppSigTrp0->text());
1448 settings.setValue("pppSigTrpP",_pppSigTrpP->text());
1449 settings.setValue("pppAverage", _pppAverageLineEdit->text());
1450 settings.setValue("pppQuickStart", _pppQuickStartLineEdit->text());
1451 settings.setValue("pppMaxSolGap", _pppMaxSolGapLineEdit->text());
1452 settings.setValue("pppRefCrdX", _pppRefCrdXLineEdit->text());
1453 settings.setValue("pppRefCrdY", _pppRefCrdYLineEdit->text());
1454 settings.setValue("pppRefCrdZ", _pppRefCrdZLineEdit->text());
1455 settings.setValue("pppRefdN", _pppRefdNLineEdit->text());
1456 settings.setValue("pppRefdE", _pppRefdELineEdit->text());
1457 settings.setValue("pppRefdU", _pppRefdULineEdit->text());
1458 settings.setValue("pppSync", _pppSync->text());
1459 settings.setValue("pppUsePhase", _pppUsePhaseCheckBox->checkState());
1460 settings.setValue("pppPlotCoordinates", _pppPlotCoordinates->checkState());
1461 settings.setValue("pppEstTropo", _pppEstTropoCheckBox->checkState());
1462 settings.setValue("pppGLONASS", _pppGLONASSCheckBox->checkState());
1463 settings.setValue("pppGalileo", _pppGalileoCheckBox->checkState());
1464 settings.setValue("pppAntenna", _pppAntennaLineEdit->text());
1465 settings.setValue("pppAntex", _pppAntexLineEdit->text());
1466 settings.setValue("pppApplySatAnt", _pppApplySatAntCheckBox->checkState());
1467 settings.setValue("mountPoints", mountPoints);
1468 settings.setValue("obsRate", _obsRateComboBox->currentText());
1469 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1470 settings.setValue("outEphPort", _outEphPortLineEdit->text());
1471 settings.setValue("outFile", _outFileLineEdit->text());
1472 settings.setValue("outPort", _outPortLineEdit->text());
1473 settings.setValue("outUPort", _outUPortLineEdit->text());
1474 settings.setValue("perfIntr", _perfIntrComboBox->currentText());
1475 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1476 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1477 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1478 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1479 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1480 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1481 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1482 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1483 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1484 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1485 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1486 settings.setValue("scanRTCM", _scanRTCMCheckBox->checkState());
1487 settings.setValue("serialFileNMEA",_serialFileNMEALineEdit->text());
1488 settings.setValue("serialHeightNMEA",_serialHeightNMEALineEdit->text());
1489 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1490 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1491 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1492 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1493 settings.setValue("serialParity", _serialParityComboBox->currentText());
1494 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1495 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1496 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1497 settings.setValue("startTab", _aogroup->currentIndex());
1498 settings.setValue("statusTab", _loggroup->currentIndex());
1499 settings.setValue("waitTime", _waitTimeSpinBox->value());
1500 if (!combineStreams.isEmpty()) {
1501 settings.setValue("combineStreams", combineStreams);
1502 }
1503 else {
1504 settings.setValue("combineStreams", "");
1505 }
1506 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1507 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1508
1509 if (!uploadMountpointsOut.isEmpty()) {
1510 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1511 }
1512 else {
1513 settings.setValue("uploadMountpointsOut", "");
1514 }
1515 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1516 settings.setValue("uploadSampl", _uploadSamplSpinBox->value());
1517 settings.setValue("uploadSamplOrb", _uploadSamplOrbSpinBox->value());
1518
1519 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1520 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
1521 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1522 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
1523 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
1524
1525 if (_caster) {
1526 _caster->slotReadMountPoints();
1527 }
1528 settings.sync();
1529}
1530
1531// All get slots terminated
1532////////////////////////////////////////////////////////////////////////////
1533void bncWindow::slotGetThreadsFinished() {
1534 ((bncApp*)qApp)->slotMessage("All Get Threads Terminated", true);
1535 delete _caster; _caster = 0;
1536 delete _casterEph; _casterEph = 0;
1537 _actGetData->setEnabled(true);
1538 _actStop->setEnabled(false);
1539}
1540
1541// Retrieve Data
1542////////////////////////////////////////////////////////////////////////////
1543void bncWindow::slotGetData() {
1544 slotSaveOptions();
1545
1546 _bncFigurePPP->reset();
1547
1548 _actDeleteMountPoints->setEnabled(false);
1549 _actGetData->setEnabled(false);
1550 _actStop->setEnabled(true);
1551
1552 _caster = new bncCaster(_outFileLineEdit->text(),
1553 _outPortLineEdit->text().toInt());
1554
1555 ((bncApp*)qApp)->setPort(_outEphPortLineEdit->text().toInt());
1556 ((bncApp*)qApp)->setPortCorr(_corrPortLineEdit->text().toInt());
1557 ((bncApp*)qApp)->initCombination();
1558
1559 connect(_caster, SIGNAL(getThreadsFinished()),
1560 this, SLOT(slotGetThreadsFinished()));
1561
1562 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
1563 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
1564
1565 ((bncApp*)qApp)->slotMessage("========== Start BNC v" BNCVERSION " =========", true);
1566
1567 bncSettings settings;
1568
1569 QDir rnxdir(settings.value("rnxPath").toString());
1570 if (!rnxdir.exists()) ((bncApp*)qApp)->slotMessage("Cannot find RINEX Observations directory", true);
1571
1572 QString rnx_file = settings.value("rnxScript").toString();
1573 if ( !rnx_file.isEmpty() ) {
1574 QFile rnxfile(settings.value("rnxScript").toString());
1575 if (!rnxfile.exists()) ((bncApp*)qApp)->slotMessage("Cannot find RINEX Observations script", true);
1576 }
1577
1578 QDir ephdir(settings.value("ephPath").toString());
1579 if (!ephdir.exists()) ((bncApp*)qApp)->slotMessage("Cannot find RINEX Ephemeris directory", true);
1580
1581 QDir corrdir(settings.value("corrPath").toString());
1582 if (!corrdir.exists()) ((bncApp*)qApp)->slotMessage("Cannot find Broadcast Corrections directory", true);
1583
1584 QString advise_file = settings.value("adviseScript").toString();
1585 if ( !advise_file.isEmpty() ) {
1586 QFile advisefile(settings.value("adviseScript").toString());
1587 if (!advisefile.exists()) ((bncApp*)qApp)->slotMessage("Cannot find Outages script", true);
1588 }
1589
1590 QString ant_file = settings.value("pppAntex").toString();
1591 if ( !ant_file.isEmpty() ) {
1592 QFile anxfile(settings.value("pppAntex").toString());
1593 if (!anxfile.exists()) ((bncApp*)qApp)->slotMessage("Cannot find IGS ANTEX file", true);
1594 }
1595
1596 _caster->slotReadMountPoints();
1597
1598 _casterEph = new bncEphUploadCaster();
1599 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
1600 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
1601}
1602
1603// Retrieve Data
1604////////////////////////////////////////////////////////////////////////////
1605void bncWindow::slotStop() {
1606 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving data?",
1607 QMessageBox::Yes, QMessageBox::No,
1608 QMessageBox::NoButton);
1609 if (iRet == QMessageBox::Yes) {
1610 ((bncApp*)qApp)->stopCombination();
1611 delete _caster; _caster = 0;
1612 delete _casterEph; _casterEph = 0;
1613 _actGetData->setEnabled(true);
1614 _actStop->setEnabled(false);
1615 }
1616}
1617
1618// Close Application gracefully
1619////////////////////////////////////////////////////////////////////////////
1620void bncWindow::closeEvent(QCloseEvent* event) {
1621
1622 int iRet = QMessageBox::question(this, "Close", "Save Options?",
1623 QMessageBox::Yes, QMessageBox::No,
1624 QMessageBox::Cancel);
1625
1626 if (iRet == QMessageBox::Cancel) {
1627 event->ignore();
1628 return;
1629 }
1630 else if (iRet == QMessageBox::Yes) {
1631 slotSaveOptions();
1632 }
1633
1634 QMainWindow::closeEvent(event);
1635}
1636
1637// User changed the selection of mountPoints
1638////////////////////////////////////////////////////////////////////////////
1639void bncWindow::slotSelectionChanged() {
1640 if (_mountPointsTable->selectedItems().isEmpty()) {
1641 _actDeleteMountPoints->setEnabled(false);
1642 }
1643 else {
1644 _actDeleteMountPoints->setEnabled(true);
1645 }
1646}
1647
1648// Display Program Messages
1649////////////////////////////////////////////////////////////////////////////
1650void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
1651
1652#ifdef DEBUG_RTCM2_2021
1653 const int maxBufferSize = 1000;
1654#else
1655 const int maxBufferSize = 10000;
1656#endif
1657
1658 if (! showOnScreen ) {
1659 return;
1660 }
1661
1662 QString txt = _log->toPlainText() + "\n" +
1663 QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg;
1664 _log->clear();
1665 _log->append(txt.right(maxBufferSize));
1666}
1667
1668// About Message
1669////////////////////////////////////////////////////////////////////////////
1670void bncWindow::slotAbout() {
1671 new bncAboutDlg(0);
1672}
1673
1674//Flowchart
1675////////////////////////////////////////////////////////////////////////////
1676void bncWindow::slotFlowchart() {
1677 new bncFlowchartDlg(0);
1678}
1679
1680// Help Window
1681////////////////////////////////////////////////////////////////////////////
1682void bncWindow::slotHelp() {
1683 QUrl url;
1684 url.setPath(":bnchelp.html");
1685 new bncHlpDlg(0, url);
1686}
1687
1688// Select Fonts
1689////////////////////////////////////////////////////////////////////////////
1690void bncWindow::slotFontSel() {
1691 bool ok;
1692 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
1693 if (ok) {
1694 bncSettings settings;
1695 settings.setValue("font", newFont.toString());
1696 QApplication::setFont(newFont);
1697 int ww = QFontMetrics(newFont).width('w');
1698 setMinimumSize(60*ww, 80*ww);
1699 resize(60*ww, 80*ww);
1700 }
1701}
1702
1703// Whats This Help
1704void bncWindow::slotWhatsThis() {
1705 QWhatsThis::enterWhatsThisMode();
1706}
1707
1708//
1709////////////////////////////////////////////////////////////////////////////
1710void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
1711 _bncFigure->updateMountPoints();
1712 _bncFigureLate->updateMountPoints();
1713
1714 populateMountPointsTable();
1715 bncSettings settings;
1716 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
1717 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
1718 QListIterator<bncGetThread*> iTh(threads);
1719 while (iTh.hasNext()) {
1720 bncGetThread* thread = iTh.next();
1721 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1722 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1723 "@" + _mountPointsTable->item(iRow, 1)->text() );
1724 if (url == thread->mountPoint() &&
1725 _mountPointsTable->item(iRow, 3)->text() == thread->latitude() &&
1726 _mountPointsTable->item(iRow, 4)->text() == thread->longitude() ) {
1727 ((bncTableItem*) _mountPointsTable->item(iRow, 7))->setGetThread(thread);
1728 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
1729 _bncFigure, SLOT(slotNewData(QByteArray, double)));
1730 connect(thread, SIGNAL(newBytes(QByteArray, double)),
1731 _bncFigure, SLOT(slotNewData(QByteArray, double)));
1732 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
1733 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
1734 connect(thread, SIGNAL(newLatency(QByteArray, double)),
1735 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
1736 if ( Qt::CheckState(settings.value("pppPlotCoordinates").toInt()) == Qt::Checked) {
1737 disconnect(thread,
1738 SIGNAL(newPosition(bncTime, double, double, double)),
1739 _bncFigurePPP,
1740 SLOT(slotNewPosition(bncTime, double, double, double)));
1741 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
1742 _bncFigurePPP,
1743 SLOT(slotNewPosition(bncTime, double, double, double)));
1744 }
1745 break;
1746 }
1747 }
1748 }
1749}
1750
1751//
1752////////////////////////////////////////////////////////////////////////////
1753void bncWindow::CreateMenu() {
1754 // Create Menus
1755 // ------------
1756 _menuFile = menuBar()->addMenu(tr("&File"));
1757 _menuFile->addAction(_actFontSel);
1758 _menuFile->addSeparator();
1759 _menuFile->addAction(_actSaveOpt);
1760 _menuFile->addSeparator();
1761 _menuFile->addAction(_actQuit);
1762
1763 _menuHlp = menuBar()->addMenu(tr("&Help"));
1764 _menuHlp->addAction(_actHelp);
1765 _menuHlp->addAction(_actFlowchart);
1766 _menuHlp->addAction(_actAbout);
1767}
1768
1769// Toolbar
1770////////////////////////////////////////////////////////////////////////////
1771void bncWindow::AddToolbar() {
1772 // Tool (Command) Bar
1773 // ------------------
1774 QToolBar* toolBar = new QToolBar;
1775 addToolBar(Qt::BottomToolBarArea, toolBar);
1776 toolBar->setMovable(false);
1777 toolBar->addAction(_actAddMountPoints);
1778 toolBar->addAction(_actDeleteMountPoints);
1779 toolBar->addAction(_actGetData);
1780 toolBar->addAction(_actStop);
1781 toolBar->addWidget(new QLabel(" "));
1782 toolBar->addAction(_actwhatsthis);
1783}
1784
1785// About
1786////////////////////////////////////////////////////////////////////////////
1787bncAboutDlg::bncAboutDlg(QWidget* parent) :
1788 QDialog(parent) {
1789
1790 QTextBrowser* tb = new QTextBrowser;
1791 QUrl url; url.setPath(":bncabout.html");
1792 tb->setSource(url);
1793 tb->setReadOnly(true);
1794
1795 int ww = QFontMetrics(font()).width('w');
1796 QPushButton* _closeButton = new QPushButton("Close");
1797 _closeButton->setMaximumWidth(10*ww);
1798 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
1799
1800 QGridLayout* dlgLayout = new QGridLayout();
1801 QLabel* img = new QLabel();
1802 img->setPixmap(QPixmap(":ntrip-logo.png"));
1803 dlgLayout->addWidget(img, 0,0);
1804 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
1805 dlgLayout->addWidget(tb,1,0,1,2);
1806 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
1807
1808 setLayout(dlgLayout);
1809 resize(60*ww, 60*ww);
1810 setWindowTitle("About BNC");
1811 show();
1812}
1813
1814//
1815////////////////////////////////////////////////////////////////////////////
1816bncAboutDlg::~bncAboutDlg() {
1817};
1818
1819// Flowchart
1820////////////////////////////////////////////////////////////////////////////
1821bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
1822 QDialog(parent) {
1823
1824 int ww = QFontMetrics(font()).width('w');
1825 QPushButton* _closeButton = new QPushButton("Close");
1826 _closeButton->setMaximumWidth(10*ww);
1827 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
1828
1829 QGridLayout* dlgLayout = new QGridLayout();
1830 QLabel* img = new QLabel();
1831 img->setPixmap(QPixmap(":bncflowchart.png"));
1832 dlgLayout->addWidget(img, 0,0);
1833 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
1834
1835 setLayout(dlgLayout);
1836 setWindowTitle("Flow Chart");
1837 show();
1838}
1839
1840//
1841////////////////////////////////////////////////////////////////////////////
1842bncFlowchartDlg::~bncFlowchartDlg() {
1843};
1844
1845// Bnc Text
1846////////////////////////////////////////////////////////////////////////////
1847void bncWindow::slotBncTextChanged(){
1848
1849 QPalette palette_white(QColor(255, 255, 255));
1850 QPalette palette_gray(QColor(230, 230, 230));
1851 bncSettings settings;
1852
1853 // Proxy
1854 //------
1855 if (sender() == 0 || sender() == _proxyHostLineEdit) {
1856 if (!_proxyHostLineEdit->text().isEmpty()) {
1857 _proxyPortLineEdit->setStyleSheet("background-color: white");
1858 _proxyPortLineEdit->setEnabled(true);
1859 }
1860 else {
1861 _proxyPortLineEdit->setStyleSheet("background-color: lightGray");
1862 _proxyPortLineEdit->setEnabled(false);
1863 }
1864 }
1865
1866 // RINEX Observations
1867 // ------------------
1868 if (sender() == 0 || sender() == _rnxPathLineEdit) {
1869 if (!_rnxPathLineEdit->text().isEmpty()) {
1870 _rnxSamplSpinBox->setStyleSheet("background-color: white");
1871 _rnxSkelLineEdit->setStyleSheet("background-color: white");
1872 _rnxScrpLineEdit->setStyleSheet("background-color: white");
1873 _rnxV3CheckBox->setPalette(palette_white);
1874 _rnxIntrComboBox->setStyleSheet("background-color: white");
1875 _rnxSamplSpinBox->setEnabled(true);
1876 _rnxSkelLineEdit->setEnabled(true);
1877 _rnxScrpLineEdit->setEnabled(true);
1878 _rnxV3CheckBox->setEnabled(true);
1879 _rnxIntrComboBox->setEnabled(true);
1880 }
1881 else {
1882 _rnxSamplSpinBox->setStyleSheet("background-color: lightGray");
1883 _rnxSkelLineEdit->setStyleSheet("background-color: lightGray");
1884 _rnxScrpLineEdit->setStyleSheet("background-color: lightGray");
1885 _rnxV3CheckBox->setPalette(palette_gray);
1886 _rnxIntrComboBox->setStyleSheet("background-color: lightGray");
1887 _rnxSamplSpinBox->setEnabled(false);
1888 _rnxSkelLineEdit->setEnabled(false);
1889 _rnxScrpLineEdit->setEnabled(false);
1890 _rnxV3CheckBox->setEnabled(false);
1891 _rnxIntrComboBox->setEnabled(false);
1892 }
1893 }
1894
1895 // RINEX Ephemeris
1896 // ---------------
1897 if (sender() == 0 ||
1898 sender() == _ephPathLineEdit || sender() == _outEphPortLineEdit) {
1899 if (!_ephPathLineEdit->text().isEmpty() ||
1900 !_outEphPortLineEdit->text().isEmpty()) {
1901 _ephIntrComboBox->setStyleSheet("background-color: white");
1902 _ephV3CheckBox->setPalette(palette_white);
1903 _ephIntrComboBox->setEnabled(true);
1904 _ephV3CheckBox->setEnabled(true);
1905 }
1906 else {
1907 _ephIntrComboBox->setStyleSheet("background-color: lightGray");
1908 _ephV3CheckBox->setPalette(palette_gray);
1909 _ephIntrComboBox->setEnabled(false);
1910 _ephV3CheckBox->setEnabled(false);
1911 }
1912 }
1913
1914 // Broadcast Corrections
1915 // ---------------------
1916 if (sender() == 0 ||
1917 sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
1918 if (!_corrPathLineEdit->text().isEmpty() ||
1919 !_corrPortLineEdit->text().isEmpty()) {
1920 _corrIntrComboBox->setStyleSheet("background-color: white");
1921 _corrIntrComboBox->setEnabled(true);
1922 }
1923 else {
1924 _corrIntrComboBox->setStyleSheet("background-color: white");
1925 _corrIntrComboBox->setEnabled(true);
1926 }
1927 }
1928
1929 // Feed Engine
1930 // -----------
1931 if (sender() == 0 ||
1932 sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
1933 if ( !_outPortLineEdit->text().isEmpty() ||
1934 !_outFileLineEdit->text().isEmpty()) {
1935 _waitTimeSpinBox->setStyleSheet("background-color: white");
1936 _binSamplSpinBox->setStyleSheet("background-color: white");
1937 _waitTimeSpinBox->setEnabled(true);
1938 _binSamplSpinBox->setEnabled(true);
1939 }
1940 else {
1941 _waitTimeSpinBox->setStyleSheet("background-color: lightGray");
1942 _binSamplSpinBox->setStyleSheet("background-color: lightGray");
1943 _waitTimeSpinBox->setEnabled(false);
1944 _binSamplSpinBox->setEnabled(false);
1945 }
1946 }
1947
1948 // Serial Output
1949 // -------------
1950 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
1951 sender() == _serialAutoNMEAComboBox) {
1952 if (!_serialMountPointLineEdit->text().isEmpty()) {
1953 _serialPortNameLineEdit->setStyleSheet("background-color: white");
1954 _serialBaudRateComboBox->setStyleSheet("background-color: white");
1955 _serialParityComboBox->setStyleSheet("background-color: white");
1956 _serialDataBitsComboBox->setStyleSheet("background-color: white");
1957 _serialStopBitsComboBox->setStyleSheet("background-color: white");
1958 _serialFlowControlComboBox->setStyleSheet("background-color: white");
1959 _serialAutoNMEAComboBox->setStyleSheet("background-color: white");
1960 _serialPortNameLineEdit->setEnabled(true);
1961 _serialBaudRateComboBox->setEnabled(true);
1962 _serialParityComboBox->setEnabled(true);
1963 _serialDataBitsComboBox->setEnabled(true);
1964 _serialStopBitsComboBox->setEnabled(true);
1965 _serialFlowControlComboBox->setEnabled(true);
1966 _serialAutoNMEAComboBox->setEnabled(true);
1967 if (_serialAutoNMEAComboBox->currentText() != "Auto" ) {
1968 _serialHeightNMEALineEdit->setStyleSheet("background-color: white");
1969 _serialHeightNMEALineEdit->setEnabled(true);
1970 _serialFileNMEALineEdit->setStyleSheet("background-color: lightGray");
1971 _serialFileNMEALineEdit->setEnabled(false);
1972 }
1973 else {
1974 _serialHeightNMEALineEdit->setStyleSheet("background-color: lightGray");
1975 _serialHeightNMEALineEdit->setEnabled(false);
1976 _serialFileNMEALineEdit->setStyleSheet("background-color: white");
1977 _serialFileNMEALineEdit->setEnabled(true);
1978 }
1979 }
1980 else {
1981 _serialPortNameLineEdit->setStyleSheet("background-color: lightGray");
1982 _serialBaudRateComboBox->setStyleSheet("background-color: lightGray");
1983 _serialParityComboBox->setStyleSheet("background-color: lightGray");
1984 _serialDataBitsComboBox->setStyleSheet("background-color: lightGray");
1985 _serialStopBitsComboBox->setStyleSheet("background-color: lightGray");
1986 _serialFlowControlComboBox->setStyleSheet("background-color: lightGray");
1987 _serialAutoNMEAComboBox->setStyleSheet("background-color: lightGray");
1988 _serialFileNMEALineEdit->setStyleSheet("background-color: lightGray");
1989 _serialHeightNMEALineEdit->setStyleSheet("background-color: lightGray");
1990 _serialPortNameLineEdit->setEnabled(false);
1991 _serialBaudRateComboBox->setEnabled(false);
1992 _serialParityComboBox->setEnabled(false);
1993 _serialDataBitsComboBox->setEnabled(false);
1994 _serialStopBitsComboBox->setEnabled(false);
1995 _serialFlowControlComboBox->setEnabled(false);
1996 _serialAutoNMEAComboBox->setEnabled(false);
1997 _serialHeightNMEALineEdit->setEnabled(false);
1998 _serialFileNMEALineEdit->setEnabled(false);
1999 }
2000 }
2001
2002 // Outages
2003 // -------
2004 if (sender() == 0 || sender() == _obsRateComboBox) {
2005 if (!_obsRateComboBox->currentText().isEmpty()) {
2006 _adviseScriptLineEdit->setStyleSheet("background-color: white");
2007 _adviseFailSpinBox->setStyleSheet("background-color: white");
2008 _adviseRecoSpinBox->setStyleSheet("background-color: white");
2009 _adviseFailSpinBox->setEnabled(true);
2010 _adviseRecoSpinBox->setEnabled(true);
2011 _adviseScriptLineEdit->setEnabled(true);
2012 } else {
2013 _adviseScriptLineEdit->setStyleSheet("background-color: lightGray");
2014 _adviseFailSpinBox->setStyleSheet("background-color: lightGray");
2015 _adviseRecoSpinBox->setStyleSheet("background-color: lightGray");
2016 _adviseFailSpinBox->setEnabled(false);
2017 _adviseRecoSpinBox->setEnabled(false);
2018 _adviseScriptLineEdit->setEnabled(false);
2019 }
2020 }
2021
2022 // Miscellaneous
2023 // -------------
2024 if (sender() == 0 || sender() == _miscMountLineEdit) {
2025 if (!_miscMountLineEdit->text().isEmpty()) {
2026 _perfIntrComboBox->setStyleSheet("background-color: white");
2027 _scanRTCMCheckBox->setPalette(palette_white);
2028 _perfIntrComboBox->setEnabled(true);
2029 _scanRTCMCheckBox->setEnabled(true);
2030 } else {
2031 _perfIntrComboBox->setStyleSheet("background-color: lightGray");
2032 _scanRTCMCheckBox->setPalette(palette_gray);
2033 _perfIntrComboBox->setEnabled(false);
2034 _scanRTCMCheckBox->setEnabled(false);
2035 }
2036 }
2037
2038 // PPP Client
2039 // ----------
2040 if (sender() == 0
2041 || sender() == _pppMountLineEdit
2042 || sender() == _pppCorrMountLineEdit
2043 || sender() == _pppRefCrdXLineEdit
2044 || sender() == _pppRefCrdYLineEdit
2045 || sender() == _pppRefCrdZLineEdit
2046 || sender() == _pppRefdNLineEdit
2047 || sender() == _pppRefdELineEdit
2048 || sender() == _pppRefdULineEdit
2049 || sender() == _pppSync
2050 || sender() == _pppSPPComboBox
2051 || sender() == _pppQuickStartLineEdit
2052 || sender() == _pppEstTropoCheckBox
2053 || sender() == _pppUsePhaseCheckBox
2054 || sender() == _pppAntexLineEdit ) {
2055 if ((!_pppMountLineEdit->text().isEmpty() &&
2056 !_pppCorrMountLineEdit->text().isEmpty()) ||
2057 ( !_pppMountLineEdit->text().isEmpty() &&
2058 _pppSPPComboBox->currentText() == "SPP")) {
2059 _pppSPPComboBox->setPalette(palette_white);
2060 _pppNMEALineEdit->setPalette(palette_white);
2061 _pppNMEAPortLineEdit->setPalette(palette_white);
2062 _pppRefCrdXLineEdit->setPalette(palette_white);
2063 _pppRefCrdYLineEdit->setPalette(palette_white);
2064 _pppRefCrdZLineEdit->setPalette(palette_white);
2065 _pppRefdNLineEdit->setPalette(palette_white);
2066 _pppRefdELineEdit->setPalette(palette_white);
2067 _pppRefdULineEdit->setPalette(palette_white);
2068 _pppUsePhaseCheckBox->setPalette(palette_white);
2069 _pppPlotCoordinates->setPalette(palette_white);
2070 _pppEstTropoCheckBox->setPalette(palette_white);
2071 _pppGLONASSCheckBox->setPalette(palette_white);
2072 _pppGalileoCheckBox->setPalette(palette_white);
2073 _pppAntexLineEdit->setPalette(palette_white);
2074 _pppSPPComboBox->setEnabled(true);
2075 _pppNMEALineEdit->setEnabled(true);
2076 _pppNMEAPortLineEdit->setEnabled(true);
2077 _pppRefCrdXLineEdit->setEnabled(true);
2078 _pppRefCrdYLineEdit->setEnabled(true);
2079 _pppRefCrdZLineEdit->setEnabled(true);
2080 _pppRefdNLineEdit->setEnabled(true);
2081 _pppRefdELineEdit->setEnabled(true);
2082 _pppRefdULineEdit->setEnabled(true);
2083 _pppUsePhaseCheckBox->setEnabled(true);
2084 _pppPlotCoordinates->setEnabled(true);
2085 _pppEstTropoCheckBox->setEnabled(true);
2086 _pppGLONASSCheckBox->setEnabled(true);
2087 _pppGalileoCheckBox->setEnabled(true);
2088 _pppRefCrdXLineEdit->setPalette(palette_white);
2089 _pppRefCrdYLineEdit->setPalette(palette_white);
2090 _pppRefCrdZLineEdit->setPalette(palette_white);
2091 _pppRefdNLineEdit->setPalette(palette_white);
2092 _pppRefdELineEdit->setPalette(palette_white);
2093 _pppRefdULineEdit->setPalette(palette_white);
2094 _pppAntexLineEdit->setEnabled(true);
2095 if (!_pppRefCrdXLineEdit->text().isEmpty() &&
2096 !_pppRefCrdYLineEdit->text().isEmpty() &&
2097 !_pppRefCrdZLineEdit->text().isEmpty()) {
2098 _pppAverageLineEdit->setPalette(palette_white);
2099 _pppQuickStartLineEdit->setPalette(palette_white);
2100 _pppAverageLineEdit->setEnabled(true);
2101 _pppQuickStartLineEdit->setEnabled(true);
2102 }
2103 else {
2104 _pppAverageLineEdit->setPalette(palette_gray);
2105 _pppQuickStartLineEdit->setPalette(palette_gray);
2106 _pppAverageLineEdit->setEnabled(false);
2107 _pppQuickStartLineEdit->setEnabled(false);
2108 }
2109 if (!_pppRefCrdXLineEdit->text().isEmpty() &&
2110 !_pppRefCrdYLineEdit->text().isEmpty() &&
2111 !_pppRefCrdZLineEdit->text().isEmpty() &&
2112 !_pppQuickStartLineEdit->text().isEmpty()) {
2113 _pppMaxSolGapLineEdit->setPalette(palette_white);
2114 _pppMaxSolGapLineEdit->setEnabled(true);
2115 }
2116 else {
2117 _pppMaxSolGapLineEdit->setPalette(palette_gray);
2118 _pppMaxSolGapLineEdit->setEnabled(false);
2119 }
2120 if (!_pppAntexLineEdit->text().isEmpty() ) {
2121 _pppAntennaLineEdit->setEnabled(true);
2122 _pppApplySatAntCheckBox->setEnabled(true);
2123 _pppAntennaLineEdit->setPalette(palette_white);
2124 _pppApplySatAntCheckBox->setPalette(palette_white);
2125 }
2126 else {
2127 _pppAntennaLineEdit->setEnabled(false);
2128 _pppApplySatAntCheckBox->setEnabled(false);
2129 _pppAntennaLineEdit->setPalette(palette_gray);
2130 _pppApplySatAntCheckBox->setPalette(palette_gray);
2131 }
2132 _pppSigCLineEdit->setPalette(palette_white);
2133 _pppSigCLineEdit->setEnabled(true);
2134 _pppSigCrd0->setPalette(palette_white);
2135 _pppSigCrd0->setEnabled(true);
2136 _pppSigCrdP->setPalette(palette_white);
2137 _pppSigCrdP->setEnabled(true);
2138 if (_pppEstTropoCheckBox->isChecked()
2139 && !_pppMountLineEdit->text().isEmpty()) {
2140 _pppSigTrp0->setPalette(palette_white);
2141 _pppSigTrp0->setEnabled(true);
2142 _pppSigTrpP->setPalette(palette_white);
2143 _pppSigTrpP->setEnabled(true);
2144 }
2145 else {
2146 _pppSigTrp0->setPalette(palette_gray);
2147 _pppSigTrp0->setEnabled(false);
2148 _pppSigTrpP->setPalette(palette_gray);
2149 _pppSigTrpP->setEnabled(false);
2150 }
2151 if (_pppUsePhaseCheckBox->isChecked()
2152 && !_pppMountLineEdit->text().isEmpty()) {
2153 _pppSigPLineEdit->setPalette(palette_white);
2154 _pppSigPLineEdit->setEnabled(true);
2155 }
2156 else {
2157 _pppSigPLineEdit->setPalette(palette_gray);
2158 _pppSigPLineEdit->setEnabled(false);
2159 }
2160 if (_pppSPPComboBox->currentText() == "PPP") {
2161 _pppSync->setPalette(palette_white);
2162 _pppSync->setEnabled(true);
2163 }
2164 else {
2165 _pppSync->setPalette(palette_gray);
2166 _pppSync->setEnabled(false);
2167 }
2168 } else {
2169 _pppSPPComboBox->setPalette(palette_gray);
2170 _pppNMEALineEdit->setPalette(palette_gray);
2171 _pppNMEAPortLineEdit->setPalette(palette_gray);
2172 _pppRefCrdXLineEdit->setPalette(palette_gray);
2173 _pppRefCrdYLineEdit->setPalette(palette_gray);
2174 _pppRefCrdZLineEdit->setPalette(palette_gray);
2175 _pppRefdNLineEdit->setPalette(palette_gray);
2176 _pppRefdELineEdit->setPalette(palette_gray);
2177 _pppRefdULineEdit->setPalette(palette_gray);
2178 _pppSync->setPalette(palette_gray);
2179 _pppUsePhaseCheckBox->setPalette(palette_gray);
2180 _pppPlotCoordinates->setPalette(palette_gray);
2181 _pppEstTropoCheckBox->setPalette(palette_gray);
2182 _pppGLONASSCheckBox->setPalette(palette_gray);
2183 _pppGalileoCheckBox->setPalette(palette_gray);
2184 _pppSigCLineEdit->setPalette(palette_gray);
2185 _pppSigPLineEdit->setPalette(palette_gray);
2186 _pppSigCrd0->setPalette(palette_gray);
2187 _pppSigCrdP->setPalette(palette_gray);
2188 _pppSigTrp0->setPalette(palette_gray);
2189 _pppSigTrpP->setPalette(palette_gray);
2190 _pppAverageLineEdit->setPalette(palette_gray);
2191 _pppQuickStartLineEdit->setPalette(palette_gray);
2192 _pppMaxSolGapLineEdit->setPalette(palette_gray);
2193 _pppAntexLineEdit->setPalette(palette_white);
2194 _pppAntennaLineEdit->setPalette(palette_gray);
2195 _pppApplySatAntCheckBox->setPalette(palette_gray);
2196 _pppSPPComboBox->setEnabled(false);
2197 _pppNMEALineEdit->setEnabled(false);
2198 _pppNMEAPortLineEdit->setEnabled(false);
2199 _pppRefCrdXLineEdit->setEnabled(false);
2200 _pppRefCrdYLineEdit->setEnabled(false);
2201 _pppRefCrdZLineEdit->setEnabled(false);
2202 _pppRefdNLineEdit->setEnabled(false);
2203 _pppRefdELineEdit->setEnabled(false);
2204 _pppRefdULineEdit->setEnabled(false);
2205 _pppSync->setEnabled(false);
2206 _pppUsePhaseCheckBox->setEnabled(false);
2207 _pppPlotCoordinates->setEnabled(false);
2208 _pppEstTropoCheckBox->setEnabled(false);
2209 _pppGLONASSCheckBox->setEnabled(false);
2210 _pppGalileoCheckBox->setEnabled(false);
2211 _pppSigCLineEdit->setEnabled(false);
2212 _pppSigPLineEdit->setEnabled(false);
2213 _pppSigCrd0->setEnabled(false);
2214 _pppSigCrdP->setEnabled(false);
2215 _pppSigTrp0->setEnabled(false);
2216 _pppSigTrpP->setEnabled(false);
2217 _pppAverageLineEdit->setEnabled(false);
2218 _pppQuickStartLineEdit->setEnabled(false);
2219 _pppMaxSolGapLineEdit->setEnabled(false);
2220 _pppAntexLineEdit->setEnabled(true);
2221 _pppAntennaLineEdit->setEnabled(false);
2222 _pppApplySatAntCheckBox->setEnabled(false);
2223 }
2224//
2225 if (_pppMountLineEdit->text().isEmpty()) {
2226 _pppCorrMountLineEdit->setPalette(palette_gray);
2227 _pppCorrMountLineEdit->setEnabled(false);
2228 } else {
2229 _pppCorrMountLineEdit->setPalette(palette_white);
2230 _pppCorrMountLineEdit->setEnabled(true);
2231 if (_pppCorrMountLineEdit->text().isEmpty()) {
2232 _pppSPPComboBox->setPalette(palette_white);
2233 _pppSPPComboBox->setEnabled(true);
2234 }
2235 }
2236 if (_pppSPPComboBox->currentText() == "SPP") {
2237 _pppCorrMountLineEdit->setPalette(palette_gray);
2238 _pppCorrMountLineEdit->setEnabled(false);
2239 }
2240 }
2241}
2242
2243//
2244////////////////////////////////////////////////////////////////////////////
2245void bncWindow::slotAddCmbRow() {
2246 int iRow = _cmbTable->rowCount();
2247 _cmbTable->insertRow(iRow);
2248 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2249 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2250 }
2251}
2252
2253//
2254////////////////////////////////////////////////////////////////////////////
2255void bncWindow::slotDelCmbRow() {
2256 int nRows = _cmbTable->rowCount();
2257 bool flg[nRows];
2258 for (int iRow = 0; iRow < nRows; iRow++) {
2259 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2260 flg[iRow] = true;
2261 }
2262 else {
2263 flg[iRow] = false;
2264 }
2265 }
2266 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2267 if (flg[iRow]) {
2268 _cmbTable->removeRow(iRow);
2269 }
2270 }
2271}
2272
2273//
2274////////////////////////////////////////////////////////////////////////////
2275void bncWindow::populateCmbTable() {
2276
2277 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2278 _cmbTable->removeRow(iRow);
2279 }
2280
2281 bncSettings settings;
2282
2283 int iRow = -1;
2284 QListIterator<QString> it(settings.value("combineStreams").toStringList());
2285 while (it.hasNext()) {
2286 QStringList hlp = it.next().split(" ");
2287 if (hlp.size() > 2) {
2288 ++iRow;
2289 _cmbTable->insertRow(iRow);
2290 }
2291 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2292 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2293 }
2294 }
2295}
2296
2297//
2298////////////////////////////////////////////////////////////////////////////
2299void bncWindow::slotAddUploadRow() {
2300 int iRow = _uploadTable->rowCount();
2301 _uploadTable->insertRow(iRow);
2302 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2303 if (iCol == 3) {
2304 QLineEdit* passwd = new QLineEdit();
2305 passwd->setFrame(false);
2306 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2307 _uploadTable->setCellWidget(iRow, iCol, passwd);
2308 }
2309 else if (iCol == 4) {
2310 QComboBox* system = new QComboBox();
2311 system->setEditable(false);
2312 system->addItems(QString("IGS05,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,Custom").split(","));
2313 system->setFrame(false);
2314 _uploadTable->setCellWidget(iRow, iCol, system);
2315 }
2316 else if (iCol == 5) {
2317 QCheckBox* com = new QCheckBox();
2318 _uploadTable->setCellWidget(iRow, iCol, com);
2319 }
2320 else if (iCol == 8) {
2321 bncTableItem* bncIt = new bncTableItem();
2322 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2323 _uploadTable->setItem(iRow, iCol, bncIt);
2324 ((bncApp*)qApp)->_uploadTableItems[iRow] = bncIt;
2325 }
2326 else {
2327 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2328 }
2329 }
2330}
2331
2332//
2333////////////////////////////////////////////////////////////////////////////
2334void bncWindow::slotDelUploadRow() {
2335 ((bncApp*)qApp)->_uploadTableItems.clear();
2336 int nRows = _uploadTable->rowCount();
2337 bool flg[nRows];
2338 for (int iRow = 0; iRow < nRows; iRow++) {
2339 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2340 flg[iRow] = true;
2341 }
2342 else {
2343 flg[iRow] = false;
2344 }
2345 }
2346 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2347 if (flg[iRow]) {
2348 _uploadTable->removeRow(iRow);
2349 }
2350 }
2351 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2352 ((bncApp*)qApp)->_uploadTableItems[iRow] =
2353 (bncTableItem*) _uploadTable->item(iRow, 8);
2354 }
2355}
2356
2357//
2358////////////////////////////////////////////////////////////////////////////
2359void bncWindow::populateUploadTable() {
2360 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2361 _uploadTable->removeRow(iRow);
2362 }
2363
2364 bncSettings settings;
2365
2366 int iRow = -1;
2367 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2368 while (it.hasNext()) {
2369 QStringList hlp = it.next().split(",");
2370 if (hlp.size() > 6) {
2371 ++iRow;
2372 _uploadTable->insertRow(iRow);
2373 }
2374 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2375 if (iCol == 3) {
2376 QLineEdit* passwd = new QLineEdit();
2377 passwd->setFrame(false);
2378 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2379 passwd->setText(hlp[iCol]);
2380 _uploadTable->setCellWidget(iRow, iCol, passwd);
2381 }
2382 else if (iCol == 4) {
2383 QComboBox* system = new QComboBox();
2384 system->setEditable(false);
2385 system->addItems(QString("IGS05,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,Custom").split(","));
2386 system->setFrame(false);
2387 system->setCurrentIndex(system->findText(hlp[iCol]));
2388 _uploadTable->setCellWidget(iRow, iCol, system);
2389 }
2390 else if (iCol == 5) {
2391 QCheckBox* com = new QCheckBox();
2392 if (hlp[iCol].toInt() == Qt::Checked) {
2393 com->setCheckState(Qt::Checked);
2394 }
2395 _uploadTable->setCellWidget(iRow, iCol, com);
2396 }
2397 else if (iCol == 8) {
2398 bncTableItem* bncIt = new bncTableItem();
2399 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2400 _uploadTable->setItem(iRow, iCol, bncIt);
2401 ((bncApp*)qApp)->_uploadTableItems[iRow] = bncIt;
2402 }
2403 else {
2404 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2405 }
2406 }
2407 }
2408}
2409
2410//
2411////////////////////////////////////////////////////////////////////////////
2412void bncWindow::slotSetUploadTrafo() {
2413 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2414 dlg->exec();
2415 delete dlg;
2416}
Note: See TracBrowser for help on using the repository browser.