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

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