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

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