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

Last change on this file since 7477 was 7475, checked in by weber, 9 years ago

Documentation completedDocumentation completedDocumentation completedDocumentation completedDocumentation completedDocumentation completedDocumentation completedDocumentation completed

File size: 144.6 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#include "rinex/reqcedit.h"
67#include "rinex/reqcanalyze.h"
68#include "orbComp/sp3Comp.h"
69#ifdef QT_WEBKIT
70# include "map/bncmapwin.h"
71#endif
72
73using namespace std;
74
75#ifdef GNSSCENTER_PLUGIN
76Q_EXPORT_PLUGIN2(gnsscenter_bnc, t_bncFactory)
77#endif
78
79// Constructor
80////////////////////////////////////////////////////////////////////////////
81bncWindow::bncWindow() {
82
83 const static QPalette paletteWhite(QColor(255, 255, 255));
84 const static QPalette paletteGray(QColor(230, 230, 230));
85
86#ifdef GNSSCENTER_PLUGIN
87 BNC_CORE->setConfFileName("");
88#endif
89
90 _caster = 0;
91 _casterEph = 0;
92
93 _bncFigure = new bncFigure(this);
94 _bncFigureLate = new bncFigureLate(this);
95 _bncFigurePPP = new bncFigurePPP(this);
96
97 connect(BNC_CORE, SIGNAL(newPosition(QByteArray, bncTime, QVector<double>)),
98 _bncFigurePPP, SLOT(slotNewPosition(QByteArray, bncTime, QVector<double>)));
99
100 connect(BNC_CORE, SIGNAL(progressRnxPPP(int)), this, SLOT(slotPostProcessingProgress(int)));
101 connect(BNC_CORE, SIGNAL(finishedRnxPPP()), this, SLOT(slotPostProcessingFinished()));
102
103 _runningRealTime = false;
104 _runningPPP = false;
105 _runningEdit = false;
106 _runningQC = false;
107 _runningSp3Comp = false;
108 _reqcActionComboBox = 0; // necessary for enableStartStop()
109
110 _mapWin = 0;
111
112 int ww = QFontMetrics(this->font()).width('w');
113
114 static const QStringList labels = QString("account, Streams: resource loader / mountpoint, decoder, country, lat, long, nmea, ntrip, bytes").split(",");
115
116 setMinimumSize(100*ww, 70*ww);
117
118 setWindowTitle(tr("BKG Ntrip Client (BNC) Version " BNCVERSION));
119
120 connect(BNC_CORE, SIGNAL(newMessage(QByteArray,bool)),
121 this, SLOT(slotWindowMessage(QByteArray,bool)));
122
123 // Create Actions
124 // --------------
125 _actHelp = new QAction(tr("&Help Contents"),this);
126 connect(_actHelp, SIGNAL(triggered()), SLOT(slotHelp()));
127
128 _actAbout = new QAction(tr("&About BNC"),this);
129 connect(_actAbout, SIGNAL(triggered()), SLOT(slotAbout()));
130
131 _actFlowchart = new QAction(tr("&Flow Chart"),this);
132 connect(_actFlowchart, SIGNAL(triggered()), SLOT(slotFlowchart()));
133
134 _actFontSel = new QAction(tr("Select &Font"),this);
135 connect(_actFontSel, SIGNAL(triggered()), SLOT(slotFontSel()));
136
137 _actSaveOpt = new QAction(tr("&Reread && Save Configuration"),this);
138 connect(_actSaveOpt, SIGNAL(triggered()), SLOT(slotSaveOptions()));
139
140 _actQuit = new QAction(tr("&Quit"),this);
141 connect(_actQuit, SIGNAL(triggered()), SLOT(close()));
142
143 _actAddMountPoints = new QAction(tr("Add &Stream"),this);
144 connect(_actAddMountPoints, SIGNAL(triggered()), SLOT(slotAddMountPoints()));
145
146 _actDeleteMountPoints = new QAction(tr("&Delete Stream"),this);
147 connect(_actDeleteMountPoints, SIGNAL(triggered()), SLOT(slotDeleteMountPoints()));
148 _actDeleteMountPoints->setEnabled(false);
149
150 _actMapMountPoints = new QAction(tr("&Map"),this);
151 connect(_actMapMountPoints, SIGNAL(triggered()), SLOT(slotMapMountPoints()));
152
153 _actStart = new QAction(tr("Sta&rt"),this);
154 connect(_actStart, SIGNAL(triggered()), SLOT(slotStart()));
155
156 _actStop = new QAction(tr("Sto&p"),this);
157 connect(_actStop, SIGNAL(triggered()), SLOT(slotStop()));
158
159 _actwhatsthis= new QAction(tr("Help ?=Shift+F1"),this);
160 connect(_actwhatsthis, SIGNAL(triggered()), SLOT(slotWhatsThis()));
161
162 CreateMenu();
163 AddToolbar();
164
165 bncSettings settings;
166
167 // Network Options
168 // ---------------
169 _proxyHostLineEdit = new QLineEdit(settings.value("proxyHost").toString());
170 _proxyPortLineEdit = new QLineEdit(settings.value("proxyPort").toString());
171
172 connect(_proxyHostLineEdit, SIGNAL(textChanged(const QString &)),
173 this, SLOT(slotBncTextChanged()));
174
175 _sslCaCertPathLineEdit = new QLineEdit(settings.value("sslCaCertPath").toString());
176 _ignoreSslErrorsCheckBox = new QCheckBox();
177 _ignoreSslErrorsCheckBox->setCheckState(Qt::CheckState(
178 settings.value("ignoreSslErrors").toInt()));
179
180 // General Options
181 // ---------------
182 _logFileLineEdit = new QLineEdit(settings.value("logFile").toString());
183 _rawOutFileLineEdit = new QLineEdit(settings.value("rawOutFile").toString());
184 _rnxAppendCheckBox = new QCheckBox();
185 _rnxAppendCheckBox->setCheckState(Qt::CheckState(
186 settings.value("rnxAppend").toInt()));
187 _onTheFlyComboBox = new QComboBox();
188 _onTheFlyComboBox->setEditable(false);
189 _onTheFlyComboBox->addItems(QString("1 day,1 hour,5 min,1 min").split(","));
190 int ii = _onTheFlyComboBox->findText(settings.value("onTheFlyInterval").toString());
191 if (ii != -1) {
192 _onTheFlyComboBox->setCurrentIndex(ii);
193 }
194 _autoStartCheckBox = new QCheckBox();
195 _autoStartCheckBox->setCheckState(Qt::CheckState(
196 settings.value("autoStart").toInt()));
197
198 // RINEX Observations Options
199 // --------------------------
200 _rnxPathLineEdit = new QLineEdit(settings.value("rnxPath").toString());
201 _rnxIntrComboBox = new QComboBox();
202 _rnxIntrComboBox->setEditable(false);
203 _rnxIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
204 ii = _rnxIntrComboBox->findText(settings.value("rnxIntr").toString());
205 if (ii != -1) {
206 _rnxIntrComboBox->setCurrentIndex(ii);
207 }
208 _rnxSamplSpinBox = new QSpinBox();
209 _rnxSamplSpinBox->setMinimum(0);
210 _rnxSamplSpinBox->setMaximum(60);
211 _rnxSamplSpinBox->setSingleStep(5);
212 _rnxSamplSpinBox->setValue(settings.value("rnxSampl").toInt());
213 _rnxFileCheckBox = new QCheckBox();
214 _rnxFileCheckBox->setCheckState(Qt::CheckState(settings.value("rnxOnlyWithSKL").toInt()));
215 _rnxSamplSpinBox->setSuffix(" sec");
216 _rnxSkelLineEdit = new QLineEdit(settings.value("rnxSkel").toString());
217 _rnxSkelLineEdit->setMaximumWidth(5*ww);
218 _rnxScrpLineEdit = new QLineEdit(settings.value("rnxScript").toString());
219 _rnxV3CheckBox = new QCheckBox();
220 _rnxV3CheckBox->setCheckState(Qt::CheckState(settings.value("rnxV3").toInt()));
221 _rnxV3filenameCheckBox = new QCheckBox();
222 _rnxV3filenameCheckBox->setCheckState(Qt::CheckState(settings.value("rnxV3filenames").toInt()));
223 QString hlp = settings.value("rnxV2Priority").toString();
224 if (hlp.isEmpty()) {
225 hlp = "CWPX_?";
226 }
227 _rnxV2Priority = new QLineEdit(hlp);
228
229 connect(_rnxPathLineEdit, SIGNAL(textChanged(const QString &)),
230 this, SLOT(slotBncTextChanged()));
231 connect(_rnxV3CheckBox, SIGNAL(stateChanged(int)),
232 this, SLOT(slotBncTextChanged()));
233
234 // RINEX Ephemeris Options
235 // -----------------------
236 _ephPathLineEdit = new QLineEdit(settings.value("ephPath").toString());
237 _ephIntrComboBox = new QComboBox();
238 _ephIntrComboBox->setEditable(false);
239 _ephIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
240 int jj = _ephIntrComboBox->findText(settings.value("ephIntr").toString());
241 if (jj != -1) {
242 _ephIntrComboBox->setCurrentIndex(jj);
243 }
244 _ephOutPortLineEdit = new QLineEdit(settings.value("ephOutPort").toString());
245 _ephV3CheckBox = new QCheckBox();
246 _ephV3CheckBox->setCheckState(Qt::CheckState(settings.value("ephV3").toInt()));
247
248 _ephV3filenameCheckBox = new QCheckBox();
249 _ephV3filenameCheckBox->setCheckState(Qt::CheckState(settings.value("ephV3filenames").toInt()));
250
251 connect(_ephOutPortLineEdit, SIGNAL(textChanged(const QString &)),
252 this, SLOT(slotBncTextChanged()));
253
254 connect(_ephPathLineEdit, SIGNAL(textChanged(const QString &)),
255 this, SLOT(slotBncTextChanged()));
256
257 // Broadcast Corrections Options
258 // -----------------------------
259 _corrPathLineEdit = new QLineEdit(settings.value("corrPath").toString());
260 _corrIntrComboBox = new QComboBox();
261 _corrIntrComboBox->setEditable(false);
262 _corrIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
263 int mm = _corrIntrComboBox->findText(settings.value("corrIntr").toString());
264 if (mm != -1) {
265 _corrIntrComboBox->setCurrentIndex(mm);
266 }
267 _corrPortLineEdit = new QLineEdit(settings.value("corrPort").toString());
268
269 connect(_corrPathLineEdit, SIGNAL(textChanged(const QString &)),
270 this, SLOT(slotBncTextChanged()));
271
272 connect(_corrPortLineEdit, SIGNAL(textChanged(const QString &)),
273 this, SLOT(slotBncTextChanged()));
274
275 // Feed Engine Options
276 // -------------------
277 _outPortLineEdit = new QLineEdit(settings.value("outPort").toString());
278 _outWaitSpinBox = new QSpinBox();
279 _outWaitSpinBox->setMinimum(1);
280 _outWaitSpinBox->setMaximum(30);
281 _outWaitSpinBox->setSingleStep(1);
282 _outWaitSpinBox->setSuffix(" sec");
283 _outWaitSpinBox->setValue(settings.value("outWait").toInt());
284 _outSamplSpinBox = new QSpinBox();
285 _outSamplSpinBox->setMinimum(0);
286 _outSamplSpinBox->setMaximum(60);
287 _outSamplSpinBox->setSingleStep(5);
288 _outSamplSpinBox->setValue(settings.value("outSampl").toInt());
289 _outSamplSpinBox->setSuffix(" sec");
290 _outFileLineEdit = new QLineEdit(settings.value("outFile").toString());
291 _outUPortLineEdit = new QLineEdit(settings.value("outUPort").toString());
292
293 connect(_outPortLineEdit, SIGNAL(textChanged(const QString &)),
294 this, SLOT(slotBncTextChanged()));
295
296 connect(_outFileLineEdit, SIGNAL(textChanged(const QString &)),
297 this, SLOT(slotBncTextChanged()));
298
299 // Serial Output Options
300 // ---------------------
301 _serialMountPointLineEdit = new QLineEdit(settings.value("serialMountPoint").toString());
302 _serialPortNameLineEdit = new QLineEdit(settings.value("serialPortName").toString());
303 _serialBaudRateComboBox = new QComboBox();
304 _serialBaudRateComboBox->addItems(QString("110,300,600,"
305 "1200,2400,4800,9600,19200,38400,57600,115200").split(","));
306 int kk = _serialBaudRateComboBox->findText(settings.value("serialBaudRate").toString());
307 if (kk != -1) {
308 _serialBaudRateComboBox->setCurrentIndex(kk);
309 }
310 _serialFlowControlComboBox = new QComboBox();
311 _serialFlowControlComboBox->addItems(QString("OFF,XONXOFF,HARDWARE").split(","));
312 kk = _serialFlowControlComboBox->findText(settings.value("serialFlowControl").toString());
313 if (kk != -1) {
314 _serialFlowControlComboBox->setCurrentIndex(kk);
315 }
316 _serialDataBitsComboBox = new QComboBox();
317 _serialDataBitsComboBox->addItems(QString("5,6,7,8").split(","));
318 kk = _serialDataBitsComboBox->findText(settings.value("serialDataBits").toString());
319 if (kk != -1) {
320 _serialDataBitsComboBox->setCurrentIndex(kk);
321 }
322 _serialParityComboBox = new QComboBox();
323 _serialParityComboBox->addItems(QString("NONE,ODD,EVEN,SPACE").split(","));
324 kk = _serialParityComboBox->findText(settings.value("serialParity").toString());
325 if (kk != -1) {
326 _serialParityComboBox->setCurrentIndex(kk);
327 }
328 _serialStopBitsComboBox = new QComboBox();
329 _serialStopBitsComboBox->addItems(QString("1,2").split(","));
330 kk = _serialStopBitsComboBox->findText(settings.value("serialStopBits").toString());
331 if (kk != -1) {
332 _serialStopBitsComboBox->setCurrentIndex(kk);
333 }
334 _serialAutoNMEAComboBox = new QComboBox();
335 _serialAutoNMEAComboBox->addItems(QString("no,Auto,Manual GPGGA,Manual GNGGA").split(","));
336 kk = _serialAutoNMEAComboBox->findText(settings.value("serialAutoNMEA").toString());
337 if (kk != -1) {
338 _serialAutoNMEAComboBox->setCurrentIndex(kk);
339 }
340 _serialFileNMEALineEdit = new QLineEdit(settings.value("serialFileNMEA").toString());
341 _serialHeightNMEALineEdit = new QLineEdit(settings.value("serialHeightNMEA").toString());
342
343 _serialManualNMEASamplingSpinBox = new QSpinBox();
344 _serialManualNMEASamplingSpinBox->setMinimum(0);
345 _serialManualNMEASamplingSpinBox->setMaximum(300);
346 _serialManualNMEASamplingSpinBox->setSingleStep(10);
347 _serialManualNMEASamplingSpinBox->setValue(settings.value("serialManualNMEASampling").toInt());
348 _serialManualNMEASamplingSpinBox->setSuffix(" sec");
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 _adviseObsRateComboBox = new QComboBox();
359 _adviseObsRateComboBox->setEditable(false);
360 _adviseObsRateComboBox->addItems(QString(",0.1 Hz,0.2 Hz,0.5 Hz,1 Hz,5 Hz").split(","));
361 kk = _adviseObsRateComboBox->findText(settings.value("adviseObsRate").toString());
362 if (kk != -1) {
363 _adviseObsRateComboBox->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(_adviseObsRateComboBox, 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 _miscIntrComboBox = new QComboBox();
387 _miscIntrComboBox->setEditable(false);
388 _miscIntrComboBox->addItems(QString(",2 sec, 10 sec,1 min,5 min,15 min,1 hour,6 hours,1 day").split(","));
389 int ll = _miscIntrComboBox->findText(settings.value("miscIntr").toString());
390 if (ll != -1) {
391 _miscIntrComboBox->setCurrentIndex(ll);
392 }
393 _miscScanRTCMCheckBox = new QCheckBox();
394 _miscScanRTCMCheckBox->setCheckState(Qt::CheckState(
395 settings.value("miscScanRTCM").toInt()));
396
397 connect(_miscMountLineEdit, SIGNAL(textChanged(const QString &)),
398 this, SLOT(slotBncTextChanged()));
399
400 // Streams
401 // -------
402 _mountPointsTable = new QTableWidget(0,9);
403
404 _mountPointsTable->horizontalHeader()->resizeSection(1,34*ww);
405 _mountPointsTable->horizontalHeader()->resizeSection(2,9*ww);
406 _mountPointsTable->horizontalHeader()->resizeSection(3,9*ww);
407 _mountPointsTable->horizontalHeader()->resizeSection(4,7*ww);
408 _mountPointsTable->horizontalHeader()->resizeSection(5,7*ww);
409 _mountPointsTable->horizontalHeader()->resizeSection(6,5*ww);
410 _mountPointsTable->horizontalHeader()->resizeSection(7,5*ww);
411 _mountPointsTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
412 _mountPointsTable->horizontalHeader()->setStretchLastSection(true);
413 _mountPointsTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
414 _mountPointsTable->setHorizontalHeaderLabels(labels);
415 _mountPointsTable->setGridStyle(Qt::NoPen);
416 _mountPointsTable->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
417 _mountPointsTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
418 _mountPointsTable->setSelectionBehavior(QAbstractItemView::SelectRows);
419 _mountPointsTable->hideColumn(0);
420 _mountPointsTable->hideColumn(3);
421 connect(_mountPointsTable, SIGNAL(itemSelectionChanged()),
422 SLOT(slotSelectionChanged()));
423 populateMountPointsTable();
424
425 _log = new QTextEdit();
426 _log->setReadOnly(true);
427 QFont msFont(""); msFont.setStyleHint(QFont::TypeWriter); // default monospace font
428 _log->setFont(msFont);
429 _log->document()->setMaximumBlockCount(1000);
430
431 // Combine Corrections
432 // -------------------
433 _cmbTable = new QTableWidget(0,3);
434 _cmbTable->setHorizontalHeaderLabels(QString("Mountpoint, AC Name, Weight").split(","));
435 _cmbTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
436 _cmbTable->setSelectionBehavior(QAbstractItemView::SelectRows);
437 _cmbTable->setMaximumWidth(30*ww);
438 _cmbTable->horizontalHeader()->resizeSection(0,10*ww);
439 _cmbTable->horizontalHeader()->resizeSection(1,8*ww);
440 _cmbTable->horizontalHeader()->resizeSection(2,8*ww);
441 _cmbTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
442 _cmbTable->horizontalHeader()->setStretchLastSection(true);
443 _cmbTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
444
445 _cmbMaxresLineEdit = new QLineEdit(settings.value("cmbMaxres").toString());
446 _cmbUseGlonass = new QCheckBox();
447 _cmbUseGlonass->setCheckState(Qt::CheckState(settings.value("cmbUseGlonass").toInt()));
448
449 _cmbSamplSpinBox = new QSpinBox;
450 _cmbSamplSpinBox->setMinimum(10);
451 _cmbSamplSpinBox->setMaximum(60);
452 _cmbSamplSpinBox->setSingleStep(10);
453 _cmbSamplSpinBox->setMaximumWidth(9*ww);
454 _cmbSamplSpinBox->setValue(settings.value("cmbSampl").toInt());
455 _cmbSamplSpinBox->setSuffix(" sec");
456
457 QPushButton* addCmbRowButton = new QPushButton("Add Row");
458 QPushButton* delCmbRowButton = new QPushButton("Delete");
459
460 connect(_cmbTable, SIGNAL(itemSelectionChanged()),
461 SLOT(slotBncTextChanged()));
462
463 _cmbMethodComboBox = new QComboBox();
464 _cmbMethodComboBox->setEditable(false);
465 _cmbMethodComboBox->addItems(QString("Filter,Single-Epoch").split(","));
466 int im = _cmbMethodComboBox->findText(settings.value("cmbMethod").toString());
467 if (im != -1) {
468 _cmbMethodComboBox->setCurrentIndex(im);
469 }
470
471 int iRow = _cmbTable->rowCount();
472 if (iRow > 0) {
473 enableWidget(true, _cmbMethodComboBox);
474 enableWidget(true, _cmbMaxresLineEdit);
475 enableWidget(true, _cmbSamplSpinBox);
476 enableWidget(true, _cmbUseGlonass);
477 }
478 else {
479 enableWidget(false, _cmbMethodComboBox);
480 enableWidget(false, _cmbMaxresLineEdit);
481 enableWidget(false, _cmbSamplSpinBox);
482 enableWidget(false, _cmbUseGlonass);
483 }
484
485 // Upload Results
486 // -------------
487 _uploadTable = new QTableWidget(0,12);
488 _uploadTable->setHorizontalHeaderLabels(QString("Host, Port, Mount, Password, System, CoM, SP3 File, RNX File, PID, SID, IOD, bytes").split(","));
489 _uploadTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
490 _uploadTable->setSelectionBehavior(QAbstractItemView::SelectRows);
491 _uploadTable->horizontalHeader()->resizeSection( 0,13*ww);
492 _uploadTable->horizontalHeader()->resizeSection( 1, 5*ww);
493 _uploadTable->horizontalHeader()->resizeSection( 2, 6*ww);
494 _uploadTable->horizontalHeader()->resizeSection( 3, 8*ww);
495 _uploadTable->horizontalHeader()->resizeSection( 4,11*ww);
496 _uploadTable->horizontalHeader()->resizeSection( 5, 4*ww);
497 _uploadTable->horizontalHeader()->resizeSection( 6,15*ww);
498 _uploadTable->horizontalHeader()->resizeSection( 7,15*ww);
499 _uploadTable->horizontalHeader()->resizeSection( 8, 4*ww);
500 _uploadTable->horizontalHeader()->resizeSection( 9, 4*ww);
501 _uploadTable->horizontalHeader()->resizeSection(10, 4*ww);
502 _uploadTable->horizontalHeader()->resizeSection(11,12*ww);
503 _uploadTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
504 _uploadTable->horizontalHeader()->setStretchLastSection(true);
505 _uploadTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
506
507 connect(_uploadTable, SIGNAL(itemSelectionChanged()),
508 SLOT(slotBncTextChanged()));
509
510 QPushButton* addUploadRowButton = new QPushButton("Add Row");
511 QPushButton* delUploadRowButton = new QPushButton("Del Row");
512 QPushButton* setUploadTrafoButton = new QPushButton("Custom Trafo");
513 _uploadIntrComboBox = new QComboBox;
514 _uploadIntrComboBox->setEditable(false);
515 _uploadIntrComboBox->addItems(QString("1 day,1 hour, 30 min,15 min,10 min,5 min,2 min,1 min").split(","));
516 ii = _uploadIntrComboBox->findText(settings.value("uploadIntr").toString());
517 if (ii != -1) {
518 _uploadIntrComboBox->setCurrentIndex(ii);
519 }
520
521 _uploadAntexFile = new qtFileChooser(0, qtFileChooser::File);
522 _uploadAntexFile->setFileName(settings.value("uploadAntexFile").toString());
523
524 _uploadSamplRtcmEphCorrSpinBox = new QSpinBox;
525 _uploadSamplRtcmEphCorrSpinBox->setMinimum(0);
526 _uploadSamplRtcmEphCorrSpinBox->setMaximum(60);
527 _uploadSamplRtcmEphCorrSpinBox->setSingleStep(5);
528 _uploadSamplRtcmEphCorrSpinBox->setMaximumWidth(9*ww);
529 _uploadSamplRtcmEphCorrSpinBox->setValue(settings.value("uploadSamplRtcmEphCorr").toInt());
530 _uploadSamplRtcmEphCorrSpinBox->setSuffix(" sec");
531
532 _uploadSamplSp3SpinBox = new QSpinBox;
533 _uploadSamplSp3SpinBox->setMinimum(0);
534 _uploadSamplSp3SpinBox->setMaximum(15);
535 _uploadSamplSp3SpinBox->setSingleStep(1);
536 _uploadSamplSp3SpinBox->setMaximumWidth(9*ww);
537 _uploadSamplSp3SpinBox->setValue(settings.value("uploadSamplSp3").toInt());
538 _uploadSamplSp3SpinBox->setSuffix(" min");
539
540 _uploadSamplClkRnxSpinBox = new QSpinBox;
541 _uploadSamplClkRnxSpinBox->setMinimum(0);
542 _uploadSamplClkRnxSpinBox->setMaximum(60);
543 _uploadSamplClkRnxSpinBox->setSingleStep(5);
544 _uploadSamplClkRnxSpinBox->setMaximumWidth(9*ww);
545 _uploadSamplClkRnxSpinBox->setValue(settings.value("uploadSamplClkRnx").toInt());
546 _uploadSamplClkRnxSpinBox->setSuffix(" sec");
547
548 int iRowT = _uploadTable->rowCount();
549 if (iRowT > 0) {
550 enableWidget(true, _uploadIntrComboBox);
551 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
552 enableWidget(true, _uploadSamplSp3SpinBox);
553 enableWidget(true, _uploadSamplClkRnxSpinBox);
554 enableWidget(true, _uploadAntexFile);
555 }
556 else {
557 enableWidget(false, _uploadIntrComboBox);
558 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
559 enableWidget(false, _uploadSamplSp3SpinBox);
560 enableWidget(false, _uploadSamplClkRnxSpinBox);
561 enableWidget(false, _uploadAntexFile);
562 }
563
564 // Upload RTCM3 Ephemeris
565 // ----------------------
566 _uploadEphHostLineEdit = new QLineEdit(settings.value("uploadEphHost").toString());
567 _uploadEphPortLineEdit = new QLineEdit(settings.value("uploadEphPort").toString());
568 _uploadEphPasswordLineEdit = new QLineEdit(settings.value("uploadEphPassword").toString());
569 _uploadEphPasswordLineEdit->setEchoMode(QLineEdit::PasswordEchoOnEdit);
570 _uploadEphMountpointLineEdit = new QLineEdit(settings.value("uploadEphMountpoint").toString());
571 _uploadEphSampleSpinBox = new QSpinBox;
572 _uploadEphSampleSpinBox->setMinimum(5);
573 _uploadEphSampleSpinBox->setMaximum(60);
574 _uploadEphSampleSpinBox->setSingleStep(5);
575 _uploadEphSampleSpinBox->setMaximumWidth(9*ww);
576 _uploadEphSampleSpinBox->setValue(settings.value("uploadEphSample").toInt());
577 _uploadEphSampleSpinBox->setSuffix(" sec");
578 _uploadEphBytesCounter = new bncBytesCounter;
579
580 // Canvas with Editable Fields
581 // ---------------------------
582 _canvas = new QWidget;
583 setCentralWidget(_canvas);
584
585 _aogroup = new QTabWidget();
586 _aogroup->setElideMode(Qt::ElideNone);
587 _aogroup->setUsesScrollButtons(true);
588 QWidget* pgroup = new QWidget();
589 QWidget* ggroup = new QWidget();
590 QWidget* sgroup = new QWidget();
591 QWidget* egroup = new QWidget();
592 QWidget* agroup = new QWidget();
593 QWidget* cgroup = new QWidget();
594 QWidget* ogroup = new QWidget();
595 QWidget* rgroup = new QWidget();
596 QWidget* sergroup = new QWidget();
597 QWidget* pppGroup1 = new QWidget();
598 QWidget* pppGroup2 = new QWidget();
599 QWidget* pppGroup3 = new QWidget();
600 QWidget* pppGroup4 = new QWidget();
601 QWidget* reqcgroup = new QWidget();
602 QWidget* sp3CompGroup = new QWidget();
603 QWidget* cmbgroup = new QWidget();
604 QWidget* uploadgroup = new QWidget();
605 QWidget* uploadEphgroup = new QWidget();
606 _aogroup->addTab(pgroup,tr("Network"));
607 _aogroup->addTab(ggroup,tr("General"));
608 _aogroup->addTab(ogroup,tr("RINEX Observations"));
609 _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
610 _aogroup->addTab(reqcgroup,tr("RINEX Editing && QC"));
611 _aogroup->addTab(sp3CompGroup,tr("SP3 Comparison"));
612 _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
613 _aogroup->addTab(sgroup,tr("Feed Engine"));
614 _aogroup->addTab(sergroup,tr("Serial Output"));
615 _aogroup->addTab(agroup,tr("Outages"));
616 _aogroup->addTab(rgroup,tr("Miscellaneous"));
617 _aogroup->addTab(pppGroup1,tr("PPP (1)"));
618 _aogroup->addTab(pppGroup2,tr("PPP (2)"));
619 _aogroup->addTab(pppGroup3,tr("PPP (3)"));
620 _aogroup->addTab(pppGroup4,tr("PPP (4)"));
621 _aogroup->addTab(cmbgroup,tr("Combine Corrections"));
622 _aogroup->addTab(uploadgroup,tr("Upload Corrections"));
623 _aogroup->addTab(uploadEphgroup,tr("Upload Ephemeris"));
624
625 // Log Tab
626 // -------
627 _loggroup = new QTabWidget();
628 _loggroup->addTab(_log,tr("Log"));
629 _loggroup->addTab(_bncFigure,tr("Throughput"));
630 _loggroup->addTab(_bncFigureLate,tr("Latency"));
631 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
632
633 // Netowork (Proxy and SSL) Tab
634 // ----------------------------
635 QGridLayout* pLayout = new QGridLayout;
636 pLayout->setColumnMinimumWidth(0,13*ww);
637 _proxyPortLineEdit->setMaximumWidth(9*ww);
638
639 pLayout->addWidget(new QLabel("Settings for proxy in protected networks and for SSL authorization, leave boxes blank if none.<br>"),0, 0, 1, 50);
640 pLayout->addWidget(new QLabel("Proxy host"), 1, 0);
641 pLayout->addWidget(_proxyHostLineEdit, 1, 1, 1,10);
642 pLayout->addWidget(new QLabel("Proxy port"), 2, 0);
643 pLayout->addWidget(_proxyPortLineEdit, 2, 1);
644 pLayout->addWidget(new QLabel("Path to SSL certificates"), 3, 0);
645 pLayout->addWidget(_sslCaCertPathLineEdit, 3, 1, 1,10);
646 pLayout->addWidget(new QLabel("Default: " + bncSslConfig::defaultPath()), 3,11, 1,20);
647 pLayout->addWidget(new QLabel("Ignore SSL authorization errors"), 4, 0);
648 pLayout->addWidget(_ignoreSslErrorsCheckBox, 4, 1, 1,10);
649 pLayout->addWidget(new QLabel(""), 5, 1);
650 pLayout->setRowStretch(6, 999);
651
652 pgroup->setLayout(pLayout);
653
654 // General Tab
655 // -----------
656 QGridLayout* gLayout = new QGridLayout;
657 gLayout->setColumnMinimumWidth(0,14*ww);
658 _onTheFlyComboBox->setMaximumWidth(9*ww);
659
660 gLayout->addWidget(new QLabel("General settings for logfile, file handling, configuration on-the-fly, auto-start, and raw file output.<br>"),0, 0, 1, 50);
661 gLayout->addWidget(new QLabel("Logfile (full path)"), 1, 0);
662 gLayout->addWidget(_logFileLineEdit, 1, 1, 1,20);
663 gLayout->addWidget(new QLabel("Append files"), 2, 0);
664 gLayout->addWidget(_rnxAppendCheckBox, 2, 1);
665 gLayout->addWidget(new QLabel("Reread configuration"), 3, 0);
666 gLayout->addWidget(_onTheFlyComboBox, 3, 1);
667 gLayout->addWidget(new QLabel("Auto start"), 4, 0);
668 gLayout->addWidget(_autoStartCheckBox, 4, 1);
669 gLayout->addWidget(new QLabel("Raw output file (full path)"), 5, 0);
670 gLayout->addWidget(_rawOutFileLineEdit, 5, 1, 1,20);
671 gLayout->addWidget(new QLabel(""), 6, 1);
672 gLayout->setRowStretch(7, 999);
673
674 ggroup->setLayout(gLayout);
675
676 // RINEX Observations
677 // ------------------
678 QGridLayout* oLayout = new QGridLayout;
679 oLayout->setColumnMinimumWidth(0,14*ww);
680 _rnxIntrComboBox->setMaximumWidth(9*ww);
681 _rnxSamplSpinBox->setMaximumWidth(9*ww);
682
683 _rnxV2Priority->setMaximumWidth(19*ww);
684
685 oLayout->addWidget(new QLabel("Saving RINEX observation files.<br>"),0, 0, 1,50);
686 oLayout->addWidget(new QLabel("Directory"), 1, 0);
687 oLayout->addWidget(_rnxPathLineEdit, 1, 1, 1, 15);
688 oLayout->addWidget(new QLabel("Interval"), 2, 0);
689 oLayout->addWidget(_rnxIntrComboBox, 2, 1);
690 oLayout->addWidget(new QLabel(" Sampling"), 2, 2, Qt::AlignRight);
691 oLayout->addWidget(_rnxSamplSpinBox, 2, 3, Qt::AlignLeft);
692 oLayout->addWidget(new QLabel("Skeleton extension"), 3, 0);
693 oLayout->addWidget(_rnxSkelLineEdit, 3, 1, Qt::AlignLeft);
694 oLayout->addWidget(new QLabel("Skeleton mandatory"), 3, 2);
695 oLayout->addWidget(_rnxFileCheckBox, 3, 3);
696 oLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
697 oLayout->addWidget(_rnxScrpLineEdit, 4, 1, 1, 15);
698 oLayout->addWidget(new QLabel("Version 2"), 5, 0);
699 oLayout->addWidget(_rnxV2Priority, 5, 1);
700 oLayout->addWidget(new QLabel("Signal priority"), 5, 2);
701 oLayout->addWidget(new QLabel("Version 3"), 6, 0);
702 oLayout->addWidget(_rnxV3CheckBox, 6, 1);
703 oLayout->addWidget(new QLabel("Version 3 filenames"), 6, 2);
704 oLayout->addWidget(_rnxV3filenameCheckBox, 6, 3);
705 oLayout->addWidget(new QLabel(""), 7, 1);
706 oLayout->setRowStretch(8, 999);
707
708 ogroup->setLayout(oLayout);
709
710 // RINEX Ephemeris
711 // ---------------
712 QGridLayout* eLayout = new QGridLayout;
713 eLayout->setColumnMinimumWidth(0,14*ww);
714 _ephIntrComboBox->setMaximumWidth(9*ww);
715 _ephOutPortLineEdit->setMaximumWidth(9*ww);
716
717 eLayout->addWidget(new QLabel("Saving RINEX navigation files and ephemeris output through IP port.<br>"),0,0,1,70);
718 eLayout->addWidget(new QLabel("Directory"), 1, 0);
719 eLayout->addWidget(_ephPathLineEdit, 1, 1, 1,30);
720 eLayout->addWidget(new QLabel("Interval"), 2, 0);
721 eLayout->addWidget(_ephIntrComboBox, 2, 1);
722 eLayout->addWidget(new QLabel("Port"), 3, 0);
723 eLayout->addWidget(_ephOutPortLineEdit, 3, 1);
724 eLayout->addWidget(new QLabel("Version 3"), 4, 0);
725 eLayout->addWidget(_ephV3CheckBox, 4, 1);
726 eLayout->addWidget(new QLabel("Version 3 filenames"), 4, 2);
727 eLayout->addWidget(_ephV3filenameCheckBox, 4, 3);
728 eLayout->setRowStretch(5, 999);
729
730 egroup->setLayout(eLayout);
731
732
733 // Broadcast Corrections
734 // ---------------------
735 QGridLayout* cLayout = new QGridLayout;
736 cLayout->setColumnMinimumWidth(0,14*ww);
737 _corrIntrComboBox->setMaximumWidth(9*ww);
738 _corrPortLineEdit->setMaximumWidth(9*ww);
739
740 cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port.<br>"),0,0,1,70);
741 cLayout->addWidget(new QLabel("Directory, ASCII"), 1, 0);
742 cLayout->addWidget(_corrPathLineEdit, 1, 1, 1,30);
743 cLayout->addWidget(new QLabel("Interval"), 2, 0);
744 cLayout->addWidget(_corrIntrComboBox, 2, 1);
745 cLayout->addWidget(new QLabel("Port"), 3, 0);
746 cLayout->addWidget(_corrPortLineEdit, 3, 1);
747 cLayout->addWidget(new QLabel(""), 4, 1);
748 cLayout->setRowStretch(7, 999);
749 cgroup->setLayout(cLayout);
750
751 // Feed Engine
752 // -----------
753 QGridLayout* sLayout = new QGridLayout;
754 sLayout->setColumnMinimumWidth(0,14*ww);
755 _outPortLineEdit->setMaximumWidth(9*ww);
756 _outWaitSpinBox->setMaximumWidth(9*ww);
757 _outSamplSpinBox->setMaximumWidth(9*ww);
758 _outUPortLineEdit->setMaximumWidth(9*ww);
759
760 sLayout->addWidget(new QLabel("Output decoded observations in ASCII format to feed a real-time GNSS network engine.<br>"),0,0,1,50);
761 sLayout->addWidget(new QLabel("Port"), 1, 0);
762 sLayout->addWidget(_outPortLineEdit, 1, 1);
763 sLayout->addWidget(new QLabel(" Wait for full obs epoch"), 1, 2, Qt::AlignRight);
764 sLayout->addWidget(_outWaitSpinBox, 1, 3, Qt::AlignLeft);
765 sLayout->addWidget(new QLabel("Sampling"), 2, 0);
766 sLayout->addWidget(_outSamplSpinBox, 2, 1, Qt::AlignLeft);
767 sLayout->addWidget(new QLabel("File (full path)"), 3, 0);
768 sLayout->addWidget(_outFileLineEdit, 3, 1, 1, 10);
769 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 4, 0);
770 sLayout->addWidget(_outUPortLineEdit, 4, 1);
771 sLayout->addWidget(new QLabel(""), 5, 1);
772 sLayout->setRowStretch(6, 999);
773
774 sgroup->setLayout(sLayout);
775
776 // Serial Output
777 // -------------
778 QGridLayout* serLayout = new QGridLayout;
779 serLayout->setColumnMinimumWidth(0,12*ww);
780 _serialBaudRateComboBox->setMaximumWidth(9*ww);
781 _serialFlowControlComboBox->setMaximumWidth(11*ww);
782 _serialDataBitsComboBox->setMaximumWidth(5*ww);
783 _serialParityComboBox->setMaximumWidth(9*ww);
784 _serialStopBitsComboBox->setMaximumWidth(5*ww);
785 _serialAutoNMEAComboBox->setMaximumWidth(14*ww);
786 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
787 _serialManualNMEASamplingSpinBox->setMaximumWidth(8*ww);
788
789 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver.<br>"),0,0,1,30);
790 serLayout->addWidget(new QLabel("Mountpoint"), 1, 0, Qt::AlignLeft);
791 serLayout->addWidget(_serialMountPointLineEdit, 1, 1, 1, 2);
792 serLayout->addWidget(new QLabel("Port name"), 2, 0, Qt::AlignLeft);
793 serLayout->addWidget(_serialPortNameLineEdit, 2, 1, 1, 2);
794 serLayout->addWidget(new QLabel("Baud rate"), 3, 0, Qt::AlignLeft);
795 serLayout->addWidget(_serialBaudRateComboBox, 3, 1);
796 serLayout->addWidget(new QLabel("Flow control"), 3, 2, Qt::AlignRight);
797 serLayout->addWidget(_serialFlowControlComboBox, 3, 3);
798 serLayout->addWidget(new QLabel("Data bits"), 4, 0, Qt::AlignLeft);
799 serLayout->addWidget(_serialDataBitsComboBox, 4, 1);
800 serLayout->addWidget(new QLabel("Parity"), 4, 2, Qt::AlignRight);
801 serLayout->addWidget(_serialParityComboBox, 4, 3);
802 serLayout->addWidget(new QLabel(" Stop bits"), 4, 4, Qt::AlignRight);
803 serLayout->addWidget(_serialStopBitsComboBox, 4, 5);
804 serLayout->addWidget(new QLabel("NMEA"), 5, 0);
805 serLayout->addWidget(_serialAutoNMEAComboBox, 5, 1);
806 serLayout->addWidget(new QLabel(" File (full path)"), 5, 2, Qt::AlignRight);
807 serLayout->addWidget(_serialFileNMEALineEdit, 5, 3, 1,10);
808 serLayout->addWidget(new QLabel("Height"), 5,14, Qt::AlignRight);
809 serLayout->addWidget(_serialHeightNMEALineEdit, 5,15, 1,11);
810 serLayout->addWidget(new QLabel("Sampling"), 5,25, Qt::AlignRight);
811 serLayout->addWidget(_serialManualNMEASamplingSpinBox, 5,26, 1,12);
812 serLayout->addWidget(new QLabel(""), 6, 1);
813 serLayout->setRowStretch(7, 999);
814
815 sergroup->setLayout(serLayout);
816
817 // Outages
818 // -------
819 QGridLayout* aLayout = new QGridLayout;
820 aLayout->setColumnMinimumWidth(0,14*ww);
821 _adviseObsRateComboBox->setMaximumWidth(9*ww);
822 _adviseFailSpinBox->setMaximumWidth(9*ww);
823 _adviseRecoSpinBox->setMaximumWidth(9*ww);
824
825 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes.<br>"),0,0,1,50,Qt::AlignLeft);
826 aLayout->addWidget(new QLabel("Observation rate"), 1, 0);
827 aLayout->addWidget(_adviseObsRateComboBox, 1, 1);
828 aLayout->addWidget(new QLabel("Failure threshold"), 2, 0);
829 aLayout->addWidget(_adviseFailSpinBox, 2, 1);
830 aLayout->addWidget(new QLabel("Recovery threshold"), 3, 0);
831 aLayout->addWidget(_adviseRecoSpinBox, 3, 1);
832 aLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
833 aLayout->addWidget(_adviseScriptLineEdit, 4, 1, 1,20);
834 aLayout->addWidget(new QLabel(""), 5, 1);
835 aLayout->setRowStretch(6, 999);
836
837 agroup->setLayout(aLayout);
838
839 // Miscellaneous
840 // -------------
841 QGridLayout* rLayout = new QGridLayout;
842 rLayout->setColumnMinimumWidth(0,14*ww);
843 _miscIntrComboBox->setMaximumWidth(9*ww);
844 _miscPortLineEdit->setMaximumWidth(9*ww);
845
846 rLayout->addWidget(new QLabel("Log latencies or scan RTCM streams for message types and antenna information or output raw data through TCP/IP port.<br>"),0, 0,1,50);
847 rLayout->addWidget(new QLabel("Mountpoint"), 1, 0);
848 rLayout->addWidget(_miscMountLineEdit, 1, 1, 1, 7);
849 rLayout->addWidget(new QLabel("Log latency"), 2, 0);
850 rLayout->addWidget(_miscIntrComboBox, 2, 1);
851 rLayout->addWidget(new QLabel("Scan RTCM"), 3, 0);
852 rLayout->addWidget(_miscScanRTCMCheckBox, 3, 1);
853 rLayout->addWidget(new QLabel("Port"), 4, 0);
854 rLayout->addWidget(_miscPortLineEdit, 4, 1);
855 rLayout->addWidget(new QLabel(""), 5, 1);
856 rLayout->setRowStretch(6, 999);
857
858 rgroup->setLayout(rLayout);
859
860 // PPP
861 // ---
862 _pppWidgets._dataSource->setMaximumWidth(20*ww);
863 _pppWidgets._corrMount->setMaximumWidth(20*ww);
864
865 QGridLayout* pppLayout1 = new QGridLayout();
866 int ir = 0;
867 pppLayout1->addWidget(new QLabel("Precise Point Positioning - Input and Output."), ir, 0, 1, 7, Qt::AlignLeft);
868 ++ir;
869 pppLayout1->addWidget(new QLabel("Data source"), ir, 0);
870 pppLayout1->addWidget(_pppWidgets._dataSource, ir, 1);
871 pppLayout1->addItem(new QSpacerItem(4*ww, 0), ir, 2);
872 pppLayout1->addWidget(new QLabel(" RINEX Obs file"), ir, 3);
873 pppLayout1->addWidget(_pppWidgets._rinexObs, ir, 4);
874 ++ir;
875 pppLayout1->addWidget(new QLabel(" RINEX Nav file"), ir, 3);
876 pppLayout1->addWidget(_pppWidgets._rinexNav, ir, 4);
877 ++ir;
878 pppLayout1->addWidget(new QLabel("Corrections stream"), ir, 0);
879 pppLayout1->addWidget(_pppWidgets._corrMount, ir, 1);
880 pppLayout1->addWidget(new QLabel(" Correction file"), ir, 3);
881 pppLayout1->addWidget(_pppWidgets._corrFile, ir, 4);
882 ++ir;
883 pppLayout1->addWidget(new QLabel("Coordinates"), ir, 0);
884 pppLayout1->addWidget(_pppWidgets._crdFile, ir, 1);
885 pppLayout1->addWidget(new QLabel(" Logfile"), ir, 3);
886 pppLayout1->addWidget(_pppWidgets._logFile, ir, 4);
887 ++ir;
888 pppLayout1->addWidget(new QLabel("ANTEX file"), ir, 0);
889 pppLayout1->addWidget(_pppWidgets._antexFile, ir, 1);
890
891 pppLayout1->addWidget(new QLabel(" NMEA file"), ir, 3);
892 pppLayout1->addWidget(_pppWidgets._nmeaFile, ir, 4);
893 ++ir;
894 pppLayout1->addWidget(new QLabel(" SNX TRO file"), ir, 3);
895 pppLayout1->addWidget(_pppWidgets._snxtroFile, ir, 4);
896 pppLayout1->addWidget(new QLabel(" Sampling"), ir, 5);
897 pppLayout1->addWidget(_pppWidgets._snxtroSampl, ir, 6);
898 ++ir;
899 pppLayout1->setRowStretch(ir, 999);
900
901 pppGroup1->setLayout(pppLayout1);
902
903
904 _pppWidgets._dataSource->setWhatsThis(tr("<p>Select 'Real-time Streams' for real-time PPP from RTCM streams or 'RINEX Files' for post processing PPP from RINEX files.</p><p><ul><li>Real-time PPP requires that you pull an RTCM stream carrying GNSS observations plus a stream providing corrections to Broadcast Ephemeris. If the observations stream does not contain Broadcast Ephemeris then you must in addition pull a Broadcast Ephemeris stream like 'RTCM3EPH' from Ntrip broadcaster www.igs-ip.net.</li><li>Post processing PPP requires RINEX observation files, RINEX navigation files and a file with corrections to Broadcast Ephemeris in plain ASCII format as saved beforehand using BNC.</li></ul></p><p>Note that BNC allows to carry out PPP solutions simultaneously for several stations.</p>"));
905
906 _pppWidgets._corrMount->setWhatsThis(tr("<p>Specify a 'mountpoint' from the 'Streams' canvas below which provides corrections to Broadcast Ephemeris.</p><p>If you don't specify a corrections stream through this option, BNC will fall back to Single Point Positioning (SPP, positioning from observations and broadcast ephemeris only only) instead of doing PPP.</p>"));
907
908 _pppWidgets._crdFile->setWhatsThis(tr("<p>Enter the full path to an ASCII file which specifies the streams or files of those stations you want to process. Specifying a 'Coordinates' file is optional. If it exists, it should contain one record per station with the following parameters separated by blank characters:<p><ul><li>Specify the station either through<ul><li>the 'Mountpoint' of the station's RTCM stream (when in real-time PPP mode), or</li><li>the 4-charater station ID of the RINEX observations file (when in post processing PPP mode).</li></ul></li><li>Approximate X,Y,Z coordinate components of station's Antenna Reference Point [m] (ARP, specify '0.0 0.0 0.0' if unknown).</li><li>Nort, East and Up component of antenna excentricity [m] (specify '0.0 0.0 0.0' if unknown).</li><li>20 Characters describing the antenna type and radome following the IGS 'ANTEX file' standard (leave blank if unknown).</li></ul></p><p>Records with exclamation mark '!' in the first column or blank records will be interpreted as comment lines and ignored.</p>"));
909
910 _pppWidgets._antexFile->setWhatsThis(tr("<p>Observations in RTCM streams or RINEX files should be referred to the receiver's and to the satellite's Antenna Phase Center (APC) and therefore be corrected for<ul><li>Receiver APC offsets</li><li>Receiver APC variations</li><li>Satellite APC offsets.</li></ul> Specify the full path to an IGS 'ANTEX file' which contains APC offsets and variations.</p><p>If you don't specify an 'ANTEX file' then observations will not be corrected for APC offsets and variations.</p>"));
911
912 _pppWidgets._rinexObs->setWhatsThis(tr("<p>Specify the RINEX observations file.</p>"));
913
914 _pppWidgets._rinexNav->setWhatsThis(tr("<p>Specify the RINEX navigation file.</p>"));
915
916 _pppWidgets._corrFile->setWhatsThis(tr("<p>Specify the Broadcast Ephemeris Corrections file as saved beforehand using BNC.</p><p>If you don't specify corrections through this option, BNC will fall back to Single Point Positioning (SPP, positioning from RINEX Obs and RINEX Nav files only) instead of doing PPP.</p>"));
917
918 _pppWidgets._logFile->setWhatsThis(tr("<p>Specify the path to daily PPP logfiles using e.g. the following syntax (example):</p><p> ./PPP_${STATION}_${DATE}.log</p><p>BNC will produce one daily PPP logfile per station. Variable ${STATION} stands for the affected station and ${DATE} stands for the date.</p>"));
919
920 _pppWidgets._nmeaFile->setWhatsThis(tr("<p>Specify the path to daily NMEA files using e.g. the following syntax (example):</p><p> ./PPP_${STATION}_${DATE}.nmea</p><p>BNC will produce one daily NMEA file per station, mainly to save NMEA GGA sentences from the PPP solution. Variable ${STATION} stands for the affected station and ${DATE} stands for the date.</p>"));
921
922 _pppWidgets._snxtroFile->setWhatsThis(tr("<p>Specify the path to daily SINEX Troposphere files using e.g. the following syntax (example):</p><p> ./PPP_${STATION}${DOY}.${YY}.zpd</p><p>BNC will produce one daily troposphere file per station to save troposphere parameters from the PPP solution in SINEX Troposphere format. Variable ${STATION} stands for the affected station, ${DOY} stands for the Day Of Year, and ${YY} for the year.</p>"));
923
924 _pppWidgets._snxtroSampl->setWhatsThis(tr("<p>Select a 'Sampling' rate for saving troposphere paramers.</p>"));
925
926 _pppWidgets._sigmaC1->setWhatsThis(tr("<p>Enter a sigma for your GNSS C1 code observations in meters.</p><p>The higher the sigma you enter, the less the contribution of C1 code observations to a PPP solution based on a combination of code and phase data. 2.0 is likely to be an appropriate choice.</p><p>Default is an empty option field, meaning<br>'Sigma C1 = 2.0'</p>"));
927
928 _pppWidgets._sigmaL1->setWhatsThis(tr("<p>Enter a sigma for your GNSS L1 phase observations in meters.</p><p>The higher the sigma you enter, the less the contribution of L1 phase observations to a PPP solutions based on a combination of code and phase data. 0.01 is likely to be an appropriate choice.</p><p>Default is an empty option field, meaning<br>'Sigma L1 = 0.01'</p>"));
929
930 _pppWidgets._maxResC1->setWhatsThis(tr("<p>Specify a maximum for residuals from C1 code observations in a PPP solution. '3.0' meters may be an appropriate choise for that.</p><p>If the maximum is exceeded, contributions from the corresponding observation will be ignored in the PPP solution.</p><p>Default is an empty option field, meaning<br>'Max Rex C1 = 3.0'</p>"));
931
932 _pppWidgets._maxResL1->setWhatsThis(tr("<p>Specify a maximum for residuals from L1 code observations in a PPP solution. '0.03' meters may be an appropriate choise for that.</p><p>If the maximum is exceeded, contributions from the corresponding observation will be ignored in the PPP solution.</p><p>Default is an empty option field, meaning<br>'Max Rex L1 = 0.03'</p>"));
933
934 _pppWidgets._eleWgtCode->setWhatsThis(tr("<p>Tic 'Ele Wgt Code' to use satellite Elevation depending Weights for Code observations in the PPP solution.</p>"));
935
936 _pppWidgets._eleWgtPhase->setWhatsThis(tr("<p>Tic 'Ele Wgt Phase' to use satellite Elevation depending Weights for Phase observations in the PPP solution.</p>"));
937
938 _pppWidgets._minObs->setWhatsThis(tr("<p>Select a Minimum Number of Observations per epoch for a PPP solution.</p><p>BNC will only process epochs with observation numbers reaching or exceeding this minimum.</p>"));
939
940 _pppWidgets._minEle->setWhatsThis(tr("<p>Select a Minimum satellite Elevation for observations.</p><p>BNC will ignore an observation if the associated Satellite Elevation does not reach or exceed this minimum.</p><p>Selecting '10 deg' may be an appropriate choise in order to avoid too noisy observations."));
941
942 _pppWidgets._lcGPS->setWhatsThis(tr("<p>Specify which kind of GPS observations you want to use and on which kind of ionosphere-free linear combination of GPS observations you want to base ambiguity resolutions.</p><p><ul><li>Specifying 'P3' means that you request BNC to use code data and the so-called P3 ionosphere-free linear combination of code observations.</li><li>'L3' means that you request BNC to use phase data and the so-called L3 ionosphere-free linear combination of phase observations.</li> <li>'P3&L3' means that you request BNC to use both, code and phase data and the so-called P3 and L3 ionosphere-free linear combination of code and phase observations.</li></ul></p><p>Note that most geodetic receivers support the observation of GPS code and phase data. Hence specifying 'P3&L3' would be a good choice when processing data from such a receiver.</p><p>Specifying 'no' means that you don't want BNC to use GPS data.</p>"));
943
944 _pppWidgets._lcGLONASS->setWhatsThis(tr("<p>Specify which kind of GLONASS observations you want to use and on which kind of ionosphere-free linear combination of GLONASS observations you want to base ambiguity resolutions.</p><p><ul><li>Specifying 'P3' means that you request BNC to use code data and the so-called P3 ionosphere-free linear combination of code observations.</li><li>'L3' means that you request BNC to use phase data and the so-called L3 ionosphere-free linear combination of phase observations.</li> <li>'P3&L3' means that you request BNC to use both, code and phase data and the so-called P3 and L3 ionosphere-free linear combination of code and phase observations.</li></ul></p><p>Specifying 'no' means that you don't want BNC to use GLONASS data.</p>"));
945
946 _pppWidgets._lcGalileo->setWhatsThis(tr("<p>Specify which kind of Galileo observations you want to use and on which kind of of ionosphere-free linear combination of Galileo observations you want to base ambiguity resolutions.</p><p><ul><li>Specifying 'P3' means that you request BNC to use code data and the so-called P3 ionosphere-free linear combination of code observations.</li><li>'L3' means that you request BNC to use phase data and the so-called L3 ionosphere-free linear combination of phase observations.</li> <li>'P3&L3' means that you request BNC to use both, code and phase data and the so-called P3 and L3 ionosphere-free linear combination of code and phase observations.</li></ul></p><p>Specifying on of these options makes only sense if Galileo data are part ot the processed observation stream.</p><p>Specifying 'no' means that you don't want BNC to use Galileo data.</p>"));
947
948 _pppWidgets._lcBDS->setWhatsThis(tr("<p>Specify which kind of BDS observations you want to use and on which kind of ionosphere-free linear combination of BDS observations you want to base ambiguity resolutions.</p><p><ul><li>Specifying 'P3' means that you request BNC to use code data and the so-called P3 ionosphere-free linear combination of code observations.</li><li>'L3' means that you request BNC to use phase data and the so-called L3 ionosphere-free linear combination of phase observations.</li> <li>'P3&L3' means that you request BNC to use both, code and phase data and the so-called P3 and L3 ionosphere-free linear combination of code and phase observations.</li></ul></p><p>Specifying on of these options makes only sense if BDS data are part ot the processed observation stream.</p><p>Specifying 'no' means that you don't want to use BDS data.</p>"));
949
950 QVBoxLayout* pppLayout2 = new QVBoxLayout();
951 pppLayout2->addWidget(new QLabel("Precise Point Positioning - Processed Stations.<br>"));
952 pppLayout2->addWidget(_pppWidgets._staTable, 99);
953 QHBoxLayout* pppLayout2sub = new QHBoxLayout();
954 pppLayout2sub->addWidget(_pppWidgets._addStaButton);
955 pppLayout2sub->addWidget(_pppWidgets._delStaButton);
956 pppLayout2sub->addStretch(99);
957
958 pppLayout2->addLayout(pppLayout2sub);
959
960 pppGroup2->setLayout(pppLayout2);
961
962 QGridLayout* pppLayout3 = new QGridLayout();
963 ir = 0;
964 pppLayout3->addWidget(new QLabel("Precise Point Positioning - Options.<br>"), ir, 0, 1, 2, Qt::AlignLeft);
965 ++ir;
966 pppLayout3->addWidget(new QLabel("GPS LCs"), ir, 0, Qt::AlignLeft);
967 pppLayout3->addWidget(_pppWidgets._lcGPS, ir, 1);
968 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 2);
969 pppLayout3->addWidget(new QLabel("Sigma C1"), ir, 3, Qt::AlignLeft);
970 pppLayout3->addWidget(_pppWidgets._sigmaC1, ir, 4); _pppWidgets._sigmaC1->setMaximumWidth(8*ww);
971 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 5);
972 pppLayout3->addWidget(new QLabel("Sigma L1"), ir, 6, Qt::AlignLeft);
973 pppLayout3->addWidget(_pppWidgets._sigmaL1, ir, 7); _pppWidgets._sigmaL1->setMaximumWidth(8*ww);
974 ++ir;
975 pppLayout3->addWidget(new QLabel("GLONASS LCs"), ir, 0, Qt::AlignLeft);
976 pppLayout3->addWidget(_pppWidgets._lcGLONASS, ir, 1);
977 pppLayout3->addWidget(new QLabel("Max Res C1"), ir, 3, Qt::AlignLeft);
978 pppLayout3->addWidget(_pppWidgets._maxResC1, ir, 4); _pppWidgets._maxResC1->setMaximumWidth(8*ww);
979 pppLayout3->addWidget(new QLabel("Max Res L1"), ir, 6, Qt::AlignLeft);
980 pppLayout3->addWidget(_pppWidgets._maxResL1, ir, 7); _pppWidgets._maxResL1->setMaximumWidth(8*ww);
981 ++ir;
982 pppLayout3->addWidget(new QLabel("Galileo LCs"), ir, 0, Qt::AlignLeft);
983 pppLayout3->addWidget(_pppWidgets._lcGalileo, ir, 1);
984 pppLayout3->addWidget(new QLabel("Ele Wgt Code"), ir, 3, Qt::AlignLeft);
985 pppLayout3->addWidget(_pppWidgets._eleWgtCode, ir, 4);
986 pppLayout3->addWidget(new QLabel("Ele Wgt Phase"), ir, 6, Qt::AlignLeft);
987 pppLayout3->addWidget(_pppWidgets._eleWgtPhase, ir, 7);
988 ++ir;
989 pppLayout3->addWidget(new QLabel("BDS LCs"), ir, 0, Qt::AlignLeft);
990 pppLayout3->addWidget(_pppWidgets._lcBDS, ir, 1);
991 pppLayout3->addWidget(new QLabel("Min # of Obs"), ir, 3, Qt::AlignLeft);
992 pppLayout3->addWidget(_pppWidgets._minObs, ir, 4);
993 pppLayout3->addWidget(new QLabel("Min Elevation"), ir, 6, Qt::AlignLeft);
994 pppLayout3->addWidget(_pppWidgets._minEle, ir, 7);
995 ++ir;
996 pppLayout3->addWidget(new QLabel("Wait for clock corr."), ir, 0, Qt::AlignLeft);
997 pppLayout3->addWidget(_pppWidgets._corrWaitTime, ir, 1);
998 pppLayout3->addWidget(new QLabel("Seeding (sec)"), ir, 3, Qt::AlignLeft);
999 pppLayout3->addWidget(_pppWidgets._seedingTime, ir, 4);
1000 ++ir;
1001 pppLayout3->addWidget(new QLabel(""), ir, 8);
1002 pppLayout3->setColumnStretch(8, 999);
1003 ++ir;
1004 pppLayout3->addWidget(new QLabel(""), ir, 1);
1005 pppLayout3->setRowStretch(ir, 999);
1006
1007 pppGroup3->setLayout(pppLayout3);
1008
1009 // ------------------------
1010 connect(_pppWidgets._mapWinButton, SIGNAL(clicked()), SLOT(slotMapPPP()));
1011 _pppWidgets._mapSpeedSlider->setMinimumWidth(33*ww);
1012 _pppWidgets._audioResponse->setMaximumWidth(8*ww);
1013
1014 QGridLayout* pppLayout4 = new QGridLayout();
1015 ir = 0;
1016 pppLayout4->addWidget(new QLabel("Precise Point Positioning - Plots.<br>"), ir, 0, 1, 50, Qt::AlignLeft);
1017 ++ir;
1018 pppLayout4->addWidget(new QLabel("PPP Plot"), ir, 0, Qt::AlignLeft);
1019 pppLayout4->addWidget(_pppWidgets._plotCoordinates, ir, 1, Qt::AlignLeft);
1020 pppLayout4->addWidget(new QLabel("Mountpoint"), ir, 2, 1, 10, Qt::AlignLeft);
1021 pppLayout4->addWidget(_pppWidgets._audioResponse, ir, 4, Qt::AlignLeft);
1022 pppLayout4->addWidget(new QLabel("Audio response"), ir, 5, Qt::AlignRight);
1023
1024 ++ir;
1025 pppLayout4->addWidget(new QLabel("Track map"), ir, 0, Qt::AlignLeft);
1026 pppLayout4->addWidget(_pppWidgets._mapWinButton, ir, 1, Qt::AlignLeft);
1027 pppLayout4->addWidget(new QLabel("OSM"), ir, 2, Qt::AlignLeft);
1028 pppLayout4->addWidget(_pppWidgets._useOpenStreetMap, ir, 3, Qt::AlignLeft);
1029 pppLayout4->addWidget(new QLabel("Google"), ir, 3, Qt::AlignRight);
1030 pppLayout4->addWidget(_pppWidgets._useGoogleMap, ir, 4, Qt::AlignLeft);
1031 ++ir;
1032 pppLayout4->addWidget(new QLabel("Dot-properties"), ir, 0, Qt::AlignLeft);
1033 pppLayout4->addWidget(_pppWidgets._mapWinDotSize, ir, 1, Qt::AlignLeft);
1034 pppLayout4->addWidget(new QLabel("Size "), ir, 2, Qt::AlignLeft);
1035 pppLayout4->addWidget(_pppWidgets._mapWinDotColor, ir, 3, Qt::AlignLeft);
1036 pppLayout4->addWidget(new QLabel("Color"), ir, 4, Qt::AlignLeft);
1037 ++ir;
1038 pppLayout4->addWidget(new QLabel("Post-processing speed"), ir, 0, Qt::AlignLeft);
1039 pppLayout4->addWidget(_pppWidgets._mapSpeedSlider, ir, 1, 1, 20, Qt::AlignLeft);
1040 ++ir;
1041 pppLayout4->addWidget(new QLabel(""), ir, 1);
1042 pppLayout4->setRowStretch(ir, 999);
1043
1044 pppGroup4->setLayout(pppLayout4);
1045
1046 // Reqc Processing
1047 // ---------------
1048 _reqcActionComboBox = new QComboBox();
1049 _reqcActionComboBox->setEditable(false);
1050 _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
1051 int ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
1052 if (ik != -1) {
1053 _reqcActionComboBox->setCurrentIndex(ik);
1054 }
1055 connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
1056 this, SLOT(slotBncTextChanged()));
1057
1058 QGridLayout* reqcLayout = new QGridLayout;
1059 _reqcActionComboBox->setMinimumWidth(15*ww);
1060 _reqcActionComboBox->setMaximumWidth(20*ww);
1061
1062 _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1063 _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
1064 _reqcObsFileChooser->setWhatsThis(tr("<p>Specify the full path to input observation files in RINEX v2 or v3 format.</p><p>Note that when in 'Analyze' mode, specifying at least one RINEX observation file is mandatory.</p>"));
1065
1066 _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1067 _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
1068 _reqcNavFileChooser->setWhatsThis(tr("<p>Specify the full path to input navigation files in RINEX v2 or v3 format.</p><p>Note that when in 'Analyze' mode, specifying at least one RINEX navigation file is mandatory.</p>"));
1069
1070 _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
1071 _reqcOutObsLineEdit->setWhatsThis(tr("<p>Specify the full path to a RINEX observation output file.</p><p>Default is an empty option field, meaning that no RINEX observation output file will be produced.</p>"));
1072
1073 _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
1074 _reqcOutNavLineEdit->setWhatsThis(tr("<p>Specify the full path to a RINEX navigation output file.</p><p>Default is an empty option field, meaning that no RINEX navigation output file will be produced.</p>"));
1075
1076 _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
1077 _reqcOutLogLineEdit->setWhatsThis(tr("<p>Specify the full path to a logfile.</p><p>Default is an empty option field, meaning that no 'RINEX Editing & QC' logfile will be produced.</p>"));
1078
1079 _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
1080 _reqcPlotDirLineEdit->setWhatsThis(tr("<p>Specify a directory for saving plots in PNG format.</p><p>Default is an empty option field, meaning that plots will not be saved on disk.</p>"));
1081
1082 _reqcSkyPlotSignals = new QLineEdit(settings.value("reqcSkyPlotSignals").toString());
1083 _reqcSkyPlotSignals->setWhatsThis(tr("<p>BNC can produce plots for multipath, signal-to-noise ratio, satellite availability, satellite elevation, and PDOP values. The 'Plots for signals' option lets you exactly specify the observation signals to be used for that and also enables the plot production. You can specify the navigation system, the frequency, and the tracking mode or channel as defined in RINEX Version 3. Specifications for fequency and tracking mode or channel must be seperated by ampersand character '&'. Specifications for each navigation systems must be seperated by blank character ' '.</p><p>Examples for 'Plots for signals' option:<ul><li> G:1&2 R:1&2 J:1&2 E:1&7 C:1&6 S:1<br>(Plots will be based on GPS observations on 1st and 2nd frequency, GLONASS observations on 1st and 2nd frequency, QZSS observations on 1st and 2nd frequency, Galileo observations on 1st and 7th frequency, BeiDou observations on 1st and 6th frequency, SBAS observations on 1st frequency.)</li><li>G:1C&5X<br>(Plots will be based on GPS observations on 1st frequency in C tracking mode and GPS observations on 5th frequency in X tracking mode.)</li><li>C:6I&7I<br>(Plots will be based on BeiDou observations on 6th frequency in I tracking mode and BeiDou observations on 7th frequency in I tracking mode.)<li></ul></p><p>Default is 'C:2&7 E:1&5 G:1&2 J:1&2 R:1&2 S:1&5'. Specifying an empty option string would be overruled by this default.</p>"));
1084
1085 connect(_reqcSkyPlotSignals, SIGNAL(textChanged(const QString &)),
1086 this, SLOT(slotBncTextChanged()));
1087
1088 _reqcLogSummaryOnly = new QCheckBox();
1089 _reqcLogSummaryOnly->setCheckState(Qt::CheckState(settings.value("reqcLogSummaryOnly").toInt()));
1090 _reqcLogSummaryOnly->setWhatsThis(tr("<p>By default BNC produces a detailed 'Logfile' providing all information resulting from editing or analyzing RINEX data. If that is too much information, you can limit the logfile contents to a short summary.</p><p>Tick 'Summary only' to suppress a full logfile output and instead produce a logfile containing only summary information.</p>"));
1091
1092 ir = 0;
1093 reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check.<br>"),ir, 0, 1, 8);
1094 ++ir;
1095 reqcLayout->addWidget(new QLabel("Action"), ir, 0);
1096 reqcLayout->addWidget(_reqcActionComboBox, ir, 1);
1097 _reqcEditOptionButton = new QPushButton("Set Edit Options");
1098 _reqcEditOptionButton->setMinimumWidth(15*ww);
1099 _reqcEditOptionButton->setMaximumWidth(20*ww);
1100
1101 reqcLayout->addWidget(_reqcEditOptionButton, ir, 3);
1102 ++ir;
1103 reqcLayout->addWidget(new QLabel("Input files (full path)"), ir, 0);
1104 reqcLayout->addWidget(_reqcObsFileChooser, ir, 1);
1105 _reqcObsFileChooser->setMaximumWidth(40*ww);
1106 reqcLayout->addWidget(new QLabel(" Obs"), ir, 2);
1107 reqcLayout->addWidget(_reqcNavFileChooser, ir, 3);
1108 _reqcNavFileChooser->setMaximumWidth(40*ww);
1109 reqcLayout->addWidget(new QLabel(" Nav"), ir, 4);
1110 ++ir;
1111 reqcLayout->addWidget(new QLabel("Output file (full path)"), ir, 0);
1112 reqcLayout->addWidget(_reqcOutObsLineEdit, ir, 1);
1113 _reqcOutObsLineEdit->setMaximumWidth(40*ww);
1114 reqcLayout->addWidget(new QLabel(" Obs"), ir, 2);
1115 reqcLayout->addWidget(_reqcOutNavLineEdit, ir, 3);
1116 _reqcOutNavLineEdit->setMaximumWidth(40*ww);
1117 reqcLayout->addWidget(new QLabel(" Nav"), ir, 4);
1118 ++ir;
1119 reqcLayout->addWidget(new QLabel("Logfile"), ir, 0);
1120 reqcLayout->addWidget(_reqcOutLogLineEdit, ir, 1);
1121 _reqcOutLogLineEdit->setMaximumWidth(40*ww);
1122 reqcLayout->addWidget(new QLabel(" Summary only"), ir, 2);
1123 reqcLayout->addWidget(_reqcLogSummaryOnly, ir, 3);
1124 ++ir;
1125 reqcLayout->addWidget(new QLabel("Plots for signals"), ir, 0);
1126 reqcLayout->addWidget(_reqcSkyPlotSignals, ir, 1);
1127 _reqcSkyPlotSignals->setMaximumWidth(40*ww);
1128 ++ir;
1129 reqcLayout->addWidget(new QLabel("Directory for plots"), ir, 0);
1130 reqcLayout->addWidget(_reqcPlotDirLineEdit, ir, 1);
1131 _reqcPlotDirLineEdit->setMaximumWidth(40*ww);
1132 ++ir;
1133 reqcLayout->setRowStretch(ir, 999);
1134
1135 reqcLayout->setColumnMinimumWidth(2, 8*ww);
1136 reqcLayout->setColumnMinimumWidth(4, 8*ww);
1137
1138 reqcgroup->setLayout(reqcLayout);
1139
1140 connect(_reqcEditOptionButton, SIGNAL(clicked()),
1141 this, SLOT(slotReqcEditOption()));
1142
1143 QGridLayout* sp3CompLayout = new QGridLayout;
1144
1145 _sp3CompFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1146 _sp3CompFileChooser->setFileName(settings.value("sp3CompFile").toString());
1147 _sp3CompFileChooser->setWhatsThis(tr("<p>BNC can compare two SP3 files containing GNSS satellite orbit and clock information.</p></p>Specify the full path to two files with orbits and clocks in SP3 format, separate them by comma.</p>"));
1148 _sp3CompFileChooser->setMinimumWidth(15*ww);
1149 _sp3CompFileChooser->setMaximumWidth(40*ww);
1150
1151 _sp3CompExclude = new QLineEdit(settings.value("sp3CompExclude").toString());
1152 _sp3CompExclude->setMinimumWidth(18*ww);
1153 _sp3CompExclude->setMaximumWidth(18*ww);
1154 _sp3CompExclude->setWhatsThis(tr("<p>Specify satellites to exclude them from orbit and clock comparision. Example:<p>G04,G31,R</p><p>This excludes GPS satellites RPN 4 and 31 as well as all GLONASS satellites from the comparision.</p><p>Default is an empty option field, meaning that no satellite is excluded from the comparison.</p>"));
1155
1156 _sp3CompLogLineEdit = new QLineEdit(settings.value("sp3CompOutLogFile").toString());
1157 _sp3CompLogLineEdit->setWhatsThis(tr("<p>Specify the full path to a logfile to save comparison results.</p><p>Specifying a logfile is mandatory. Comparing SP3 files and not saving the results on disk would be meaningless.</p>"));
1158 _sp3CompLogLineEdit->setMinimumWidth(18*ww);
1159 _sp3CompLogLineEdit->setMaximumWidth(18*ww);
1160
1161 ir = 0;
1162 sp3CompLayout->addWidget(new QLabel("Orbit and clock comparison.<br>"), ir, 0, 1, 40);
1163 ++ir;
1164 sp3CompLayout->addWidget(new QLabel("Input SP3 files (full path)"), ir, 0, Qt::AlignLeft);
1165 sp3CompLayout->addWidget(_sp3CompFileChooser, ir, 1, 1, 20);
1166 ++ir;
1167 sp3CompLayout->addWidget(new QLabel("Exclude satellites"), ir, 0, Qt::AlignLeft);
1168 sp3CompLayout->addWidget(_sp3CompExclude, ir, 1, Qt::AlignRight);
1169 ++ir;
1170 sp3CompLayout->addWidget(new QLabel("Logfile"), ir, 0, Qt::AlignLeft);
1171 sp3CompLayout->addWidget(_sp3CompLogLineEdit, ir, 1, Qt::AlignRight);
1172 ++ir;
1173 sp3CompLayout->addWidget(new QLabel(""), ir, 1);
1174 ++ir;
1175 sp3CompLayout->setRowStretch(ir, 999);
1176
1177 sp3CompLayout->setColumnMinimumWidth(2, 8*ww);
1178 sp3CompLayout->setColumnMinimumWidth(4, 8*ww);
1179
1180 sp3CompGroup->setLayout(sp3CompLayout);
1181
1182 connect(_sp3CompFileChooser, SIGNAL(fileNameChanged(const QString &)),
1183 this, SLOT(slotBncTextChanged()));
1184
1185 // Combine Corrections
1186 // -------------------
1187 QGridLayout* cmbLayout = new QGridLayout;
1188
1189 populateCmbTable();
1190 cmbLayout->addWidget(_cmbTable, 0, 0, 8, 3);
1191 cmbLayout->addWidget(new QLabel(" Combine Broadcast Correction streams.<br>"), 1, 6, 1, 10);
1192 cmbLayout->addWidget(addCmbRowButton, 2, 6);
1193 cmbLayout->addWidget(delCmbRowButton, 2, 7);
1194 cmbLayout->addWidget(new QLabel("Method"), 3, 6, Qt::AlignRight);
1195 cmbLayout->addWidget(_cmbMethodComboBox, 3, 7);
1196 cmbLayout->addWidget(new QLabel(" Maximal residuum"), 4, 6, Qt::AlignRight);
1197 cmbLayout->addWidget(_cmbMaxresLineEdit, 4, 7, Qt::AlignRight);
1198 cmbLayout->addWidget(new QLabel("Sampling"), 5, 6, Qt::AlignRight);
1199 cmbLayout->addWidget(_cmbSamplSpinBox, 5, 7);
1200 cmbLayout->addWidget(new QLabel(" Use GLONASS"), 6, 6, Qt::AlignRight);
1201 cmbLayout->addWidget(_cmbUseGlonass, 6, 7);
1202 cmbLayout->setRowStretch(7, 999);
1203
1204 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1205 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
1206
1207 cmbgroup->setLayout(cmbLayout);
1208
1209 // Upload Layout (Clocks)
1210 // ----------------------
1211 QGridLayout* uploadHlpLayout = new QGridLayout();
1212
1213 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1214 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1215 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
1216
1217 uploadHlpLayout->addWidget(addUploadRowButton, 0, 0);
1218 uploadHlpLayout->addWidget(delUploadRowButton, 0, 1);
1219 uploadHlpLayout->addWidget(new QLabel("Interval"), 0, 2, Qt::AlignRight);
1220 uploadHlpLayout->addWidget(_uploadIntrComboBox, 0, 3);
1221 uploadHlpLayout->addWidget(new QLabel(" Sampling: Orb"), 0, 4, Qt::AlignRight);
1222 uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox, 0, 5);
1223 uploadHlpLayout->addWidget(new QLabel("SP3"), 0, 6, Qt::AlignRight);
1224 uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox, 0, 7);
1225 uploadHlpLayout->addWidget(new QLabel("RNX"), 0, 8, Qt::AlignRight);
1226 uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox, 0, 9);
1227 uploadHlpLayout->addWidget(setUploadTrafoButton, 0,10);
1228 uploadHlpLayout->addWidget(new QLabel("ANTEX file"), 1, 0, Qt::AlignLeft);
1229 uploadHlpLayout->addWidget(_uploadAntexFile, 1, 1, 1, 4);
1230
1231 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1232 populateUploadTable();
1233
1234 uploadLayout->addWidget(new QLabel("Upload RTCM Version 3 Broadcast Corrections to caster.<br>"));
1235 uploadLayout->addWidget(_uploadTable);
1236 uploadLayout->addLayout(uploadHlpLayout);
1237
1238 uploadgroup->setLayout(uploadLayout);
1239
1240 // Upload Layout (Ephemeris)
1241 // -------------------------
1242 QGridLayout* uploadLayoutEph = new QGridLayout;
1243
1244 uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1245 _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1246 _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1247 _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1248
1249 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster.<br>"), 0, 0, 1, 50);
1250 uploadLayoutEph->addWidget(new QLabel("Host"), 1, 0);
1251 uploadLayoutEph->addWidget(_uploadEphHostLineEdit, 1, 1, 1, 3);
1252 uploadLayoutEph->addWidget(new QLabel(" Port"), 1, 4, Qt::AlignRight);
1253 uploadLayoutEph->addWidget(_uploadEphPortLineEdit, 1, 5, 1, 1);
1254 uploadLayoutEph->addWidget(new QLabel("Mountpoint "), 2, 0);
1255 uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit, 2, 1);
1256 uploadLayoutEph->addWidget(new QLabel(" Password"), 2, 2, Qt::AlignRight);
1257 uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit, 2, 3);
1258 uploadLayoutEph->addWidget(new QLabel("Sampling"), 3, 0);
1259 uploadLayoutEph->addWidget(_uploadEphSampleSpinBox, 3, 1);
1260 uploadLayoutEph->addWidget(new QLabel("Uploaded"), 4, 0);
1261 uploadLayoutEph->addWidget(_uploadEphBytesCounter, 4, 1);
1262 uploadLayoutEph->setRowStretch(5, 999);
1263
1264 uploadEphgroup->setLayout(uploadLayoutEph);
1265
1266 connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1267 this, SLOT(slotBncTextChanged()));
1268
1269 // Main Layout
1270 // -----------
1271 QGridLayout* mLayout = new QGridLayout;
1272 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
1273 mLayout->addWidget(_aogroup, 0,0);
1274 mLayout->addWidget(_mountPointsTable, 1,0);
1275 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
1276 mLayout->addWidget(_loggroup, 2,0);
1277
1278 _canvas->setLayout(mLayout);
1279
1280 // WhatsThis
1281 // ---------
1282 _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>"));
1283 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1284 _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>"));
1285 _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>"));
1286 _outWaitSpinBox->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>"));
1287 _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."));
1288 _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."));
1289 _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."));
1290 _ephOutPortLineEdit->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."));
1291 _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."));
1292 _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."));
1293 _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."));
1294 _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."));
1295 _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>"));
1296 _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>"));
1297 _rnxFileCheckBox->setWhatsThis(tr("<p>Tick check box 'Skeleton mandatory' in case you want that RINEX files are only produced if skeleton files are available for BNC. If no skeleton file is available for a particular source then no RINEX observation file will be produced from the affected stream.</p><p>Note that a skeleton file contains RINEX header information such as receiver and antenna types. In case of stream conversion to RINEX Version 3 a skeleton file should also contain information on potentially available observation types. A missing skeleton file will therefore enforce BNC to only save a default set of RINEX 3 observation types."));
1298 _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>"));
1299 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1300 _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p>"));
1301 _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>"));
1302 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1303 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1304 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of the Broadcast Ephemeris Correction files.</p>"));
1305 _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>"));
1306 _outSamplSpinBox->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>"));
1307 _adviseObsRateComboBox->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><p>Default is an empty option field, meaning that you don't want BNC to report on stream failures or recoveries when exceeding a threshold time span.</p>"));
1308 _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>"));
1309 _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>"));
1310 _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."));
1311 _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.</p><p>An empty option field (default) or invalid path means that you don't want to use this option.</p>"));
1312 _miscIntrComboBox->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>"));
1313 _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 together with an approximation for the height. The default values for latitude and longitude 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>"));
1314 _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."));
1315 _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)."));
1316 _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."));
1317 _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."));
1318 _rnxV3filenameCheckBox->setWhatsThis(tr("<p>Tick 'Version 3 filenames' to let BNC create so-called extended filenames following the RINEX Version 3 standard.</p><p>Default is an empty check box, meaning to create filenames following the RINEX Version 2 standard although the file contents is saved in RINEX Version 3 format.</p>"));
1319 _ephV3filenameCheckBox->setWhatsThis(tr("<p>Tick 'Version 3 filenames' to let BNC create so-called extended filenames following the RINEX Version 3 standard.</p><p>Default is an empty check box, meaning to create filenames following the RINEX Version 2 standard although the file contents is saved in RINEX Version 3 format.</p>"));
1320 _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."));
1321
1322 _rnxV2Priority->setWhatsThis(tr("<p>Specify a priority list of characters defining signal attributes as defined in RINEX Version 3. Priorities will be used to map observations with RINEX Version 3 attributes from incoming streams to Version 2. The underscore character '_' stands for undefined attributes. A question mark '?' can be used as wildcard which represents any one character.</p><p>Signal priorities can be specified either as equal for all systems or system specifics. The following are example priority strings:</li><ul><li>'CWPX_?' (Same signal priorities valid for all systems)</li><li>'G:CWPX_? R:PCX_? E:CPX_?' (Specific signal priorities for GPS, GLONASS and Galileo system)</li></ul>Default is priority list 'CWPX_?'.</p>"));
1323
1324 _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>"));
1325 _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."));
1326 _miscScanRTCMCheckBox->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>."));
1327 _serialMountPointLineEdit->setWhatsThis(tr("<p>Enter a 'Mountpoint' to forward the corresponding stream to a serial connected receiver.</p><p>Depending on the stream contents the receiver may use it for Differential GNSS, Precise Point Positioning or any other purpose supported by the firmware.</p>"));
1328 _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>"));
1329 _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>"));
1330 _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>"));
1331 _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>"));
1332 _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>"));
1333 _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>"));
1334 _serialAutoNMEAComboBox->setWhatsThis(tr("<p>The 'NMEA' option supports the so-called 'Virtural Reference Station' (VRS) concept which requires the receiver to send approximate position information to the Ntrip Broadcaster. Select 'no' if you don't want BNC to forward or upload any NMEA message to the Ntrip broadcaster in support of VRS.</p><p>Select 'Auto' to automatically forward NMEA messages of type GGA from your serial connected receiver to the Ntrip broadcaster and/or save them in a file.</p><p>Select 'Manual GPGGA' or 'Manual GNGGA' if you want BNC to produce and upload GPGGA or GNGGA NMEA messages to the Ntrip broadcaster because your serial connected receiver doesn't generate these messages. A Talker ID 'GP' preceding the GGA string stands for GPS solutions while a Talker ID 'GN' stands for multi constellation solutions.</p><p>Note that selecting 'Auto' or 'Manual' works only for VRS streams which show up under the 'Streams' canvas on BNC's main window with 'nmea' stream attribute set to 'yes'. This attribute is either extracted from the Ntrip broadcaster's sourcetable or introduced by the user through editing the BNC configuration file.</p>"));
1335 _serialFileNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where NMEA messages coming from your serial connected receiver are saved.</p><p>Default is an empty option field, meaning that NMEA messages will not be saved on disk.</p>"));
1336 _serialHeightNMEALineEdit->setWhatsThis(tr("<p>Specify an approximate 'Height' above mean sea level in meters for the reference station introduced through 'Mountpoint'. Together with the latitude and longitude from the Ntrip broadcaster sourcetable the height information is used to build GGA messages to be sent to the Ntrip broadcaster.</p><p>For adjusting latitude and longitude values of a VRS stream given in the 'Streams' canvas you can double click the latitude/longitude data fields, specify appropriate values and then hit Enter.</p><p>This option is only relevant when option 'NMEA' is set to 'Manual GPGGA' or 'Manual GNGGA' respectively.</p>"));
1337 _serialManualNMEASamplingSpinBox->setWhatsThis(tr("<p>Select the sampling interval in seconds for manual generation and upload of NMEA GGA sentences.</p><p>A sampling rate of '0' means, the a GGA sentence will be send only once to initialize the requested VRS stream. Note that some VRS systems need GGA sentences at regular intervals.</p>"));
1338 _reqcActionComboBox->setWhatsThis(tr("<p>BNC allows to 'Edit or Concatenate' RINEX v2 or v3 files or to perform a quality check and 'Analyze' the data following UNAVCO's famous 'teqc' program.</p>"));
1339 _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX v2 or v3 files.</p>"));
1340 _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."));
1341
1342 _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.</p><p>Note 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."));
1343
1344 _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>"));
1345 _cmbSamplSpinBox->setWhatsThis(tr("<p>Specify a combination sampling interval for the Clocks. The clock corrections will be produced following that interval. A value of 10 sec may be an appropriate choice.</p>"));
1346 _cmbUseGlonass->setWhatsThis(tr("<p>In case the incoming orbit and clock correction stream(s) support GLONASS, you can tick 'Use GLONASS' to produce a GPS plus GLONASS combination solution.</p><p>Default is a GPS-only combination."));
1347 _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>"));
1348 _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 filename.</p><p>When saving SP3 file contents and/or referring correctors to the satellite's Center of Mass (CoM), an offset has to be applied because correctors originally refer to the satellite's Antenna Phase Center (APC). Antenna offsets are available from the IGS 'ANTEX file' which can be introduced through specifying its path. If you don't specify an 'ANTEX file' path, the SP3 file contents and the orbit and clock correctors will be referred to satellite APCs and not to CoM.</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 filename.</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>"));
1349
1350 addCmbRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the mountpoints table."));
1351 delCmbRowButton->setWhatsThis(tr("Hit 'Delete' button to delete the highlighted line from the mountpoints table."));
1352 addUploadRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the stream upload table."));
1353 delUploadRowButton->setWhatsThis(tr("Hit 'Del Row' button to delete the highlighted line from the stream upload table."));
1354 _uploadIntrComboBox->setWhatsThis(tr("Select the length of the SP3 and Clock RINEX files."));
1355 _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."));
1356 _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."));
1357 _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."));
1358 setUploadTrafoButton->setWhatsThis(tr("Hit 'Custom Trafo' to specify your own 14 parameter Helmert Transformation instead of selecting a predefined transformation through 'System' button."));
1359 _uploadAntexFile->setWhatsThis(tr("<p>When producing SP3 files or referring orbit and clock corrections to the satellite's Center of Mass (CoM) instead of Antenna Phase Center (APC), an offset has to be applied which is available from the IGS 'ANTEX file'. You must therefore specify the 'ANTEX file' path if you want to save the stream contents in SP3 format and/or refer correctors to CoM.</p><p>If you don't specify an 'ANTEX file' path, the SP3 file contents as well as the orbit and clock correctors will be referred to satellite APCs.</p>"));
1360 _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."));
1361 _uploadEphPortLineEdit->setWhatsThis(tr("Specify the IP port of an Ntrip Broadcaster to upload the stream. Default is port 80."));
1362 _uploadEphMountpointLineEdit->setWhatsThis(tr("Specify the mounpoint for stream upload to an Ntrip Broadcaster."));
1363 _uploadEphPasswordLineEdit->setWhatsThis(tr("Specify the stream upload password protecting the mounpoint on an Ntrip Broadcaster."));
1364 _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."));
1365 _uploadEphBytesCounter->setWhatsThis(tr("BNC shows the amount of data uploaded through this stream."));
1366 _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1367 _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
1368 _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>"));
1369 _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1370 _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1371
1372 // Enable/Disable all Widgets
1373 // --------------------------
1374 slotBncTextChanged();
1375 enableStartStop();
1376
1377 // Auto start
1378 // ----------
1379 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1380 slotStart();
1381 }
1382}
1383
1384// Destructor
1385////////////////////////////////////////////////////////////////////////////
1386bncWindow::~bncWindow() {
1387 delete _caster; BNC_CORE->setCaster(0);
1388 delete _casterEph;
1389}
1390
1391//
1392////////////////////////////////////////////////////////////////////////////
1393void bncWindow::populateMountPointsTable() {
1394
1395 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1396 _mountPointsTable->removeRow(iRow);
1397 }
1398
1399 bncSettings settings;
1400
1401 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1402 int iRow = 0;
1403 while (it.hasNext()) {
1404 QStringList hlp = it.next().split(" ");
1405 if (hlp.size() < 7) continue;
1406 _mountPointsTable->insertRow(iRow);
1407
1408 QUrl url(hlp[0]);
1409
1410 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1411 QString format(hlp[1]); QString country(hlp[2]); QString latitude(hlp[3]); QString longitude(hlp[4]);
1412 QString nmea(hlp[5]);
1413 if (hlp[6] == "S") {
1414 fullPath = hlp[0].replace(0,2,"");
1415 }
1416 QString ntripVersion = "2";
1417 if (hlp.size() >= 7) {
1418 ntripVersion = (hlp[6]);
1419 }
1420
1421 QTableWidgetItem* it;
1422 it = new QTableWidgetItem(url.userInfo());
1423 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1424 _mountPointsTable->setItem(iRow, 0, it);
1425
1426 it = new QTableWidgetItem(fullPath);
1427 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1428 _mountPointsTable->setItem(iRow, 1, it);
1429
1430 it = new QTableWidgetItem(format);
1431 _mountPointsTable->setItem(iRow, 2, it);
1432
1433 it = new QTableWidgetItem(country);
1434 _mountPointsTable->setItem(iRow, 3, it);
1435
1436 if (nmea == "yes") {
1437 it = new QTableWidgetItem(latitude);
1438 _mountPointsTable->setItem(iRow, 4, it);
1439 it = new QTableWidgetItem(longitude);
1440 _mountPointsTable->setItem(iRow, 5, it);
1441 } else {
1442 it = new QTableWidgetItem(latitude);
1443 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1444 _mountPointsTable->setItem(iRow, 4, it);
1445
1446 it = new QTableWidgetItem(longitude);
1447 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1448 _mountPointsTable->setItem(iRow, 5, it);
1449 }
1450
1451 it = new QTableWidgetItem(nmea);
1452 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1453 _mountPointsTable->setItem(iRow, 6, it);
1454
1455 it = new QTableWidgetItem(ntripVersion);
1456 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1457 _mountPointsTable->setItem(iRow, 7, it);
1458
1459 bncTableItem* bncIt = new bncTableItem();
1460 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1461 _mountPointsTable->setItem(iRow, 8, bncIt);
1462
1463 iRow++;
1464 }
1465
1466 _mountPointsTable->sortItems(1);
1467
1468 enableStartStop();
1469}
1470
1471// Retrieve Table
1472////////////////////////////////////////////////////////////////////////////
1473void bncWindow::slotAddMountPoints() {
1474
1475 bncSettings settings;
1476 QString proxyHost = settings.value("proxyHost").toString();
1477 int proxyPort = settings.value("proxyPort").toInt();
1478 if (proxyHost != _proxyHostLineEdit->text() ||
1479 proxyPort != _proxyPortLineEdit->text().toInt()) {
1480 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1481 "changed. Use the new ones?",
1482 QMessageBox::Yes, QMessageBox::No,
1483 QMessageBox::NoButton);
1484 if (iRet == QMessageBox::Yes) {
1485 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1486 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1487 }
1488 }
1489
1490 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1491 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1492
1493 QMessageBox msgBox;
1494 msgBox.setIcon(QMessageBox::Question);
1495 msgBox.setWindowTitle("Add Stream");
1496 msgBox.setText("Add stream(s) coming from:");
1497
1498 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1499 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1500 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1501 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1502 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1503
1504 msgBox.exec();
1505
1506 if (msgBox.clickedButton() == buttonNtrip) {
1507 bncTableDlg* dlg = new bncTableDlg(this);
1508 dlg->move(this->pos().x()+50, this->pos().y()+50);
1509 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1510 this, SLOT(slotNewMountPoints(QStringList*)));
1511 dlg->exec();
1512 delete dlg;
1513 } else if (msgBox.clickedButton() == buttonIP) {
1514 bncIpPort* ipp = new bncIpPort(this);
1515 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1516 this, SLOT(slotNewMountPoints(QStringList*)));
1517 ipp->exec();
1518 delete ipp;
1519 } else if (msgBox.clickedButton() == buttonUDP) {
1520 bncUdpPort* udp = new bncUdpPort(this);
1521 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1522 this, SLOT(slotNewMountPoints(QStringList*)));
1523 udp->exec();
1524 delete udp;
1525 } else if (msgBox.clickedButton() == buttonSerial) {
1526 bncSerialPort* sep = new bncSerialPort(this);
1527 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1528 this, SLOT(slotNewMountPoints(QStringList*)));
1529 sep->exec();
1530 delete sep;
1531 } else if (msgBox.clickedButton() == buttonCancel) {
1532 // Cancel
1533 }
1534
1535 enableStartStop();
1536}
1537
1538// Delete Selected Mount Points
1539////////////////////////////////////////////////////////////////////////////
1540void bncWindow::slotDeleteMountPoints() {
1541
1542 int nRows = _mountPointsTable->rowCount();
1543 bool flg[nRows];
1544 for (int iRow = 0; iRow < nRows; iRow++) {
1545 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1546 flg[iRow] = true;
1547 }
1548 else {
1549 flg[iRow] = false;
1550 }
1551 }
1552 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1553 if (flg[iRow]) {
1554 _mountPointsTable->removeRow(iRow);
1555 }
1556 }
1557 _actDeleteMountPoints->setEnabled(false);
1558
1559 enableStartStop();
1560}
1561
1562// New Mount Points Selected
1563////////////////////////////////////////////////////////////////////////////
1564void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1565 int iRow = 0;
1566 QListIterator<QString> it(*mountPoints);
1567 while (it.hasNext()) {
1568 QStringList hlp = it.next().split(" ");
1569 QUrl url(hlp[0]);
1570 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1571 QString format(hlp[1]); QString country(hlp[2]); QString latitude(hlp[3]); QString longitude(hlp[4]);
1572 QString nmea(hlp[5]);
1573 if (hlp[6] == "S") {
1574 fullPath = hlp[0].replace(0,2,"");
1575 }
1576 QString ntripVersion = "2";
1577 if (hlp.size() >= 7) {
1578 ntripVersion = (hlp[6]);
1579 }
1580
1581 _mountPointsTable->insertRow(iRow);
1582
1583 QTableWidgetItem* it;
1584 it = new QTableWidgetItem(url.userInfo());
1585 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1586 _mountPointsTable->setItem(iRow, 0, it);
1587
1588 it = new QTableWidgetItem(fullPath);
1589 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1590 _mountPointsTable->setItem(iRow, 1, it);
1591
1592 it = new QTableWidgetItem(format);
1593 _mountPointsTable->setItem(iRow, 2, it);
1594
1595 it = new QTableWidgetItem(country);
1596 _mountPointsTable->setItem(iRow, 3, it);
1597
1598 if (nmea == "yes") {
1599 it = new QTableWidgetItem(latitude);
1600 _mountPointsTable->setItem(iRow, 4, it);
1601 it = new QTableWidgetItem(longitude);
1602 _mountPointsTable->setItem(iRow, 5, it);
1603 } else {
1604 it = new QTableWidgetItem(latitude);
1605 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1606 _mountPointsTable->setItem(iRow, 4, it);
1607 it = new QTableWidgetItem(longitude);
1608 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1609 _mountPointsTable->setItem(iRow, 5, it);
1610 }
1611
1612 it = new QTableWidgetItem(nmea);
1613 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1614 _mountPointsTable->setItem(iRow, 6, it);
1615
1616 it = new QTableWidgetItem(ntripVersion);
1617 ////it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1618 _mountPointsTable->setItem(iRow, 7, it);
1619
1620 bncTableItem* bncIt = new bncTableItem();
1621 _mountPointsTable->setItem(iRow, 8, bncIt);
1622
1623 iRow++;
1624 }
1625 _mountPointsTable->hideColumn(0);
1626 _mountPointsTable->hideColumn(3);
1627 _mountPointsTable->sortItems(1);
1628 delete mountPoints;
1629
1630 enableStartStop();
1631}
1632
1633// Save Options (serialize)
1634////////////////////////////////////////////////////////////////////////////
1635void bncWindow::slotSaveOptions() {
1636 saveOptions();
1637 bncSettings settings;
1638 settings.sync();
1639}
1640
1641// Save Options (memory only)
1642////////////////////////////////////////////////////////////////////////////
1643void bncWindow::saveOptions() {
1644
1645 QStringList mountPoints;
1646 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1647
1648 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1649 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1650 "@" + _mountPointsTable->item(iRow, 1)->text() );
1651
1652 mountPoints.append(url.toString() + " " +
1653 _mountPointsTable->item(iRow, 2)->text()
1654 + " " + _mountPointsTable->item(iRow, 3)->text()
1655 + " " + _mountPointsTable->item(iRow, 4)->text()
1656 + " " + _mountPointsTable->item(iRow, 5)->text()
1657 + " " + _mountPointsTable->item(iRow, 6)->text()
1658 + " " + _mountPointsTable->item(iRow, 7)->text());
1659 } else {
1660 mountPoints.append(
1661 "//" + _mountPointsTable->item(iRow, 1)->text()
1662 + " " + _mountPointsTable->item(iRow, 2)->text()
1663 + " " + _mountPointsTable->item(iRow, 3)->text()
1664 + " " + _mountPointsTable->item(iRow, 4)->text()
1665 + " " + _mountPointsTable->item(iRow, 5)->text()
1666 + " " + _mountPointsTable->item(iRow, 6)->text()
1667 + " " + _mountPointsTable->item(iRow, 7)->text());
1668 }
1669 }
1670
1671 QStringList cmbStreams;
1672 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1673 QString hlp;
1674 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1675 if (_cmbTable->item(iRow, iCol)) {
1676 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1677 }
1678 }
1679 if (!hlp.isEmpty()) {
1680 cmbStreams << hlp;
1681 }
1682 }
1683
1684 QStringList uploadMountpointsOut;
1685 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1686 QString hlp;
1687 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1688 if (_uploadTable->cellWidget(iRow, iCol) &&
1689 (iCol == 3 || iCol == 4 || iCol == 5)) {
1690 if (iCol == 3) {
1691 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1692 hlp += passwd->text() + ",";
1693 }
1694 else if (iCol == 4) {
1695 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1696 hlp += system->currentText() + ",";
1697 }
1698 else if (iCol == 5) {
1699 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1700 QString state; state.setNum(com->checkState());
1701 hlp += state + ",";
1702 }
1703 }
1704 else if (_uploadTable->item(iRow, iCol)) {
1705 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1706 }
1707 }
1708 if (!hlp.isEmpty()) {
1709 uploadMountpointsOut << hlp;
1710 }
1711 }
1712
1713 bncSettings settings;
1714
1715 settings.setValue("startTab", _aogroup->currentIndex());
1716 settings.setValue("statusTab", _loggroup->currentIndex());
1717 settings.setValue("mountPoints", mountPoints);
1718// Network
1719 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1720 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1721 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1722 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1723// General
1724 settings.setValue("logFile", _logFileLineEdit->text());
1725 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1726 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1727 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1728 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1729// RINEX Observations
1730 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1731 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1732 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1733 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1734 settings.setValue("rnxOnlyWithSKL",_rnxFileCheckBox->checkState());
1735 settings.setValue("rnxV3filenames",_rnxV3filenameCheckBox->checkState());
1736 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1737 (_rnxV3filenameCheckBox->checkState()) ?
1738 settings.setValue("rnxV3", _rnxV3filenameCheckBox->checkState()) :
1739 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1740 settings.setValue("rnxV2Priority",_rnxV2Priority->text());
1741// RINEX Ephemeris
1742 settings.setValue("ephPath", _ephPathLineEdit->text());
1743 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1744 settings.setValue("ephOutPort", _ephOutPortLineEdit->text());
1745 settings.setValue("ephV3filenames", _ephV3filenameCheckBox->checkState());
1746 (_ephV3filenameCheckBox->checkState()) ?
1747 settings.setValue("ephV3", _ephV3filenameCheckBox->checkState()) :
1748 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1749// Broadcast Corrections
1750 settings.setValue("corrPath", _corrPathLineEdit->text());
1751 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1752 settings.setValue("corrPort", _corrPortLineEdit->text());
1753// Feed Engine
1754 settings.setValue("outPort", _outPortLineEdit->text());
1755 settings.setValue("outWait", _outWaitSpinBox->value());
1756 settings.setValue("outSampl", _outSamplSpinBox->value());
1757 settings.setValue("outFile", _outFileLineEdit->text());
1758 settings.setValue("outUPort", _outUPortLineEdit->text());
1759// Serial Output
1760 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1761 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1762 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1763 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1764 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1765 settings.setValue("serialParity", _serialParityComboBox->currentText());
1766 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1767 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1768 settings.setValue("serialFileNMEA", _serialFileNMEALineEdit->text());
1769 settings.setValue("serialHeightNMEA", _serialHeightNMEALineEdit->text());
1770 settings.setValue("serialManualNMEASampling", _serialManualNMEASamplingSpinBox->value());
1771// Outages
1772 settings.setValue("adviseObsRate", _adviseObsRateComboBox->currentText());
1773 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1774 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1775 settings.setValue("adviseScript", _adviseScriptLineEdit->text());
1776// Miscellaneous
1777 settings.setValue("miscMount", _miscMountLineEdit->text());
1778 settings.setValue("miscPort", _miscPortLineEdit->text());
1779 settings.setValue("miscIntr", _miscIntrComboBox->currentText());
1780 settings.setValue("miscScanRTCM", _miscScanRTCMCheckBox->checkState());
1781// Reqc
1782 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1783 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1784 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1785 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1786 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1787 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
1788 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
1789 settings.setValue("reqcSkyPlotSignals", _reqcSkyPlotSignals->text());
1790 settings.setValue("reqcLogSummaryOnly", _reqcLogSummaryOnly->checkState());
1791// SP3 Comparison
1792 settings.setValue("sp3CompFile", _sp3CompFileChooser->fileName());
1793 settings.setValue("sp3CompExclude", _sp3CompExclude->text());
1794 settings.setValue("sp3CompOutLogFile", _sp3CompLogLineEdit->text());
1795// Combine Corrections
1796 if (!cmbStreams.isEmpty()) {
1797 settings.setValue("cmbStreams", cmbStreams);
1798 }
1799 else {
1800 settings.setValue("cmbStreams", "");
1801 }
1802 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1803 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1804 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1805 settings.setValue("cmbUseGlonass", _cmbUseGlonass->checkState());
1806// Upload Corrections
1807 if (!uploadMountpointsOut.isEmpty()) {
1808 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1809 }
1810 else {
1811 settings.setValue("uploadMountpointsOut", "");
1812 }
1813 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1814 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1815 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1816 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
1817 settings.setValue("uploadAntexFile", _uploadAntexFile->fileName());
1818// Upload Ephemeris
1819 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1820 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
1821 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
1822 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1823 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
1824
1825 if (_caster) {
1826 _caster->readMountPoints();
1827 }
1828
1829 _pppWidgets.saveOptions();
1830}
1831
1832// All get slots terminated
1833////////////////////////////////////////////////////////////////////////////
1834void bncWindow::slotGetThreadsFinished() {
1835 BNC_CORE->slotMessage("All Get Threads Terminated", true);
1836 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
1837 delete _casterEph; _casterEph = 0;
1838 _runningRealTime = false;
1839}
1840
1841// Start It!
1842////////////////////////////////////////////////////////////////////////////
1843void bncWindow::slotStart() {
1844 saveOptions();
1845 if ( _pppWidgets._dataSource->currentText() == "RINEX Files") {
1846 _runningPPP = true;
1847 enableStartStop();
1848 _caster = new bncCaster(); BNC_CORE->setCaster(_caster);
1849 BNC_CORE->startPPP();
1850 _bncFigurePPP->reset();
1851 }
1852 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
1853 if (_reqcActionComboBox->currentText() == "Analyze") {
1854 _runningQC = true;
1855 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
1856 connect(reqcAnalyze, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1857 reqcAnalyze->start();
1858 }
1859 else {
1860 _runningEdit = true;
1861 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
1862 connect(reqcEdit, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1863 reqcEdit->start();
1864 }
1865 enableStartStop();
1866 }
1867 else if (!_sp3CompFileChooser->fileName().isEmpty()) {
1868 _runningSp3Comp = true;
1869 t_sp3Comp* sp3Comp = new t_sp3Comp(this);
1870 connect(sp3Comp, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1871 sp3Comp->start();
1872 enableStartStop();
1873 }
1874 else {
1875 startRealTime();
1876 BNC_CORE->startPPP();
1877 }
1878}
1879
1880// Start Real-Time (Retrieve Data etc.)
1881////////////////////////////////////////////////////////////////////////////
1882void bncWindow::startRealTime() {
1883
1884 _runningRealTime = true;
1885
1886 _bncFigurePPP->reset();
1887
1888 _actDeleteMountPoints->setEnabled(false);
1889
1890 enableStartStop();
1891
1892 _caster = new bncCaster();
1893
1894 BNC_CORE->setCaster(_caster);
1895 BNC_CORE->setPortEph(_ephOutPortLineEdit->text().toInt());
1896 BNC_CORE->setPortCorr(_corrPortLineEdit->text().toInt());
1897 BNC_CORE->initCombination();
1898
1899 connect(_caster, SIGNAL(getThreadsFinished()),
1900 this, SLOT(slotGetThreadsFinished()));
1901
1902 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
1903 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
1904
1905 BNC_CORE->slotMessage("========== Start BNC v" BNCVERSION " ("BNC_OS") ==========", true);
1906
1907 bncSettings settings;
1908
1909 // Active panels
1910 // -------------
1911 if (!_rnxPathLineEdit->text().isEmpty())
1912 BNC_CORE->slotMessage("Panel 'RINEX Observations' active", true);
1913 if (!_ephPathLineEdit->text().isEmpty())
1914 BNC_CORE->slotMessage("Panel 'RINEX Ephemeris' active", true);
1915 if (!_corrPathLineEdit->text().isEmpty())
1916 BNC_CORE->slotMessage("Panel 'Broadcast Corrections' active", true);
1917 if (!_outPortLineEdit->text().isEmpty())
1918 BNC_CORE->slotMessage("Panel 'Feed Engine' active", true);
1919 if (!_serialMountPointLineEdit->text().isEmpty())
1920 BNC_CORE->slotMessage("Panel 'Serial Output' active", true);
1921 if (!_adviseObsRateComboBox->currentText().isEmpty())
1922 BNC_CORE->slotMessage("Panel 'Outages' active", true);
1923 if (!_miscMountLineEdit->text().isEmpty())
1924 BNC_CORE->slotMessage("Panel 'Miscellaneous' active", true);
1925 if (_pppWidgets._dataSource->currentText() == "Real-Time Streams")
1926 BNC_CORE->slotMessage("Panel 'PPP' active", true);
1927 if (_cmbTable->rowCount() > 0)
1928 BNC_CORE->slotMessage("Panel 'Combine Corrections' active", true);
1929 if (_uploadTable->rowCount() > 0)
1930 BNC_CORE->slotMessage("Panel 'Upload Corrections' active", true);
1931 if (!_uploadEphHostLineEdit->text().isEmpty())
1932 BNC_CORE->slotMessage("Panel 'UploadEphemeris' active", true);
1933
1934 QDir rnxdir(settings.value("rnxPath").toString());
1935 if (!rnxdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations directory", true);
1936
1937 QString rnx_file = settings.value("rnxScript").toString();
1938 if ( !rnx_file.isEmpty() ) {
1939 QFile rnxfile(settings.value("rnxScript").toString());
1940 if (!rnxfile.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations script", true);
1941 }
1942
1943 QDir ephdir(settings.value("ephPath").toString());
1944 if (!ephdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Ephemeris directory", true);
1945
1946 QDir corrdir(settings.value("corrPath").toString());
1947 if (!corrdir.exists()) BNC_CORE->slotMessage("Cannot find Broadcast Corrections directory", true);
1948
1949 QString advise_file = settings.value("adviseScript").toString();
1950 if ( !advise_file.isEmpty() ) {
1951 QFile advisefile(settings.value("adviseScript").toString());
1952 if (!advisefile.exists()) BNC_CORE->slotMessage("Cannot find Outages script", true);
1953 }
1954
1955 _caster->readMountPoints();
1956
1957 _casterEph = new bncEphUploadCaster();
1958 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
1959 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
1960}
1961
1962// Retrieve Data
1963////////////////////////////////////////////////////////////////////////////
1964void bncWindow::slotStop() {
1965 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving/processing data?",
1966 QMessageBox::Yes, QMessageBox::No,
1967 QMessageBox::NoButton);
1968 if (iRet == QMessageBox::Yes) {
1969 BNC_CORE->stopPPP();
1970 BNC_CORE->stopCombination();
1971 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
1972 delete _casterEph; _casterEph = 0;
1973 _runningRealTime = false;
1974 _runningPPP = false;
1975 enableStartStop();
1976 }
1977}
1978
1979// Close Application gracefully
1980////////////////////////////////////////////////////////////////////////////
1981void bncWindow::closeEvent(QCloseEvent* event) {
1982
1983 int iRet = QMessageBox::question(this, "Close", "Save Options?",
1984 QMessageBox::Yes, QMessageBox::No,
1985 QMessageBox::Cancel);
1986
1987 if (iRet == QMessageBox::Cancel) {
1988 event->ignore();
1989 return;
1990 }
1991 else if (iRet == QMessageBox::Yes) {
1992 slotSaveOptions();
1993 }
1994
1995 BNC_CORE->stopPPP();
1996
1997 QMainWindow::closeEvent(event);
1998}
1999
2000// User changed the selection of mountPoints
2001////////////////////////////////////////////////////////////////////////////
2002void bncWindow::slotSelectionChanged() {
2003 if (_mountPointsTable->selectedItems().isEmpty()) {
2004 _actDeleteMountPoints->setEnabled(false);
2005 }
2006 else {
2007 _actDeleteMountPoints->setEnabled(true);
2008 }
2009}
2010
2011// Display Program Messages
2012////////////////////////////////////////////////////////////////////////////
2013void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
2014 if (showOnScreen ) {
2015 _log->append(QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg);
2016 }
2017}
2018
2019// About Message
2020////////////////////////////////////////////////////////////////////////////
2021void bncWindow::slotAbout() {
2022 new bncAboutDlg(0);
2023}
2024
2025//Flowchart
2026////////////////////////////////////////////////////////////////////////////
2027void bncWindow::slotFlowchart() {
2028 new bncFlowchartDlg(0);
2029}
2030
2031// Help Window
2032////////////////////////////////////////////////////////////////////////////
2033void bncWindow::slotHelp() {
2034 QUrl url;
2035 url.setPath(":bnchelp.html");
2036 new bncHlpDlg(0, url);
2037}
2038
2039// Select Fonts
2040////////////////////////////////////////////////////////////////////////////
2041void bncWindow::slotFontSel() {
2042 bool ok;
2043 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
2044 if (ok) {
2045 bncSettings settings;
2046 settings.setValue("font", newFont.toString());
2047 QApplication::setFont(newFont);
2048 int ww = QFontMetrics(newFont).width('w');
2049 setMinimumSize(60*ww, 80*ww);
2050 resize(60*ww, 80*ww);
2051 }
2052}
2053
2054// Whats This Help
2055void bncWindow::slotWhatsThis() {
2056 QWhatsThis::enterWhatsThisMode();
2057}
2058
2059//
2060////////////////////////////////////////////////////////////////////////////
2061void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
2062 _threads = threads;
2063
2064 _bncFigure->updateMountPoints();
2065 _bncFigureLate->updateMountPoints();
2066
2067 populateMountPointsTable();
2068 bncSettings settings;
2069 _outSamplSpinBox->setValue(settings.value("outSampl").toInt());
2070 _outWaitSpinBox->setValue(settings.value("outWait").toInt());
2071 QListIterator<bncGetThread*> iTh(threads);
2072 while (iTh.hasNext()) {
2073 bncGetThread* thread = iTh.next();
2074 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
2075 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
2076 "@" + _mountPointsTable->item(iRow, 1)->text() );
2077 if (url == thread->mountPoint() &&
2078 _mountPointsTable->item(iRow, 4)->text() == thread->latitude() &&
2079 _mountPointsTable->item(iRow, 5)->text() == thread->longitude() ) {
2080 ((bncTableItem*) _mountPointsTable->item(iRow, 8))->setGetThread(thread);
2081 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
2082 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2083 connect(thread, SIGNAL(newBytes(QByteArray, double)),
2084 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2085 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
2086 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2087 connect(thread, SIGNAL(newLatency(QByteArray, double)),
2088 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2089 break;
2090 }
2091 }
2092 }
2093}
2094
2095//
2096////////////////////////////////////////////////////////////////////////////
2097void bncWindow::CreateMenu() {
2098 // Create Menus
2099 // ------------
2100 _menuFile = menuBar()->addMenu(tr("&File"));
2101 _menuFile->addAction(_actFontSel);
2102 _menuFile->addSeparator();
2103 _menuFile->addAction(_actSaveOpt);
2104 _menuFile->addSeparator();
2105 _menuFile->addAction(_actQuit);
2106
2107 _menuHlp = menuBar()->addMenu(tr("&Help"));
2108 _menuHlp->addAction(_actHelp);
2109 _menuHlp->addAction(_actFlowchart);
2110 _menuHlp->addAction(_actAbout);
2111}
2112
2113// Toolbar
2114////////////////////////////////////////////////////////////////////////////
2115void bncWindow::AddToolbar() {
2116 QToolBar* toolBar = new QToolBar;
2117 addToolBar(Qt::BottomToolBarArea, toolBar);
2118 toolBar->setMovable(false);
2119 toolBar->addAction(_actAddMountPoints);
2120 toolBar->addAction(_actDeleteMountPoints);
2121 toolBar->addAction(_actMapMountPoints);
2122 toolBar->addAction(_actStart);
2123 toolBar->addAction(_actStop);
2124 toolBar->addWidget(new QLabel(" "));
2125 toolBar->addAction(_actwhatsthis);
2126}
2127
2128// About
2129////////////////////////////////////////////////////////////////////////////
2130bncAboutDlg::bncAboutDlg(QWidget* parent) :
2131 QDialog(parent) {
2132
2133 QTextBrowser* tb = new QTextBrowser;
2134 QUrl url; url.setPath(":bncabout.html");
2135 tb->setSource(url);
2136 tb->setReadOnly(true);
2137
2138 int ww = QFontMetrics(font()).width('w');
2139 QPushButton* _closeButton = new QPushButton("Close");
2140 _closeButton->setMaximumWidth(10*ww);
2141 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2142
2143 QGridLayout* dlgLayout = new QGridLayout();
2144 QLabel* img = new QLabel();
2145 img->setPixmap(QPixmap(":ntrip-logo.png"));
2146 dlgLayout->addWidget(img, 0,0);
2147 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
2148 dlgLayout->addWidget(tb,1,0,1,2);
2149 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2150
2151 setLayout(dlgLayout);
2152 resize(60*ww, 60*ww);
2153 setWindowTitle("About BNC");
2154 show();
2155}
2156
2157//
2158////////////////////////////////////////////////////////////////////////////
2159bncAboutDlg::~bncAboutDlg() {
2160};
2161
2162// Flowchart
2163////////////////////////////////////////////////////////////////////////////
2164bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2165 QDialog(parent) {
2166
2167 int ww = QFontMetrics(font()).width('w');
2168 QPushButton* _closeButton = new QPushButton("Close");
2169 _closeButton->setMaximumWidth(10*ww);
2170 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2171
2172 QGridLayout* dlgLayout = new QGridLayout();
2173 QLabel* img = new QLabel();
2174 img->setPixmap(QPixmap(":bncflowchart.png"));
2175 dlgLayout->addWidget(img, 0,0);
2176 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2177
2178 setLayout(dlgLayout);
2179 setWindowTitle("Flow Chart");
2180 show();
2181}
2182
2183//
2184////////////////////////////////////////////////////////////////////////////
2185bncFlowchartDlg::~bncFlowchartDlg() {
2186};
2187
2188// Enable/Disable Widget (and change its color)
2189////////////////////////////////////////////////////////////////////////////
2190void bncWindow::enableWidget(bool enable, QWidget* widget) {
2191
2192 const static QPalette paletteWhite(QColor(255, 255, 255));
2193 const static QPalette paletteGray(QColor(230, 230, 230));
2194
2195 widget->setEnabled(enable);
2196 if (enable) {
2197 widget->setPalette(paletteWhite);
2198 }
2199 else {
2200 widget->setPalette(paletteGray);
2201 }
2202}
2203
2204// Bnc Text
2205////////////////////////////////////////////////////////////////////////////
2206void bncWindow::slotBncTextChanged(){
2207
2208 const static QPalette paletteWhite(QColor(255, 255, 255));
2209 const static QPalette paletteGray(QColor(230, 230, 230));
2210
2211 bool enable = true;
2212
2213 // Proxy
2214 //------
2215 if (sender() == 0 || sender() == _proxyHostLineEdit) {
2216 enable = !_proxyHostLineEdit->text().isEmpty();
2217 enableWidget(enable, _proxyPortLineEdit);
2218 }
2219
2220 // RINEX Observations
2221 // ------------------
2222 if (sender() == 0 || sender() == _rnxPathLineEdit) {
2223 enable = !_rnxPathLineEdit->text().isEmpty();
2224 enableWidget(enable, _rnxIntrComboBox);
2225 enableWidget(enable, _rnxSamplSpinBox);
2226 enableWidget(enable, _rnxSkelLineEdit);
2227 enableWidget(enable, _rnxFileCheckBox);
2228 enableWidget(enable, _rnxScrpLineEdit);
2229 enableWidget(enable, _rnxV2Priority);
2230 enableWidget(enable, _rnxV3CheckBox);
2231
2232 bool enable1 = true;
2233 enable1 = _rnxV3CheckBox->isChecked();
2234 if (enable && enable1) {
2235 enableWidget(false, _rnxV2Priority);
2236 }
2237 if (enable && !enable1) {
2238 enableWidget(true, _rnxV2Priority);
2239 }
2240 }
2241
2242 // RINEX Observations, Signal Priority
2243 // -----------------------------------
2244 if (sender() == 0 || sender() == _rnxV3CheckBox) {
2245 if (!_rnxPathLineEdit->text().isEmpty()) {
2246 enableWidget(enable, _rnxIntrComboBox);
2247 enable = !_rnxV3CheckBox->isChecked();
2248 enableWidget(enable, _rnxV2Priority);
2249 }
2250 }
2251
2252 // RINEX Ephemeris
2253 // ---------------
2254 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _ephOutPortLineEdit) {
2255 enable = !_ephPathLineEdit->text().isEmpty() || !_ephOutPortLineEdit->text().isEmpty();
2256 enableWidget(enable, _ephIntrComboBox);
2257 enableWidget(enable, _ephV3CheckBox);
2258 enableWidget(enable, _ephV3filenameCheckBox);
2259 }
2260
2261 // Broadcast Corrections
2262 // ---------------------
2263 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2264 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2265 enableWidget(enable, _corrIntrComboBox);
2266 }
2267
2268 // Feed Engine
2269 // -----------
2270 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2271 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2272 enableWidget(enable, _outWaitSpinBox);
2273 enableWidget(enable, _outSamplSpinBox);
2274 }
2275
2276 // Serial Output
2277 // -------------
2278 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
2279 sender() == _serialAutoNMEAComboBox) {
2280 enable = !_serialMountPointLineEdit->text().isEmpty();
2281 enableWidget(enable, _serialPortNameLineEdit);
2282 enableWidget(enable, _serialBaudRateComboBox);
2283 enableWidget(enable, _serialParityComboBox);
2284 enableWidget(enable, _serialDataBitsComboBox);
2285 enableWidget(enable, _serialStopBitsComboBox);
2286 enableWidget(enable, _serialFlowControlComboBox);
2287 enableWidget(enable, _serialAutoNMEAComboBox);
2288 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() == "Auto";
2289 enableWidget(enable2, _serialFileNMEALineEdit);
2290 bool enable3 = enable && _serialAutoNMEAComboBox->currentText().contains("Manual");
2291 enableWidget(enable3, _serialHeightNMEALineEdit);
2292 enableWidget(enable3, _serialManualNMEASamplingSpinBox);
2293 }
2294
2295 // Outages
2296 // -------
2297 if (sender() == 0 || sender() == _adviseObsRateComboBox) {
2298 enable = !_adviseObsRateComboBox->currentText().isEmpty();
2299 enableWidget(enable, _adviseFailSpinBox);
2300 enableWidget(enable, _adviseRecoSpinBox);
2301 enableWidget(enable, _adviseScriptLineEdit);
2302 }
2303
2304 // Miscellaneous
2305 // -------------
2306 if (sender() == 0 || sender() == _miscMountLineEdit) {
2307 enable = !_miscMountLineEdit->text().isEmpty();
2308 enableWidget(enable, _miscIntrComboBox);
2309 enableWidget(enable, _miscScanRTCMCheckBox);
2310 enableWidget(enable, _miscPortLineEdit);
2311 }
2312
2313 // Enable/disable Broadcast Ephemerides
2314 // ------------------------------------
2315 if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2316 enable = !_uploadEphHostLineEdit->text().isEmpty();
2317 enableWidget(enable, _uploadEphPortLineEdit);
2318 enableWidget(enable, _uploadEphMountpointLineEdit);
2319 enableWidget(enable, _uploadEphPasswordLineEdit);
2320 enableWidget(enable, _uploadEphSampleSpinBox);
2321 }
2322
2323 // Combine Corrections
2324 // -------------------
2325 if (sender() == 0 || sender() == _cmbTable) {
2326 int iRow = _cmbTable->rowCount();
2327 if (iRow > 0) {
2328 enableWidget(true, _cmbMethodComboBox);
2329 enableWidget(true, _cmbMaxresLineEdit);
2330 enableWidget(true, _cmbSamplSpinBox);
2331 enableWidget(true, _cmbUseGlonass);
2332 }
2333 else {
2334 enableWidget(false, _cmbMethodComboBox);
2335 enableWidget(false, _cmbMaxresLineEdit);
2336 enableWidget(false, _cmbSamplSpinBox);
2337 enableWidget(false, _cmbUseGlonass);
2338 }
2339 }
2340
2341 // Upload(clk)
2342 // -----------
2343 int iRow = _uploadTable->rowCount();
2344 if (iRow > 0) {
2345 enableWidget(true, _uploadIntrComboBox);
2346 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2347 enableWidget(true, _uploadSamplClkRnxSpinBox);
2348 enableWidget(true, _uploadSamplSp3SpinBox);
2349 enableWidget(true, _uploadAntexFile);
2350 }
2351 else {
2352 enableWidget(false, _uploadIntrComboBox);
2353 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2354 enableWidget(false, _uploadSamplClkRnxSpinBox);
2355 enableWidget(false, _uploadSamplSp3SpinBox);
2356 enableWidget(false, _uploadAntexFile);
2357 }
2358
2359 // QC
2360 // --
2361 if (sender() == 0 || sender() == _reqcActionComboBox || sender() == _reqcSkyPlotSignals) {
2362 enable = !_reqcActionComboBox->currentText().isEmpty();
2363 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2364// bool enablePlot = !_reqcSkyPlotSignals->text().isEmpty();
2365 enableWidget(enable, _reqcObsFileChooser);
2366 enableWidget(enable, _reqcNavFileChooser);
2367 enableWidget(enable, _reqcOutLogLineEdit);
2368 enableWidget(enable && enable10, _reqcEditOptionButton);
2369 enableWidget(enable && enable10, _reqcOutObsLineEdit);
2370 enableWidget(enable && enable10, _reqcOutNavLineEdit);
2371 enableWidget(enable && !enable10, _reqcLogSummaryOnly);
2372 enableWidget(enable && !enable10, _reqcSkyPlotSignals);
2373// enableWidget(enable && !enable10 && enablePlot, _reqcPlotDirLineEdit);
2374 enableWidget(enable && !enable10, _reqcPlotDirLineEdit);
2375 }
2376
2377 // SP3 File Comparison
2378 // -------------------
2379 if (sender() == 0 || sender() == _sp3CompFileChooser) {
2380 enable = !_sp3CompFileChooser->fileName().isEmpty();
2381 enableWidget(enable, _sp3CompLogLineEdit);
2382 enableWidget(enable, _sp3CompExclude);
2383 }
2384
2385 enableStartStop();
2386}
2387
2388//
2389////////////////////////////////////////////////////////////////////////////
2390void bncWindow::slotAddCmbRow() {
2391 int iRow = _cmbTable->rowCount();
2392 _cmbTable->insertRow(iRow);
2393 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2394 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2395 }
2396}
2397
2398//
2399////////////////////////////////////////////////////////////////////////////
2400void bncWindow::slotDelCmbRow() {
2401
2402 const static QPalette paletteWhite(QColor(255, 255, 255));
2403 const static QPalette paletteGray(QColor(230, 230, 230));
2404
2405 int nRows = _cmbTable->rowCount();
2406 bool flg[nRows];
2407 for (int iRow = 0; iRow < nRows; iRow++) {
2408 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2409 flg[iRow] = true;
2410 }
2411 else {
2412 flg[iRow] = false;
2413 }
2414 }
2415 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2416 if (flg[iRow]) {
2417 _cmbTable->removeRow(iRow);
2418 }
2419 }
2420 nRows = _cmbTable->rowCount();
2421 if (nRows < 1) {
2422 enableWidget(false, _cmbMethodComboBox);
2423 enableWidget(false, _cmbMaxresLineEdit);
2424 enableWidget(false, _cmbSamplSpinBox);
2425 enableWidget(false, _cmbUseGlonass);
2426 }
2427}
2428
2429//
2430////////////////////////////////////////////////////////////////////////////
2431void bncWindow::populateCmbTable() {
2432
2433 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2434 _cmbTable->removeRow(iRow);
2435 }
2436
2437 bncSettings settings;
2438
2439 int iRow = -1;
2440 QListIterator<QString> it(settings.value("cmbStreams").toStringList());
2441 while (it.hasNext()) {
2442 QStringList hlp = it.next().split(" ");
2443 if (hlp.size() > 2) {
2444 ++iRow;
2445 _cmbTable->insertRow(iRow);
2446 }
2447 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2448 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2449 }
2450 }
2451}
2452
2453//
2454////////////////////////////////////////////////////////////////////////////
2455void bncWindow::slotAddUploadRow() {
2456 int iRow = _uploadTable->rowCount();
2457 _uploadTable->insertRow(iRow);
2458 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2459 if (iCol == 3) {
2460 QLineEdit* passwd = new QLineEdit();
2461 passwd->setFrame(false);
2462 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2463 _uploadTable->setCellWidget(iRow, iCol, passwd);
2464 }
2465 else if (iCol == 4) {
2466 QComboBox* system = new QComboBox();
2467 system->setEditable(false);
2468 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2469 system->setFrame(false);
2470 _uploadTable->setCellWidget(iRow, iCol, system);
2471 }
2472 else if (iCol == 5) {
2473 QCheckBox* com = new QCheckBox();
2474 _uploadTable->setCellWidget(iRow, iCol, com);
2475 }
2476 else if (iCol == 11) {
2477 bncTableItem* bncIt = new bncTableItem();
2478 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2479 _uploadTable->setItem(iRow, iCol, bncIt);
2480 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2481 }
2482 else {
2483 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2484 }
2485 }
2486}
2487
2488//
2489////////////////////////////////////////////////////////////////////////////
2490void bncWindow::slotDelUploadRow() {
2491 BNC_CORE->_uploadTableItems.clear();
2492 int nRows = _uploadTable->rowCount();
2493 bool flg[nRows];
2494 for (int iRow = 0; iRow < nRows; iRow++) {
2495 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2496 flg[iRow] = true;
2497 }
2498 else {
2499 flg[iRow] = false;
2500 }
2501 }
2502 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2503 if (flg[iRow]) {
2504 _uploadTable->removeRow(iRow);
2505 }
2506 }
2507 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2508 BNC_CORE->_uploadTableItems[iRow] =
2509 (bncTableItem*) _uploadTable->item(iRow, 11);
2510 }
2511 nRows = _uploadTable->rowCount();
2512 if (nRows < 1) {
2513 enableWidget(false, _uploadIntrComboBox);
2514 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2515 enableWidget(false, _uploadSamplSp3SpinBox);
2516 enableWidget(false, _uploadSamplClkRnxSpinBox);
2517 enableWidget(false, _uploadAntexFile);
2518 }
2519}
2520
2521//
2522////////////////////////////////////////////////////////////////////////////
2523void bncWindow::populateUploadTable() {
2524 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2525 _uploadTable->removeRow(iRow);
2526 }
2527
2528 bncSettings settings;
2529
2530 int iRow = -1;
2531 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2532 while (it.hasNext()) {
2533 QStringList hlp = it.next().split(",");
2534 if (hlp.size() > 6) {
2535 ++iRow;
2536 _uploadTable->insertRow(iRow);
2537 }
2538 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2539 if (iCol == 3) {
2540 QLineEdit* passwd = new QLineEdit();
2541 passwd->setFrame(false);
2542 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2543 passwd->setText(hlp[iCol]);
2544 _uploadTable->setCellWidget(iRow, iCol, passwd);
2545 }
2546 else if (iCol == 4) {
2547 QComboBox* system = new QComboBox();
2548 system->setEditable(false);
2549 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2550 system->setFrame(false);
2551 system->setCurrentIndex(system->findText(hlp[iCol]));
2552 _uploadTable->setCellWidget(iRow, iCol, system);
2553 }
2554 else if (iCol == 5) {
2555 QCheckBox* com = new QCheckBox();
2556 if (hlp[iCol].toInt() == Qt::Checked) {
2557 com->setCheckState(Qt::Checked);
2558 }
2559 _uploadTable->setCellWidget(iRow, iCol, com);
2560 }
2561 else if (iCol == 11) {
2562 bncTableItem* bncIt = new bncTableItem();
2563 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2564 _uploadTable->setItem(iRow, iCol, bncIt);
2565 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2566 }
2567 else {
2568 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2569 }
2570 }
2571 }
2572}
2573
2574//
2575////////////////////////////////////////////////////////////////////////////
2576void bncWindow::slotSetUploadTrafo() {
2577 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2578 dlg->exec();
2579 delete dlg;
2580}
2581
2582// Progress Bar Change
2583////////////////////////////////////////////////////////////////////////////
2584void bncWindow::slotPostProcessingProgress(int nEpo) {
2585 _actStart->setText(QString("%1 Epochs").arg(nEpo));
2586}
2587
2588// Post-Processing Reqc Finished
2589////////////////////////////////////////////////////////////////////////////
2590void bncWindow::slotPostProcessingFinished() {
2591 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
2592 _runningPPP = false;
2593 _runningEdit = false;
2594 _runningQC = false;
2595 _runningSp3Comp = false;
2596 _actStart->setText(tr("Sta&rt"));
2597 enableStartStop();
2598}
2599
2600// Edit teqc-like editing options
2601////////////////////////////////////////////////////////////////////////////
2602void bncWindow::slotReqcEditOption() {
2603 saveOptions();
2604 reqcDlg* dlg = new reqcDlg(this);
2605 dlg->move(this->pos().x()+50, this->pos().y()+50);
2606 dlg->exec();
2607 delete dlg;
2608}
2609
2610// Enable/Disable Start and Stop Buttons
2611////////////////////////////////////////////////////////////////////////////
2612void bncWindow::enableStartStop() {
2613 if ( running() ) {
2614 _actStart->setEnabled(false);
2615 if (_runningRealTime || _runningPPP) {
2616 _actStop->setEnabled(true);
2617 }
2618 }
2619 else {
2620 _actStart->setEnabled(true);
2621 _actStop->setEnabled(false);
2622 }
2623}
2624
2625// Show Map
2626////////////////////////////////////////////////////////////////////////////
2627void bncWindow::slotMapMountPoints() {
2628 saveOptions();
2629 t_bncMap* bncMap = new t_bncMap(this);
2630 bncMap->setMinimumSize(800, 600);
2631 bncMap->setWindowTitle("Selected Mountpoints");
2632
2633 bncSettings settings;
2634 QListIterator<QString> it(settings.value("mountPoints").toStringList());
2635 while (it.hasNext()) {
2636 QStringList hlp = it.next().split(" ");
2637 if (hlp.size() < 5) continue;
2638 QUrl url(hlp[0]);
2639 double latDeg = hlp[2].toDouble();
2640 double lonDeg = hlp[3].toDouble();
2641 bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
2642 }
2643
2644 bncMap->show();
2645}
2646
2647// Show Map
2648////////////////////////////////////////////////////////////////////////////
2649void bncWindow::slotMapPPP() {
2650#ifdef QT_WEBKIT
2651 saveOptions();
2652 enableWidget(false, _pppWidgets._mapWinButton);
2653 enableWidget(false, _pppWidgets._useGoogleMap);
2654 enableWidget(false, _pppWidgets._useOpenStreetMap);
2655 enableWidget(false, _pppWidgets._mapWinDotSize);
2656 enableWidget(false, _pppWidgets._mapWinDotColor);
2657
2658 if (!_mapWin) {
2659 _mapWin = new bncMapWin(this);
2660 connect(_mapWin, SIGNAL(mapClosed()), this, SLOT(slotMapPPPClosed()));
2661 connect(BNC_CORE, SIGNAL(newPosition(QByteArray, bncTime, QVector<double>)),
2662 _mapWin, SLOT(slotNewPosition(QByteArray, bncTime, QVector<double>)));
2663 }
2664 _mapWin->show();
2665#else
2666 QMessageBox::information(this, "Information",
2667 "Qt Library compiled without QtWebKit");
2668#endif
2669}
2670
2671// Show Map
2672////////////////////////////////////////////////////////////////////////////
2673void bncWindow::slotMapPPPClosed() {
2674#ifdef QT_WEBKIT
2675 enableWidget(true, _pppWidgets._mapWinButton);
2676 enableWidget(true, _pppWidgets._useGoogleMap);
2677 enableWidget(true, _pppWidgets._useOpenStreetMap);
2678 enableWidget(true, _pppWidgets._mapWinDotSize);
2679 enableWidget(true, _pppWidgets._mapWinDotColor);
2680 if (_mapWin) {
2681 QListIterator<bncGetThread*> it(_threads);
2682 while (it.hasNext()) {
2683 bncGetThread* thread = it.next();
2684 thread->disconnect(_mapWin);
2685 }
2686 _mapWin->deleteLater();
2687 _mapWin = 0;
2688 }
2689#endif
2690}
Note: See TracBrowser for help on using the repository browser.