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

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