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

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