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

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