source: ntrip/branches/BNC_LM/bncwindow.cpp@ 8450

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