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

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