source: ntrip/trunk/BNC/src/bncwindow.cpp@ 5220

Last change on this file since 5220 was 5220, checked in by mervart, 11 years ago
File size: 151.9 KB
Line 
1// Part of BNC, a utility for retrieving decoding and
2// converting GNSS data streams from NTRIP broadcasters.
3//
4// Copyright (C) 2007
5// German Federal Agency for Cartography and Geodesy (BKG)
6// http://www.bkg.bund.de
7// Czech Technical University Prague, Department of Geodesy
8// http://www.fsv.cvut.cz
9//
10// Email: euref-ip@bkg.bund.de
11//
12// This program is free software; you can redistribute it and/or
13// modify it under the terms of the GNU General Public License
14// as published by the Free Software Foundation, version 2.
15//
16// This program is distributed in the hope that it will be useful,
17// but WITHOUT ANY WARRANTY; without even the implied warranty of
18// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19// GNU General Public License for more details.
20//
21// You should have received a copy of the GNU General Public License
22// along with this program; if not, write to the Free Software
23// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24
25/* -------------------------------------------------------------------------
26 * BKG NTRIP Client
27 * -------------------------------------------------------------------------
28 *
29 * Class: bncWindow
30 *
31 * Purpose: This class implements the main application window.
32 *
33 * Author: L. Mervart
34 *
35 * Created: 24-Dec-2005
36 *
37 * Changes:
38 *
39 * -----------------------------------------------------------------------*/
40
41#include <iostream>
42
43#include <unistd.h>
44#include "bncwindow.h"
45#include "bnccore.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#include "reqcdlg.h"
65#include "bncmap.h"
66#ifdef QT_WEBKIT
67# include "map/bncmapwin.h"
68#endif
69#ifdef USE_POSTPROCESSING
70# include "rinex/bncpostprocess.h"
71# include "rinex/reqcedit.h"
72# include "rinex/reqcanalyze.h"
73#endif
74
75using namespace std;
76
77#ifdef GNSSCENTER_PLUGIN
78Q_EXPORT_PLUGIN2(gnsscenter_bnc, t_bncFactory)
79#endif
80
81// Constructor
82////////////////////////////////////////////////////////////////////////////
83bncWindow::bncWindow() {
84
85#ifdef GNSSCENTER_PLUGIN
86 BNC_CORE->setConfFileName("");
87#endif
88
89 _caster = 0;
90 _casterEph = 0;
91
92 _bncFigure = new bncFigure(this);
93 _bncFigureLate = new bncFigureLate(this);
94 _bncFigurePPP = new bncFigurePPP(this);
95 _runningRealTime = false;
96 _runningPostProcessingPPP = false;
97 _runningPostProcessingReqc = false;
98 _postProcessing = 0;
99
100 _pppSPPComboBox = 0; // necessary for enableStartStop()
101 _reqcActionComboBox = 0; // necessary for enableStartStop()
102
103 _mapWin = 0;
104
105 int ww = QFontMetrics(this->font()).width('w');
106
107 static const QStringList labels = QString("account, Streams: resource loader / mountpoint, decoder, lat, long, nmea, ntrip, bytes").split(",");
108
109 setMinimumSize(85*ww, 65*ww);
110
111 setWindowTitle(tr("BKG Ntrip Client (BNC) Version " BNCVERSION));
112
113 connect(BNC_CORE, SIGNAL(newMessage(QByteArray,bool)),
114 this, SLOT(slotWindowMessage(QByteArray,bool)));
115
116 // Create Actions
117 // --------------
118 _actHelp = new QAction(tr("&Help Contents"),this);
119 connect(_actHelp, SIGNAL(triggered()), SLOT(slotHelp()));
120
121 _actAbout = new QAction(tr("&About BNC"),this);
122 connect(_actAbout, SIGNAL(triggered()), SLOT(slotAbout()));
123
124 _actFlowchart = new QAction(tr("&Flow Chart"),this);
125 connect(_actFlowchart, SIGNAL(triggered()), SLOT(slotFlowchart()));
126
127 _actFontSel = new QAction(tr("Select &Font"),this);
128 connect(_actFontSel, SIGNAL(triggered()), SLOT(slotFontSel()));
129
130 _actSaveOpt = new QAction(tr("&Save && Reread Configuration"),this);
131 connect(_actSaveOpt, SIGNAL(triggered()), SLOT(slotSaveOptions()));
132
133 _actQuit = new QAction(tr("&Quit"),this);
134 connect(_actQuit, SIGNAL(triggered()), SLOT(close()));
135
136 _actAddMountPoints = new QAction(tr("Add &Stream"),this);
137 connect(_actAddMountPoints, SIGNAL(triggered()), SLOT(slotAddMountPoints()));
138
139 _actDeleteMountPoints = new QAction(tr("&Delete Stream"),this);
140 connect(_actDeleteMountPoints, SIGNAL(triggered()), SLOT(slotDeleteMountPoints()));
141 _actDeleteMountPoints->setEnabled(false);
142
143 _actMapMountPoints = new QAction(tr("Streams &Map"),this);
144 connect(_actMapMountPoints, SIGNAL(triggered()), SLOT(slotMapMountPoints()));
145
146 _actStart = new QAction(tr("Sta&rt"),this);
147 connect(_actStart, SIGNAL(triggered()), SLOT(slotStart()));
148
149 _actStop = new QAction(tr("Sto&p"),this);
150 connect(_actStop, SIGNAL(triggered()), SLOT(slotStop()));
151
152 _actwhatsthis= new QAction(tr("Help ?=Shift+F1"),this);
153 connect(_actwhatsthis, SIGNAL(triggered()), SLOT(slotWhatsThis()));
154
155 CreateMenu();
156 AddToolbar();
157
158 bncSettings settings;
159
160 // Network Options
161 // ---------------
162 _proxyHostLineEdit = new QLineEdit(settings.value("proxyHost").toString());
163 _proxyPortLineEdit = new QLineEdit(settings.value("proxyPort").toString());
164
165 connect(_proxyHostLineEdit, SIGNAL(textChanged(const QString &)),
166 this, SLOT(slotBncTextChanged()));
167
168 _sslCaCertPathLineEdit = new QLineEdit(settings.value("sslCaCertPath").toString());
169 _ignoreSslErrorsCheckBox = new QCheckBox();
170 _ignoreSslErrorsCheckBox->setCheckState(Qt::CheckState(
171 settings.value("ignoreSslErrors").toInt()));
172
173 // General Options
174 // ---------------
175 _logFileLineEdit = new QLineEdit(settings.value("logFile").toString());
176 _rawOutFileLineEdit = new QLineEdit(settings.value("rawOutFile").toString());
177 _rnxAppendCheckBox = new QCheckBox();
178 _rnxAppendCheckBox->setCheckState(Qt::CheckState(
179 settings.value("rnxAppend").toInt()));
180 _onTheFlyComboBox = new QComboBox();
181 _onTheFlyComboBox->setEditable(false);
182 _onTheFlyComboBox->addItems(QString("1 day,1 hour,5 min,1 min").split(","));
183 int ii = _onTheFlyComboBox->findText(settings.value("onTheFlyInterval").toString());
184 if (ii != -1) {
185 _onTheFlyComboBox->setCurrentIndex(ii);
186 }
187 _autoStartCheckBox = new QCheckBox();
188 _autoStartCheckBox->setCheckState(Qt::CheckState(
189 settings.value("autoStart").toInt()));
190
191 // RINEX Observations Options
192 // --------------------------
193 _rnxPathLineEdit = new QLineEdit(settings.value("rnxPath").toString());
194 _rnxIntrComboBox = new QComboBox();
195 _rnxIntrComboBox->setEditable(false);
196 _rnxIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
197 ii = _rnxIntrComboBox->findText(settings.value("rnxIntr").toString());
198 if (ii != -1) {
199 _rnxIntrComboBox->setCurrentIndex(ii);
200 }
201 _rnxSamplSpinBox = new QSpinBox();
202 _rnxSamplSpinBox->setMinimum(0);
203 _rnxSamplSpinBox->setMaximum(60);
204 _rnxSamplSpinBox->setSingleStep(5);
205 _rnxSamplSpinBox->setValue(settings.value("rnxSampl").toInt());
206 _rnxSamplSpinBox->setSuffix(" sec");
207 _rnxSkelLineEdit = new QLineEdit(settings.value("rnxSkel").toString());
208 _rnxSkelLineEdit->setMaximumWidth(5*ww);
209 _rnxScrpLineEdit = new QLineEdit(settings.value("rnxScript").toString());
210 _rnxV3CheckBox = new QCheckBox();
211 _rnxV3CheckBox->setCheckState(Qt::CheckState(settings.value("rnxV3").toInt()));
212
213 connect(_rnxPathLineEdit, SIGNAL(textChanged(const QString &)),
214 this, SLOT(slotBncTextChanged()));
215
216 // RINEX Ephemeris Options
217 // -----------------------
218 _ephPathLineEdit = new QLineEdit(settings.value("ephPath").toString());
219 _ephIntrComboBox = new QComboBox();
220 _ephIntrComboBox->setEditable(false);
221 _ephIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
222 int jj = _ephIntrComboBox->findText(settings.value("ephIntr").toString());
223 if (jj != -1) {
224 _ephIntrComboBox->setCurrentIndex(jj);
225 }
226 _outEphPortLineEdit = new QLineEdit(settings.value("outEphPort").toString());
227 _ephV3CheckBox = new QCheckBox();
228 _ephV3CheckBox->setCheckState(Qt::CheckState(settings.value("ephV3").toInt()));
229
230 connect(_outEphPortLineEdit, SIGNAL(textChanged(const QString &)),
231 this, SLOT(slotBncTextChanged()));
232
233 connect(_ephPathLineEdit, SIGNAL(textChanged(const QString &)),
234 this, SLOT(slotBncTextChanged()));
235
236 // Broadcast Corrections Options
237 // -----------------------------
238 _corrPathLineEdit = new QLineEdit(settings.value("corrPath").toString());
239 _corrIntrComboBox = new QComboBox();
240 _corrIntrComboBox->setEditable(false);
241 _corrIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
242 int mm = _corrIntrComboBox->findText(settings.value("corrIntr").toString());
243 if (mm != -1) {
244 _corrIntrComboBox->setCurrentIndex(mm);
245 }
246 _corrPortLineEdit = new QLineEdit(settings.value("corrPort").toString());
247 _corrTimeSpinBox = new QSpinBox();
248 _corrTimeSpinBox->setMinimum(0);
249 _corrTimeSpinBox->setMaximum(60);
250 _corrTimeSpinBox->setSingleStep(1);
251 _corrTimeSpinBox->setSuffix(" sec");
252 _corrTimeSpinBox->setValue(settings.value("corrTime").toInt());
253
254 connect(_corrPathLineEdit, SIGNAL(textChanged(const QString &)),
255 this, SLOT(slotBncTextChanged()));
256
257 connect(_corrPortLineEdit, SIGNAL(textChanged(const QString &)),
258 this, SLOT(slotBncTextChanged()));
259
260 // Feed Engine Options
261 // -------------------
262 _outPortLineEdit = new QLineEdit(settings.value("outPort").toString());
263 _waitTimeSpinBox = new QSpinBox();
264 _waitTimeSpinBox->setMinimum(1);
265 _waitTimeSpinBox->setMaximum(30);
266 _waitTimeSpinBox->setSingleStep(1);
267 _waitTimeSpinBox->setSuffix(" sec");
268 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
269 _binSamplSpinBox = new QSpinBox();
270 _binSamplSpinBox->setMinimum(0);
271 _binSamplSpinBox->setMaximum(60);
272 _binSamplSpinBox->setSingleStep(5);
273 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
274 _binSamplSpinBox->setSuffix(" sec");
275 _outFileLineEdit = new QLineEdit(settings.value("outFile").toString());
276 _outUPortLineEdit = new QLineEdit(settings.value("outUPort").toString());
277
278 connect(_outPortLineEdit, SIGNAL(textChanged(const QString &)),
279 this, SLOT(slotBncTextChanged()));
280
281 connect(_outFileLineEdit, SIGNAL(textChanged(const QString &)),
282 this, SLOT(slotBncTextChanged()));
283
284 // Serial Output Options
285 // ---------------------
286 _serialMountPointLineEdit = new QLineEdit(settings.value("serialMountPoint").toString());
287 _serialPortNameLineEdit = new QLineEdit(settings.value("serialPortName").toString());
288 _serialBaudRateComboBox = new QComboBox();
289 _serialBaudRateComboBox->addItems(QString("110,300,600,"
290 "1200,2400,4800,9600,19200,38400,57600,115200").split(","));
291 int kk = _serialBaudRateComboBox->findText(settings.value("serialBaudRate").toString());
292 if (kk != -1) {
293 _serialBaudRateComboBox->setCurrentIndex(kk);
294 }
295 _serialFlowControlComboBox = new QComboBox();
296 _serialFlowControlComboBox->addItems(QString("OFF,XONXOFF,HARDWARE").split(","));
297 kk = _serialFlowControlComboBox->findText(settings.value("serialFlowControl").toString());
298 if (kk != -1) {
299 _serialFlowControlComboBox->setCurrentIndex(kk);
300 }
301 _serialDataBitsComboBox = new QComboBox();
302 _serialDataBitsComboBox->addItems(QString("5,6,7,8").split(","));
303 kk = _serialDataBitsComboBox->findText(settings.value("serialDataBits").toString());
304 if (kk != -1) {
305 _serialDataBitsComboBox->setCurrentIndex(kk);
306 }
307 _serialParityComboBox = new QComboBox();
308 _serialParityComboBox->addItems(QString("NONE,ODD,EVEN,SPACE").split(","));
309 kk = _serialParityComboBox->findText(settings.value("serialParity").toString());
310 if (kk != -1) {
311 _serialParityComboBox->setCurrentIndex(kk);
312 }
313 _serialStopBitsComboBox = new QComboBox();
314 _serialStopBitsComboBox->addItems(QString("1,2").split(","));
315 kk = _serialStopBitsComboBox->findText(settings.value("serialStopBits").toString());
316 if (kk != -1) {
317 _serialStopBitsComboBox->setCurrentIndex(kk);
318 }
319 _serialAutoNMEAComboBox = new QComboBox();
320 _serialAutoNMEAComboBox->addItems(QString("Auto,Manual").split(","));
321 kk = _serialAutoNMEAComboBox->findText(settings.value("serialAutoNMEA").toString());
322 if (kk != -1) {
323 _serialAutoNMEAComboBox->setCurrentIndex(kk);
324 }
325 _serialFileNMEALineEdit = new QLineEdit(settings.value("serialFileNMEA").toString());
326 _serialHeightNMEALineEdit = new QLineEdit(settings.value("serialHeightNMEA").toString());
327
328 connect(_serialMountPointLineEdit, SIGNAL(textChanged(const QString &)),
329 this, SLOT(slotBncTextChanged()));
330
331 connect(_serialAutoNMEAComboBox, SIGNAL(currentIndexChanged(const QString &)),
332 this, SLOT(slotBncTextChanged()));
333
334 // Outages Options
335 // ---------------
336 _obsRateComboBox = new QComboBox();
337 _obsRateComboBox->setEditable(false);
338 _obsRateComboBox->addItems(QString(",0.1 Hz,0.2 Hz,0.5 Hz,1 Hz,5 Hz").split(","));
339 kk = _obsRateComboBox->findText(settings.value("obsRate").toString());
340 if (kk != -1) {
341 _obsRateComboBox->setCurrentIndex(kk);
342 }
343 _adviseFailSpinBox = new QSpinBox();
344 _adviseFailSpinBox->setMinimum(0);
345 _adviseFailSpinBox->setMaximum(60);
346 _adviseFailSpinBox->setSingleStep(1);
347 _adviseFailSpinBox->setSuffix(" min");
348 _adviseFailSpinBox->setValue(settings.value("adviseFail").toInt());
349 _adviseRecoSpinBox = new QSpinBox();
350 _adviseRecoSpinBox->setMinimum(0);
351 _adviseRecoSpinBox->setMaximum(60);
352 _adviseRecoSpinBox->setSingleStep(1);
353 _adviseRecoSpinBox->setSuffix(" min");
354 _adviseRecoSpinBox->setValue(settings.value("adviseReco").toInt());
355 _adviseScriptLineEdit = new QLineEdit(settings.value("adviseScript").toString());
356
357 connect(_obsRateComboBox, SIGNAL(currentIndexChanged(const QString &)),
358 this, SLOT(slotBncTextChanged()));
359
360 // Miscellaneous Options
361 // ---------------------
362 _miscMountLineEdit = new QLineEdit(settings.value("miscMount").toString());
363 _perfIntrComboBox = new QComboBox();
364 _perfIntrComboBox->setEditable(false);
365 _perfIntrComboBox->addItems(QString(",2 sec, 10 sec,1 min,5 min,15 min,1 hour,6 hours,1 day").split(","));
366 int ll = _perfIntrComboBox->findText(settings.value("perfIntr").toString());
367 if (ll != -1) {
368 _perfIntrComboBox->setCurrentIndex(ll);
369 }
370 _scanRTCMCheckBox = new QCheckBox();
371 _scanRTCMCheckBox->setCheckState(Qt::CheckState(
372 settings.value("scanRTCM").toInt()));
373
374 connect(_miscMountLineEdit, SIGNAL(textChanged(const QString &)),
375 this, SLOT(slotBncTextChanged()));
376
377 // PPP Options
378 // -----------
379 _pppMountLineEdit = new QLineEdit(settings.value("pppMount").toString());
380 _pppMountLineEdit->setMaximumWidth(8*ww);
381 _pppCorrMountLineEdit = new QLineEdit(settings.value("pppCorrMount").toString());
382 _pppMountLineEdit->setMinimumWidth(8*ww);
383 _pppCorrMountLineEdit->setMinimumWidth(8*ww);
384 _pppCorrMountLineEdit->setMaximumWidth(8*ww);
385 _pppNMEALineEdit = new QLineEdit(settings.value("nmeaFile").toString());
386 _pppNMEALineEdit->setMinimumWidth(15*ww);
387 _pppNMEAPortLineEdit = new QLineEdit(settings.value("nmeaPort").toString());
388 _pppNMEAPortLineEdit->setMaximumWidth(8*ww);
389 _pppNMEAPortLineEdit->setMinimumWidth(8*ww);
390 _pppSigCLineEdit = new QLineEdit(settings.value("pppSigmaCode").toString());
391 _pppSigPLineEdit = new QLineEdit(settings.value("pppSigmaPhase").toString());
392 _pppSigCrd0 = new QLineEdit(settings.value("pppSigCrd0").toString());
393 _pppSigCrdP = new QLineEdit(settings.value("pppSigCrdP").toString());
394 _pppSigTrp0 = new QLineEdit(settings.value("pppSigTrp0").toString());
395 _pppSigTrpP = new QLineEdit(settings.value("pppSigTrpP").toString());
396 _pppAverageLineEdit = new QLineEdit(settings.value("pppAverage").toString());
397 _pppQuickStartLineEdit = new QLineEdit(settings.value("pppQuickStart").toString());
398 _pppMaxSolGapLineEdit = new QLineEdit(settings.value("pppMaxSolGap").toString());
399 _pppAudioResponseLineEdit = new QLineEdit(settings.value("pppAudioResponse").toString());
400 _pppRefCrdXLineEdit = new QLineEdit(settings.value("pppRefCrdX").toString());
401 _pppRefCrdYLineEdit = new QLineEdit(settings.value("pppRefCrdY").toString());
402 _pppRefCrdZLineEdit = new QLineEdit(settings.value("pppRefCrdZ").toString());
403 _pppRefdNLineEdit = new QLineEdit(settings.value("pppRefdN").toString());
404 _pppRefdELineEdit = new QLineEdit(settings.value("pppRefdE").toString());
405 _pppRefdULineEdit = new QLineEdit(settings.value("pppRefdU").toString());
406 _pppSync = new QLineEdit(settings.value("pppSync").toString());
407 _pppAntexFileChooser = new qtFileChooser;
408 _pppAntexFileChooser->setMinimumWidth(12*ww);
409 _pppAntennaLineEdit = new QLineEdit(settings.value("pppAntenna").toString());
410 _pppAntexFileChooser->setFileName(settings.value("pppAntex").toString());
411
412 _pppSPPComboBox = new QComboBox();
413 _pppSPPComboBox->setEditable(false);
414 _pppSPPComboBox->addItems(QString(",Realtime-PPP,Realtime-SPP,Post-Processing").split(","));
415 int ik = _pppSPPComboBox->findText(settings.value("pppSPP").toString());
416 if (ik != -1) {
417 _pppSPPComboBox->setCurrentIndex(ik);
418 }
419 _pppUsePhaseCheckBox = new QCheckBox();
420 _pppUsePhaseCheckBox->setCheckState(Qt::CheckState(
421 settings.value("pppUsePhase").toInt()));
422 _pppEstTropoCheckBox = new QCheckBox();
423 _pppEstTropoCheckBox->setCheckState(Qt::CheckState(
424 settings.value("pppEstTropo").toInt()));
425 _pppGLONASSCheckBox = new QCheckBox();
426 _pppGLONASSCheckBox->setCheckState(Qt::CheckState(
427 settings.value("pppGLONASS").toInt()));
428 _pppGalileoCheckBox = new QCheckBox();
429 _pppGalileoCheckBox->setCheckState(Qt::CheckState(
430 settings.value("pppGalileo").toInt()));
431
432 _pppPlotCoordinates = new QCheckBox();
433 _pppPlotCoordinates->setCheckState(Qt::CheckState(
434 settings.value("pppPlotCoordinates").toInt()));
435
436 connect(_pppMountLineEdit, SIGNAL(textChanged(const QString &)),
437 this, SLOT(slotBncTextChanged()));
438
439 connect(_pppCorrMountLineEdit, SIGNAL(textChanged(const QString &)),
440 this, SLOT(slotBncTextChanged()));
441
442 connect(_pppUsePhaseCheckBox, SIGNAL(stateChanged(int)),
443 this, SLOT(slotBncTextChanged()));
444
445 connect(_pppRefCrdXLineEdit, SIGNAL(textChanged(const QString &)),
446 this, SLOT(slotBncTextChanged()));
447 connect(_pppRefCrdYLineEdit, SIGNAL(textChanged(const QString &)),
448 this, SLOT(slotBncTextChanged()));
449 connect(_pppRefCrdZLineEdit, SIGNAL(textChanged(const QString &)),
450 this, SLOT(slotBncTextChanged()));
451 connect(_pppRefdNLineEdit, SIGNAL(textChanged(const QString &)),
452 this, SLOT(slotBncTextChanged()));
453 connect(_pppRefdELineEdit, SIGNAL(textChanged(const QString &)),
454 this, SLOT(slotBncTextChanged()));
455 connect(_pppRefdULineEdit, SIGNAL(textChanged(const QString &)),
456 this, SLOT(slotBncTextChanged()));
457
458 connect(_pppEstTropoCheckBox, SIGNAL(stateChanged(int)),
459 this, SLOT(slotBncTextChanged()));
460
461 connect(_pppSync, SIGNAL(textChanged(const QString &)),
462 this, SLOT(slotBncTextChanged()));
463
464 connect(_pppSPPComboBox, SIGNAL(currentIndexChanged(const QString &)),
465 this, SLOT(slotBncTextChanged()));
466
467 connect(_pppAntexFileChooser, SIGNAL(fileNameChanged(const QString &)),
468 this, SLOT(slotBncTextChanged()));
469
470 connect(_pppQuickStartLineEdit, SIGNAL(textChanged(const QString &)),
471 this, SLOT(slotBncTextChanged()));
472
473 // Streams
474 // -------
475 _mountPointsTable = new QTableWidget(0,8);
476
477 _mountPointsTable->horizontalHeader()->resizeSection(1,34*ww);
478 _mountPointsTable->horizontalHeader()->resizeSection(2,9*ww);
479 _mountPointsTable->horizontalHeader()->resizeSection(3,7*ww);
480 _mountPointsTable->horizontalHeader()->resizeSection(4,7*ww);
481 _mountPointsTable->horizontalHeader()->resizeSection(5,5*ww);
482 _mountPointsTable->horizontalHeader()->resizeSection(6,5*ww);
483 _mountPointsTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
484 _mountPointsTable->horizontalHeader()->setStretchLastSection(true);
485 _mountPointsTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
486_mountPointsTable->setHorizontalHeaderLabels(labels);
487 _mountPointsTable->setGridStyle(Qt::NoPen);
488 _mountPointsTable->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
489 _mountPointsTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
490 _mountPointsTable->setSelectionBehavior(QAbstractItemView::SelectRows);
491 _mountPointsTable->hideColumn(0);
492 connect(_mountPointsTable, SIGNAL(itemSelectionChanged()),
493 SLOT(slotSelectionChanged()));
494 populateMountPointsTable();
495
496 _log = new QTextBrowser();
497 _log->setReadOnly(true);
498
499 // Combine Corrections
500 // -------------------
501 _cmbTable = new QTableWidget(0,3);
502 _cmbTable->setHorizontalHeaderLabels(QString("Mountpoint, AC Name, Weight").split(","));
503 _cmbTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
504 _cmbTable->setSelectionBehavior(QAbstractItemView::SelectRows);
505 _cmbTable->setMaximumWidth(30*ww);
506 _cmbTable->horizontalHeader()->resizeSection(0,10*ww);
507 _cmbTable->horizontalHeader()->resizeSection(1,8*ww);
508 _cmbTable->horizontalHeader()->resizeSection(2,8*ww);
509 _cmbTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
510 _cmbTable->horizontalHeader()->setStretchLastSection(true);
511 _cmbTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
512
513 _cmbMaxresLineEdit = new QLineEdit(settings.value("cmbMaxres").toString());
514
515 _cmbSamplSpinBox = new QSpinBox;
516 _cmbSamplSpinBox->setMinimum(10);
517 _cmbSamplSpinBox->setMaximum(60);
518 _cmbSamplSpinBox->setSingleStep(10);
519 _cmbSamplSpinBox->setMaximumWidth(9*ww);
520 _cmbSamplSpinBox->setValue(settings.value("cmbSampl").toInt());
521 _cmbSamplSpinBox->setSuffix(" sec");
522
523 QPushButton* addCmbRowButton = new QPushButton("Add Row");
524 QPushButton* delCmbRowButton = new QPushButton("Delete");
525
526 connect(_cmbTable, SIGNAL(itemSelectionChanged()),
527 SLOT(slotBncTextChanged()));
528
529 _cmbMethodComboBox = new QComboBox();
530 _cmbMethodComboBox->setEditable(false);
531 _cmbMethodComboBox->addItems(QString("Filter,Single-Epoch").split(","));
532 int im = _cmbMethodComboBox->findText(settings.value("cmbMethod").toString());
533 if (im != -1) {
534 _cmbMethodComboBox->setCurrentIndex(im);
535 }
536
537 int iRow = _cmbTable->rowCount();
538 if (iRow > 0) {
539 enableWidget(true, _cmbMethodComboBox);
540 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
541 _cmbMaxresLineEdit->setEnabled(true);
542 _cmbSamplSpinBox->setEnabled(true);
543 }
544 else {
545 enableWidget(false, _cmbMethodComboBox);
546 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
547 _cmbMaxresLineEdit->setEnabled(false);
548 _cmbSamplSpinBox->setEnabled(false);
549 }
550
551 // Upload Results
552 // -------------
553 _uploadTable = new QTableWidget(0,12);
554 _uploadTable->setHorizontalHeaderLabels(QString("Host, Port, Mount, Password, System, CoM, SP3 File, RNX File, PID, SID, IOD, bytes").split(","));
555 _uploadTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
556 _uploadTable->setSelectionBehavior(QAbstractItemView::SelectRows);
557 _uploadTable->horizontalHeader()->resizeSection( 0,13*ww);
558 _uploadTable->horizontalHeader()->resizeSection( 1, 5*ww);
559 _uploadTable->horizontalHeader()->resizeSection( 2, 6*ww);
560 _uploadTable->horizontalHeader()->resizeSection( 3, 8*ww);
561 _uploadTable->horizontalHeader()->resizeSection( 4,11*ww);
562 _uploadTable->horizontalHeader()->resizeSection( 5, 4*ww);
563 _uploadTable->horizontalHeader()->resizeSection( 6,15*ww);
564 _uploadTable->horizontalHeader()->resizeSection( 7,15*ww);
565 _uploadTable->horizontalHeader()->resizeSection( 8, 4*ww);
566 _uploadTable->horizontalHeader()->resizeSection( 9, 4*ww);
567 _uploadTable->horizontalHeader()->resizeSection(10, 4*ww);
568 _uploadTable->horizontalHeader()->resizeSection(11,12*ww);
569 _uploadTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
570 _uploadTable->horizontalHeader()->setStretchLastSection(true);
571 _uploadTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
572
573 connect(_uploadTable, SIGNAL(itemSelectionChanged()),
574 SLOT(slotBncTextChanged()));
575
576 QPushButton* addUploadRowButton = new QPushButton("Add Row");
577 QPushButton* delUploadRowButton = new QPushButton("Del Row");
578 QPushButton* setUploadTrafoButton = new QPushButton("Custom Trafo");
579 _uploadIntrComboBox = new QComboBox;
580 _uploadIntrComboBox->setEditable(false);
581 _uploadIntrComboBox->addItems(QString("1 day,1 hour, 30 min,15 min,10 min,5 min,2 min,1 min").split(","));
582 ii = _uploadIntrComboBox->findText(settings.value("uploadIntr").toString());
583 if (ii != -1) {
584 _uploadIntrComboBox->setCurrentIndex(ii);
585 }
586
587 _uploadSamplRtcmEphCorrSpinBox = new QSpinBox;
588 _uploadSamplRtcmEphCorrSpinBox->setMinimum(0);
589 _uploadSamplRtcmEphCorrSpinBox->setMaximum(60);
590 _uploadSamplRtcmEphCorrSpinBox->setSingleStep(5);
591 _uploadSamplRtcmEphCorrSpinBox->setMaximumWidth(9*ww);
592 _uploadSamplRtcmEphCorrSpinBox->setValue(settings.value("uploadSamplRtcmEphCorr").toInt());
593 _uploadSamplRtcmEphCorrSpinBox->setSuffix(" sec");
594
595 _uploadSamplSp3SpinBox = new QSpinBox;
596 _uploadSamplSp3SpinBox->setMinimum(0);
597 _uploadSamplSp3SpinBox->setMaximum(15);
598 _uploadSamplSp3SpinBox->setSingleStep(1);
599 _uploadSamplSp3SpinBox->setMaximumWidth(9*ww);
600 _uploadSamplSp3SpinBox->setValue(settings.value("uploadSamplSp3").toInt());
601 _uploadSamplSp3SpinBox->setSuffix(" min");
602
603 _uploadSamplClkRnxSpinBox = new QSpinBox;
604 _uploadSamplClkRnxSpinBox->setMinimum(0);
605 _uploadSamplClkRnxSpinBox->setMaximum(60);
606 _uploadSamplClkRnxSpinBox->setSingleStep(5);
607 _uploadSamplClkRnxSpinBox->setMaximumWidth(9*ww);
608 _uploadSamplClkRnxSpinBox->setValue(settings.value("uploadSamplClkRnx").toInt());
609 _uploadSamplClkRnxSpinBox->setSuffix(" sec");
610
611 int iRowT = _uploadTable->rowCount();
612 if (iRowT > 0) {
613 enableWidget(true, _uploadIntrComboBox);
614 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
615 enableWidget(true, _uploadSamplSp3SpinBox);
616 enableWidget(true, _uploadSamplClkRnxSpinBox);
617 }
618 else {
619 enableWidget(false, _uploadIntrComboBox);
620 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
621 enableWidget(false, _uploadSamplSp3SpinBox);
622 enableWidget(false, _uploadSamplClkRnxSpinBox);
623 }
624
625 // Upload RTCM3 Ephemeris
626 // ----------------------
627 _uploadEphHostLineEdit = new QLineEdit(settings.value("uploadEphHost").toString());
628 _uploadEphPortLineEdit = new QLineEdit(settings.value("uploadEphPort").toString());
629 _uploadEphPasswordLineEdit = new QLineEdit(settings.value("uploadEphPassword").toString());
630 _uploadEphPasswordLineEdit->setEchoMode(QLineEdit::PasswordEchoOnEdit);
631 _uploadEphMountpointLineEdit = new QLineEdit(settings.value("uploadEphMountpoint").toString());
632 _uploadEphSampleSpinBox = new QSpinBox;
633 _uploadEphSampleSpinBox->setMinimum(5);
634 _uploadEphSampleSpinBox->setMaximum(60);
635 _uploadEphSampleSpinBox->setSingleStep(5);
636 _uploadEphSampleSpinBox->setMaximumWidth(9*ww);
637 _uploadEphSampleSpinBox->setValue(settings.value("uploadEphSample").toInt());
638 _uploadEphSampleSpinBox->setSuffix(" sec");
639 _uploadEphBytesCounter = new bncBytesCounter;
640
641 // Canvas with Editable Fields
642 // ---------------------------
643 _canvas = new QWidget;
644 setCentralWidget(_canvas);
645
646 _aogroup = new QTabWidget();
647 QWidget* pgroup = new QWidget();
648 QWidget* ggroup = new QWidget();
649 QWidget* sgroup = new QWidget();
650 QWidget* egroup = new QWidget();
651 QWidget* agroup = new QWidget();
652 QWidget* cgroup = new QWidget();
653 QWidget* ogroup = new QWidget();
654 QWidget* rgroup = new QWidget();
655 QWidget* sergroup = new QWidget();
656 QWidget* pppgroup = new QWidget();
657 QWidget* ppp2group = new QWidget();
658 QWidget* ppp3group = new QWidget();
659 QWidget* reqcgroup = new QWidget();
660 QWidget* cmbgroup = new QWidget();
661 QWidget* uploadgroup = new QWidget();
662 QWidget* uploadEphgroup = new QWidget();
663 _aogroup->addTab(pgroup,tr("Network"));
664 _aogroup->addTab(ggroup,tr("General"));
665 _aogroup->addTab(ogroup,tr("RINEX Observations"));
666 _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
667 _aogroup->addTab(reqcgroup,tr("RINEX Editing && QC"));
668 _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
669 _aogroup->addTab(sgroup,tr("Feed Engine"));
670 _aogroup->addTab(sergroup,tr("Serial Output"));
671 _aogroup->addTab(agroup,tr("Outages"));
672 _aogroup->addTab(rgroup,tr("Miscellaneous"));
673 _aogroup->addTab(pppgroup,tr("PPP (1)"));
674 _aogroup->addTab(ppp2group,tr("PPP (2)"));
675 _aogroup->addTab(ppp3group,tr("PPP (3)"));
676#ifdef USE_COMBINATION
677 _aogroup->addTab(cmbgroup,tr("Combine Corrections"));
678#endif
679 _aogroup->addTab(uploadgroup,tr("Upload Corrections"));
680 _aogroup->addTab(uploadEphgroup,tr("Upload Ephemeris"));
681
682 // Log Tab
683 // -------
684 _loggroup = new QTabWidget();
685 _loggroup->addTab(_log,tr("Log"));
686 _loggroup->addTab(_bncFigure,tr("Throughput"));
687 _loggroup->addTab(_bncFigureLate,tr("Latency"));
688 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
689
690 // Netowork (Proxy and SSL) Tab
691 // ----------------------------
692 QGridLayout* pLayout = new QGridLayout;
693 pLayout->setColumnMinimumWidth(0,13*ww);
694 _proxyPortLineEdit->setMaximumWidth(9*ww);
695
696 pLayout->addWidget(new QLabel("Settings for proxy in protected networks and for SSL authorization, leave boxes blank if none."),0, 0, 1, 50);
697 pLayout->addWidget(new QLabel("Proxy host"), 1, 0);
698 pLayout->addWidget(_proxyHostLineEdit, 1, 1, 1,10);
699 pLayout->addWidget(new QLabel("Proxy port"), 2, 0);
700 pLayout->addWidget(_proxyPortLineEdit, 2, 1);
701 pLayout->addWidget(new QLabel("Path to SSL Certificates"), 3, 0);
702 pLayout->addWidget(_sslCaCertPathLineEdit, 3, 1, 1,10);
703 pLayout->addWidget(new QLabel("Default: " + bncSslConfig::defaultPath()), 3,11, 1,20);
704 pLayout->addWidget(new QLabel("Ignore SSL Authorization Errors"), 4, 0);
705 pLayout->addWidget(_ignoreSslErrorsCheckBox, 4, 1, 1,10);
706 pLayout->addWidget(new QLabel(" "), 4, 0);
707 pLayout->addWidget(new QLabel(" "), 5, 0);
708 pLayout->addWidget(new QLabel(" "), 6, 0);
709 pgroup->setLayout(pLayout);
710
711 // General Tab
712 // -----------
713 QGridLayout* gLayout = new QGridLayout;
714 gLayout->setColumnMinimumWidth(0,14*ww);
715 _onTheFlyComboBox->setMaximumWidth(9*ww);
716
717 gLayout->addWidget(new QLabel("General settings for logfile, file handling, configuration on-the-fly, and auto-start."),0, 0, 1, 50);
718 gLayout->addWidget(new QLabel("Logfile (full path)"), 1, 0);
719 gLayout->addWidget(_logFileLineEdit, 1, 1, 1,30);
720 gLayout->addWidget(new QLabel("Append files"), 2, 0);
721 gLayout->addWidget(_rnxAppendCheckBox, 2, 1);
722 gLayout->addWidget(new QLabel("Reread configuration"), 3, 0);
723 gLayout->addWidget(_onTheFlyComboBox, 3, 1);
724 gLayout->addWidget(new QLabel("Auto start"), 4, 0);
725 gLayout->addWidget(_autoStartCheckBox, 4, 1);
726 gLayout->addWidget(new QLabel("Raw output file (full path)"), 5, 0);
727 gLayout->addWidget(_rawOutFileLineEdit, 5, 1, 1,30);
728 gLayout->addWidget(new QLabel(" "), 6, 0);
729 ggroup->setLayout(gLayout);
730
731 // RINEX Observations
732 // ------------------
733 QGridLayout* oLayout = new QGridLayout;
734 oLayout->setColumnMinimumWidth(0,14*ww);
735 _rnxIntrComboBox->setMaximumWidth(9*ww);
736 _rnxSamplSpinBox->setMaximumWidth(9*ww);
737
738 oLayout->addWidget(new QLabel("Saving RINEX observation files."),0, 0, 1,50);
739 oLayout->addWidget(new QLabel("Directory"), 1, 0);
740 oLayout->addWidget(_rnxPathLineEdit, 1, 1, 1,24);
741 oLayout->addWidget(new QLabel("Interval"), 2, 0);
742 oLayout->addWidget(_rnxIntrComboBox, 2, 1);
743 oLayout->addWidget(new QLabel(" Sampling"), 2, 2, Qt::AlignRight);
744 oLayout->addWidget(_rnxSamplSpinBox, 2, 3, Qt::AlignLeft);
745 oLayout->addWidget(new QLabel("Skeleton extension"), 3, 0);
746 oLayout->addWidget(_rnxSkelLineEdit, 3, 1, 1, 1, Qt::AlignLeft);
747 oLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
748 oLayout->addWidget(_rnxScrpLineEdit, 4, 1, 1,24);
749 oLayout->addWidget(new QLabel("Version 3"), 5, 0);
750 oLayout->addWidget(_rnxV3CheckBox, 5, 1);
751 oLayout->addWidget(new QLabel(" "), 6, 0);
752 ogroup->setLayout(oLayout);
753
754 // RINEX Ephemeris
755 // ---------------
756 QGridLayout* eLayout = new QGridLayout;
757 eLayout->setColumnMinimumWidth(0,14*ww);
758 _ephIntrComboBox->setMaximumWidth(9*ww);
759 _outEphPortLineEdit->setMaximumWidth(9*ww);
760
761 eLayout->addWidget(new QLabel("Saving RINEX ephemeris files and ephemeris output through IP port."),0,0,1,50);
762 eLayout->addWidget(new QLabel("Directory"), 1, 0);
763 eLayout->addWidget(_ephPathLineEdit, 1, 1, 1,30);
764 eLayout->addWidget(new QLabel("Interval"), 2, 0);
765 eLayout->addWidget(_ephIntrComboBox, 2, 1);
766 eLayout->addWidget(new QLabel("Port"), 3, 0);
767 eLayout->addWidget(_outEphPortLineEdit, 3, 1);
768 eLayout->addWidget(new QLabel("Version 3"), 4, 0);
769 eLayout->addWidget(_ephV3CheckBox, 4, 1);
770 eLayout->addWidget(new QLabel(" "), 5, 0);
771 eLayout->addWidget(new QLabel(" "), 6, 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("Saving Broadcast Ephemeris correction files and correction output through IP port."),0,0,1,50);
784 cLayout->addWidget(new QLabel("Directory, ASCII"), 1, 0);
785 cLayout->addWidget(_corrPathLineEdit, 1, 1, 1,20);
786 cLayout->addWidget(new QLabel("Interval"), 2, 0);
787 cLayout->addWidget(_corrIntrComboBox, 2, 1);
788 cLayout->addWidget(new QLabel("Port"), 3, 0);
789 cLayout->addWidget(_corrPortLineEdit, 3, 1);
790 cLayout->addWidget(new QLabel(" Wait for full corr epoch"), 3, 2, Qt::AlignRight);
791 cLayout->addWidget(_corrTimeSpinBox, 3, 3, Qt::AlignLeft);
792 cLayout->addWidget(new QLabel(" "), 4, 0);
793 cLayout->addWidget(new QLabel(" "), 5, 0);
794 cLayout->addWidget(new QLabel(" "), 6, 0);
795 cgroup->setLayout(cLayout);
796
797 // Feed Engine
798 // -----------
799 QGridLayout* sLayout = new QGridLayout;
800 sLayout->setColumnMinimumWidth(0,14*ww);
801 _outPortLineEdit->setMaximumWidth(9*ww);
802 _waitTimeSpinBox->setMaximumWidth(9*ww);
803 _binSamplSpinBox->setMaximumWidth(9*ww);
804 _outUPortLineEdit->setMaximumWidth(9*ww);
805
806 sLayout->addWidget(new QLabel("Output decoded observations in ASCII format to feed a real-time GNSS network engine."),0,0,1,50);
807 sLayout->addWidget(new QLabel("Port"), 1, 0);
808 sLayout->addWidget(_outPortLineEdit, 1, 1);
809 sLayout->addWidget(new QLabel("Wait for full obs epoch"), 1, 2, Qt::AlignRight);
810 sLayout->addWidget(_waitTimeSpinBox, 1, 3, Qt::AlignLeft);
811 sLayout->addWidget(new QLabel("Sampling"), 2, 0);
812 sLayout->addWidget(_binSamplSpinBox, 2, 1, Qt::AlignLeft);
813 sLayout->addWidget(new QLabel("File (full path)"), 3, 0);
814 sLayout->addWidget(_outFileLineEdit, 3, 1, 1, 20);
815 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 4, 0);
816 sLayout->addWidget(_outUPortLineEdit, 4, 1);
817 sLayout->addWidget(new QLabel(" "), 5, 0);
818 sLayout->addWidget(new QLabel(" "), 6, 0);
819 sgroup->setLayout(sLayout);
820
821 // Serial Output
822 // -------------
823 QGridLayout* serLayout = new QGridLayout;
824 serLayout->setColumnMinimumWidth(0,14*ww);
825 _serialBaudRateComboBox->setMaximumWidth(9*ww);
826 _serialFlowControlComboBox->setMaximumWidth(11*ww);
827 _serialDataBitsComboBox->setMaximumWidth(5*ww);
828 _serialParityComboBox->setMaximumWidth(9*ww);
829 _serialStopBitsComboBox->setMaximumWidth(5*ww);
830 _serialAutoNMEAComboBox->setMaximumWidth(9*ww);
831 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
832
833 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver."),0,0,1,30);
834 serLayout->addWidget(new QLabel("Mountpoint"), 1, 0, Qt::AlignLeft);
835 serLayout->addWidget(_serialMountPointLineEdit, 1, 1, 1, 2);
836 serLayout->addWidget(new QLabel("Port name"), 2, 0, Qt::AlignLeft);
837 serLayout->addWidget(_serialPortNameLineEdit, 2, 1, 1, 2);
838 serLayout->addWidget(new QLabel("Baud rate"), 3, 0, Qt::AlignLeft);
839 serLayout->addWidget(_serialBaudRateComboBox, 3, 1);
840 serLayout->addWidget(new QLabel("Flow control"), 3, 2, Qt::AlignRight);
841 serLayout->addWidget(_serialFlowControlComboBox, 3, 3);
842 serLayout->addWidget(new QLabel("Data bits"), 4, 0, Qt::AlignLeft);
843 serLayout->addWidget(_serialDataBitsComboBox, 4, 1);
844 serLayout->addWidget(new QLabel("Parity"), 4, 2, Qt::AlignRight);
845 serLayout->addWidget(_serialParityComboBox, 4, 3);
846 serLayout->addWidget(new QLabel(" Stop bits"), 4, 4, Qt::AlignRight);
847 serLayout->addWidget(_serialStopBitsComboBox, 4, 5);
848 serLayout->addWidget(new QLabel("NMEA"), 5, 0);
849 serLayout->addWidget(_serialAutoNMEAComboBox, 5, 1);
850 serLayout->addWidget(new QLabel(" File (full path)"), 5, 2, Qt::AlignRight);
851 serLayout->addWidget(_serialFileNMEALineEdit, 5, 3, 1,15);
852 serLayout->addWidget(new QLabel("Height"), 5,20, Qt::AlignRight);
853 serLayout->addWidget(_serialHeightNMEALineEdit, 5,21, 1,11);
854 serLayout->addWidget(new QLabel(" "), 6, 0);
855
856 sergroup->setLayout(serLayout);
857
858 // Outages
859 // -------
860 QGridLayout* aLayout = new QGridLayout;
861 aLayout->setColumnMinimumWidth(0,14*ww);
862 _obsRateComboBox->setMaximumWidth(9*ww);
863 _adviseFailSpinBox->setMaximumWidth(9*ww);
864 _adviseRecoSpinBox->setMaximumWidth(9*ww);
865
866 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes."),0,0,1,50,Qt::AlignLeft);
867 aLayout->addWidget(new QLabel("Observation rate"), 1, 0);
868 aLayout->addWidget(_obsRateComboBox, 1, 1);
869 aLayout->addWidget(new QLabel("Failure threshold"), 2, 0);
870 aLayout->addWidget(_adviseFailSpinBox, 2, 1);
871 aLayout->addWidget(new QLabel("Recovery threshold"), 3, 0);
872 aLayout->addWidget(_adviseRecoSpinBox, 3, 1);
873 aLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
874 aLayout->addWidget(_adviseScriptLineEdit, 4, 1, 1,30);
875 aLayout->addWidget(new QLabel(" "), 5, 0);
876 aLayout->addWidget(new QLabel(" "), 6, 0);
877 agroup->setLayout(aLayout);
878
879 // Miscellaneous
880 // -------------
881 QGridLayout* rLayout = new QGridLayout;
882 rLayout->setColumnMinimumWidth(0,14*ww);
883 _perfIntrComboBox->setMaximumWidth(9*ww);
884
885 rLayout->addWidget(new QLabel("Log latencies or scan RTCM streams for numbers of message types and antenna information."),0, 0,1,30);
886 rLayout->addWidget(new QLabel("Mountpoint"), 1, 0);
887 rLayout->addWidget(_miscMountLineEdit, 1, 1, 1,7);
888 rLayout->addWidget(new QLabel("Log latency"), 2, 0);
889 rLayout->addWidget(_perfIntrComboBox, 2, 1);
890 rLayout->addWidget(new QLabel("Scan RTCM"), 3, 0);
891 rLayout->addWidget(_scanRTCMCheckBox, 3, 1);
892 rLayout->addWidget(new QLabel(" "), 4, 0);
893 rLayout->addWidget(new QLabel(" "), 5, 0);
894 rLayout->addWidget(new QLabel(" "), 6, 0);
895 rgroup->setLayout(rLayout);
896
897 // PPP Client
898 // ----------
899 QGridLayout* pppLayout = new QGridLayout;
900 pppLayout->setColumnMinimumWidth(0,14*ww);
901 _pppSigCLineEdit->setMaximumWidth(6*ww);
902 _pppSigPLineEdit->setMaximumWidth(6*ww);
903 _pppSigCrd0->setMaximumWidth(6*ww);
904 _pppSigCrdP->setMaximumWidth(6*ww);
905 _pppSigTrp0->setMaximumWidth(6*ww);
906 _pppSigTrpP->setMaximumWidth(6*ww);
907 _pppAverageLineEdit->setMaximumWidth(6*ww);
908 _pppQuickStartLineEdit->setMaximumWidth(6*ww);
909 _pppMaxSolGapLineEdit->setMaximumWidth(6*ww);
910 _pppAudioResponseLineEdit->setMaximumWidth(6*ww);
911 _pppRefCrdXLineEdit->setMaximumWidth(10*ww);
912 _pppRefCrdYLineEdit->setMaximumWidth(10*ww);
913 _pppRefCrdZLineEdit->setMaximumWidth(10*ww);
914 _pppRefdNLineEdit->setMaximumWidth(6*ww);
915 _pppRefdELineEdit->setMaximumWidth(6*ww);
916 _pppRefdULineEdit->setMaximumWidth(6*ww);
917 _pppSync->setMaximumWidth(6*ww);
918 _pppSPPComboBox->setMinimumWidth(15*ww);
919
920 _postObsFileChooser = new qtFileChooser;
921 _postObsFileChooser->setFileName(settings.value("postObsFile").toString());
922 _postObsFileChooser->setMinimumWidth(15*ww);
923 _postNavFileChooser = new qtFileChooser;
924 _postNavFileChooser->setFileName(settings.value("postNavFile").toString());
925 _postNavFileChooser->setMinimumWidth(15*ww);
926 _postCorrFileChooser = new qtFileChooser;
927 _postCorrFileChooser->setFileName(settings.value("postCorrFile").toString());
928 _postCorrFileChooser->setMinimumWidth(15*ww);
929 _postOutLineEdit = new QLineEdit(settings.value("postOutFile").toString());
930 _postOutLineEdit->setMinimumWidth(15*ww);
931
932 int ir = 0;
933 pppLayout->addWidget(new QLabel("Precise Point Positioning, Panel 1."), ir, 0, 1, 2, Qt::AlignLeft);
934 ++ir;
935 pppLayout->addWidget(new QLabel("Mode & mountpoints"),ir, 0, Qt::AlignLeft);
936 pppLayout->addWidget(_pppSPPComboBox, ir, 1, Qt::AlignRight);
937 pppLayout->addWidget(_pppMountLineEdit, ir, 3, Qt::AlignRight);
938 pppLayout->addWidget(new QLabel("Obs."), ir, 4, Qt::AlignLeft);
939 pppLayout->addWidget(_pppCorrMountLineEdit, ir, 5, Qt::AlignRight);
940 pppLayout->addWidget(new QLabel("Corr."), ir, 6, Qt::AlignLeft);
941 ++ir;
942 pppLayout->addWidget(new QLabel("Marker coordinates"), ir, 0, Qt::AlignLeft);
943 pppLayout->addWidget(_pppRefCrdXLineEdit, ir, 1, Qt::AlignRight);
944 pppLayout->addWidget(new QLabel("X "), ir, 2, Qt::AlignLeft);
945 pppLayout->addWidget(_pppRefCrdYLineEdit, ir, 3, Qt::AlignRight);
946 pppLayout->addWidget(new QLabel("Y"), ir, 4, Qt::AlignLeft);
947 pppLayout->addWidget(_pppRefCrdZLineEdit, ir, 5, Qt::AlignRight);
948 pppLayout->addWidget(new QLabel("Z"), ir, 6, Qt::AlignLeft);
949 ++ir;
950 pppLayout->addWidget(new QLabel("Antenna excentricity"), ir, 0, Qt::AlignLeft);
951 pppLayout->addWidget(_pppRefdNLineEdit, ir, 1, Qt::AlignRight);
952 pppLayout->addWidget(new QLabel("dN"), ir, 2, Qt::AlignLeft);
953 pppLayout->addWidget(_pppRefdELineEdit, ir, 3, Qt::AlignRight);
954 pppLayout->addWidget(new QLabel("dE"), ir, 4, Qt::AlignLeft);
955 pppLayout->addWidget(_pppRefdULineEdit, ir, 5, Qt::AlignRight);
956 pppLayout->addWidget(new QLabel("dU"), ir, 6, Qt::AlignLeft);
957 ++ir;
958 pppLayout->addWidget(new QLabel("NMEA & plot output"),ir, 0, Qt::AlignLeft);
959 pppLayout->addWidget(_pppNMEALineEdit, ir, 1, Qt::AlignRight);
960 pppLayout->addWidget(new QLabel("NMEA File"), ir, 2, Qt::AlignLeft);
961 pppLayout->addWidget(_pppNMEAPortLineEdit, ir, 3, Qt::AlignRight);
962 pppLayout->addWidget(new QLabel("NMEA Port"), ir, 4, Qt::AlignLeft);
963 ++ir;
964 pppLayout->addWidget(new QLabel("Post-processing"), ir, 0, Qt::AlignLeft);
965 pppLayout->addWidget(_postObsFileChooser, ir, 1, Qt::AlignRight);
966 pppLayout->addWidget(new QLabel("Obs "), ir, 2, Qt::AlignLeft);
967 pppLayout->addWidget(_postNavFileChooser, ir, 3, Qt::AlignRight);
968 pppLayout->addWidget(new QLabel("Nav "), ir, 4, Qt::AlignLeft);
969 ++ir;
970 pppLayout->addWidget(_postCorrFileChooser, ir, 1, Qt::AlignRight);
971 pppLayout->addWidget(new QLabel("Corr"), ir, 2, Qt::AlignLeft);
972 pppLayout->addWidget(_postOutLineEdit, ir, 3, Qt::AlignRight);
973 pppLayout->addWidget(new QLabel("Log (full path)"), ir, 4, Qt::AlignLeft);
974
975 pppgroup->setLayout(pppLayout);
976
977 // PPP Client (second panel)
978 // -------------------------
979 QGridLayout* ppp2Layout = new QGridLayout;
980 ppp2Layout->setColumnMinimumWidth(0,14*ww);
981 ir = 0;
982 ppp2Layout->addWidget(new QLabel("Precise Point Positioning, Panel 2."), ir, 0, 1, 10);
983 ++ir;
984 ppp2Layout->addWidget(new QLabel("Antennas"), ir, 0);
985 ppp2Layout->addWidget(_pppAntexFileChooser, ir, 1,1,3);
986 ppp2Layout->addWidget(new QLabel("ANTEX File"), ir, 4);
987 ppp2Layout->addWidget(_pppAntennaLineEdit, ir, 5,1,3);
988 ppp2Layout->addWidget(new QLabel("Antenna Name"), ir, 8);
989 ++ir;
990 ppp2Layout->addWidget(new QLabel("Basics"), ir, 0, 1, 5);
991 ppp2Layout->addWidget(_pppUsePhaseCheckBox, ir, 1, Qt::AlignRight);
992 ppp2Layout->addWidget(new QLabel("Use phase obs"), ir, 2);
993 ppp2Layout->addWidget(_pppEstTropoCheckBox, ir, 3, Qt::AlignRight);
994 ppp2Layout->addWidget(new QLabel("Estimate tropo"), ir, 4);
995 ppp2Layout->addWidget(_pppGLONASSCheckBox, ir, 5, Qt::AlignRight);
996 ppp2Layout->addWidget(new QLabel("Use GLONASS"), ir, 6);
997 ppp2Layout->addWidget(_pppGalileoCheckBox, ir, 7, Qt::AlignRight);
998 ppp2Layout->addWidget(new QLabel("Use Galileo "), ir, 8);
999 ++ir;
1000 ppp2Layout->addWidget(new QLabel("Basics cont'd"), ir, 0);
1001 ppp2Layout->addWidget(_pppSync, ir, 1);
1002 ppp2Layout->addWidget(new QLabel("Sync Corr (sec) "), ir, 2);
1003 ppp2Layout->addWidget(_pppAverageLineEdit, ir, 3, Qt::AlignRight);
1004 ppp2Layout->addWidget(new QLabel("Averaging (min)") , ir, 4);
1005 ppp2Layout->addWidget(_pppQuickStartLineEdit, ir, 5, Qt::AlignRight);
1006 ppp2Layout->addWidget(new QLabel("Quick-Start (sec) "), ir, 6);
1007 ppp2Layout->addWidget(_pppMaxSolGapLineEdit, ir, 7, Qt::AlignRight);
1008 ppp2Layout->addWidget(new QLabel("Max Sol. Gap (sec)"), ir, 8);
1009 ++ir;
1010 ppp2Layout->addWidget(new QLabel("Basics cont'd"), ir, 0);
1011 ppp2Layout->addWidget(_pppAudioResponseLineEdit, ir, 1, Qt::AlignRight);
1012 ppp2Layout->addWidget(new QLabel("Audio response (m)"), ir, 2);
1013 ++ir;
1014 ppp2Layout->addWidget(new QLabel("Sigmas"), ir, 0);
1015 ppp2Layout->addWidget(_pppSigCLineEdit, ir, 1, Qt::AlignRight);
1016 ppp2Layout->addWidget(new QLabel("Code"), ir, 2);
1017 ppp2Layout->addWidget(_pppSigPLineEdit, ir, 3);
1018 ppp2Layout->addWidget(new QLabel("Phase"), ir, 4);
1019 ++ir;
1020 ppp2Layout->addWidget(new QLabel("Sigmas cont'd"), ir, 0);
1021 ppp2Layout->addWidget(_pppSigCrd0, ir, 1, Qt::AlignRight);
1022 ppp2Layout->addWidget(new QLabel("XYZ Init "), ir, 2);
1023 ppp2Layout->addWidget(_pppSigCrdP, ir, 3, Qt::AlignRight);
1024 ppp2Layout->addWidget(new QLabel("XYZ White Noise "), ir, 4);
1025 ppp2Layout->addWidget(_pppSigTrp0, ir, 5, Qt::AlignRight);
1026 ppp2Layout->addWidget(new QLabel("Tropo Init "), ir, 6);
1027 ppp2Layout->addWidget(_pppSigTrpP, ir, 7);
1028 ppp2Layout->addWidget(new QLabel("Tropo White Noise"), ir, 8);
1029 ++ir;
1030 ppp2Layout->addWidget(new QLabel(""), ir, 0);
1031
1032 ppp2group->setLayout(ppp2Layout);
1033
1034 // PPP Client (third panel)
1035 // ------------------------
1036 QVBoxLayout* ppp3Layout = new QVBoxLayout;
1037 ppp3Layout->addWidget(new QLabel("Precise Point Positioning, Panel 3."));
1038 ppp3Layout->addSpacing(ww);
1039
1040 QHBoxLayout* ppp3LayoutHlp1 = new QHBoxLayout;
1041 ppp3LayoutHlp1->addWidget(new QLabel("PPP Plot"));
1042 ppp3LayoutHlp1->addWidget(_pppPlotCoordinates);
1043 ppp3LayoutHlp1->addStretch();
1044 ppp3Layout->addLayout(ppp3LayoutHlp1);
1045 ppp3Layout->addSpacing(ww);
1046
1047 QHBoxLayout* ppp3LayoutHlp2 = new QHBoxLayout;
1048 _mapWinButton = new QPushButton;
1049 _mapWinButton->setText("Google / Open Street Map");
1050 connect(_mapWinButton, SIGNAL(clicked()), SLOT(slotMapPPP()));
1051 ppp3LayoutHlp2->addWidget(_mapWinButton);
1052
1053 ppp3LayoutHlp2->addSpacing(5*ww);
1054
1055 QRadioButton* _gmRadioButton = new QRadioButton;
1056 ppp3LayoutHlp2->addWidget(new QLabel("Google"));
1057 ppp3LayoutHlp2->addWidget(_gmRadioButton);
1058
1059 QRadioButton* _osmRadioButton = new QRadioButton;
1060 ppp3LayoutHlp2->addWidget(new QLabel("OSM"));
1061 ppp3LayoutHlp2->addWidget(_osmRadioButton);
1062
1063 ppp3LayoutHlp2->addSpacing(5*ww);
1064
1065 _mapWinTraceCheckBox = new QCheckBox;
1066 ppp3LayoutHlp2->addWidget(new QLabel("Trace"));
1067 ppp3LayoutHlp2->addWidget(_mapWinTraceCheckBox);
1068
1069 ppp3LayoutHlp2->addStretch();
1070 ppp3Layout->addLayout(ppp3LayoutHlp2);
1071
1072 ppp3Layout->addStretch();
1073 ppp3group->setLayout(ppp3Layout);
1074
1075 // Reqc Processing
1076 // ---------------
1077 _reqcActionComboBox = new QComboBox();
1078 _reqcActionComboBox->setEditable(false);
1079 _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
1080 ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
1081 if (ik != -1) {
1082 _reqcActionComboBox->setCurrentIndex(ik);
1083 }
1084 connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
1085 this, SLOT(slotBncTextChanged()));
1086
1087 QGridLayout* reqcLayout = new QGridLayout;
1088 _reqcActionComboBox->setMinimumWidth(15*ww);
1089 _reqcActionComboBox->setMaximumWidth(15*ww);
1090
1091 _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1092 _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
1093 _reqcObsFileChooser->setWhatsThis(tr("Specify the full path to an observation file in RINEX v2 or v3 format."));
1094 _reqcObsFileChooser->setMinimumWidth(15*ww);
1095 _reqcObsFileChooser->setMaximumWidth(15*ww);
1096
1097 _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1098 _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
1099 _reqcNavFileChooser->setWhatsThis(tr("Specify the full path to a RINEX v2 or v3 navigation file."));
1100 _reqcNavFileChooser->setMinimumWidth(15*ww);
1101 _reqcNavFileChooser->setMaximumWidth(15*ww);
1102
1103 _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
1104 _reqcOutObsLineEdit->setWhatsThis(tr("Specify the full path to a RINEX observation output file."));
1105 _reqcOutObsLineEdit->setMinimumWidth(15*ww);
1106 _reqcOutObsLineEdit->setMaximumWidth(15*ww);
1107
1108 _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
1109 _reqcOutNavLineEdit->setWhatsThis(tr("Specify the full path to a RINEX navigation output file."));
1110 _reqcOutNavLineEdit->setMinimumWidth(15*ww);
1111 _reqcOutNavLineEdit->setMaximumWidth(15*ww);
1112
1113 _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
1114 _reqcOutLogLineEdit->setWhatsThis(tr("Specify the full path to a logfile."));
1115 _reqcOutLogLineEdit->setMinimumWidth(15*ww);
1116 _reqcOutLogLineEdit->setMaximumWidth(15*ww);
1117
1118 _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
1119 _reqcPlotDirLineEdit->setWhatsThis(tr("Specify the directory name for saving plots."));
1120 _reqcPlotDirLineEdit->setMinimumWidth(15*ww);
1121 _reqcPlotDirLineEdit->setMaximumWidth(15*ww);
1122
1123 _reqcSkyPlotSystems = new QComboBox();
1124 _reqcSkyPlotSystems->setEditable(false);
1125 _reqcSkyPlotSystems->addItems(QString("ALL,GPS,GLONASS,Galileo").split(","));
1126 ik = _reqcSkyPlotSystems->findText(settings.value("reqcSkyPlotSystems").toString());
1127 if (ik != -1) {
1128 _reqcSkyPlotSystems->setCurrentIndex(ik);
1129 }
1130
1131 ir = 0;
1132 reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check."),ir, 0, 1, 20);
1133 ++ir;
1134 reqcLayout->addWidget(new QLabel("Action"), ir, 0, Qt::AlignLeft);
1135 reqcLayout->addWidget(_reqcActionComboBox, ir, 1, Qt::AlignLeft);
1136 _reqcEditOptionButton = new QPushButton("Set Edit Options");
1137 reqcLayout->addWidget(_reqcEditOptionButton, ir, 3, Qt::AlignRight);
1138 ++ir;
1139 reqcLayout->addWidget(new QLabel("Input files (full path)"), ir, 0, Qt::AlignLeft);
1140 reqcLayout->addWidget(_reqcObsFileChooser, ir, 1, Qt::AlignRight);
1141 reqcLayout->addWidget(new QLabel("Obs"), ir, 2, Qt::AlignLeft);
1142 reqcLayout->addWidget(_reqcNavFileChooser, ir, 3, Qt::AlignRight);
1143 reqcLayout->addWidget(new QLabel("Nav"), ir, 4, Qt::AlignLeft);
1144 ++ir;
1145 reqcLayout->addWidget(new QLabel("Output files (full path)"), ir, 0, Qt::AlignLeft);
1146 reqcLayout->addWidget(_reqcOutObsLineEdit, ir, 1, Qt::AlignRight);
1147 reqcLayout->addWidget(new QLabel("Obs"), ir, 2, Qt::AlignLeft);
1148 reqcLayout->addWidget(_reqcOutNavLineEdit, ir, 3, Qt::AlignRight);
1149 reqcLayout->addWidget(new QLabel("Nav"), ir, 4, Qt::AlignLeft);
1150 ++ir;
1151 reqcLayout->addWidget(_reqcOutLogLineEdit, ir, 1, Qt::AlignRight);
1152 reqcLayout->addWidget(new QLabel("Log"), ir, 2, Qt::AlignLeft);
1153 ++ir;
1154 reqcLayout->addWidget(new QLabel("Directory for plots"), ir, 0, Qt::AlignLeft);
1155 reqcLayout->addWidget(_reqcPlotDirLineEdit, ir, 1, Qt::AlignRight);
1156 ++ir;
1157 reqcLayout->addWidget(new QLabel("Sky plots for"), ir, 0, Qt::AlignLeft);
1158 reqcLayout->addWidget(_reqcSkyPlotSystems, ir, 1, Qt::AlignRight);
1159 ++ir;
1160 reqcLayout->addWidget(new QLabel(""), ir, 1);
1161 reqcLayout->setRowStretch(ir, 999);
1162
1163 reqcLayout->setColumnMinimumWidth(2, 8*ww);
1164 reqcLayout->setColumnMinimumWidth(4, 8*ww);
1165
1166 reqcgroup->setLayout(reqcLayout);
1167
1168 connect(_reqcEditOptionButton, SIGNAL(clicked()),
1169 this, SLOT(slotReqcEditOption()));
1170
1171 // Combine Corrections
1172 // -------------------
1173 QGridLayout* cmbLayout = new QGridLayout;
1174
1175 populateCmbTable();
1176 cmbLayout->addWidget(_cmbTable, 0, 0, 6, 3);
1177 cmbLayout->addWidget(new QLabel(" "), 0, 5);
1178 cmbLayout->addWidget(new QLabel("Combine Broadcast Correction streams."), 0, 6, 1, 50);
1179 cmbLayout->addWidget(new QLabel(" "), 1, 5);
1180 cmbLayout->addWidget(addCmbRowButton, 1, 6);
1181 cmbLayout->addWidget(delCmbRowButton, 1, 7);
1182 cmbLayout->addWidget(new QLabel(" "), 2, 5);
1183 cmbLayout->addWidget(new QLabel("Method"), 2, 6, Qt::AlignRight);
1184 cmbLayout->addWidget(_cmbMethodComboBox, 2, 7, Qt::AlignRight);
1185 cmbLayout->addWidget(new QLabel(" "), 3, 5);
1186 cmbLayout->addWidget(new QLabel("Maximal Residuum"), 3, 6, Qt::AlignRight);
1187 cmbLayout->addWidget(_cmbMaxresLineEdit, 3, 7, Qt::AlignRight);
1188 cmbLayout->addWidget(new QLabel(" "), 4, 5);
1189 cmbLayout->addWidget(new QLabel("Sampling"), 4, 6, Qt::AlignRight);
1190 cmbLayout->addWidget(_cmbSamplSpinBox, 4, 7, Qt::AlignRight);
1191 cmbLayout->addWidget(new QLabel(" "), 5, 0);
1192
1193 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1194 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
1195
1196 cmbgroup->setLayout(cmbLayout);
1197
1198 // Upload Layout (Clocks)
1199 // ----------------------
1200 QGridLayout* uploadHlpLayout = new QGridLayout();
1201
1202 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1203 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1204 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
1205
1206 uploadHlpLayout->addWidget(addUploadRowButton, 0, 0);
1207 uploadHlpLayout->addWidget(delUploadRowButton, 0, 1);
1208 uploadHlpLayout->addWidget(new QLabel("Interval"), 0, 2, Qt::AlignRight);
1209 uploadHlpLayout->addWidget(_uploadIntrComboBox, 0, 3);
1210 uploadHlpLayout->addWidget(new QLabel(" Sampling: Orb"), 0, 4, Qt::AlignRight);
1211 uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox, 0, 5);
1212 uploadHlpLayout->addWidget(new QLabel("SP3"), 0, 6, Qt::AlignRight);
1213 uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox, 0, 7);
1214 uploadHlpLayout->addWidget(new QLabel("RNX"), 0, 8, Qt::AlignRight);
1215 uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox, 0, 9);
1216 uploadHlpLayout->addWidget(setUploadTrafoButton, 0,10);
1217
1218 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1219 populateUploadTable();
1220
1221 uploadLayout->addWidget(new QLabel("Upload RTCMv3 Broadcast Corrections to caster."));
1222 uploadLayout->addWidget(_uploadTable);
1223 uploadLayout->addLayout(uploadHlpLayout);
1224
1225 uploadgroup->setLayout(uploadLayout);
1226
1227 // Upload Layout (Ephemeris)
1228 // -------------------------
1229 QGridLayout* uploadLayoutEph = new QGridLayout;
1230
1231 uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1232 _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1233 _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1234 _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1235
1236 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster."), 0, 0, 1, 50);
1237 uploadLayoutEph->addWidget(new QLabel("Host"), 1, 0);
1238 uploadLayoutEph->addWidget(_uploadEphHostLineEdit, 1, 1, 1, 3);
1239 uploadLayoutEph->addWidget(new QLabel(" Port"), 1, 4, Qt::AlignRight);
1240 uploadLayoutEph->addWidget(_uploadEphPortLineEdit, 1, 5, 1, 1);
1241 uploadLayoutEph->addWidget(new QLabel("Mountpoint "), 2, 0);
1242 uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit, 2, 1);
1243 uploadLayoutEph->addWidget(new QLabel(" Password"), 2, 2, Qt::AlignRight);
1244 uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit, 2, 3);
1245 uploadLayoutEph->addWidget(new QLabel("Sampling"), 3, 0);
1246 uploadLayoutEph->addWidget(_uploadEphSampleSpinBox, 3, 1);
1247 uploadLayoutEph->addWidget(new QLabel("Uploaded"), 4, 0);
1248 uploadLayoutEph->addWidget(_uploadEphBytesCounter, 4, 1);
1249 uploadLayoutEph->addWidget(new QLabel(" "), 5, 0);
1250 uploadLayoutEph->addWidget(new QLabel(" "), 6, 0);
1251
1252 uploadEphgroup->setLayout(uploadLayoutEph);
1253
1254 connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1255 this, SLOT(slotBncTextChanged()));
1256
1257#ifdef RTROVER_INTERFACE
1258 QWidget* rtroverGroup = new QWidget();
1259 _aogroup->addTab(rtroverGroup,tr("RTRover"));
1260 QGridLayout* rtroverLayout = new QGridLayout();
1261
1262 _rtroverModeComboBox = new QComboBox();
1263
1264 _rtroverModeComboBox->setEditable(false);
1265 _rtroverModeComboBox->addItems(QString(",PPP_DF,SPP_DF,PPP_SF,SPP_SF,PPP_AR,RTK,PPP_FTTF").split(","));
1266 ik = _rtroverModeComboBox->findText(settings.value("rtroverMode").toString());
1267 if (ik != -1) {
1268 _rtroverModeComboBox->setCurrentIndex(ik);
1269 }
1270 _rtroverModeComboBox->setMinimumWidth(10*ww);
1271
1272 _rtroverRoverMountLineEdit = new QLineEdit(settings.value("rtroverRoverMount").toString());
1273 _rtroverRoverMountLineEdit->setMaximumWidth(8*ww);
1274 _rtroverCorrMountLineEdit = new QLineEdit(settings.value("rtroverCorrMount").toString());
1275 _rtroverCorrMountLineEdit->setMaximumWidth(8*ww);
1276 _rtroverBaseMountLineEdit = new QLineEdit(settings.value("rtroverBaseMount").toString());
1277 _rtroverBaseMountLineEdit->setMaximumWidth(8*ww);
1278 _rtroverRoverRefCrdXLineEdit = new QLineEdit(settings.value("rtroverRoverRefCrdX").toString());
1279 _rtroverRoverRefCrdYLineEdit = new QLineEdit(settings.value("rtroverRoverRefCrdY").toString());
1280 _rtroverRoverRefCrdZLineEdit = new QLineEdit(settings.value("rtroverRoverRefCrdZ").toString());
1281 _rtroverBaseRefCrdXLineEdit = new QLineEdit(settings.value("rtroverBaseRefCrdX").toString());
1282 _rtroverBaseRefCrdYLineEdit = new QLineEdit(settings.value("rtroverBaseRefCrdY").toString());
1283 _rtroverBaseCrdZLineEdit = new QLineEdit(settings.value("rtroverBaseRefCrdZ").toString());
1284 _rtroverRoverDNLineEdit = new QLineEdit(settings.value("rtroverRoverDN").toString());
1285 _rtroverRoverDNLineEdit->setMaximumWidth(6*ww);
1286 _rtroverRoverDELineEdit = new QLineEdit(settings.value("rtroverRoverDE").toString());
1287 _rtroverRoverDELineEdit->setMaximumWidth(6*ww);
1288 _rtroverRoverDULineEdit = new QLineEdit(settings.value("rtroverRoverDU").toString());
1289 _rtroverRoverDULineEdit->setMaximumWidth(6*ww);
1290 _rtroverBaseDNLineEdit = new QLineEdit(settings.value("rtroverBaseDN").toString());
1291 _rtroverBaseDNLineEdit->setMaximumWidth(6*ww);
1292 _rtroverBaseDELineEdit = new QLineEdit(settings.value("rtroverBaseDE").toString());
1293 _rtroverBaseDELineEdit->setMaximumWidth(6*ww);
1294 _rtroverBaseDULineEdit = new QLineEdit(settings.value("rtroverBaseDU").toString());
1295 _rtroverBaseDULineEdit->setMaximumWidth(6*ww);
1296 _rtroverRoverAntennaLineEdit = new QLineEdit(settings.value("rtroverRoverAntenna").toString());
1297 _rtroverBaseAntennaLineEdit = new QLineEdit(settings.value("rtroverBaseAntenna").toString());
1298 _rtroverAntexFileChooser = new qtFileChooser;
1299 _rtroverAntexFileChooser->setMinimumWidth(12*ww);
1300 _rtroverAntexFileChooser->setFileName(settings.value("rtroverAntex").toString());
1301 _rtroverOutputLineEdit = new QLineEdit(settings.value("rtroverOutput").toString());
1302 _rtroverOutputLineEdit->setMinimumWidth(15*ww);
1303
1304 ir = 0;
1305 rtroverLayout->addWidget(new QLabel("Real-Time Rover"), ir, 0, 1, 2, Qt::AlignLeft);
1306 ++ir;
1307 rtroverLayout->addWidget(new QLabel("Mode & mountpoints"),ir, 0, Qt::AlignLeft);
1308 rtroverLayout->addWidget(_rtroverModeComboBox, ir, 1, Qt::AlignRight);
1309 rtroverLayout->addWidget(_rtroverRoverMountLineEdit, ir, 3, Qt::AlignRight);
1310 rtroverLayout->addWidget(new QLabel("Rover"), ir, 4, Qt::AlignLeft);
1311 rtroverLayout->addWidget(_rtroverCorrMountLineEdit, ir, 5, Qt::AlignRight);
1312 rtroverLayout->addWidget(new QLabel("Corr."), ir, 6, Qt::AlignLeft);
1313 rtroverLayout->addWidget(_rtroverBaseMountLineEdit, ir, 7, Qt::AlignRight);
1314 rtroverLayout->addWidget(new QLabel("Base"), ir, 8, Qt::AlignLeft);
1315 ++ir;
1316 rtroverLayout->addWidget(new QLabel("Rover coordinates"), ir, 0, Qt::AlignLeft);
1317 rtroverLayout->addWidget(_rtroverRoverRefCrdXLineEdit, ir, 1, Qt::AlignRight);
1318 rtroverLayout->addWidget(new QLabel("X "), ir, 2, Qt::AlignLeft);
1319 rtroverLayout->addWidget(_rtroverRoverRefCrdYLineEdit, ir, 3, Qt::AlignRight);
1320 rtroverLayout->addWidget(new QLabel("Y"), ir, 4, Qt::AlignLeft);
1321 rtroverLayout->addWidget(_rtroverRoverRefCrdZLineEdit, ir, 5, Qt::AlignRight);
1322 rtroverLayout->addWidget(new QLabel("Z"), ir, 6, Qt::AlignLeft);
1323 ++ir;
1324 rtroverLayout->addWidget(_rtroverRoverDNLineEdit, ir, 1, Qt::AlignRight);
1325 rtroverLayout->addWidget(new QLabel("dN"), ir, 2, Qt::AlignLeft);
1326 rtroverLayout->addWidget(_rtroverRoverDELineEdit, ir, 3, Qt::AlignRight);
1327 rtroverLayout->addWidget(new QLabel("dE"), ir, 4, Qt::AlignLeft);
1328 rtroverLayout->addWidget(_rtroverRoverDULineEdit, ir, 5, Qt::AlignRight);
1329 rtroverLayout->addWidget(new QLabel("dU"), ir, 6, Qt::AlignLeft);
1330 ++ir;
1331 rtroverLayout->addWidget(new QLabel("Base coordinates"), ir, 0, Qt::AlignLeft);
1332 rtroverLayout->addWidget(_rtroverBaseRefCrdXLineEdit, ir, 1, Qt::AlignRight);
1333 rtroverLayout->addWidget(new QLabel("X "), ir, 2, Qt::AlignLeft);
1334 rtroverLayout->addWidget(_rtroverBaseRefCrdYLineEdit, ir, 3, Qt::AlignRight);
1335 rtroverLayout->addWidget(new QLabel("Y"), ir, 4, Qt::AlignLeft);
1336 rtroverLayout->addWidget(_rtroverBaseCrdZLineEdit, ir, 5, Qt::AlignRight);
1337 rtroverLayout->addWidget(new QLabel("Z"), ir, 6, Qt::AlignLeft);
1338 ++ir;
1339 rtroverLayout->addWidget(_rtroverBaseDNLineEdit, ir, 1, Qt::AlignRight);
1340 rtroverLayout->addWidget(new QLabel("dN"), ir, 2, Qt::AlignLeft);
1341 rtroverLayout->addWidget(_rtroverBaseDELineEdit, ir, 3, Qt::AlignRight);
1342 rtroverLayout->addWidget(new QLabel("dE"), ir, 4, Qt::AlignLeft);
1343 rtroverLayout->addWidget(_rtroverBaseDULineEdit, ir, 5, Qt::AlignRight);
1344 rtroverLayout->addWidget(new QLabel("dU"), ir, 6, Qt::AlignLeft);
1345 ++ir;
1346 rtroverLayout->addWidget(new QLabel("ANTEX"), ir, 0, Qt::AlignLeft);
1347 rtroverLayout->addWidget(_rtroverAntexFileChooser, ir, 1, Qt::AlignRight);
1348 rtroverLayout->addWidget(new QLabel("file"), ir, 2, Qt::AlignLeft);
1349 rtroverLayout->addWidget(_rtroverBaseAntennaLineEdit, ir, 3, Qt::AlignRight);
1350 rtroverLayout->addWidget(new QLabel("Ant. Rover"), ir, 4, Qt::AlignLeft);
1351 rtroverLayout->addWidget(_rtroverRoverAntennaLineEdit, ir, 5, Qt::AlignRight);
1352 rtroverLayout->addWidget(new QLabel("Ant. Base"), ir, 6, Qt::AlignLeft);
1353 ++ir;
1354 rtroverLayout->addWidget(new QLabel("Output"), ir, 0, Qt::AlignLeft);
1355 rtroverLayout->addWidget(_rtroverOutputLineEdit, ir, 1, Qt::AlignRight);
1356
1357 rtroverGroup->setLayout(rtroverLayout);
1358#endif
1359
1360 // Main Layout
1361 // -----------
1362 QGridLayout* mLayout = new QGridLayout;
1363 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
1364 mLayout->addWidget(_aogroup, 0,0);
1365 mLayout->addWidget(_mountPointsTable, 1,0);
1366 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
1367 mLayout->addWidget(_loggroup, 2,0);
1368
1369 _canvas->setLayout(mLayout);
1370
1371 // WhatsThis
1372 // ---------
1373 _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>"));
1374 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1375 _sslCaCertPathLineEdit->setWhatsThis(tr("<p>Communication with an NTRIP broadcaster over SSL requires the exchange of client and/or server certificates. Specify the path to a directory where you save certificates on your system. Don't try communication via SSL if you are not sure wheter this is supported by the involved NTRIP broadcaster. Note that SSL communication is usually done over port 443.</p>"));
1376 _ignoreSslErrorsCheckBox->setWhatsThis(tr("<p>SSL communication may involve queries coming from the NTRIP broadcaster. Tick 'Ignore SSL authorization erros' if you don't want to be bothered with this.</p>"));
1377 _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 obs 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>"));
1378 _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."));
1379 _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."));
1380 _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."));
1381 _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."));
1382 _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."));
1383 _corrTimeSpinBox->setWhatsThis(tr("<p>Concerning output through IP port, BNC drops Broadcast Ephemeris Corrections received later than 'Wait for full corr 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>"));
1384 _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."));
1385 _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."));
1386 _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."));
1387 _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>"));
1388 _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>"));
1389 _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>"));
1390 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1391 _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p>"));
1392
1393 _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', '5 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>"));
1394 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1395 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1396 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of the Broadcast Ephemeris Correction files.</p>"));
1397 _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>"));
1398 _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>"));
1399 _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>"));
1400 _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>"));
1401 _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>"));
1402 _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."));
1403 _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>"));
1404 _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>"));
1405 _mountPointsTable->setWhatsThis(tr("<p>Streams selected for retrieval are listed in the 'Streams' section. Clicking on 'Add Stream' button will open a window that allows the user to select data streams from an NTRIP broadcaster according to their mountpoints. To remove a stream from the 'Streams' list, highlight it by clicking on it and hit the 'Delete Stream' button. You can also remove multiple streams by highlighting them using +Shift and +Ctrl.</p><p>BNC automatically allocates one of its internal decoders to a stream based on the stream's 'format' as given in the sourcetable. BNC allows users to change this selection by editing the decoder string. Double click on the 'decoder' field, enter your preferred decoder and then hit Enter. The accepted decoder strings are 'RTCM_2.x', 'RTCM_3.x' and 'RTNET'.</p><p>In case you need to log the raw data as is, BNC allows users to by-pass its decoders 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>"));
1406 _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."));
1407 _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)."));
1408 _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."));
1409 _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."));
1410 _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."));
1411 _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>"));
1412 _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><p>In case of RTCM Version 3 MSM streams, BNC will also log contained RINEX Version 3 observation types.</p>."));
1413 _serialMountPointLineEdit->setWhatsThis(tr("<p>Enter a 'Mountpoint' to forward the corresponding stream to a serial connected receiver.</p>"));
1414 _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>"));
1415 _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>"));
1416 _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>"));
1417 _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>"));
1418 _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>"));
1419 _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>"));
1420 _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>"));
1421 _serialFileNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where NMEA messages coming from your serial connected receiver are saved.</p>"));
1422 _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>"));
1423 _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>"));
1424 _pppCorrMountLineEdit->setWhatsThis(tr("<p>You must specify an orbit/clock Broadcast Ephemeris corrections stream by its mountpoint from the 'Streams' list below. Example: 'CLK10'. Corrections must refer to satellite Antenna Phase Centers (APC).</p><p>Note that BNC can produce an internal PPP solution from combined Broadcast Ephemeris corrections as specified under 'Combine Corrections' if you introduce keyword 'INTERNAL' as the corrections mountpoint.</p>"));
1425 _pppSPPComboBox->setWhatsThis(tr("<p>Choose between plain Single Point Positioning (SPP) and Precise Point Positioning (PPP) in 'Realtime' or 'Post-Processing' mode.</p><p>When in 'Post-Processing mode:<ul><li>Specifying a RINEX Observation, a RINEX Navigation and a Broadcast Correction file leads to a PPP solution.</li><li>Specifying only a RINEX Observation and a RINEX Navigation file and no Broadcast Correction file leads to a SPP solution.</ul></p>"));
1426 _reqcActionComboBox->setWhatsThis(tr("<p>BNC allows to edit or concatenate RINEX v2 or v3 files or to perform a quality check following UNAVCO's famous 'teqc' program.</p>"));
1427 _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX v2 or v3 files.</p>"));
1428 _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>"));
1429 _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>"));
1430 _pppGLONASSCheckBox->setWhatsThis(tr("<p>By default BNC does not use GLONASS observations in PPP mode.</p><p>Tick 'Use GLONASS' for adding GLONASS observations to GPS and Galileo (optional) in a PPP solution.</p>"));
1431 _pppGalileoCheckBox->setWhatsThis(tr("<p>By default BNC does not use Galileo observations in PPP mode.</p><p>Tick 'Use Galileo' for adding Galileo observations to GPS and GLONASS (optional) in a PPP solution.</p>"));
1432 _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."));
1433 _pppNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where PPP results are saved as NMEA messages.</p>"));
1434 _pppNMEAPortLineEdit->setWhatsThis(tr("<p>Specify an IP port number to output PPP results as NMEA messages through an IP port.</p>"));
1435 _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>"));
1436 _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>"));
1437 _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 Quick-Start mode and fixes the introduced reference coordinate for the specified period. A value of '60' 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>"));
1438 _pppAudioResponseLineEdit->setWhatsThis(tr("<p>Specify an 'Audio response' threshold in meters. A beep is produced by BNC whenever a horizontal PPP coordinate component differs by more than the threshold value from the marker coordinate.</p><p>Default is an empty option field, meaning that you don't want BNC to produce alarm signals.</p>"));
1439 _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>"));
1440 _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>"));
1441 _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."));
1442 _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>"));
1443 _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>"));
1444 _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 3e-6 (default) would mean that the tropospheric effect may vary for 3600 * 3e-6 = 0.01 meters per hour.</p>"));
1445 _pppRefCrdXLineEdit->setWhatsThis(tr("<p>Enter reference coordinate X of the receiver's position.</p><p>This option only makes sense in static observation conditions.</p>"));
1446 _pppRefCrdYLineEdit->setWhatsThis(tr("<p>Enter reference coordinate Y of the receiver's position.</p><p>This option only makes sens in static observation conditions.</p>"));
1447 _pppRefCrdZLineEdit->setWhatsThis(tr("<p>Enter reference coordinate Z of the receiver's position.</p><p>This option only makes sens in static observation conditions.</p>"));
1448 _pppRefdNLineEdit->setWhatsThis(tr("<p>Enter north antenna excentricity.</p>"));
1449 _pppRefdELineEdit->setWhatsThis(tr("<p>Enter east antenna excentricity.</p>"));
1450 _pppRefdULineEdit->setWhatsThis(tr("<p>Enter up antenna excentricity.</p>"));
1451 _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."));
1452 _pppSync->setWhatsThis(tr(
1453 "<p> Zero value (or empty field, default) means that BNC processes each epoch of data "
1454 "immediately after its arrival using satellite clock corrections available at "
1455 "that time.</p><p> Non-zero value 'Sync Corr' (i.e. 5) means that the epochs of data "
1456 "are buffered and the processing of each epoch is postponed till the satellite clock "
1457 "corrections not older than 'Sync Corr' seconds are available.<p>"));
1458 _pppAntexFileChooser->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>"));
1459 _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>"));
1460 _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 coming 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.<ul><li>Note that an appropriate 'Wait for full corr 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.</li><li>Note also that you need to tick 'Use GLONASS' which is part ot the 'PPP (2)' panel in case you want to produce an GPS plus GLONASS combination.</li></ul></p><p>Note further that the orbit information in the final combination stream is just copied from one of the incoming streams. The stream used for providing the orbits may vary over time: if the orbit providing stream has an outage then BNC switches to the next remaining stream for getting hold of the orbit information.</p><p>The combination process requires Broadcast Ephemeris. Besides the orbit and clock corrections stream(s) BNC should therefore pull a stream carrying Broadcast Ephemeris in the form of RTCM Version 3 messages.</p><p>It is possible to specify only one Broadcast Ephemeris corrections stream in the combination table. Instead of combining corrections BNC will then merge them with Broadcast Ephemeris to save results in SP3 and/or Clock RINEX format."));
1461 _cmbMaxresLineEdit->setWhatsThis(tr("<p>BNC combines all incoming clocks according to specified weights. Individual clock estimates that differ by more than 'Maximal Residuum' meters from the average of all clocks will be ignored.<p></p>It is suggested to specify a value of about 0.2 m for the Kalman filter combination approach and a value of about 3.0 meters for the Single-Epoch combination approach.</p><p>Default is a value of '999.0'.</p>"));
1462 _cmbSamplSpinBox->setWhatsThis(tr("<p>Specify a combination sampling interval. Clock and orbit corrections will be produced following that interval. A value of 10 sec may be an appropriate choice.</p>"));
1463 _cmbMethodComboBox->setWhatsThis(tr("<p>Select a clock combination approach. Options are 'Single-Epoch' and Kalman 'Filter'. It is suggested to use the Kalman filter approach for the purpose of Precise Point Positioning.</p>"));
1464 _uploadTable->setWhatsThis(tr("<p>BNC can upload clock and orbit corrections to broadcast ephemeris (Broadcast Corrections) in RTCM Version 3 SSR format. You may have a situation where clocks and orbits come from an external Real-time Network Engine (1) or a situation where clock and orbit corrections are combined within BNC (2).</p><p>(1) BNC identifies a stream as coming from a Real-time Network Engine if its format is specified as 'RTNET' and hence its decoder string in the 'Streams' canvas is 'RTNET'. It encodes and uploads that stream to the specified NTRIP broadcaster</p><p>(2) BNC understands that it is expected to encode and upload combined Broadcast Ephemeris corrections if you specify correction streams in the 'Combine Corrections' stream table.</p><p>Hit the 'Add Row' button, double click on the 'Host' field to enter the IP or URL of an NTRIP broadcaster and hit Enter. Then double click on the 'Port', 'Mount' and 'Password' fields to enter the NTRIP broadcaster IP port (default is 80), the mountpoint and the stream upload password. An empty 'Host' option field means that you don't want to upload corrections.</p><p>Select a target coordinate reference system (e.g. IGS08) for outgoing clock and orbit corrections.</p><p>By default orbit and clock corrections refer to Antenna Phase Center (APC). Tick 'CoM' to refer uploaded corrections to Center of Mass instead of APC.</p><p>Specify a path for saving the generated Broadcast Corrections plus Broadcast Ephemeris as SP3 orbit files. If the specified directory does not exist, BNC will not create SP3 orbit files. The following is a path example for a Linux system:<br>/home/user/BNC${GPSWD}.sp3<br>Note that '${GPSWD}' produces the GPS Week and Day number in the file name.</p><ul><li>As an SP3 file contents should be referred to the satellites Center of Mass (CoM) while correctors are referred to the satellites Antenna Phase Center (APC), an offset has to be applied which is available from an IGS ANTEX file. You should therefore specify the 'ANTEX File' path under tab 'PPP (2)' if you want to save the stream contents in SP3 format. If you don't specify an 'ANTEX File' path there, the SP3 file contents will be referred to the satellites APCs.</li></ul></p><p>Specify a path for saving the generated Broadcast Correction clocks plus Broadcast Ephemeris clocks as Clock RINEX files. If the specified directory does not exist, BNC will not create Clock RINEX files. The following is a path example for a Linux system:<br>/home/user/BNC${GPSWD}.clk<br>Note that '${GPSWD}' produces the GPS Week and Day number in the file name.</p><p>Specify finally an SSR Provider ID number, an SSR Solution ID number and an Issue of Data SSR number.</p><p>In case the 'Combine Corrections' table contains only one Broadcast Corrections stream, BNC will merge that stream with Broadcast Ephemeris to save results in files specified here through SP3 and/or Clock RINEX file path. In such a case you should define only the SP3 and Clock RINEX file path and no further options in the 'Upload Corrections' table.</p>"));
1465 _postObsFileChooser->setWhatsThis(tr("Full path to RINEX v2/v3 Observation file."));
1466 _postNavFileChooser->setWhatsThis(tr("Full path to RINEX v2/v3 Navigation file."));
1467 _postCorrFileChooser->setWhatsThis(tr("Full path to Broadcast Corrections file as previously saved with BNC in plain ASCII format."));
1468 _postOutLineEdit->setWhatsThis(tr("Full path to file with post processing PPP results. "));
1469 addCmbRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the mountpoints table."));
1470 delCmbRowButton->setWhatsThis(tr("Hit 'Delete' button to delete the highlighted line from the mountpoints table."));
1471 addUploadRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the stream upload table."));
1472 delUploadRowButton->setWhatsThis(tr("Hit 'Del Row' button to delete the highlighted line from the stream upload table."));
1473 _uploadIntrComboBox->setWhatsThis(tr("Select the length of the SP3 and Clock RINEX files."));
1474 _uploadSamplRtcmEphCorrSpinBox->setWhatsThis(tr("Select the stream's orbit correction sampling interval in seconds. A value of zero '0' tells BNC to upload all available orbit and clock correction samples together in combined messages."));
1475 _uploadSamplClkRnxSpinBox->setWhatsThis(tr("Select the Clock RINEX file sampling interval in seconds. A value of zero '0' tells BNC to store all available samples into Clock RINEX files."));
1476 _uploadSamplSp3SpinBox->setWhatsThis(tr("Select the SP3 orbit file sampling interval in minutes. A value of zero '0' tells BNC to store all available samples into SP3 orbit files."));
1477 setUploadTrafoButton->setWhatsThis(tr("Hit 'Custom Trafo' to specify your own 14 parameter Helmert Transformation instead of selecting a predefined transformation through 'System' button."));
1478
1479 _uploadEphHostLineEdit->setWhatsThis(tr("BNC can upload a Broadcast Ephemeris stream in RTCM Version 3 format. Specify the host IP of an NTRIP Broadcaster to upload the stream. An empty option field means that you don't want to upload Broadcast Ephemeris."));
1480 _uploadEphPortLineEdit->setWhatsThis(tr("Specify the IP port of an NTRIP Broadcaster to upload the stream. Default is port 80."));
1481 _uploadEphMountpointLineEdit->setWhatsThis(tr("Specify the mounpoint for stream upload to an NTRIP Broadcaster."));
1482 _uploadEphPasswordLineEdit->setWhatsThis(tr("Specify the stream upload password protecting the mounpoint on an NTRIP Broadcaster."));
1483 _uploadEphSampleSpinBox->setWhatsThis(tr("Select the Broadcast Ephemeris sampling interval in seconds. Defaut is '5' meaning that a complete set of Broadcast Ephemeris is uploaded every 5 seconds."));
1484 _uploadEphBytesCounter->setWhatsThis(tr("BNC shows the amount of data uploaded through this stream."));
1485
1486 _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1487 _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
1488 _actMapMountPoints->setWhatsThis(tr("<p> Draw distribution map of stream selection presented in the 'Streams' canvas. Use the mouse to zoom in or out.</p><p>Left button: Draw rectangle to zoom in.<br>Right button: Zoom out.<br>Middle button: Zoom back.</p>"));
1489
1490 _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1491 _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1492// Weber
1493
1494 // Enable/Disable all Widgets
1495 // --------------------------
1496 slotBncTextChanged();
1497 enableStartStop();
1498
1499 // Auto start
1500 // ----------
1501 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1502 slotStart();
1503 }
1504}
1505
1506// Destructor
1507////////////////////////////////////////////////////////////////////////////
1508bncWindow::~bncWindow() {
1509 delete _caster;
1510 delete _casterEph;
1511}
1512
1513//
1514////////////////////////////////////////////////////////////////////////////
1515void bncWindow::populateMountPointsTable() {
1516
1517 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1518 _mountPointsTable->removeRow(iRow);
1519 }
1520
1521 bncSettings settings;
1522
1523 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1524 int iRow = 0;
1525 while (it.hasNext()) {
1526 QStringList hlp = it.next().split(" ");
1527 if (hlp.size() < 5) continue;
1528 _mountPointsTable->insertRow(iRow);
1529
1530 QUrl url(hlp[0]);
1531
1532 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1533 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1534 QString nmea(hlp[4]);
1535 if (hlp[5] == "S") {
1536 fullPath = hlp[0].replace(0,2,"");
1537 }
1538 QString ntripVersion = "2";
1539 if (hlp.size() >= 6) {
1540 ntripVersion = (hlp[5]);
1541 }
1542
1543 QTableWidgetItem* it;
1544 it = new QTableWidgetItem(url.userInfo());
1545 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1546 _mountPointsTable->setItem(iRow, 0, it);
1547
1548 it = new QTableWidgetItem(fullPath);
1549 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1550 _mountPointsTable->setItem(iRow, 1, it);
1551
1552 it = new QTableWidgetItem(format);
1553 _mountPointsTable->setItem(iRow, 2, it);
1554
1555 if (nmea == "yes") {
1556 it = new QTableWidgetItem(latitude);
1557 _mountPointsTable->setItem(iRow, 3, it);
1558 it = new QTableWidgetItem(longitude);
1559 _mountPointsTable->setItem(iRow, 4, it);
1560 } else {
1561 it = new QTableWidgetItem(latitude);
1562 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1563 _mountPointsTable->setItem(iRow, 3, it);
1564 it = new QTableWidgetItem(longitude);
1565 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1566 _mountPointsTable->setItem(iRow, 4, it);
1567 }
1568
1569 it = new QTableWidgetItem(nmea);
1570 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1571 _mountPointsTable->setItem(iRow, 5, it);
1572
1573 it = new QTableWidgetItem(ntripVersion);
1574 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1575 _mountPointsTable->setItem(iRow, 6, it);
1576
1577 bncTableItem* bncIt = new bncTableItem();
1578 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1579 _mountPointsTable->setItem(iRow, 7, bncIt);
1580
1581 iRow++;
1582 }
1583
1584 _mountPointsTable->sortItems(1);
1585
1586 enableStartStop();
1587}
1588
1589// Retrieve Table
1590////////////////////////////////////////////////////////////////////////////
1591void bncWindow::slotAddMountPoints() {
1592
1593 bncSettings settings;
1594 QString proxyHost = settings.value("proxyHost").toString();
1595 int proxyPort = settings.value("proxyPort").toInt();
1596 if (proxyHost != _proxyHostLineEdit->text() ||
1597 proxyPort != _proxyPortLineEdit->text().toInt()) {
1598 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1599 "changed. Use the new ones?",
1600 QMessageBox::Yes, QMessageBox::No,
1601 QMessageBox::NoButton);
1602 if (iRet == QMessageBox::Yes) {
1603 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1604 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1605 }
1606 }
1607
1608 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1609 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1610
1611 QMessageBox msgBox;
1612 msgBox.setIcon(QMessageBox::Question);
1613 msgBox.setWindowTitle("Add Stream");
1614 msgBox.setText("Add stream(s) coming from:");
1615
1616 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1617 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1618 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1619 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1620 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1621
1622 msgBox.exec();
1623
1624 if (msgBox.clickedButton() == buttonNtrip) {
1625 bncTableDlg* dlg = new bncTableDlg(this);
1626 dlg->move(this->pos().x()+50, this->pos().y()+50);
1627 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1628 this, SLOT(slotNewMountPoints(QStringList*)));
1629 dlg->exec();
1630 delete dlg;
1631 } else if (msgBox.clickedButton() == buttonIP) {
1632 bncIpPort* ipp = new bncIpPort(this);
1633 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1634 this, SLOT(slotNewMountPoints(QStringList*)));
1635 ipp->exec();
1636 delete ipp;
1637 } else if (msgBox.clickedButton() == buttonUDP) {
1638 bncUdpPort* udp = new bncUdpPort(this);
1639 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1640 this, SLOT(slotNewMountPoints(QStringList*)));
1641 udp->exec();
1642 delete udp;
1643 } else if (msgBox.clickedButton() == buttonSerial) {
1644 bncSerialPort* sep = new bncSerialPort(this);
1645 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1646 this, SLOT(slotNewMountPoints(QStringList*)));
1647 sep->exec();
1648 delete sep;
1649 } else if (msgBox.clickedButton() == buttonCancel) {
1650 // Cancel
1651 }
1652
1653 enableStartStop();
1654}
1655
1656// Delete Selected Mount Points
1657////////////////////////////////////////////////////////////////////////////
1658void bncWindow::slotDeleteMountPoints() {
1659
1660 int nRows = _mountPointsTable->rowCount();
1661 bool flg[nRows];
1662 for (int iRow = 0; iRow < nRows; iRow++) {
1663 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1664 flg[iRow] = true;
1665 }
1666 else {
1667 flg[iRow] = false;
1668 }
1669 }
1670 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1671 if (flg[iRow]) {
1672 _mountPointsTable->removeRow(iRow);
1673 }
1674 }
1675 _actDeleteMountPoints->setEnabled(false);
1676
1677 enableStartStop();
1678}
1679
1680// New Mount Points Selected
1681////////////////////////////////////////////////////////////////////////////
1682void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1683 int iRow = 0;
1684 QListIterator<QString> it(*mountPoints);
1685 while (it.hasNext()) {
1686 QStringList hlp = it.next().split(" ");
1687 QUrl url(hlp[0]);
1688 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1689 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1690 QString nmea(hlp[4]);
1691 if (hlp[5] == "S") {
1692 fullPath = hlp[0].replace(0,2,"");
1693 }
1694 QString ntripVersion = "2";
1695 if (hlp.size() >= 6) {
1696 ntripVersion = (hlp[5]);
1697 }
1698
1699 _mountPointsTable->insertRow(iRow);
1700
1701 QTableWidgetItem* it;
1702 it = new QTableWidgetItem(url.userInfo());
1703 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1704 _mountPointsTable->setItem(iRow, 0, it);
1705
1706 it = new QTableWidgetItem(fullPath);
1707 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1708 _mountPointsTable->setItem(iRow, 1, it);
1709
1710 it = new QTableWidgetItem(format);
1711 _mountPointsTable->setItem(iRow, 2, it);
1712
1713 if (nmea == "yes") {
1714 it = new QTableWidgetItem(latitude);
1715 _mountPointsTable->setItem(iRow, 3, it);
1716 it = new QTableWidgetItem(longitude);
1717 _mountPointsTable->setItem(iRow, 4, it);
1718 } else {
1719 it = new QTableWidgetItem(latitude);
1720 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1721 _mountPointsTable->setItem(iRow, 3, it);
1722 it = new QTableWidgetItem(longitude);
1723 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1724 _mountPointsTable->setItem(iRow, 4, it);
1725 }
1726
1727 it = new QTableWidgetItem(nmea);
1728 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1729 _mountPointsTable->setItem(iRow, 5, it);
1730
1731 it = new QTableWidgetItem(ntripVersion);
1732 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1733 _mountPointsTable->setItem(iRow, 6, it);
1734
1735 bncTableItem* bncIt = new bncTableItem();
1736 _mountPointsTable->setItem(iRow, 7, bncIt);
1737
1738 iRow++;
1739 }
1740 _mountPointsTable->hideColumn(0);
1741 _mountPointsTable->sortItems(1);
1742 delete mountPoints;
1743
1744 enableStartStop();
1745}
1746
1747// Save Options (serialize)
1748////////////////////////////////////////////////////////////////////////////
1749void bncWindow::slotSaveOptions() {
1750 saveOptions();
1751 bncSettings settings;
1752 settings.sync();
1753}
1754
1755// Save Options (memory only)
1756////////////////////////////////////////////////////////////////////////////
1757void bncWindow::saveOptions() {
1758
1759 QStringList mountPoints;
1760 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1761
1762 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1763 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1764 "@" + _mountPointsTable->item(iRow, 1)->text() );
1765
1766 mountPoints.append(url.toString() + " " +
1767 _mountPointsTable->item(iRow, 2)->text()
1768 + " " + _mountPointsTable->item(iRow, 3)->text()
1769 + " " + _mountPointsTable->item(iRow, 4)->text()
1770 + " " + _mountPointsTable->item(iRow, 5)->text()
1771 + " " + _mountPointsTable->item(iRow, 6)->text());
1772 } else {
1773 mountPoints.append(
1774 "//" + _mountPointsTable->item(iRow, 1)->text()
1775 + " " + _mountPointsTable->item(iRow, 2)->text()
1776 + " " + _mountPointsTable->item(iRow, 3)->text()
1777 + " " + _mountPointsTable->item(iRow, 4)->text()
1778 + " " + _mountPointsTable->item(iRow, 5)->text()
1779 + " " + _mountPointsTable->item(iRow, 6)->text());
1780 }
1781 }
1782
1783 QStringList combineStreams;
1784 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1785 QString hlp;
1786 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1787 if (_cmbTable->item(iRow, iCol)) {
1788 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1789 }
1790 }
1791 if (!hlp.isEmpty()) {
1792 combineStreams << hlp;
1793 }
1794 }
1795
1796 QStringList uploadMountpointsOut;
1797 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1798 QString hlp;
1799 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1800 if (_uploadTable->cellWidget(iRow, iCol) &&
1801 (iCol == 3 || iCol == 4 || iCol == 5)) {
1802 if (iCol == 3) {
1803 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1804 hlp += passwd->text() + ",";
1805 }
1806 else if (iCol == 4) {
1807 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1808 hlp += system->currentText() + ",";
1809 }
1810 else if (iCol == 5) {
1811 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1812 QString state; state.setNum(com->checkState());
1813 hlp += state + ",";
1814 }
1815 }
1816 else if (_uploadTable->item(iRow, iCol)) {
1817 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1818 }
1819 }
1820 if (!hlp.isEmpty()) {
1821 uploadMountpointsOut << hlp;
1822 }
1823 }
1824
1825 bncSettings settings;
1826
1827 settings.setValue("startTab", _aogroup->currentIndex());
1828 settings.setValue("statusTab", _loggroup->currentIndex());
1829 settings.setValue("mountPoints", mountPoints);
1830// Network
1831 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1832 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1833 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1834 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1835// General
1836 settings.setValue("logFile", _logFileLineEdit->text());
1837 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1838 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1839 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1840 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1841// RINEX Observations
1842 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1843 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1844 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1845 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1846 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1847 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1848// RINEX Ephemeris
1849 settings.setValue("ephPath", _ephPathLineEdit->text());
1850 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1851 settings.setValue("outEphPort", _outEphPortLineEdit->text());
1852 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1853// Broadcast Corrections
1854 settings.setValue("corrPath", _corrPathLineEdit->text());
1855 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1856 settings.setValue("corrPort", _corrPortLineEdit->text());
1857 settings.setValue("corrTime", _corrTimeSpinBox->value());
1858// Feed Engine
1859 settings.setValue("outPort", _outPortLineEdit->text());
1860 settings.setValue("waitTime", _waitTimeSpinBox->value());
1861 settings.setValue("binSampl", _binSamplSpinBox->value());
1862 settings.setValue("outFile", _outFileLineEdit->text());
1863 settings.setValue("outUPort", _outUPortLineEdit->text());
1864// Serial Output
1865 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1866 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1867 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1868 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1869 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1870 settings.setValue("serialParity", _serialParityComboBox->currentText());
1871 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1872 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1873 settings.setValue("serialFileNMEA",_serialFileNMEALineEdit->text());
1874 settings.setValue("serialHeightNMEA",_serialHeightNMEALineEdit->text());
1875// Outages
1876 settings.setValue("obsRate", _obsRateComboBox->currentText());
1877 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1878 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1879 settings.setValue("adviseScript",_adviseScriptLineEdit->text());
1880// Miscellaneous
1881 settings.setValue("miscMount", _miscMountLineEdit->text());
1882 settings.setValue("perfIntr", _perfIntrComboBox->currentText());
1883 settings.setValue("scanRTCM", _scanRTCMCheckBox->checkState());
1884// PPPP
1885 settings.setValue("pppSPP", _pppSPPComboBox->currentText());
1886 settings.setValue("pppMount", _pppMountLineEdit->text());
1887 settings.setValue("pppCorrMount",_pppCorrMountLineEdit->text());
1888 settings.setValue("pppRefCrdX", _pppRefCrdXLineEdit->text());
1889 settings.setValue("pppRefCrdY", _pppRefCrdYLineEdit->text());
1890 settings.setValue("pppRefCrdZ", _pppRefCrdZLineEdit->text());
1891 settings.setValue("pppRefdN", _pppRefdNLineEdit->text());
1892 settings.setValue("pppRefdE", _pppRefdELineEdit->text());
1893 settings.setValue("pppRefdU", _pppRefdULineEdit->text());
1894 settings.setValue("nmeaFile", _pppNMEALineEdit->text());
1895 settings.setValue("nmeaPort", _pppNMEAPortLineEdit->text());
1896 settings.setValue("pppPlotCoordinates", _pppPlotCoordinates->checkState());
1897 settings.setValue("postObsFile", _postObsFileChooser->fileName());
1898 settings.setValue("postNavFile", _postNavFileChooser->fileName());
1899 settings.setValue("postCorrFile", _postCorrFileChooser->fileName());
1900 settings.setValue("postOutFile", _postOutLineEdit->text());
1901 settings.setValue("pppAntenna", _pppAntennaLineEdit->text());
1902 settings.setValue("pppAntex", _pppAntexFileChooser->fileName());
1903 settings.setValue("pppUsePhase", _pppUsePhaseCheckBox->checkState());
1904 settings.setValue("pppEstTropo", _pppEstTropoCheckBox->checkState());
1905 settings.setValue("pppGLONASS", _pppGLONASSCheckBox->checkState());
1906 settings.setValue("pppGalileo", _pppGalileoCheckBox->checkState());
1907 settings.setValue("pppSync", _pppSync->text());
1908 settings.setValue("pppAverage", _pppAverageLineEdit->text());
1909 settings.setValue("pppQuickStart", _pppQuickStartLineEdit->text());
1910 settings.setValue("pppMaxSolGap", _pppMaxSolGapLineEdit->text());
1911 settings.setValue("pppAudioResponse", _pppAudioResponseLineEdit->text());
1912 settings.setValue("pppSigmaCode",_pppSigCLineEdit->text());
1913 settings.setValue("pppSigmaPhase",_pppSigPLineEdit->text());
1914 settings.setValue("pppSigCrd0",_pppSigCrd0->text());
1915 settings.setValue("pppSigCrdP",_pppSigCrdP->text());
1916 settings.setValue("pppSigTrp0",_pppSigTrp0->text());
1917 settings.setValue("pppSigTrpP",_pppSigTrpP->text());
1918// Reqc
1919 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1920 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1921 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1922 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1923 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1924 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
1925 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
1926 settings.setValue("reqcSkyPlotSystems", _reqcSkyPlotSystems->currentText());
1927// Combine Corrections
1928 if (!combineStreams.isEmpty()) {
1929 settings.setValue("combineStreams", combineStreams);
1930 }
1931 else {
1932 settings.setValue("combineStreams", "");
1933 }
1934 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1935 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1936 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1937// Upload Corrections
1938 if (!uploadMountpointsOut.isEmpty()) {
1939 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1940 }
1941 else {
1942 settings.setValue("uploadMountpointsOut", "");
1943 }
1944 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1945 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1946 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1947 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
1948// Upload Ephemeris
1949 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1950 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
1951 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
1952 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1953 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
1954
1955#ifdef RTROVER_INTERFACE
1956 settings.setValue("rtroverMode", _rtroverModeComboBox->currentText());
1957 settings.setValue("rtroverRoverMount", _rtroverRoverMountLineEdit->text());
1958 settings.setValue("rtroverCorrMount", _rtroverCorrMountLineEdit->text());
1959 settings.setValue("rtroverBaseMount", _rtroverBaseMountLineEdit->text());
1960 settings.setValue("rtroverRoverRefCrdX", _rtroverRoverRefCrdXLineEdit->text());
1961 settings.setValue("rtroverRoverRefCrdY", _rtroverRoverRefCrdYLineEdit->text());
1962 settings.setValue("rtroverRoverRefCrdZ", _rtroverRoverRefCrdZLineEdit->text());
1963 settings.setValue("rtroverBaseRefCrdX", _rtroverBaseRefCrdXLineEdit->text());
1964 settings.setValue("rtroverBaseRefCrdY", _rtroverBaseRefCrdYLineEdit->text());
1965 settings.setValue("rtroverBaseRefCrdZ", _rtroverBaseCrdZLineEdit->text());
1966 settings.setValue("rtroverRoverDN", _rtroverRoverDNLineEdit->text());
1967 settings.setValue("rtroverRoverDE", _rtroverRoverDELineEdit->text());
1968 settings.setValue("rtroverRoverDU", _rtroverRoverDULineEdit->text());
1969 settings.setValue("rtroverBaseDN", _rtroverBaseDNLineEdit->text());
1970 settings.setValue("rtroverBaseDE", _rtroverBaseDELineEdit->text());
1971 settings.setValue("rtroverBaseDU", _rtroverBaseDULineEdit->text());
1972 settings.setValue("rtroverRoverAntenna", _rtroverRoverAntennaLineEdit->text());
1973 settings.setValue("rtroverBaseAntenna", _rtroverBaseAntennaLineEdit->text());
1974 settings.setValue("rtroverAntex", _rtroverAntexFileChooser->fileName());
1975 settings.setValue("rtroverOutput", _rtroverOutputLineEdit->text());
1976#endif
1977
1978 if (_caster) {
1979 _caster->readMountPoints();
1980 }
1981}
1982
1983// All get slots terminated
1984////////////////////////////////////////////////////////////////////////////
1985void bncWindow::slotGetThreadsFinished() {
1986 BNC_CORE->slotMessage("All Get Threads Terminated", true);
1987 delete _caster; _caster = 0;
1988 delete _casterEph; _casterEph = 0;
1989 _runningRealTime = false;
1990}
1991
1992// Start It!
1993////////////////////////////////////////////////////////////////////////////
1994void bncWindow::slotStart() {
1995 saveOptions();
1996 if ( _pppSPPComboBox->currentText() == "Post-Processing" ) {
1997 startPostProcessingPPP();
1998 }
1999 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
2000 startPostProcessingReqc();
2001 }
2002 else {
2003 startRealTime();
2004 }
2005}
2006
2007// Start Real-Time (Retrieve Data etc.)
2008////////////////////////////////////////////////////////////////////////////
2009void bncWindow::startRealTime() {
2010
2011 _runningRealTime = true;
2012
2013 _bncFigurePPP->reset();
2014
2015 _actDeleteMountPoints->setEnabled(false);
2016
2017 enableStartStop();
2018
2019 _caster = new bncCaster(_outFileLineEdit->text(),
2020 _outPortLineEdit->text().toInt());
2021
2022 BNC_CORE->setPort(_outEphPortLineEdit->text().toInt());
2023 BNC_CORE->setPortCorr(_corrPortLineEdit->text().toInt());
2024 BNC_CORE->initCombination();
2025
2026 connect(_caster, SIGNAL(getThreadsFinished()),
2027 this, SLOT(slotGetThreadsFinished()));
2028
2029 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
2030 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
2031
2032 BNC_CORE->slotMessage("========== Start BNC v" BNCVERSION " =========", true);
2033
2034 bncSettings settings;
2035
2036 QDir rnxdir(settings.value("rnxPath").toString());
2037 if (!rnxdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations directory", true);
2038
2039 QString rnx_file = settings.value("rnxScript").toString();
2040 if ( !rnx_file.isEmpty() ) {
2041 QFile rnxfile(settings.value("rnxScript").toString());
2042 if (!rnxfile.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations script", true);
2043 }
2044
2045 QDir ephdir(settings.value("ephPath").toString());
2046 if (!ephdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Ephemeris directory", true);
2047
2048 QDir corrdir(settings.value("corrPath").toString());
2049 if (!corrdir.exists()) BNC_CORE->slotMessage("Cannot find Broadcast Corrections directory", true);
2050
2051 QString advise_file = settings.value("adviseScript").toString();
2052 if ( !advise_file.isEmpty() ) {
2053 QFile advisefile(settings.value("adviseScript").toString());
2054 if (!advisefile.exists()) BNC_CORE->slotMessage("Cannot find Outages script", true);
2055 }
2056
2057 QString ant_file = settings.value("pppAntex").toString();
2058 if ( !ant_file.isEmpty() ) {
2059 QFile anxfile(settings.value("pppAntex").toString());
2060 if (!anxfile.exists()) BNC_CORE->slotMessage("Cannot find IGS ANTEX file", true);
2061 }
2062
2063 _caster->readMountPoints();
2064
2065 _casterEph = new bncEphUploadCaster();
2066 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
2067 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
2068}
2069
2070// Retrieve Data
2071////////////////////////////////////////////////////////////////////////////
2072void bncWindow::slotStop() {
2073 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving data?",
2074 QMessageBox::Yes, QMessageBox::No,
2075 QMessageBox::NoButton);
2076 if (iRet == QMessageBox::Yes) {
2077 BNC_CORE->stopCombination();
2078 delete _caster; _caster = 0;
2079 delete _casterEph; _casterEph = 0;
2080 _runningRealTime = false;
2081 enableStartStop();
2082 }
2083}
2084
2085// Close Application gracefully
2086////////////////////////////////////////////////////////////////////////////
2087void bncWindow::closeEvent(QCloseEvent* event) {
2088
2089 int iRet = QMessageBox::question(this, "Close", "Save Options?",
2090 QMessageBox::Yes, QMessageBox::No,
2091 QMessageBox::Cancel);
2092
2093 if (iRet == QMessageBox::Cancel) {
2094 event->ignore();
2095 return;
2096 }
2097 else if (iRet == QMessageBox::Yes) {
2098 slotSaveOptions();
2099 }
2100
2101 QMainWindow::closeEvent(event);
2102}
2103
2104// User changed the selection of mountPoints
2105////////////////////////////////////////////////////////////////////////////
2106void bncWindow::slotSelectionChanged() {
2107 if (_mountPointsTable->selectedItems().isEmpty()) {
2108 _actDeleteMountPoints->setEnabled(false);
2109 }
2110 else {
2111 _actDeleteMountPoints->setEnabled(true);
2112 }
2113}
2114
2115// Display Program Messages
2116////////////////////////////////////////////////////////////////////////////
2117void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
2118
2119#ifdef DEBUG_RTCM2_2021
2120 const int maxBufferSize = 1000;
2121#else
2122 const int maxBufferSize = 10000;
2123#endif
2124
2125 if (! showOnScreen ) {
2126 return;
2127 }
2128
2129 QString txt = _log->toPlainText() + "\n" +
2130 QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg;
2131 _log->clear();
2132 _log->append(txt.right(maxBufferSize));
2133}
2134
2135// About Message
2136////////////////////////////////////////////////////////////////////////////
2137void bncWindow::slotAbout() {
2138 new bncAboutDlg(0);
2139}
2140
2141//Flowchart
2142////////////////////////////////////////////////////////////////////////////
2143void bncWindow::slotFlowchart() {
2144 new bncFlowchartDlg(0);
2145}
2146
2147// Help Window
2148////////////////////////////////////////////////////////////////////////////
2149void bncWindow::slotHelp() {
2150 QUrl url;
2151 url.setPath(":bnchelp.html");
2152 new bncHlpDlg(0, url);
2153}
2154
2155// Select Fonts
2156////////////////////////////////////////////////////////////////////////////
2157void bncWindow::slotFontSel() {
2158 bool ok;
2159 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
2160 if (ok) {
2161 bncSettings settings;
2162 settings.setValue("font", newFont.toString());
2163 QApplication::setFont(newFont);
2164 int ww = QFontMetrics(newFont).width('w');
2165 setMinimumSize(60*ww, 80*ww);
2166 resize(60*ww, 80*ww);
2167 }
2168}
2169
2170// Whats This Help
2171void bncWindow::slotWhatsThis() {
2172 QWhatsThis::enterWhatsThisMode();
2173}
2174
2175//
2176////////////////////////////////////////////////////////////////////////////
2177void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
2178 _threads = threads;
2179
2180 _bncFigure->updateMountPoints();
2181 _bncFigureLate->updateMountPoints();
2182
2183 populateMountPointsTable();
2184 bncSettings settings;
2185 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
2186 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
2187 QListIterator<bncGetThread*> iTh(threads);
2188 while (iTh.hasNext()) {
2189 bncGetThread* thread = iTh.next();
2190 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
2191 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
2192 "@" + _mountPointsTable->item(iRow, 1)->text() );
2193 if (url == thread->mountPoint() &&
2194 _mountPointsTable->item(iRow, 3)->text() == thread->latitude() &&
2195 _mountPointsTable->item(iRow, 4)->text() == thread->longitude() ) {
2196 ((bncTableItem*) _mountPointsTable->item(iRow, 7))->setGetThread(thread);
2197 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
2198 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2199 connect(thread, SIGNAL(newBytes(QByteArray, double)),
2200 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2201 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
2202 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2203 connect(thread, SIGNAL(newLatency(QByteArray, double)),
2204 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2205 if ( Qt::CheckState(settings.value("pppPlotCoordinates").toInt()) == Qt::Checked) {
2206 disconnect(thread,
2207 SIGNAL(newPosition(bncTime, double, double, double)),
2208 _bncFigurePPP,
2209 SLOT(slotNewPosition(bncTime, double, double, double)));
2210 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2211 _bncFigurePPP,
2212 SLOT(slotNewPosition(bncTime, double, double, double)));
2213 }
2214#ifdef QT_WEBKIT
2215 if (_mapWin) {
2216 disconnect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2217 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2218 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2219 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2220 }
2221#endif
2222 break;
2223 }
2224 }
2225 }
2226}
2227
2228//
2229////////////////////////////////////////////////////////////////////////////
2230void bncWindow::CreateMenu() {
2231 // Create Menus
2232 // ------------
2233 _menuFile = menuBar()->addMenu(tr("&File"));
2234 _menuFile->addAction(_actFontSel);
2235 _menuFile->addSeparator();
2236 _menuFile->addAction(_actSaveOpt);
2237 _menuFile->addSeparator();
2238 _menuFile->addAction(_actQuit);
2239
2240 _menuHlp = menuBar()->addMenu(tr("&Help"));
2241 _menuHlp->addAction(_actHelp);
2242 _menuHlp->addAction(_actFlowchart);
2243 _menuHlp->addAction(_actAbout);
2244}
2245
2246// Toolbar
2247////////////////////////////////////////////////////////////////////////////
2248void bncWindow::AddToolbar() {
2249 QToolBar* toolBar = new QToolBar;
2250 addToolBar(Qt::BottomToolBarArea, toolBar);
2251 toolBar->setMovable(false);
2252 toolBar->addAction(_actAddMountPoints);
2253 toolBar->addAction(_actDeleteMountPoints);
2254 toolBar->addAction(_actMapMountPoints);
2255 toolBar->addAction(_actStart);
2256 toolBar->addAction(_actStop);
2257 toolBar->addWidget(new QLabel(" "));
2258 toolBar->addAction(_actwhatsthis);
2259}
2260
2261// About
2262////////////////////////////////////////////////////////////////////////////
2263bncAboutDlg::bncAboutDlg(QWidget* parent) :
2264 QDialog(parent) {
2265
2266 QTextBrowser* tb = new QTextBrowser;
2267 QUrl url; url.setPath(":bncabout.html");
2268 tb->setSource(url);
2269 tb->setReadOnly(true);
2270
2271 int ww = QFontMetrics(font()).width('w');
2272 QPushButton* _closeButton = new QPushButton("Close");
2273 _closeButton->setMaximumWidth(10*ww);
2274 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2275
2276 QGridLayout* dlgLayout = new QGridLayout();
2277 QLabel* img = new QLabel();
2278 img->setPixmap(QPixmap(":ntrip-logo.png"));
2279 dlgLayout->addWidget(img, 0,0);
2280 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
2281 dlgLayout->addWidget(tb,1,0,1,2);
2282 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2283
2284 setLayout(dlgLayout);
2285 resize(60*ww, 60*ww);
2286 setWindowTitle("About BNC");
2287 show();
2288}
2289
2290//
2291////////////////////////////////////////////////////////////////////////////
2292bncAboutDlg::~bncAboutDlg() {
2293};
2294
2295// Flowchart
2296////////////////////////////////////////////////////////////////////////////
2297bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2298 QDialog(parent) {
2299
2300 int ww = QFontMetrics(font()).width('w');
2301 QPushButton* _closeButton = new QPushButton("Close");
2302 _closeButton->setMaximumWidth(10*ww);
2303 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2304
2305 QGridLayout* dlgLayout = new QGridLayout();
2306 QLabel* img = new QLabel();
2307 img->setPixmap(QPixmap(":bncflowchart.png"));
2308 dlgLayout->addWidget(img, 0,0);
2309 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2310
2311 setLayout(dlgLayout);
2312 setWindowTitle("Flow Chart");
2313 show();
2314}
2315
2316//
2317////////////////////////////////////////////////////////////////////////////
2318bncFlowchartDlg::~bncFlowchartDlg() {
2319};
2320
2321// Enable/Disable Widget (and change its color)
2322////////////////////////////////////////////////////////////////////////////
2323void bncWindow::enableWidget(bool enable, QWidget* widget) {
2324 const static QPalette paletteWhite(QColor(255, 255, 255));
2325 const static QPalette paletteGray(QColor(230, 230, 230));
2326
2327 widget->setEnabled(enable);
2328 if (enable) {
2329 widget->setPalette(paletteWhite);
2330 }
2331 else {
2332 widget->setPalette(paletteGray);
2333 }
2334}
2335
2336// Bnc Text
2337////////////////////////////////////////////////////////////////////////////
2338void bncWindow::slotBncTextChanged(){
2339
2340 bool enable = true;
2341
2342 // Proxy
2343 //------
2344 if (sender() == 0 || sender() == _proxyHostLineEdit) {
2345 enable = !_proxyHostLineEdit->text().isEmpty();
2346 enableWidget(enable, _proxyPortLineEdit);
2347 }
2348
2349 // RINEX Observations
2350 // ------------------
2351 if (sender() == 0 || sender() == _rnxPathLineEdit) {
2352 enable = !_rnxPathLineEdit->text().isEmpty();
2353 enableWidget(enable, _rnxSamplSpinBox);
2354 enableWidget(enable, _rnxSkelLineEdit);
2355 enableWidget(enable, _rnxScrpLineEdit);
2356 enableWidget(enable, _rnxV3CheckBox);
2357 enableWidget(enable, _rnxIntrComboBox);
2358 }
2359
2360 // RINEX Ephemeris
2361 // ---------------
2362 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _outEphPortLineEdit) {
2363 enable = !_ephPathLineEdit->text().isEmpty() || !_outEphPortLineEdit->text().isEmpty();
2364 enableWidget(enable, _ephIntrComboBox);
2365 enableWidget(enable, _ephV3CheckBox);
2366 }
2367
2368 // Broadcast Corrections
2369 // ---------------------
2370 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2371 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2372 enableWidget(enable, _corrIntrComboBox);
2373 }
2374
2375 // Feed Engine
2376 // -----------
2377 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2378 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2379 enableWidget(enable, _waitTimeSpinBox);
2380 enableWidget(enable, _binSamplSpinBox);
2381 }
2382
2383 // Serial Output
2384 // -------------
2385 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
2386 sender() == _serialAutoNMEAComboBox) {
2387 enable = !_serialMountPointLineEdit->text().isEmpty();
2388 enableWidget(enable, _serialPortNameLineEdit);
2389 enableWidget(enable, _serialBaudRateComboBox);
2390 enableWidget(enable, _serialParityComboBox);
2391 enableWidget(enable, _serialDataBitsComboBox);
2392 enableWidget(enable, _serialStopBitsComboBox);
2393 enableWidget(enable, _serialFlowControlComboBox);
2394 enableWidget(enable, _serialAutoNMEAComboBox);
2395
2396 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() != "Auto";
2397 enableWidget(enable2, _serialFileNMEALineEdit);
2398 }
2399
2400 // Outages
2401 // -------
2402 if (sender() == 0 || sender() == _obsRateComboBox) {
2403 enable = !_obsRateComboBox->currentText().isEmpty();
2404 enableWidget(enable, _adviseFailSpinBox);
2405 enableWidget(enable, _adviseRecoSpinBox);
2406 enableWidget(enable, _adviseScriptLineEdit);
2407 }
2408
2409 // Miscellaneous
2410 // -------------
2411 if (sender() == 0 || sender() == _miscMountLineEdit) {
2412 enable = !_miscMountLineEdit->text().isEmpty();
2413 enableWidget(enable, _perfIntrComboBox);
2414 enableWidget(enable, _scanRTCMCheckBox);
2415 }
2416
2417 // Enable/disable Broadcast Ephemerides
2418 // ------------------------------------
2419 if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2420 if (!_uploadEphHostLineEdit->text().isEmpty()) {
2421 _uploadEphPortLineEdit->setStyleSheet("background-color: white");
2422 _uploadEphMountpointLineEdit->setStyleSheet("background-color: white");
2423 _uploadEphPasswordLineEdit->setStyleSheet("background-color: white");
2424 _uploadEphSampleSpinBox->setStyleSheet("background-color: white");
2425 _uploadEphPortLineEdit->setEnabled(true);
2426 _uploadEphMountpointLineEdit->setEnabled(true);
2427 _uploadEphPasswordLineEdit->setEnabled(true);
2428 _uploadEphSampleSpinBox->setEnabled(true);
2429 }
2430 else {
2431 _uploadEphPortLineEdit->setStyleSheet("background-color: lightGray");
2432 _uploadEphMountpointLineEdit->setStyleSheet("background-color: lightGray");
2433 _uploadEphPasswordLineEdit->setStyleSheet("background-color: lightGray");
2434 _uploadEphSampleSpinBox->setStyleSheet("background-color: lightGray");
2435 _uploadEphPortLineEdit->setEnabled(false);
2436 _uploadEphMountpointLineEdit->setEnabled(false);
2437 _uploadEphPasswordLineEdit->setEnabled(false);
2438 _uploadEphSampleSpinBox->setEnabled(false);
2439 }
2440 }
2441
2442 // Combine Corrections
2443 // -------------------
2444 if (sender() == 0 || sender() == _cmbTable) {
2445 int iRow = _cmbTable->rowCount();
2446 if (iRow > 0) {
2447 enableWidget(true, _cmbMethodComboBox);
2448 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
2449 _cmbMaxresLineEdit->setEnabled(true);
2450 _cmbSamplSpinBox->setEnabled(true);
2451 }
2452 else {
2453 enableWidget(false, _cmbMethodComboBox);
2454 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2455 _cmbMaxresLineEdit->setEnabled(false);
2456 _cmbSamplSpinBox->setEnabled(false);
2457 }
2458 }
2459
2460 // Upload(clk)
2461 // -----------
2462 int iRow = _uploadTable->rowCount();
2463 if (iRow > 0) {
2464 enableWidget(true, _uploadIntrComboBox);
2465 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2466 enableWidget(true, _uploadSamplClkRnxSpinBox);
2467 enableWidget(true, _uploadSamplSp3SpinBox);
2468 }
2469 else {
2470 enableWidget(false, _uploadIntrComboBox);
2471 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2472 enableWidget(false, _uploadSamplClkRnxSpinBox);
2473 enableWidget(false, _uploadSamplSp3SpinBox);
2474 }
2475
2476 // PPP Client
2477 // ----------
2478 if (sender() == 0
2479 || sender() == _pppMountLineEdit
2480 || sender() == _pppCorrMountLineEdit
2481 || sender() == _pppRefCrdXLineEdit
2482 || sender() == _pppRefCrdYLineEdit
2483 || sender() == _pppRefCrdZLineEdit
2484 || sender() == _pppRefdNLineEdit
2485 || sender() == _pppRefdELineEdit
2486 || sender() == _pppRefdULineEdit
2487 || sender() == _pppSync
2488 || sender() == _pppSPPComboBox
2489 || sender() == _pppQuickStartLineEdit
2490 || sender() == _pppEstTropoCheckBox
2491 || sender() == _pppUsePhaseCheckBox
2492 || sender() == _pppAntexFileChooser ) {
2493
2494 enable = !_pppSPPComboBox->currentText().isEmpty();
2495 if (enable) {
2496 enable = (!_pppMountLineEdit->text().isEmpty() && !_pppCorrMountLineEdit->text().isEmpty()) ||
2497 (!_pppMountLineEdit->text().isEmpty() && _pppSPPComboBox->currentText() == "Realtime-SPP") ||
2498 (_pppSPPComboBox->currentText() == "Post-Processing");
2499 }
2500
2501 enableWidget(enable, _pppNMEALineEdit);
2502 enableWidget(enable, _pppNMEAPortLineEdit);
2503 enableWidget(enable, _pppRefCrdXLineEdit);
2504 enableWidget(enable, _pppRefCrdYLineEdit);
2505 enableWidget(enable, _pppRefCrdZLineEdit);
2506 enableWidget(enable, _pppRefdNLineEdit);
2507 enableWidget(enable, _pppRefdELineEdit);
2508 enableWidget(enable, _pppRefdULineEdit);
2509 enableWidget(enable, _pppUsePhaseCheckBox);
2510 enableWidget(enable, _pppPlotCoordinates);
2511 enableWidget(enable, _pppEstTropoCheckBox);
2512// enableWidget(enable, _pppGLONASSCheckBox);
2513 enableWidget(enable, _pppGalileoCheckBox);
2514// enableWidget(enable, _pppAntexFileChooser);
2515 enableWidget(enable, _pppSigCLineEdit);
2516 enableWidget(enable, _pppSigCrd0);
2517 enableWidget(enable, _pppSigCrdP);
2518
2519 bool enable2 = enable && !_pppRefCrdXLineEdit->text().isEmpty() &&
2520 !_pppRefCrdYLineEdit->text().isEmpty() &&
2521 !_pppRefCrdZLineEdit->text().isEmpty();
2522
2523 enableWidget(enable2, _pppAverageLineEdit);
2524 enableWidget(enable2, _pppQuickStartLineEdit);
2525
2526 bool enable3 = enable2 && !_pppQuickStartLineEdit->text().isEmpty();
2527 enableWidget(enable3, _pppMaxSolGapLineEdit);
2528 enableWidget(enable3, _pppAudioResponseLineEdit);
2529
2530 bool enable4 = enable && !_pppAntexFileChooser->fileName().isEmpty();
2531 enableWidget(enable4, _pppAntennaLineEdit);
2532
2533 bool enable5 = enable && _pppEstTropoCheckBox->isChecked();
2534 enableWidget(enable5, _pppSigTrp0);
2535 enableWidget(enable5, _pppSigTrpP);
2536
2537 bool enable6 = enable && _pppUsePhaseCheckBox->isChecked();
2538 enableWidget(enable6, _pppSigPLineEdit);
2539
2540 bool enable7 = enable && _pppSPPComboBox->currentText() == "Realtime-PPP";
2541 enableWidget(enable7, _pppSync);
2542
2543 bool enable8 = _pppSPPComboBox->currentText() == "Realtime-PPP";
2544 enableWidget(enable8, _pppCorrMountLineEdit);
2545
2546 bool enable9 = _pppSPPComboBox->currentText() == "Post-Processing";
2547 enableWidget(enable9, _postObsFileChooser);
2548 enableWidget(enable9, _postNavFileChooser);
2549 enableWidget(enable9, _postCorrFileChooser);
2550 enableWidget(enable9, _postOutLineEdit);
2551
2552 bool enable10 = !_pppSPPComboBox->currentText().isEmpty() && !enable9;
2553 enableWidget(enable10, _pppMountLineEdit);
2554 }
2555
2556 if (sender() == 0 || sender() == _reqcActionComboBox) {
2557 enable = !_reqcActionComboBox->currentText().isEmpty();
2558 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2559 enableWidget(enable && enable10, _reqcEditOptionButton);
2560 enableWidget(enable, _reqcObsFileChooser);
2561 enableWidget(enable, _reqcNavFileChooser);
2562 enableWidget(enable && enable10, _reqcOutObsLineEdit);
2563 enableWidget(enable && enable10, _reqcOutNavLineEdit);
2564 enableWidget(enable, _reqcOutLogLineEdit);
2565 enableWidget(enable && !enable10, _reqcPlotDirLineEdit);
2566 enableWidget(enable && !enable10, _reqcSkyPlotSystems);
2567 }
2568
2569 enableStartStop();
2570}
2571
2572//
2573////////////////////////////////////////////////////////////////////////////
2574void bncWindow::slotAddCmbRow() {
2575 int iRow = _cmbTable->rowCount();
2576 _cmbTable->insertRow(iRow);
2577 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2578 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2579 }
2580}
2581
2582//
2583////////////////////////////////////////////////////////////////////////////
2584void bncWindow::slotDelCmbRow() {
2585 int nRows = _cmbTable->rowCount();
2586 bool flg[nRows];
2587 for (int iRow = 0; iRow < nRows; iRow++) {
2588 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2589 flg[iRow] = true;
2590 }
2591 else {
2592 flg[iRow] = false;
2593 }
2594 }
2595 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2596 if (flg[iRow]) {
2597 _cmbTable->removeRow(iRow);
2598 }
2599 }
2600 nRows = _cmbTable->rowCount();
2601 if (nRows < 1) {
2602 enableWidget(false, _cmbMethodComboBox);
2603 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2604 _cmbMaxresLineEdit->setEnabled(false);
2605 _cmbSamplSpinBox->setEnabled(false);
2606 }
2607}
2608
2609//
2610////////////////////////////////////////////////////////////////////////////
2611void bncWindow::populateCmbTable() {
2612
2613 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2614 _cmbTable->removeRow(iRow);
2615 }
2616
2617 bncSettings settings;
2618
2619 int iRow = -1;
2620 QListIterator<QString> it(settings.value("combineStreams").toStringList());
2621 while (it.hasNext()) {
2622 QStringList hlp = it.next().split(" ");
2623 if (hlp.size() > 2) {
2624 ++iRow;
2625 _cmbTable->insertRow(iRow);
2626 }
2627 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2628 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2629 }
2630 }
2631}
2632
2633//
2634////////////////////////////////////////////////////////////////////////////
2635void bncWindow::slotAddUploadRow() {
2636 int iRow = _uploadTable->rowCount();
2637 _uploadTable->insertRow(iRow);
2638 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2639 if (iCol == 3) {
2640 QLineEdit* passwd = new QLineEdit();
2641 passwd->setFrame(false);
2642 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2643 _uploadTable->setCellWidget(iRow, iCol, passwd);
2644 }
2645 else if (iCol == 4) {
2646 QComboBox* system = new QComboBox();
2647 system->setEditable(false);
2648 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,Custom").split(","));
2649 system->setFrame(false);
2650 _uploadTable->setCellWidget(iRow, iCol, system);
2651 }
2652 else if (iCol == 5) {
2653 QCheckBox* com = new QCheckBox();
2654 _uploadTable->setCellWidget(iRow, iCol, com);
2655 }
2656 else if (iCol == 11) {
2657 bncTableItem* bncIt = new bncTableItem();
2658 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2659 _uploadTable->setItem(iRow, iCol, bncIt);
2660 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2661 }
2662 else {
2663 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2664 }
2665 }
2666}
2667
2668//
2669////////////////////////////////////////////////////////////////////////////
2670void bncWindow::slotDelUploadRow() {
2671 BNC_CORE->_uploadTableItems.clear();
2672 int nRows = _uploadTable->rowCount();
2673 bool flg[nRows];
2674 for (int iRow = 0; iRow < nRows; iRow++) {
2675 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2676 flg[iRow] = true;
2677 }
2678 else {
2679 flg[iRow] = false;
2680 }
2681 }
2682 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2683 if (flg[iRow]) {
2684 _uploadTable->removeRow(iRow);
2685 }
2686 }
2687 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2688 BNC_CORE->_uploadTableItems[iRow] =
2689 (bncTableItem*) _uploadTable->item(iRow, 11);
2690 }
2691 nRows = _uploadTable->rowCount();
2692 if (nRows < 1) {
2693 enableWidget(false, _uploadIntrComboBox);
2694 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2695 enableWidget(false, _uploadSamplSp3SpinBox);
2696 enableWidget(false, _uploadSamplClkRnxSpinBox);
2697 }
2698}
2699
2700//
2701////////////////////////////////////////////////////////////////////////////
2702void bncWindow::populateUploadTable() {
2703 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2704 _uploadTable->removeRow(iRow);
2705 }
2706
2707 bncSettings settings;
2708
2709 int iRow = -1;
2710 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2711 while (it.hasNext()) {
2712 QStringList hlp = it.next().split(",");
2713 if (hlp.size() > 6) {
2714 ++iRow;
2715 _uploadTable->insertRow(iRow);
2716 }
2717 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2718 if (iCol == 3) {
2719 QLineEdit* passwd = new QLineEdit();
2720 passwd->setFrame(false);
2721 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2722 passwd->setText(hlp[iCol]);
2723 _uploadTable->setCellWidget(iRow, iCol, passwd);
2724 }
2725 else if (iCol == 4) {
2726 QComboBox* system = new QComboBox();
2727 system->setEditable(false);
2728 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,Custom").split(","));
2729 system->setFrame(false);
2730 system->setCurrentIndex(system->findText(hlp[iCol]));
2731 _uploadTable->setCellWidget(iRow, iCol, system);
2732 }
2733 else if (iCol == 5) {
2734 QCheckBox* com = new QCheckBox();
2735 if (hlp[iCol].toInt() == Qt::Checked) {
2736 com->setCheckState(Qt::Checked);
2737 }
2738 _uploadTable->setCellWidget(iRow, iCol, com);
2739 }
2740 else if (iCol == 11) {
2741 bncTableItem* bncIt = new bncTableItem();
2742 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2743 _uploadTable->setItem(iRow, iCol, bncIt);
2744 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2745 }
2746 else {
2747 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2748 }
2749 }
2750 }
2751}
2752
2753//
2754////////////////////////////////////////////////////////////////////////////
2755void bncWindow::slotSetUploadTrafo() {
2756 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2757 dlg->exec();
2758 delete dlg;
2759}
2760
2761// Start Post-Processing PPP
2762////////////////////////////////////////////////////////////////////////////
2763void bncWindow::startPostProcessingPPP() {
2764#ifdef USE_POSTPROCESSING
2765 _runningPostProcessingPPP = true;
2766 _actStart->setText("0 Epochs");
2767 enableStartStop();
2768
2769 _postProcessing = new t_postProcessing(this);
2770 connect(_postProcessing, SIGNAL(finished()), this, SLOT(slotFinishedPostProcessingPPP()));
2771 connect(_postProcessing, SIGNAL(progress(int)), this, SLOT(slotPostProgress(int)));
2772 bncSettings settings;
2773 if ( Qt::CheckState(settings.value("pppPlotCoordinates").toInt()) == Qt::Checked) {
2774 connect(_postProcessing, SIGNAL(newPosition(bncTime, double, double, double)),
2775 _bncFigurePPP, SLOT(slotNewPosition(bncTime, double, double, double)));
2776 }
2777#ifdef QT_WEBKIT
2778 if (_mapWin) {
2779 connect(_postProcessing, SIGNAL(newPosition(bncTime, double, double, double)),
2780 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2781 }
2782#endif
2783
2784 _postProcessing->start();
2785#else
2786 QMessageBox::information(this, "Information",
2787 "Post-Processing Not Permitted");
2788#endif
2789}
2790
2791// Post-Processing PPP Finished
2792////////////////////////////////////////////////////////////////////////////
2793void bncWindow::slotFinishedPostProcessingPPP() {
2794 _runningPostProcessingPPP = false;
2795 _postProcessing = 0;
2796 QMessageBox::information(this, "Information",
2797 "Post-Processing Thread Finished");
2798 _actStart->setText("Start");
2799 enableStartStop();
2800}
2801
2802// Progress Bar Change
2803////////////////////////////////////////////////////////////////////////////
2804void bncWindow::slotPostProgress(int nEpo) {
2805 if (_actStart) {
2806 _actStart->setText(QString("%1 Epochs").arg(nEpo));
2807 }
2808}
2809
2810// Start Post-Processing Reqc
2811////////////////////////////////////////////////////////////////////////////
2812void bncWindow::startPostProcessingReqc() {
2813#ifdef USE_POSTPROCESSING
2814 _runningPostProcessingReqc = true;
2815 enableStartStop();
2816 if (_reqcActionComboBox->currentText() == "Analyze") {
2817 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
2818 connect(reqcAnalyze, SIGNAL(finished()),
2819 this, SLOT(slotFinishedPostProcessingReqc()));
2820 reqcAnalyze->start();
2821 }
2822 else {
2823 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
2824 connect(reqcEdit, SIGNAL(finished()),
2825 this, SLOT(slotFinishedPostProcessingReqc()));
2826 reqcEdit->start();
2827 }
2828#else
2829 QMessageBox::information(this, "Information",
2830 "Post-Processing Not Permitted");
2831#endif
2832}
2833
2834// Post-Processing Reqc Finished
2835////////////////////////////////////////////////////////////////////////////
2836void bncWindow::slotFinishedPostProcessingReqc() {
2837 _runningPostProcessingReqc = false;
2838 if (_reqcActionComboBox->currentText() != "Analyze") {
2839 QMessageBox::information(this, "Information",
2840 "RINEX Processing Thread Finished");
2841 }
2842 enableStartStop();
2843}
2844
2845// Edit teqc-like editing options
2846////////////////////////////////////////////////////////////////////////////
2847void bncWindow::slotReqcEditOption() {
2848 reqcDlg* dlg = new reqcDlg(this);
2849 dlg->move(this->pos().x()+50, this->pos().y()+50);
2850 dlg->exec();
2851 delete dlg;
2852}
2853
2854// Enable/Disable Start and Stop Buttons
2855////////////////////////////////////////////////////////////////////////////
2856void bncWindow::enableStartStop() {
2857
2858 if ( _pppSPPComboBox && _pppSPPComboBox->currentText() == "Post-Processing" ) {
2859 if (_runningPostProcessingPPP) {
2860 _actStart->setEnabled(false);
2861 }
2862 else {
2863 _actStart->setEnabled(true);
2864 }
2865 _actStop->setEnabled(false);
2866 }
2867 else if ( _reqcActionComboBox && !_reqcActionComboBox->currentText().isEmpty() ) {
2868 if (_runningPostProcessingReqc) {
2869 _actStart->setEnabled(false);
2870 }
2871 else {
2872 _actStart->setEnabled(true);
2873 }
2874 _actStop->setEnabled(false);
2875 }
2876 else {
2877 if (_runningRealTime) {
2878 _actStart->setEnabled(false);
2879 _actStop->setEnabled(true);
2880 }
2881 else {
2882 _actStop->setEnabled(false);
2883 if (_mountPointsTable->rowCount() == 0) {
2884 _actStart->setEnabled(false);
2885 }
2886 else {
2887 _actStart->setEnabled(true);
2888 }
2889 }
2890 }
2891}
2892
2893// Show Map
2894////////////////////////////////////////////////////////////////////////////
2895void bncWindow::slotMapMountPoints() {
2896 saveOptions();
2897 t_bncMap* bncMap = new t_bncMap(this);
2898 bncMap->setMinimumSize(800, 600);
2899 bncMap->setWindowTitle("Selected Mountpoints");
2900
2901 bncSettings settings;
2902 QListIterator<QString> it(settings.value("mountPoints").toStringList());
2903 while (it.hasNext()) {
2904 QStringList hlp = it.next().split(" ");
2905 if (hlp.size() < 5) continue;
2906 QUrl url(hlp[0]);
2907 double latDeg = hlp[2].toDouble();
2908 double lonDeg = hlp[3].toDouble();
2909 bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
2910 }
2911
2912 bncMap->show();
2913}
2914
2915// Show Map
2916////////////////////////////////////////////////////////////////////////////
2917void bncWindow::slotMapPPP() {
2918#ifdef QT_WEBKIT
2919 if (!_mapWin) {
2920 _mapWin = new bncMapWin(this);
2921 QListIterator<bncGetThread*> it(_threads);
2922 while (it.hasNext()) {
2923 bncGetThread* thread = it.next();
2924 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2925 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2926 }
2927 if (_postProcessing) {
2928 connect(_postProcessing, SIGNAL(newPosition(bncTime, double, double, double)),
2929 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2930 }
2931 }
2932 _mapWin->show();
2933#else
2934 QMessageBox::information(this, "Information",
2935 "Qt Library compiled without QtWebKit");
2936#endif
2937}
Note: See TracBrowser for help on using the repository browser.