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

Last change on this file since 7297 was 7297, checked in by stuerze, 9 years ago

some re-naming

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 _outEphPortLineEdit = new QLineEdit(settings.value("outEphPort").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(_outEphPortLineEdit, 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 _waitTimeSpinBox = new QSpinBox();
279 _waitTimeSpinBox->setMinimum(1);
280 _waitTimeSpinBox->setMaximum(30);
281 _waitTimeSpinBox->setSingleStep(1);
282 _waitTimeSpinBox->setSuffix(" sec");
283 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
284 _binSamplSpinBox = new QSpinBox();
285 _binSamplSpinBox->setMinimum(0);
286 _binSamplSpinBox->setMaximum(60);
287 _binSamplSpinBox->setSingleStep(5);
288 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
289 _binSamplSpinBox->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 _obsRateComboBox = new QComboBox();
359 _obsRateComboBox->setEditable(false);
360 _obsRateComboBox->addItems(QString(",0.1 Hz,0.2 Hz,0.5 Hz,1 Hz,5 Hz").split(","));
361 kk = _obsRateComboBox->findText(settings.value("obsRate").toString());
362 if (kk != -1) {
363 _obsRateComboBox->setCurrentIndex(kk);
364 }
365 _adviseFailSpinBox = new QSpinBox();
366 _adviseFailSpinBox->setMinimum(0);
367 _adviseFailSpinBox->setMaximum(60);
368 _adviseFailSpinBox->setSingleStep(1);
369 _adviseFailSpinBox->setSuffix(" min");
370 _adviseFailSpinBox->setValue(settings.value("adviseFail").toInt());
371 _adviseRecoSpinBox = new QSpinBox();
372 _adviseRecoSpinBox->setMinimum(0);
373 _adviseRecoSpinBox->setMaximum(60);
374 _adviseRecoSpinBox->setSingleStep(1);
375 _adviseRecoSpinBox->setSuffix(" min");
376 _adviseRecoSpinBox->setValue(settings.value("adviseReco").toInt());
377 _adviseScriptLineEdit = new QLineEdit(settings.value("adviseScript").toString());
378
379 connect(_obsRateComboBox, SIGNAL(currentIndexChanged(const QString &)),
380 this, SLOT(slotBncTextChanged()));
381
382 // Miscellaneous Options
383 // ---------------------
384 _miscMountLineEdit = new QLineEdit(settings.value("miscMount").toString());
385 _miscPortLineEdit = new QLineEdit(settings.value("miscPort").toString());
386 _perfIntrComboBox = new QComboBox();
387 _perfIntrComboBox->setEditable(false);
388 _perfIntrComboBox->addItems(QString(",2 sec, 10 sec,1 min,5 min,15 min,1 hour,6 hours,1 day").split(","));
389 int ll = _perfIntrComboBox->findText(settings.value("perfIntr").toString());
390 if (ll != -1) {
391 _perfIntrComboBox->setCurrentIndex(ll);
392 }
393 _scanRTCMCheckBox = new QCheckBox();
394 _scanRTCMCheckBox->setCheckState(Qt::CheckState(
395 settings.value("scanRTCM").toInt()));
396
397 connect(_miscMountLineEdit, SIGNAL(textChanged(const QString &)),
398 this, SLOT(slotBncTextChanged()));
399
400 // 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
622#ifdef USE_COMBINATION
623 _aogroup->addTab(cmbgroup,tr("Combine Corrections"));
624#endif
625 _aogroup->addTab(uploadgroup,tr("Upload Corrections"));
626 _aogroup->addTab(uploadEphgroup,tr("Upload Ephemeris"));
627
628 // Log Tab
629 // -------
630 _loggroup = new QTabWidget();
631 _loggroup->addTab(_log,tr("Log"));
632 _loggroup->addTab(_bncFigure,tr("Throughput"));
633 _loggroup->addTab(_bncFigureLate,tr("Latency"));
634 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
635
636 // Netowork (Proxy and SSL) Tab
637 // ----------------------------
638 QGridLayout* pLayout = new QGridLayout;
639 pLayout->setColumnMinimumWidth(0,13*ww);
640 _proxyPortLineEdit->setMaximumWidth(9*ww);
641
642 pLayout->addWidget(new QLabel("Settings for proxy in protected networks and for SSL authorization, leave boxes blank if none.<br>"),0, 0, 1, 50);
643 pLayout->addWidget(new QLabel("Proxy host"), 1, 0);
644 pLayout->addWidget(_proxyHostLineEdit, 1, 1, 1,10);
645 pLayout->addWidget(new QLabel("Proxy port"), 2, 0);
646 pLayout->addWidget(_proxyPortLineEdit, 2, 1);
647 pLayout->addWidget(new QLabel("Path to SSL certificates"), 3, 0);
648 pLayout->addWidget(_sslCaCertPathLineEdit, 3, 1, 1,10);
649 pLayout->addWidget(new QLabel("Default: " + bncSslConfig::defaultPath()), 3,11, 1,20);
650 pLayout->addWidget(new QLabel("Ignore SSL authorization errors"), 4, 0);
651 pLayout->addWidget(_ignoreSslErrorsCheckBox, 4, 1, 1,10);
652 pLayout->addWidget(new QLabel(""), 5, 1);
653 pLayout->setRowStretch(6, 999);
654
655 pgroup->setLayout(pLayout);
656
657 // General Tab
658 // -----------
659 QGridLayout* gLayout = new QGridLayout;
660 gLayout->setColumnMinimumWidth(0,14*ww);
661 _onTheFlyComboBox->setMaximumWidth(9*ww);
662
663 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);
664 gLayout->addWidget(new QLabel("Logfile (full path)"), 1, 0);
665 gLayout->addWidget(_logFileLineEdit, 1, 1, 1,20);
666 gLayout->addWidget(new QLabel("Append files"), 2, 0);
667 gLayout->addWidget(_rnxAppendCheckBox, 2, 1);
668 gLayout->addWidget(new QLabel("Reread configuration"), 3, 0);
669 gLayout->addWidget(_onTheFlyComboBox, 3, 1);
670 gLayout->addWidget(new QLabel("Auto start"), 4, 0);
671 gLayout->addWidget(_autoStartCheckBox, 4, 1);
672 gLayout->addWidget(new QLabel("Raw output file (full path)"), 5, 0);
673 gLayout->addWidget(_rawOutFileLineEdit, 5, 1, 1,20);
674 gLayout->addWidget(new QLabel(""), 6, 1);
675 gLayout->setRowStretch(7, 999);
676
677 ggroup->setLayout(gLayout);
678
679 // RINEX Observations
680 // ------------------
681 QGridLayout* oLayout = new QGridLayout;
682 oLayout->setColumnMinimumWidth(0,14*ww);
683 _rnxIntrComboBox->setMaximumWidth(9*ww);
684 _rnxSamplSpinBox->setMaximumWidth(9*ww);
685
686 _rnxV2Priority->setMaximumWidth(19*ww);
687
688 oLayout->addWidget(new QLabel("Saving RINEX observation files.<br>"),0, 0, 1,50);
689 oLayout->addWidget(new QLabel("Directory"), 1, 0);
690 oLayout->addWidget(_rnxPathLineEdit, 1, 1, 1, 15);
691 oLayout->addWidget(new QLabel("Interval"), 2, 0);
692 oLayout->addWidget(_rnxIntrComboBox, 2, 1);
693 oLayout->addWidget(new QLabel(" Sampling"), 2, 2, Qt::AlignRight);
694 oLayout->addWidget(_rnxSamplSpinBox, 2, 3, Qt::AlignLeft);
695 oLayout->addWidget(new QLabel("Skeleton extension"), 3, 0);
696 oLayout->addWidget(_rnxSkelLineEdit, 3, 1, Qt::AlignLeft);
697 oLayout->addWidget(new QLabel("Skeleton mandatory"), 3, 2);
698 oLayout->addWidget(_rnxFileCheckBox, 3, 3);
699 oLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
700 oLayout->addWidget(_rnxScrpLineEdit, 4, 1, 1, 15);
701 oLayout->addWidget(new QLabel("Version 2"), 5, 0);
702 oLayout->addWidget(_rnxV2Priority, 5, 1);
703 oLayout->addWidget(new QLabel("Signal priority"), 5, 2);
704 oLayout->addWidget(new QLabel("Version 3"), 6, 0);
705 oLayout->addWidget(_rnxV3CheckBox, 6, 1);
706 oLayout->addWidget(new QLabel("Version 3 filenames"), 6, 2);
707 oLayout->addWidget(_rnxV3filenameCheckBox, 6, 3);
708 oLayout->addWidget(new QLabel(""), 7, 1);
709 oLayout->setRowStretch(8, 999);
710
711 ogroup->setLayout(oLayout);
712
713 // RINEX Ephemeris
714 // ---------------
715 QGridLayout* eLayout = new QGridLayout;
716 eLayout->setColumnMinimumWidth(0,14*ww);
717 _ephIntrComboBox->setMaximumWidth(9*ww);
718 _outEphPortLineEdit->setMaximumWidth(9*ww);
719
720 eLayout->addWidget(new QLabel("Saving RINEX navigation files and ephemeris output through IP port.<br>"),0,0,1,70);
721 eLayout->addWidget(new QLabel("Directory"), 1, 0);
722 eLayout->addWidget(_ephPathLineEdit, 1, 1, 1,30);
723 eLayout->addWidget(new QLabel("Interval"), 2, 0);
724 eLayout->addWidget(_ephIntrComboBox, 2, 1);
725 eLayout->addWidget(new QLabel("Port"), 3, 0);
726 eLayout->addWidget(_outEphPortLineEdit, 3, 1);
727 eLayout->addWidget(new QLabel("Version 3"), 4, 0);
728 eLayout->addWidget(_ephV3CheckBox, 4, 1);
729 eLayout->addWidget(new QLabel("Version 3 filenames"), 4, 2);
730 eLayout->addWidget(_ephV3filenameCheckBox, 4, 3);
731 eLayout->setRowStretch(5, 999);
732
733 egroup->setLayout(eLayout);
734
735
736 // Broadcast Corrections
737 // ---------------------
738 QGridLayout* cLayout = new QGridLayout;
739 cLayout->setColumnMinimumWidth(0,14*ww);
740 _corrIntrComboBox->setMaximumWidth(9*ww);
741 _corrPortLineEdit->setMaximumWidth(9*ww);
742
743 cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port.<br>"),0,0,1,70);
744 cLayout->addWidget(new QLabel("Directory, ASCII"), 1, 0);
745 cLayout->addWidget(_corrPathLineEdit, 1, 1, 1,30);
746 cLayout->addWidget(new QLabel("Interval"), 2, 0);
747 cLayout->addWidget(_corrIntrComboBox, 2, 1);
748 cLayout->addWidget(new QLabel("Port"), 3, 0);
749 cLayout->addWidget(_corrPortLineEdit, 3, 1);
750 cLayout->addWidget(new QLabel(""), 4, 1);
751 cLayout->setRowStretch(7, 999);
752 cgroup->setLayout(cLayout);
753
754 // Feed Engine
755 // -----------
756 QGridLayout* sLayout = new QGridLayout;
757 sLayout->setColumnMinimumWidth(0,14*ww);
758 _outPortLineEdit->setMaximumWidth(9*ww);
759 _waitTimeSpinBox->setMaximumWidth(9*ww);
760 _binSamplSpinBox->setMaximumWidth(9*ww);
761 _outUPortLineEdit->setMaximumWidth(9*ww);
762
763 sLayout->addWidget(new QLabel("Output decoded observations in ASCII format to feed a real-time GNSS network engine.<br>"),0,0,1,50);
764 sLayout->addWidget(new QLabel("Port"), 1, 0);
765 sLayout->addWidget(_outPortLineEdit, 1, 1);
766 sLayout->addWidget(new QLabel(" Wait for full obs epoch"), 1, 2, Qt::AlignRight);
767 sLayout->addWidget(_waitTimeSpinBox, 1, 3, Qt::AlignLeft);
768 sLayout->addWidget(new QLabel("Sampling"), 2, 0);
769 sLayout->addWidget(_binSamplSpinBox, 2, 1, Qt::AlignLeft);
770 sLayout->addWidget(new QLabel("File (full path)"), 3, 0);
771 sLayout->addWidget(_outFileLineEdit, 3, 1, 1, 10);
772 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 4, 0);
773 sLayout->addWidget(_outUPortLineEdit, 4, 1);
774 sLayout->addWidget(new QLabel(""), 5, 1);
775 sLayout->setRowStretch(6, 999);
776
777 sgroup->setLayout(sLayout);
778
779 // Serial Output
780 // -------------
781 QGridLayout* serLayout = new QGridLayout;
782 serLayout->setColumnMinimumWidth(0,12*ww);
783 _serialBaudRateComboBox->setMaximumWidth(9*ww);
784 _serialFlowControlComboBox->setMaximumWidth(11*ww);
785 _serialDataBitsComboBox->setMaximumWidth(5*ww);
786 _serialParityComboBox->setMaximumWidth(9*ww);
787 _serialStopBitsComboBox->setMaximumWidth(5*ww);
788 _serialAutoNMEAComboBox->setMaximumWidth(14*ww);
789 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
790 _serialManualNMEASamplingSpinBox->setMaximumWidth(8*ww);
791
792 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver.<br>"),0,0,1,30);
793 serLayout->addWidget(new QLabel("Mountpoint"), 1, 0, Qt::AlignLeft);
794 serLayout->addWidget(_serialMountPointLineEdit, 1, 1, 1, 2);
795 serLayout->addWidget(new QLabel("Port name"), 2, 0, Qt::AlignLeft);
796 serLayout->addWidget(_serialPortNameLineEdit, 2, 1, 1, 2);
797 serLayout->addWidget(new QLabel("Baud rate"), 3, 0, Qt::AlignLeft);
798 serLayout->addWidget(_serialBaudRateComboBox, 3, 1);
799 serLayout->addWidget(new QLabel("Flow control"), 3, 2, Qt::AlignRight);
800 serLayout->addWidget(_serialFlowControlComboBox, 3, 3);
801 serLayout->addWidget(new QLabel("Data bits"), 4, 0, Qt::AlignLeft);
802 serLayout->addWidget(_serialDataBitsComboBox, 4, 1);
803 serLayout->addWidget(new QLabel("Parity"), 4, 2, Qt::AlignRight);
804 serLayout->addWidget(_serialParityComboBox, 4, 3);
805 serLayout->addWidget(new QLabel(" Stop bits"), 4, 4, Qt::AlignRight);
806 serLayout->addWidget(_serialStopBitsComboBox, 4, 5);
807 serLayout->addWidget(new QLabel("NMEA"), 5, 0);
808 serLayout->addWidget(_serialAutoNMEAComboBox, 5, 1);
809 serLayout->addWidget(new QLabel(" File (full path)"), 5, 2, Qt::AlignRight);
810 serLayout->addWidget(_serialFileNMEALineEdit, 5, 3, 1,10);
811 serLayout->addWidget(new QLabel("Height"), 5,14, Qt::AlignRight);
812 serLayout->addWidget(_serialHeightNMEALineEdit, 5,15, 1,11);
813 serLayout->addWidget(new QLabel("Sampling"), 5,25, Qt::AlignRight);
814 serLayout->addWidget(_serialManualNMEASamplingSpinBox, 5,26, 1,12);
815 serLayout->addWidget(new QLabel(""), 6, 1);
816 serLayout->setRowStretch(7, 999);
817
818 sergroup->setLayout(serLayout);
819
820 // Outages
821 // -------
822 QGridLayout* aLayout = new QGridLayout;
823 aLayout->setColumnMinimumWidth(0,14*ww);
824 _obsRateComboBox->setMaximumWidth(9*ww);
825 _adviseFailSpinBox->setMaximumWidth(9*ww);
826 _adviseRecoSpinBox->setMaximumWidth(9*ww);
827
828 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes.<br>"),0,0,1,50,Qt::AlignLeft);
829 aLayout->addWidget(new QLabel("Observation rate"), 1, 0);
830 aLayout->addWidget(_obsRateComboBox, 1, 1);
831 aLayout->addWidget(new QLabel("Failure threshold"), 2, 0);
832 aLayout->addWidget(_adviseFailSpinBox, 2, 1);
833 aLayout->addWidget(new QLabel("Recovery threshold"), 3, 0);
834 aLayout->addWidget(_adviseRecoSpinBox, 3, 1);
835 aLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
836 aLayout->addWidget(_adviseScriptLineEdit, 4, 1, 1,20);
837 aLayout->addWidget(new QLabel(""), 5, 1);
838 aLayout->setRowStretch(6, 999);
839
840 agroup->setLayout(aLayout);
841
842 // Miscellaneous
843 // -------------
844 QGridLayout* rLayout = new QGridLayout;
845 rLayout->setColumnMinimumWidth(0,14*ww);
846 _perfIntrComboBox->setMaximumWidth(9*ww);
847 _miscPortLineEdit->setMaximumWidth(9*ww);
848
849 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);
850 rLayout->addWidget(new QLabel("Mountpoint"), 1, 0);
851 rLayout->addWidget(_miscMountLineEdit, 1, 1, 1, 7);
852 rLayout->addWidget(new QLabel("Log latency"), 2, 0);
853 rLayout->addWidget(_perfIntrComboBox, 2, 1);
854 rLayout->addWidget(new QLabel("Scan RTCM"), 3, 0);
855 rLayout->addWidget(_scanRTCMCheckBox, 3, 1);
856 rLayout->addWidget(new QLabel("Port"), 4, 0);
857 rLayout->addWidget(_miscPortLineEdit, 4, 1);
858 rLayout->addWidget(new QLabel(""), 5, 1);
859 rLayout->setRowStretch(6, 999);
860
861 rgroup->setLayout(rLayout);
862
863 // PPP
864 // ---
865 _pppWidgets._dataSource->setMaximumWidth(20*ww);
866 _pppWidgets._corrMount->setMaximumWidth(20*ww);
867
868 QGridLayout* pppLayout1 = new QGridLayout();
869 int ir = 0;
870 pppLayout1->addWidget(new QLabel("Precise Point Positioning - Input and Output."), ir, 0, 1, 7, Qt::AlignLeft);
871 ++ir;
872 pppLayout1->addWidget(new QLabel("Data source"), ir, 0);
873 pppLayout1->addWidget(_pppWidgets._dataSource, ir, 1);
874 pppLayout1->addItem(new QSpacerItem(4*ww, 0), ir, 2);
875 pppLayout1->addWidget(new QLabel(" RINEX Obs file"), ir, 3);
876 pppLayout1->addWidget(_pppWidgets._rinexObs, ir, 4);
877 ++ir;
878 pppLayout1->addWidget(new QLabel(" RINEX Nav file"), ir, 3);
879 pppLayout1->addWidget(_pppWidgets._rinexNav, ir, 4);
880 ++ir;
881 pppLayout1->addWidget(new QLabel("Corrections stream"), ir, 0);
882 pppLayout1->addWidget(_pppWidgets._corrMount, ir, 1);
883 pppLayout1->addWidget(new QLabel(" Correction file"), ir, 3);
884 pppLayout1->addWidget(_pppWidgets._corrFile, ir, 4);
885 ++ir;
886 pppLayout1->addWidget(new QLabel("Coordinates"), ir, 0);
887 pppLayout1->addWidget(_pppWidgets._crdFile, ir, 1);
888 pppLayout1->addWidget(new QLabel(" Logfile"), ir, 3);
889 pppLayout1->addWidget(_pppWidgets._logFile, ir, 4);
890 ++ir;
891 pppLayout1->addWidget(new QLabel("ANTEX file"), ir, 0);
892 pppLayout1->addWidget(_pppWidgets._antexFile, ir, 1);
893
894 pppLayout1->addWidget(new QLabel(" NMEA file"), ir, 3);
895 pppLayout1->addWidget(_pppWidgets._nmeaFile, ir, 4);
896 ++ir;
897 pppLayout1->addWidget(new QLabel(" SNX TRO file"), ir, 3);
898 pppLayout1->addWidget(_pppWidgets._snxtroFile, ir, 4);
899 pppLayout1->addWidget(new QLabel(" Sampling"), ir, 5);
900 pppLayout1->addWidget(_pppWidgets._snxtroSampl, ir, 6);
901 ++ir;
902 pppLayout1->setRowStretch(ir, 999);
903
904 pppGroup1->setLayout(pppLayout1);
905
906
907 _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>"));
908
909 _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>"));
910
911 _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>"));
912
913 _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>"));
914
915 _pppWidgets._rinexObs->setWhatsThis(tr("<p>Specify the RINEX observations file.</p>"));
916
917 _pppWidgets._rinexNav->setWhatsThis(tr("<p>Specify the RINEX navigation file.</p>"));
918
919 _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>"));
920
921 _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>"));
922
923 _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>"));
924
925 _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>"));
926
927 _pppWidgets._snxtroSampl->setWhatsThis(tr("<p>Select a 'Sampling' rate for saving troposphere paramers.</p>"));
928
929 _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>"));
930
931 _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>"));
932
933 _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>"));
934
935 _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>"));
936
937 _pppWidgets._eleWgtCode->setWhatsThis(tr("<p>Tic 'Ele Wgt Code' to use satellite Elevation depending Weights for Code observations in the PPP solution.</p>"));
938
939 _pppWidgets._eleWgtPhase->setWhatsThis(tr("<p>Tic 'Ele Wgt Phase' to use satellite Elevation depending Weights for Phase observations in the PPP solution.</p>"));
940
941 _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>"));
942
943 _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."));
944
945 _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>"));
946
947 _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>"));
948
949 _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>"));
950
951 _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>"));
952
953 QVBoxLayout* pppLayout2 = new QVBoxLayout();
954 pppLayout2->addWidget(new QLabel("Precise Point Positioning - Processed Stations.<br>"));
955 pppLayout2->addWidget(_pppWidgets._staTable, 99);
956 QHBoxLayout* pppLayout2sub = new QHBoxLayout();
957 pppLayout2sub->addWidget(_pppWidgets._addStaButton);
958 pppLayout2sub->addWidget(_pppWidgets._delStaButton);
959 pppLayout2sub->addStretch(99);
960
961 pppLayout2->addLayout(pppLayout2sub);
962
963 pppGroup2->setLayout(pppLayout2);
964
965 QGridLayout* pppLayout3 = new QGridLayout();
966 ir = 0;
967 pppLayout3->addWidget(new QLabel("Precise Point Positioning - Options.<br>"), ir, 0, 1, 2, Qt::AlignLeft);
968 ++ir;
969 pppLayout3->addWidget(new QLabel("GPS LCs"), ir, 0, Qt::AlignLeft);
970 pppLayout3->addWidget(_pppWidgets._lcGPS, ir, 1);
971 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 2);
972 pppLayout3->addWidget(new QLabel("Sigma C1"), ir, 3, Qt::AlignLeft);
973 pppLayout3->addWidget(_pppWidgets._sigmaC1, ir, 4); _pppWidgets._sigmaC1->setMaximumWidth(8*ww);
974 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 5);
975 pppLayout3->addWidget(new QLabel("Sigma L1"), ir, 6, Qt::AlignLeft);
976 pppLayout3->addWidget(_pppWidgets._sigmaL1, ir, 7); _pppWidgets._sigmaL1->setMaximumWidth(8*ww);
977 ++ir;
978 pppLayout3->addWidget(new QLabel("GLONASS LCs"), ir, 0, Qt::AlignLeft);
979 pppLayout3->addWidget(_pppWidgets._lcGLONASS, ir, 1);
980 pppLayout3->addWidget(new QLabel("Max Res C1"), ir, 3, Qt::AlignLeft);
981 pppLayout3->addWidget(_pppWidgets._maxResC1, ir, 4); _pppWidgets._maxResC1->setMaximumWidth(8*ww);
982 pppLayout3->addWidget(new QLabel("Max Res L1"), ir, 6, Qt::AlignLeft);
983 pppLayout3->addWidget(_pppWidgets._maxResL1, ir, 7); _pppWidgets._maxResL1->setMaximumWidth(8*ww);
984 ++ir;
985 pppLayout3->addWidget(new QLabel("Galileo LCs"), ir, 0, Qt::AlignLeft);
986 pppLayout3->addWidget(_pppWidgets._lcGalileo, ir, 1);
987 pppLayout3->addWidget(new QLabel("Ele Wgt Code"), ir, 3, Qt::AlignLeft);
988 pppLayout3->addWidget(_pppWidgets._eleWgtCode, ir, 4);
989 pppLayout3->addWidget(new QLabel("Ele Wgt Phase"), ir, 6, Qt::AlignLeft);
990 pppLayout3->addWidget(_pppWidgets._eleWgtPhase, ir, 7);
991 ++ir;
992 pppLayout3->addWidget(new QLabel("BDS LCs"), ir, 0, Qt::AlignLeft);
993 pppLayout3->addWidget(_pppWidgets._lcBDS, ir, 1);
994 pppLayout3->addWidget(new QLabel("Min # of Obs"), ir, 3, Qt::AlignLeft);
995 pppLayout3->addWidget(_pppWidgets._minObs, ir, 4);
996 pppLayout3->addWidget(new QLabel("Min Elevation"), ir, 6, Qt::AlignLeft);
997 pppLayout3->addWidget(_pppWidgets._minEle, ir, 7);
998 ++ir;
999 pppLayout3->addWidget(new QLabel("Wait for clock corr."), ir, 0, Qt::AlignLeft);
1000 pppLayout3->addWidget(_pppWidgets._corrWaitTime, ir, 1);
1001 pppLayout3->addWidget(new QLabel("Seeding (sec)"), ir, 3, Qt::AlignLeft);
1002 pppLayout3->addWidget(_pppWidgets._seedingTime, ir, 4);
1003 ++ir;
1004 pppLayout3->addWidget(new QLabel(""), ir, 8);
1005 pppLayout3->setColumnStretch(8, 999);
1006 ++ir;
1007 pppLayout3->addWidget(new QLabel(""), ir, 1);
1008 pppLayout3->setRowStretch(ir, 999);
1009
1010 pppGroup3->setLayout(pppLayout3);
1011
1012 // ------------------------
1013 connect(_pppWidgets._mapWinButton, SIGNAL(clicked()), SLOT(slotMapPPP()));
1014 _pppWidgets._mapSpeedSlider->setMinimumWidth(33*ww);
1015 _pppWidgets._audioResponse->setMaximumWidth(8*ww);
1016
1017 QGridLayout* pppLayout4 = new QGridLayout();
1018 ir = 0;
1019 pppLayout4->addWidget(new QLabel("Precise Point Positioning - Plots.<br>"), ir, 0, 1, 50, Qt::AlignLeft);
1020 ++ir;
1021 pppLayout4->addWidget(new QLabel("PPP Plot"), ir, 0, Qt::AlignLeft);
1022 pppLayout4->addWidget(_pppWidgets._plotCoordinates, ir, 1, Qt::AlignLeft);
1023 pppLayout4->addWidget(new QLabel("Mountpoint"), ir, 2, 1, 10, Qt::AlignLeft);
1024 pppLayout4->addWidget(_pppWidgets._audioResponse, ir, 4, Qt::AlignLeft);
1025 pppLayout4->addWidget(new QLabel("Audio response"), ir, 5, Qt::AlignRight);
1026
1027 ++ir;
1028 pppLayout4->addWidget(new QLabel("Track map"), ir, 0, Qt::AlignLeft);
1029 pppLayout4->addWidget(_pppWidgets._mapWinButton, ir, 1, Qt::AlignLeft);
1030 pppLayout4->addWidget(new QLabel("OSM"), ir, 2, Qt::AlignLeft);
1031 pppLayout4->addWidget(_pppWidgets._useOpenStreetMap, ir, 3, Qt::AlignLeft);
1032 pppLayout4->addWidget(new QLabel("Google"), ir, 3, Qt::AlignRight);
1033 pppLayout4->addWidget(_pppWidgets._useGoogleMap, ir, 4, Qt::AlignLeft);
1034 ++ir;
1035 pppLayout4->addWidget(new QLabel("Dot-properties"), ir, 0, Qt::AlignLeft);
1036 pppLayout4->addWidget(_pppWidgets._mapWinDotSize, ir, 1, Qt::AlignLeft);
1037 pppLayout4->addWidget(new QLabel("Size "), ir, 2, Qt::AlignLeft);
1038 pppLayout4->addWidget(_pppWidgets._mapWinDotColor, ir, 3, Qt::AlignLeft);
1039 pppLayout4->addWidget(new QLabel("Color"), ir, 4, Qt::AlignLeft);
1040 ++ir;
1041 pppLayout4->addWidget(new QLabel("Post-processing speed"), ir, 0, Qt::AlignLeft);
1042 pppLayout4->addWidget(_pppWidgets._mapSpeedSlider, ir, 1, 1, 20, Qt::AlignLeft);
1043 ++ir;
1044 pppLayout4->addWidget(new QLabel(""), ir, 1);
1045 pppLayout4->setRowStretch(ir, 999);
1046
1047 pppGroup4->setLayout(pppLayout4);
1048
1049 // Reqc Processing
1050 // ---------------
1051 _reqcActionComboBox = new QComboBox();
1052 _reqcActionComboBox->setEditable(false);
1053 _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
1054 int ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
1055 if (ik != -1) {
1056 _reqcActionComboBox->setCurrentIndex(ik);
1057 }
1058 connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
1059 this, SLOT(slotBncTextChanged()));
1060
1061 QGridLayout* reqcLayout = new QGridLayout;
1062 _reqcActionComboBox->setMinimumWidth(15*ww);
1063 _reqcActionComboBox->setMaximumWidth(20*ww);
1064
1065 _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1066 _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
1067 _reqcObsFileChooser->setWhatsThis(tr("<p>Specify the full path to an input observation file in RINEX v2 or v3 format.</p><p>Note that when in 'Analyze' mode, specifying at least one RINEX observation file is mandatory.</p>"));
1068
1069 _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1070 _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
1071 _reqcNavFileChooser->setWhatsThis(tr("<p>Specify the full path to an input navigation file in RINEX v2 or v3 format.</p><p>Note that when in 'Analyze' mode, specifying at least one RINEX navigation file is mandatory.</p>"));
1072
1073 _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
1074 _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>"));
1075
1076 _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
1077 _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>"));
1078
1079 _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
1080 _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>"));
1081
1082 _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
1083 _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>"));
1084
1085 _reqcSkyPlotSignals = new QLineEdit(settings.value("reqcSkyPlotSignals").toString());
1086 _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>"));
1087
1088 connect(_reqcSkyPlotSignals, SIGNAL(textChanged(const QString &)),
1089 this, SLOT(slotBncTextChanged()));
1090
1091 _reqcLogSummaryOnly = new QCheckBox();
1092 _reqcLogSummaryOnly->setCheckState(Qt::CheckState(settings.value("reqcLogSummaryOnly").toInt()));
1093 _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>"));
1094
1095 ir = 0;
1096 reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check.<br>"),ir, 0, 1, 8);
1097 ++ir;
1098 reqcLayout->addWidget(new QLabel("Action"), ir, 0);
1099 reqcLayout->addWidget(_reqcActionComboBox, ir, 1);
1100 _reqcEditOptionButton = new QPushButton("Set Edit Options");
1101 _reqcEditOptionButton->setMinimumWidth(15*ww);
1102 _reqcEditOptionButton->setMaximumWidth(20*ww);
1103
1104 reqcLayout->addWidget(_reqcEditOptionButton, ir, 3);
1105 ++ir;
1106 reqcLayout->addWidget(new QLabel("Input files (full path)"), ir, 0);
1107 reqcLayout->addWidget(_reqcObsFileChooser, ir, 1);
1108 _reqcObsFileChooser->setMaximumWidth(40*ww);
1109 reqcLayout->addWidget(new QLabel(" Obs"), ir, 2);
1110 reqcLayout->addWidget(_reqcNavFileChooser, ir, 3);
1111 _reqcNavFileChooser->setMaximumWidth(40*ww);
1112 reqcLayout->addWidget(new QLabel(" Nav"), ir, 4);
1113 ++ir;
1114 reqcLayout->addWidget(new QLabel("Output files (full path)"), ir, 0);
1115 reqcLayout->addWidget(_reqcOutObsLineEdit, ir, 1);
1116 _reqcOutObsLineEdit->setMaximumWidth(40*ww);
1117 reqcLayout->addWidget(new QLabel(" Obs"), ir, 2);
1118 reqcLayout->addWidget(_reqcOutNavLineEdit, ir, 3);
1119 _reqcOutNavLineEdit->setMaximumWidth(40*ww);
1120 reqcLayout->addWidget(new QLabel(" Nav"), ir, 4);
1121 ++ir;
1122 reqcLayout->addWidget(new QLabel("Logfile"), ir, 0);
1123 reqcLayout->addWidget(_reqcOutLogLineEdit, ir, 1);
1124 _reqcOutLogLineEdit->setMaximumWidth(40*ww);
1125 reqcLayout->addWidget(new QLabel(" Summary only"), ir, 2);
1126 reqcLayout->addWidget(_reqcLogSummaryOnly, ir, 3);
1127 ++ir;
1128 reqcLayout->addWidget(new QLabel("Plots for signals"), ir, 0);
1129 reqcLayout->addWidget(_reqcSkyPlotSignals, ir, 1);
1130 _reqcSkyPlotSignals->setMaximumWidth(40*ww);
1131 ++ir;
1132 reqcLayout->addWidget(new QLabel("Directory for plots"), ir, 0);
1133 reqcLayout->addWidget(_reqcPlotDirLineEdit, ir, 1);
1134 _reqcPlotDirLineEdit->setMaximumWidth(40*ww);
1135 ++ir;
1136 reqcLayout->setRowStretch(ir, 999);
1137
1138 reqcLayout->setColumnMinimumWidth(2, 8*ww);
1139 reqcLayout->setColumnMinimumWidth(4, 8*ww);
1140
1141 reqcgroup->setLayout(reqcLayout);
1142
1143 connect(_reqcEditOptionButton, SIGNAL(clicked()),
1144 this, SLOT(slotReqcEditOption()));
1145
1146 QGridLayout* sp3CompLayout = new QGridLayout;
1147
1148 _sp3CompFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1149 _sp3CompFileChooser->setFileName(settings.value("sp3CompFile").toString());
1150 _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>"));
1151 _sp3CompFileChooser->setMinimumWidth(15*ww);
1152 _sp3CompFileChooser->setMaximumWidth(40*ww);
1153
1154 _sp3CompExclude = new QLineEdit(settings.value("sp3CompExclude").toString());
1155 _sp3CompExclude->setMinimumWidth(18*ww);
1156 _sp3CompExclude->setMaximumWidth(18*ww);
1157 _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>"));
1158
1159 _sp3CompLogLineEdit = new QLineEdit(settings.value("sp3CompOutLogFile").toString());
1160 _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>"));
1161 _sp3CompLogLineEdit->setMinimumWidth(18*ww);
1162 _sp3CompLogLineEdit->setMaximumWidth(18*ww);
1163
1164 ir = 0;
1165 sp3CompLayout->addWidget(new QLabel("Orbit and clock comparison.<br>"), ir, 0, 1, 40);
1166 ++ir;
1167 sp3CompLayout->addWidget(new QLabel("Input SP3 files (full path)"), ir, 0, Qt::AlignLeft);
1168 sp3CompLayout->addWidget(_sp3CompFileChooser, ir, 1, 1, 20);
1169 ++ir;
1170 sp3CompLayout->addWidget(new QLabel("Exclude satellites"), ir, 0, Qt::AlignLeft);
1171 sp3CompLayout->addWidget(_sp3CompExclude, ir, 1, Qt::AlignRight);
1172 ++ir;
1173 sp3CompLayout->addWidget(new QLabel("Logfile"), ir, 0, Qt::AlignLeft);
1174 sp3CompLayout->addWidget(_sp3CompLogLineEdit, ir, 1, Qt::AlignRight);
1175 ++ir;
1176 sp3CompLayout->addWidget(new QLabel(""), ir, 1);
1177 ++ir;
1178 sp3CompLayout->setRowStretch(ir, 999);
1179
1180 sp3CompLayout->setColumnMinimumWidth(2, 8*ww);
1181 sp3CompLayout->setColumnMinimumWidth(4, 8*ww);
1182
1183 sp3CompGroup->setLayout(sp3CompLayout);
1184
1185 connect(_sp3CompFileChooser, SIGNAL(fileNameChanged(const QString &)),
1186 this, SLOT(slotBncTextChanged()));
1187
1188 // Combine Corrections
1189 // -------------------
1190 QGridLayout* cmbLayout = new QGridLayout;
1191
1192 populateCmbTable();
1193 cmbLayout->addWidget(_cmbTable, 0, 0, 8, 3);
1194 cmbLayout->addWidget(new QLabel(" Combine Broadcast Correction streams.<br>"), 1, 6, 1, 10);
1195 cmbLayout->addWidget(addCmbRowButton, 2, 6);
1196 cmbLayout->addWidget(delCmbRowButton, 2, 7);
1197 cmbLayout->addWidget(new QLabel("Method"), 3, 6, Qt::AlignRight);
1198 cmbLayout->addWidget(_cmbMethodComboBox, 3, 7);
1199 cmbLayout->addWidget(new QLabel(" Maximal residuum"), 4, 6, Qt::AlignRight);
1200 cmbLayout->addWidget(_cmbMaxresLineEdit, 4, 7, Qt::AlignRight);
1201 cmbLayout->addWidget(new QLabel("Sampling"), 5, 6, Qt::AlignRight);
1202 cmbLayout->addWidget(_cmbSamplSpinBox, 5, 7);
1203 cmbLayout->addWidget(new QLabel(" Use GLONASS"), 6, 6, Qt::AlignRight);
1204 cmbLayout->addWidget(_cmbUseGlonass, 6, 7);
1205 cmbLayout->setRowStretch(7, 999);
1206
1207 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1208 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
1209
1210 cmbgroup->setLayout(cmbLayout);
1211
1212 // Upload Layout (Clocks)
1213 // ----------------------
1214 QGridLayout* uploadHlpLayout = new QGridLayout();
1215
1216 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1217 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1218 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
1219
1220 uploadHlpLayout->addWidget(addUploadRowButton, 0, 0);
1221 uploadHlpLayout->addWidget(delUploadRowButton, 0, 1);
1222 uploadHlpLayout->addWidget(new QLabel("Interval"), 0, 2, Qt::AlignRight);
1223 uploadHlpLayout->addWidget(_uploadIntrComboBox, 0, 3);
1224 uploadHlpLayout->addWidget(new QLabel(" Sampling: Orb"), 0, 4, Qt::AlignRight);
1225 uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox, 0, 5);
1226 uploadHlpLayout->addWidget(new QLabel("SP3"), 0, 6, Qt::AlignRight);
1227 uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox, 0, 7);
1228 uploadHlpLayout->addWidget(new QLabel("RNX"), 0, 8, Qt::AlignRight);
1229 uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox, 0, 9);
1230 uploadHlpLayout->addWidget(setUploadTrafoButton, 0,10);
1231 uploadHlpLayout->addWidget(new QLabel("ANTEX file"), 1, 0, Qt::AlignLeft);
1232 uploadHlpLayout->addWidget(_uploadAntexFile, 1, 1, 1, 4);
1233
1234 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1235 populateUploadTable();
1236
1237 uploadLayout->addWidget(new QLabel("Upload RTCM Version 3 Broadcast Corrections to caster.<br>"));
1238 uploadLayout->addWidget(_uploadTable);
1239 uploadLayout->addLayout(uploadHlpLayout);
1240
1241 uploadgroup->setLayout(uploadLayout);
1242
1243 // Upload Layout (Ephemeris)
1244 // -------------------------
1245 QGridLayout* uploadLayoutEph = new QGridLayout;
1246
1247 uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1248 _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1249 _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1250 _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1251
1252 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster.<br>"), 0, 0, 1, 50);
1253 uploadLayoutEph->addWidget(new QLabel("Host"), 1, 0);
1254 uploadLayoutEph->addWidget(_uploadEphHostLineEdit, 1, 1, 1, 3);
1255 uploadLayoutEph->addWidget(new QLabel(" Port"), 1, 4, Qt::AlignRight);
1256 uploadLayoutEph->addWidget(_uploadEphPortLineEdit, 1, 5, 1, 1);
1257 uploadLayoutEph->addWidget(new QLabel("Mountpoint "), 2, 0);
1258 uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit, 2, 1);
1259 uploadLayoutEph->addWidget(new QLabel(" Password"), 2, 2, Qt::AlignRight);
1260 uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit, 2, 3);
1261 uploadLayoutEph->addWidget(new QLabel("Sampling"), 3, 0);
1262 uploadLayoutEph->addWidget(_uploadEphSampleSpinBox, 3, 1);
1263 uploadLayoutEph->addWidget(new QLabel("Uploaded"), 4, 0);
1264 uploadLayoutEph->addWidget(_uploadEphBytesCounter, 4, 1);
1265 uploadLayoutEph->setRowStretch(5, 999);
1266
1267 uploadEphgroup->setLayout(uploadLayoutEph);
1268
1269 connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1270 this, SLOT(slotBncTextChanged()));
1271
1272 // Main Layout
1273 // -----------
1274 QGridLayout* mLayout = new QGridLayout;
1275 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
1276 mLayout->addWidget(_aogroup, 0,0);
1277 mLayout->addWidget(_mountPointsTable, 1,0);
1278 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
1279 mLayout->addWidget(_loggroup, 2,0);
1280
1281 _canvas->setLayout(mLayout);
1282
1283 // WhatsThis
1284 // ---------
1285 _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>"));
1286 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1287 _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>"));
1288 _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>"));
1289 _waitTimeSpinBox->setWhatsThis(tr("<p>When feeding a real-time GNSS network engine waiting for synchronized input epoch by epoch, BNC drops whatever is received later than 'Wait for full obs epoch' seconds. A value of 3 to 5 seconds is recommended, depending on the latency of the incoming streams and the delay acceptable to your real-time GNSS network engine or products.</p>"));
1290 _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."));
1291 _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."));
1292 _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."));
1293 _outEphPortLineEdit->setWhatsThis(tr("BNC can produce ephemeris data in RINEX ASCII format on your local host through an IP port. Specify a port number here to activate this function."));
1294 _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."));
1295 _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."));
1296 _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."));
1297 _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."));
1298 _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>"));
1299 _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>"));
1300 _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."));
1301 _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>"));
1302 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1303 _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p>"));
1304 _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>"));
1305 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1306 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1307 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of the Broadcast Ephemeris Correction files.</p>"));
1308 _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>"));
1309 _binSamplSpinBox->setWhatsThis(tr("<p>Select the synchronized observation sampling interval in seconds. A value of zero '0' tells BNC to send/store all received epochs.</p>"));
1310 _obsRateComboBox->setWhatsThis(tr("<p>BNC can collect all returns (success or failure) coming from a decoder within a certain short time span to then decide whether a stream has an outage or its content is corrupted. The procedure needs a rough estimate of the expected 'Observation rate' of the incoming streams. When a continuous problem is detected, BNC can inform its operator about this event through an advisory note.</p><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>"));
1311 _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>"));
1312 _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>"));
1313 _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."));
1314 _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>"));
1315 _perfIntrComboBox->setWhatsThis(tr("<p>BNC can average latencies per stream over a certain period of GPS time. The resulting mean latencies are recorded in the 'Log' tab at the end of each 'Log latency' interval together with results of a statistical evaluation (approximate number of covered epochs, data gaps).</p><p>Select a 'Log latency' interval or select the empty option field if you do not want BNC to log latencies and statistical information.</p>"));
1316 _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>"));
1317 _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."));
1318 _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)."));
1319 _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."));
1320 _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."));
1321 _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>"));
1322 _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>"));
1323 _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."));
1324
1325 _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 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>"));
1326
1327 _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>"));
1328 _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."));
1329 _scanRTCMCheckBox->setWhatsThis(tr("<p>Tick 'Scan RTCM' to log the numbers of incomming message types as well as contained antenna coordinates, antenna heigt, and antenna descriptor.</p><p>In case of RTCM Version 3 MSM streams, BNC will also log contained RINEX Version 3 observation types.</p>."));
1330 _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>"));
1331 _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>"));
1332 _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>"));
1333 _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>"));
1334 _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>"));
1335 _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>"));
1336 _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>"));
1337 _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>"));
1338 _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>"));
1339 _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>"));
1340 _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>"));
1341 _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>"));
1342 _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX v2 or v3 files.</p>"));
1343 _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."));
1344
1345 _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."));
1346
1347 _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>"));
1348 _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>"));
1349 _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."));
1350 _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>"));
1351 _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>"));
1352
1353 addCmbRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the mountpoints table."));
1354 delCmbRowButton->setWhatsThis(tr("Hit 'Delete' button to delete the highlighted line from the mountpoints table."));
1355 addUploadRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the stream upload table."));
1356 delUploadRowButton->setWhatsThis(tr("Hit 'Del Row' button to delete the highlighted line from the stream upload table."));
1357 _uploadIntrComboBox->setWhatsThis(tr("Select the length of the SP3 and Clock RINEX files."));
1358 _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."));
1359 _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."));
1360 _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."));
1361 setUploadTrafoButton->setWhatsThis(tr("Hit 'Custom Trafo' to specify your own 14 parameter Helmert Transformation instead of selecting a predefined transformation through 'System' button."));
1362 _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>"));
1363 _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."));
1364 _uploadEphPortLineEdit->setWhatsThis(tr("Specify the IP port of an Ntrip Broadcaster to upload the stream. Default is port 80."));
1365 _uploadEphMountpointLineEdit->setWhatsThis(tr("Specify the mounpoint for stream upload to an Ntrip Broadcaster."));
1366 _uploadEphPasswordLineEdit->setWhatsThis(tr("Specify the stream upload password protecting the mounpoint on an Ntrip Broadcaster."));
1367 _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."));
1368 _uploadEphBytesCounter->setWhatsThis(tr("BNC shows the amount of data uploaded through this stream."));
1369 _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1370 _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
1371 _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>"));
1372 _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1373 _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1374
1375 // Enable/Disable all Widgets
1376 // --------------------------
1377 slotBncTextChanged();
1378 enableStartStop();
1379
1380 // Auto start
1381 // ----------
1382 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1383 slotStart();
1384 }
1385}
1386
1387// Destructor
1388////////////////////////////////////////////////////////////////////////////
1389bncWindow::~bncWindow() {
1390 delete _caster; BNC_CORE->setCaster(0);
1391 delete _casterEph;
1392}
1393
1394//
1395////////////////////////////////////////////////////////////////////////////
1396void bncWindow::populateMountPointsTable() {
1397
1398 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1399 _mountPointsTable->removeRow(iRow);
1400 }
1401
1402 bncSettings settings;
1403
1404 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1405 int iRow = 0;
1406 while (it.hasNext()) {
1407 QStringList hlp = it.next().split(" ");
1408 if (hlp.size() < 7) continue;
1409 _mountPointsTable->insertRow(iRow);
1410
1411 QUrl url(hlp[0]);
1412
1413 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1414 QString format(hlp[1]); QString country(hlp[2]); QString latitude(hlp[3]); QString longitude(hlp[4]);
1415 QString nmea(hlp[5]);
1416 if (hlp[6] == "S") {
1417 fullPath = hlp[0].replace(0,2,"");
1418 }
1419 QString ntripVersion = "2";
1420 if (hlp.size() >= 7) {
1421 ntripVersion = (hlp[6]);
1422 }
1423
1424 QTableWidgetItem* it;
1425 it = new QTableWidgetItem(url.userInfo());
1426 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1427 _mountPointsTable->setItem(iRow, 0, it);
1428
1429 it = new QTableWidgetItem(fullPath);
1430 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1431 _mountPointsTable->setItem(iRow, 1, it);
1432
1433 it = new QTableWidgetItem(format);
1434 _mountPointsTable->setItem(iRow, 2, it);
1435
1436 it = new QTableWidgetItem(country);
1437 _mountPointsTable->setItem(iRow, 3, it);
1438
1439 if (nmea == "yes") {
1440 it = new QTableWidgetItem(latitude);
1441 _mountPointsTable->setItem(iRow, 4, it);
1442 it = new QTableWidgetItem(longitude);
1443 _mountPointsTable->setItem(iRow, 5, it);
1444 } else {
1445 it = new QTableWidgetItem(latitude);
1446 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1447 _mountPointsTable->setItem(iRow, 4, it);
1448
1449 it = new QTableWidgetItem(longitude);
1450 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1451 _mountPointsTable->setItem(iRow, 5, it);
1452 }
1453
1454 it = new QTableWidgetItem(nmea);
1455 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1456 _mountPointsTable->setItem(iRow, 6, it);
1457
1458 it = new QTableWidgetItem(ntripVersion);
1459 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1460 _mountPointsTable->setItem(iRow, 7, it);
1461
1462 bncTableItem* bncIt = new bncTableItem();
1463 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1464 _mountPointsTable->setItem(iRow, 8, bncIt);
1465
1466 iRow++;
1467 }
1468
1469 _mountPointsTable->sortItems(1);
1470
1471 enableStartStop();
1472}
1473
1474// Retrieve Table
1475////////////////////////////////////////////////////////////////////////////
1476void bncWindow::slotAddMountPoints() {
1477
1478 bncSettings settings;
1479 QString proxyHost = settings.value("proxyHost").toString();
1480 int proxyPort = settings.value("proxyPort").toInt();
1481 if (proxyHost != _proxyHostLineEdit->text() ||
1482 proxyPort != _proxyPortLineEdit->text().toInt()) {
1483 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1484 "changed. Use the new ones?",
1485 QMessageBox::Yes, QMessageBox::No,
1486 QMessageBox::NoButton);
1487 if (iRet == QMessageBox::Yes) {
1488 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1489 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1490 }
1491 }
1492
1493 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1494 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1495
1496 QMessageBox msgBox;
1497 msgBox.setIcon(QMessageBox::Question);
1498 msgBox.setWindowTitle("Add Stream");
1499 msgBox.setText("Add stream(s) coming from:");
1500
1501 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1502 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1503 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1504 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1505 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1506
1507 msgBox.exec();
1508
1509 if (msgBox.clickedButton() == buttonNtrip) {
1510 bncTableDlg* dlg = new bncTableDlg(this);
1511 dlg->move(this->pos().x()+50, this->pos().y()+50);
1512 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1513 this, SLOT(slotNewMountPoints(QStringList*)));
1514 dlg->exec();
1515 delete dlg;
1516 } else if (msgBox.clickedButton() == buttonIP) {
1517 bncIpPort* ipp = new bncIpPort(this);
1518 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1519 this, SLOT(slotNewMountPoints(QStringList*)));
1520 ipp->exec();
1521 delete ipp;
1522 } else if (msgBox.clickedButton() == buttonUDP) {
1523 bncUdpPort* udp = new bncUdpPort(this);
1524 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1525 this, SLOT(slotNewMountPoints(QStringList*)));
1526 udp->exec();
1527 delete udp;
1528 } else if (msgBox.clickedButton() == buttonSerial) {
1529 bncSerialPort* sep = new bncSerialPort(this);
1530 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1531 this, SLOT(slotNewMountPoints(QStringList*)));
1532 sep->exec();
1533 delete sep;
1534 } else if (msgBox.clickedButton() == buttonCancel) {
1535 // Cancel
1536 }
1537
1538 enableStartStop();
1539}
1540
1541// Delete Selected Mount Points
1542////////////////////////////////////////////////////////////////////////////
1543void bncWindow::slotDeleteMountPoints() {
1544
1545 int nRows = _mountPointsTable->rowCount();
1546 bool flg[nRows];
1547 for (int iRow = 0; iRow < nRows; iRow++) {
1548 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1549 flg[iRow] = true;
1550 }
1551 else {
1552 flg[iRow] = false;
1553 }
1554 }
1555 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1556 if (flg[iRow]) {
1557 _mountPointsTable->removeRow(iRow);
1558 }
1559 }
1560 _actDeleteMountPoints->setEnabled(false);
1561
1562 enableStartStop();
1563}
1564
1565// New Mount Points Selected
1566////////////////////////////////////////////////////////////////////////////
1567void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1568 int iRow = 0;
1569 QListIterator<QString> it(*mountPoints);
1570 while (it.hasNext()) {
1571 QStringList hlp = it.next().split(" ");
1572 QUrl url(hlp[0]);
1573 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1574 QString format(hlp[1]); QString country(hlp[2]); QString latitude(hlp[3]); QString longitude(hlp[4]);
1575 QString nmea(hlp[5]);
1576 if (hlp[6] == "S") {
1577 fullPath = hlp[0].replace(0,2,"");
1578 }
1579 QString ntripVersion = "2";
1580 if (hlp.size() >= 7) {
1581 ntripVersion = (hlp[6]);
1582 }
1583
1584 _mountPointsTable->insertRow(iRow);
1585
1586 QTableWidgetItem* it;
1587 it = new QTableWidgetItem(url.userInfo());
1588 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1589 _mountPointsTable->setItem(iRow, 0, it);
1590
1591 it = new QTableWidgetItem(fullPath);
1592 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1593 _mountPointsTable->setItem(iRow, 1, it);
1594
1595 it = new QTableWidgetItem(format);
1596 _mountPointsTable->setItem(iRow, 2, it);
1597
1598 it = new QTableWidgetItem(country);
1599 _mountPointsTable->setItem(iRow, 3, it);
1600
1601 if (nmea == "yes") {
1602 it = new QTableWidgetItem(latitude);
1603 _mountPointsTable->setItem(iRow, 4, it);
1604 it = new QTableWidgetItem(longitude);
1605 _mountPointsTable->setItem(iRow, 5, it);
1606 } else {
1607 it = new QTableWidgetItem(latitude);
1608 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1609 _mountPointsTable->setItem(iRow, 4, it);
1610 it = new QTableWidgetItem(longitude);
1611 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1612 _mountPointsTable->setItem(iRow, 5, it);
1613 }
1614
1615 it = new QTableWidgetItem(nmea);
1616 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1617 _mountPointsTable->setItem(iRow, 6, it);
1618
1619 it = new QTableWidgetItem(ntripVersion);
1620 ////it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1621 _mountPointsTable->setItem(iRow, 7, it);
1622
1623 bncTableItem* bncIt = new bncTableItem();
1624 _mountPointsTable->setItem(iRow, 8, bncIt);
1625
1626 iRow++;
1627 }
1628 _mountPointsTable->hideColumn(0);
1629 _mountPointsTable->hideColumn(3);
1630 _mountPointsTable->sortItems(1);
1631 delete mountPoints;
1632
1633 enableStartStop();
1634}
1635
1636// Save Options (serialize)
1637////////////////////////////////////////////////////////////////////////////
1638void bncWindow::slotSaveOptions() {
1639 saveOptions();
1640 bncSettings settings;
1641 settings.sync();
1642}
1643
1644// Save Options (memory only)
1645////////////////////////////////////////////////////////////////////////////
1646void bncWindow::saveOptions() {
1647
1648 QStringList mountPoints;
1649 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1650
1651 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1652 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1653 "@" + _mountPointsTable->item(iRow, 1)->text() );
1654
1655 mountPoints.append(url.toString() + " " +
1656 _mountPointsTable->item(iRow, 2)->text()
1657 + " " + _mountPointsTable->item(iRow, 3)->text()
1658 + " " + _mountPointsTable->item(iRow, 4)->text()
1659 + " " + _mountPointsTable->item(iRow, 5)->text()
1660 + " " + _mountPointsTable->item(iRow, 6)->text()
1661 + " " + _mountPointsTable->item(iRow, 7)->text());
1662 } else {
1663 mountPoints.append(
1664 "//" + _mountPointsTable->item(iRow, 1)->text()
1665 + " " + _mountPointsTable->item(iRow, 2)->text()
1666 + " " + _mountPointsTable->item(iRow, 3)->text()
1667 + " " + _mountPointsTable->item(iRow, 4)->text()
1668 + " " + _mountPointsTable->item(iRow, 5)->text()
1669 + " " + _mountPointsTable->item(iRow, 6)->text()
1670 + " " + _mountPointsTable->item(iRow, 7)->text());
1671 }
1672 }
1673
1674 QStringList cmbStreams;
1675 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1676 QString hlp;
1677 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1678 if (_cmbTable->item(iRow, iCol)) {
1679 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1680 }
1681 }
1682 if (!hlp.isEmpty()) {
1683 cmbStreams << hlp;
1684 }
1685 }
1686
1687 QStringList uploadMountpointsOut;
1688 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1689 QString hlp;
1690 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1691 if (_uploadTable->cellWidget(iRow, iCol) &&
1692 (iCol == 3 || iCol == 4 || iCol == 5)) {
1693 if (iCol == 3) {
1694 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1695 hlp += passwd->text() + ",";
1696 }
1697 else if (iCol == 4) {
1698 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1699 hlp += system->currentText() + ",";
1700 }
1701 else if (iCol == 5) {
1702 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1703 QString state; state.setNum(com->checkState());
1704 hlp += state + ",";
1705 }
1706 }
1707 else if (_uploadTable->item(iRow, iCol)) {
1708 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1709 }
1710 }
1711 if (!hlp.isEmpty()) {
1712 uploadMountpointsOut << hlp;
1713 }
1714 }
1715
1716 bncSettings settings;
1717
1718 settings.setValue("startTab", _aogroup->currentIndex());
1719 settings.setValue("statusTab", _loggroup->currentIndex());
1720 settings.setValue("mountPoints", mountPoints);
1721// Network
1722 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1723 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1724 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1725 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1726// General
1727 settings.setValue("logFile", _logFileLineEdit->text());
1728 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1729 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1730 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1731 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1732// RINEX Observations
1733 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1734 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1735 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1736 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1737 settings.setValue("rnxOnlyWithSKL",_rnxFileCheckBox->checkState());
1738 settings.setValue("rnxV3filenames",_rnxV3filenameCheckBox->checkState());
1739 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1740 (_rnxV3filenameCheckBox->checkState()) ?
1741 settings.setValue("rnxV3", _rnxV3filenameCheckBox->checkState()) :
1742 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1743 settings.setValue("rnxV2Priority",_rnxV2Priority->text());
1744// RINEX Ephemeris
1745 settings.setValue("ephPath", _ephPathLineEdit->text());
1746 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1747 settings.setValue("outEphPort", _outEphPortLineEdit->text());
1748 settings.setValue("ephV3filenames", _ephV3filenameCheckBox->checkState());
1749 (_ephV3filenameCheckBox->checkState()) ?
1750 settings.setValue("ephV3", _ephV3filenameCheckBox->checkState()) :
1751 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1752// Broadcast Corrections
1753 settings.setValue("corrPath", _corrPathLineEdit->text());
1754 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1755 settings.setValue("corrPort", _corrPortLineEdit->text());
1756// Feed Engine
1757 settings.setValue("outPort", _outPortLineEdit->text());
1758 settings.setValue("waitTime", _waitTimeSpinBox->value());
1759 settings.setValue("binSampl", _binSamplSpinBox->value());
1760 settings.setValue("outFile", _outFileLineEdit->text());
1761 settings.setValue("outUPort", _outUPortLineEdit->text());
1762// Serial Output
1763 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1764 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1765 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1766 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1767 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1768 settings.setValue("serialParity", _serialParityComboBox->currentText());
1769 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1770 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1771 settings.setValue("serialFileNMEA", _serialFileNMEALineEdit->text());
1772 settings.setValue("serialHeightNMEA", _serialHeightNMEALineEdit->text());
1773 settings.setValue("serialManualNMEASampling", _serialManualNMEASamplingSpinBox->value());
1774// Outages
1775 settings.setValue("obsRate", _obsRateComboBox->currentText());
1776 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1777 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1778 settings.setValue("adviseScript",_adviseScriptLineEdit->text());
1779// Miscellaneous
1780 settings.setValue("miscMount", _miscMountLineEdit->text());
1781 settings.setValue("miscPort", _miscPortLineEdit->text());
1782 settings.setValue("perfIntr", _perfIntrComboBox->currentText());
1783 settings.setValue("scanRTCM", _scanRTCMCheckBox->checkState());
1784// Reqc
1785 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1786 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1787 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1788 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1789 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1790 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
1791 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
1792 settings.setValue("reqcSkyPlotSignals", _reqcSkyPlotSignals->text());
1793 settings.setValue("reqcLogSummaryOnly", _reqcLogSummaryOnly->checkState());
1794// SP3 Comparison
1795 settings.setValue("sp3CompFile", _sp3CompFileChooser->fileName());
1796 settings.setValue("sp3CompExclude", _sp3CompExclude->text());
1797 settings.setValue("sp3CompOutLogFile", _sp3CompLogLineEdit->text());
1798// Combine Corrections
1799 if (!cmbStreams.isEmpty()) {
1800 settings.setValue("cmbStreams", cmbStreams);
1801 }
1802 else {
1803 settings.setValue("cmbStreams", "");
1804 }
1805 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1806 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1807 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1808 settings.setValue("cmbUseGlonass", _cmbUseGlonass->checkState());
1809// Upload Corrections
1810 if (!uploadMountpointsOut.isEmpty()) {
1811 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1812 }
1813 else {
1814 settings.setValue("uploadMountpointsOut", "");
1815 }
1816 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1817 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1818 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1819 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
1820 settings.setValue("uploadAntexFile", _uploadAntexFile->fileName());
1821// Upload Ephemeris
1822 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1823 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
1824 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
1825 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1826 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
1827
1828 if (_caster) {
1829 _caster->readMountPoints();
1830 }
1831
1832 _pppWidgets.saveOptions();
1833}
1834
1835// All get slots terminated
1836////////////////////////////////////////////////////////////////////////////
1837void bncWindow::slotGetThreadsFinished() {
1838 BNC_CORE->slotMessage("All Get Threads Terminated", true);
1839 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
1840 delete _casterEph; _casterEph = 0;
1841 _runningRealTime = false;
1842}
1843
1844// Start It!
1845////////////////////////////////////////////////////////////////////////////
1846void bncWindow::slotStart() {
1847 saveOptions();
1848 if ( _pppWidgets._dataSource->currentText() == "RINEX Files") {
1849 _runningPPP = true;
1850 enableStartStop();
1851 _caster = new bncCaster(); BNC_CORE->setCaster(_caster);
1852 BNC_CORE->startPPP();
1853 _bncFigurePPP->reset();
1854 }
1855 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
1856 if (_reqcActionComboBox->currentText() == "Analyze") {
1857 _runningQC = true;
1858 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
1859 connect(reqcAnalyze, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1860 reqcAnalyze->start();
1861 }
1862 else {
1863 _runningEdit = true;
1864 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
1865 connect(reqcEdit, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1866 reqcEdit->start();
1867 }
1868 enableStartStop();
1869 }
1870 else if (!_sp3CompFileChooser->fileName().isEmpty()) {
1871 _runningSp3Comp = true;
1872 t_sp3Comp* sp3Comp = new t_sp3Comp(this);
1873 connect(sp3Comp, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1874 sp3Comp->start();
1875 enableStartStop();
1876 }
1877 else {
1878 startRealTime();
1879 BNC_CORE->startPPP();
1880 }
1881}
1882
1883// Start Real-Time (Retrieve Data etc.)
1884////////////////////////////////////////////////////////////////////////////
1885void bncWindow::startRealTime() {
1886
1887 _runningRealTime = true;
1888
1889 _bncFigurePPP->reset();
1890
1891 _actDeleteMountPoints->setEnabled(false);
1892
1893 enableStartStop();
1894
1895 _caster = new bncCaster();
1896
1897 BNC_CORE->setCaster(_caster);
1898 BNC_CORE->setPortEph(_outEphPortLineEdit->text().toInt());
1899 BNC_CORE->setPortCorr(_corrPortLineEdit->text().toInt());
1900 BNC_CORE->initCombination();
1901
1902 connect(_caster, SIGNAL(getThreadsFinished()),
1903 this, SLOT(slotGetThreadsFinished()));
1904
1905 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
1906 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
1907
1908 BNC_CORE->slotMessage("========== Start BNC v" BNCVERSION " ("BNC_OS") ==========", true);
1909
1910 bncSettings settings;
1911
1912 // Active panels
1913 // -------------
1914 if (!_rnxPathLineEdit->text().isEmpty())
1915 BNC_CORE->slotMessage("Panel 'RINEX Observations' active", true);
1916 if (!_ephPathLineEdit->text().isEmpty())
1917 BNC_CORE->slotMessage("Panel 'RINEX Ephemeris' active", true);
1918 if (!_corrPathLineEdit->text().isEmpty())
1919 BNC_CORE->slotMessage("Panel 'Broadcast Corrections' active", true);
1920 if (!_outPortLineEdit->text().isEmpty())
1921 BNC_CORE->slotMessage("Panel 'Feed Engine' active", true);
1922 if (!_serialMountPointLineEdit->text().isEmpty())
1923 BNC_CORE->slotMessage("Panel 'Serial Output' active", true);
1924 if (!_obsRateComboBox->currentText().isEmpty())
1925 BNC_CORE->slotMessage("Panel 'Outages' active", true);
1926 if (!_miscMountLineEdit->text().isEmpty())
1927 BNC_CORE->slotMessage("Panel 'Miscellaneous' active", true);
1928 if (_pppWidgets._dataSource->currentText() == "Real-Time Streams")
1929 BNC_CORE->slotMessage("Panel 'PPP' active", true);
1930 if (_cmbTable->rowCount() > 0)
1931 BNC_CORE->slotMessage("Panel 'Combine Corrections' active", true);
1932 if (_uploadTable->rowCount() > 0)
1933 BNC_CORE->slotMessage("Panel 'Upload Corrections' active", true);
1934 if (!_uploadEphHostLineEdit->text().isEmpty())
1935 BNC_CORE->slotMessage("Panel 'UploadEphemeris' active", true);
1936
1937 QDir rnxdir(settings.value("rnxPath").toString());
1938 if (!rnxdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations directory", true);
1939
1940 QString rnx_file = settings.value("rnxScript").toString();
1941 if ( !rnx_file.isEmpty() ) {
1942 QFile rnxfile(settings.value("rnxScript").toString());
1943 if (!rnxfile.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations script", true);
1944 }
1945
1946 QDir ephdir(settings.value("ephPath").toString());
1947 if (!ephdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Ephemeris directory", true);
1948
1949 QDir corrdir(settings.value("corrPath").toString());
1950 if (!corrdir.exists()) BNC_CORE->slotMessage("Cannot find Broadcast Corrections directory", true);
1951
1952 QString advise_file = settings.value("adviseScript").toString();
1953 if ( !advise_file.isEmpty() ) {
1954 QFile advisefile(settings.value("adviseScript").toString());
1955 if (!advisefile.exists()) BNC_CORE->slotMessage("Cannot find Outages script", true);
1956 }
1957
1958 _caster->readMountPoints();
1959
1960 _casterEph = new bncEphUploadCaster();
1961 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
1962 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
1963}
1964
1965// Retrieve Data
1966////////////////////////////////////////////////////////////////////////////
1967void bncWindow::slotStop() {
1968 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving/processing data?",
1969 QMessageBox::Yes, QMessageBox::No,
1970 QMessageBox::NoButton);
1971 if (iRet == QMessageBox::Yes) {
1972 BNC_CORE->stopPPP();
1973 BNC_CORE->stopCombination();
1974 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
1975 delete _casterEph; _casterEph = 0;
1976 _runningRealTime = false;
1977 _runningPPP = false;
1978 enableStartStop();
1979 }
1980}
1981
1982// Close Application gracefully
1983////////////////////////////////////////////////////////////////////////////
1984void bncWindow::closeEvent(QCloseEvent* event) {
1985
1986 int iRet = QMessageBox::question(this, "Close", "Save Options?",
1987 QMessageBox::Yes, QMessageBox::No,
1988 QMessageBox::Cancel);
1989
1990 if (iRet == QMessageBox::Cancel) {
1991 event->ignore();
1992 return;
1993 }
1994 else if (iRet == QMessageBox::Yes) {
1995 slotSaveOptions();
1996 }
1997
1998 BNC_CORE->stopPPP();
1999
2000 QMainWindow::closeEvent(event);
2001}
2002
2003// User changed the selection of mountPoints
2004////////////////////////////////////////////////////////////////////////////
2005void bncWindow::slotSelectionChanged() {
2006 if (_mountPointsTable->selectedItems().isEmpty()) {
2007 _actDeleteMountPoints->setEnabled(false);
2008 }
2009 else {
2010 _actDeleteMountPoints->setEnabled(true);
2011 }
2012}
2013
2014// Display Program Messages
2015////////////////////////////////////////////////////////////////////////////
2016void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
2017 if (showOnScreen ) {
2018 _log->append(QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg);
2019 }
2020}
2021
2022// About Message
2023////////////////////////////////////////////////////////////////////////////
2024void bncWindow::slotAbout() {
2025 new bncAboutDlg(0);
2026}
2027
2028//Flowchart
2029////////////////////////////////////////////////////////////////////////////
2030void bncWindow::slotFlowchart() {
2031 new bncFlowchartDlg(0);
2032}
2033
2034// Help Window
2035////////////////////////////////////////////////////////////////////////////
2036void bncWindow::slotHelp() {
2037 QUrl url;
2038 url.setPath(":bnchelp.html");
2039 new bncHlpDlg(0, url);
2040}
2041
2042// Select Fonts
2043////////////////////////////////////////////////////////////////////////////
2044void bncWindow::slotFontSel() {
2045 bool ok;
2046 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
2047 if (ok) {
2048 bncSettings settings;
2049 settings.setValue("font", newFont.toString());
2050 QApplication::setFont(newFont);
2051 int ww = QFontMetrics(newFont).width('w');
2052 setMinimumSize(60*ww, 80*ww);
2053 resize(60*ww, 80*ww);
2054 }
2055}
2056
2057// Whats This Help
2058void bncWindow::slotWhatsThis() {
2059 QWhatsThis::enterWhatsThisMode();
2060}
2061
2062//
2063////////////////////////////////////////////////////////////////////////////
2064void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
2065 _threads = threads;
2066
2067 _bncFigure->updateMountPoints();
2068 _bncFigureLate->updateMountPoints();
2069
2070 populateMountPointsTable();
2071 bncSettings settings;
2072 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
2073 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
2074 QListIterator<bncGetThread*> iTh(threads);
2075 while (iTh.hasNext()) {
2076 bncGetThread* thread = iTh.next();
2077 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
2078 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
2079 "@" + _mountPointsTable->item(iRow, 1)->text() );
2080 if (url == thread->mountPoint() &&
2081 _mountPointsTable->item(iRow, 4)->text() == thread->latitude() &&
2082 _mountPointsTable->item(iRow, 5)->text() == thread->longitude() ) {
2083 ((bncTableItem*) _mountPointsTable->item(iRow, 8))->setGetThread(thread);
2084 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
2085 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2086 connect(thread, SIGNAL(newBytes(QByteArray, double)),
2087 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2088 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
2089 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2090 connect(thread, SIGNAL(newLatency(QByteArray, double)),
2091 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2092 break;
2093 }
2094 }
2095 }
2096}
2097
2098//
2099////////////////////////////////////////////////////////////////////////////
2100void bncWindow::CreateMenu() {
2101 // Create Menus
2102 // ------------
2103 _menuFile = menuBar()->addMenu(tr("&File"));
2104 _menuFile->addAction(_actFontSel);
2105 _menuFile->addSeparator();
2106 _menuFile->addAction(_actSaveOpt);
2107 _menuFile->addSeparator();
2108 _menuFile->addAction(_actQuit);
2109
2110 _menuHlp = menuBar()->addMenu(tr("&Help"));
2111 _menuHlp->addAction(_actHelp);
2112 _menuHlp->addAction(_actFlowchart);
2113 _menuHlp->addAction(_actAbout);
2114}
2115
2116// Toolbar
2117////////////////////////////////////////////////////////////////////////////
2118void bncWindow::AddToolbar() {
2119 QToolBar* toolBar = new QToolBar;
2120 addToolBar(Qt::BottomToolBarArea, toolBar);
2121 toolBar->setMovable(false);
2122 toolBar->addAction(_actAddMountPoints);
2123 toolBar->addAction(_actDeleteMountPoints);
2124 toolBar->addAction(_actMapMountPoints);
2125 toolBar->addAction(_actStart);
2126 toolBar->addAction(_actStop);
2127 toolBar->addWidget(new QLabel(" "));
2128 toolBar->addAction(_actwhatsthis);
2129}
2130
2131// About
2132////////////////////////////////////////////////////////////////////////////
2133bncAboutDlg::bncAboutDlg(QWidget* parent) :
2134 QDialog(parent) {
2135
2136 QTextBrowser* tb = new QTextBrowser;
2137 QUrl url; url.setPath(":bncabout.html");
2138 tb->setSource(url);
2139 tb->setReadOnly(true);
2140
2141 int ww = QFontMetrics(font()).width('w');
2142 QPushButton* _closeButton = new QPushButton("Close");
2143 _closeButton->setMaximumWidth(10*ww);
2144 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2145
2146 QGridLayout* dlgLayout = new QGridLayout();
2147 QLabel* img = new QLabel();
2148 img->setPixmap(QPixmap(":ntrip-logo.png"));
2149 dlgLayout->addWidget(img, 0,0);
2150 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
2151 dlgLayout->addWidget(tb,1,0,1,2);
2152 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2153
2154 setLayout(dlgLayout);
2155 resize(60*ww, 60*ww);
2156 setWindowTitle("About BNC");
2157 show();
2158}
2159
2160//
2161////////////////////////////////////////////////////////////////////////////
2162bncAboutDlg::~bncAboutDlg() {
2163};
2164
2165// Flowchart
2166////////////////////////////////////////////////////////////////////////////
2167bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2168 QDialog(parent) {
2169
2170 int ww = QFontMetrics(font()).width('w');
2171 QPushButton* _closeButton = new QPushButton("Close");
2172 _closeButton->setMaximumWidth(10*ww);
2173 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2174
2175 QGridLayout* dlgLayout = new QGridLayout();
2176 QLabel* img = new QLabel();
2177 img->setPixmap(QPixmap(":bncflowchart.png"));
2178 dlgLayout->addWidget(img, 0,0);
2179 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2180
2181 setLayout(dlgLayout);
2182 setWindowTitle("Flow Chart");
2183 show();
2184}
2185
2186//
2187////////////////////////////////////////////////////////////////////////////
2188bncFlowchartDlg::~bncFlowchartDlg() {
2189};
2190
2191// Enable/Disable Widget (and change its color)
2192////////////////////////////////////////////////////////////////////////////
2193void bncWindow::enableWidget(bool enable, QWidget* widget) {
2194
2195 const static QPalette paletteWhite(QColor(255, 255, 255));
2196 const static QPalette paletteGray(QColor(230, 230, 230));
2197
2198 widget->setEnabled(enable);
2199 if (enable) {
2200 widget->setPalette(paletteWhite);
2201 }
2202 else {
2203 widget->setPalette(paletteGray);
2204 }
2205}
2206
2207// Bnc Text
2208////////////////////////////////////////////////////////////////////////////
2209void bncWindow::slotBncTextChanged(){
2210
2211 const static QPalette paletteWhite(QColor(255, 255, 255));
2212 const static QPalette paletteGray(QColor(230, 230, 230));
2213
2214 bool enable = true;
2215
2216 // Proxy
2217 //------
2218 if (sender() == 0 || sender() == _proxyHostLineEdit) {
2219 enable = !_proxyHostLineEdit->text().isEmpty();
2220 enableWidget(enable, _proxyPortLineEdit);
2221 }
2222
2223 // RINEX Observations
2224 // ------------------
2225 if (sender() == 0 || sender() == _rnxPathLineEdit) {
2226 enable = !_rnxPathLineEdit->text().isEmpty();
2227 enableWidget(enable, _rnxIntrComboBox);
2228 enableWidget(enable, _rnxSamplSpinBox);
2229 enableWidget(enable, _rnxSkelLineEdit);
2230 enableWidget(enable, _rnxFileCheckBox);
2231 enableWidget(enable, _rnxScrpLineEdit);
2232 enableWidget(enable, _rnxV2Priority);
2233 enableWidget(enable, _rnxV3CheckBox);
2234
2235 bool enable1 = true;
2236 enable1 = _rnxV3CheckBox->isChecked();
2237 if (enable && enable1) {
2238 enableWidget(false, _rnxV2Priority);
2239 }
2240 if (enable && !enable1) {
2241 enableWidget(true, _rnxV2Priority);
2242 }
2243 }
2244
2245 // RINEX Observations, Signal Priority
2246 // -----------------------------------
2247 if (sender() == 0 || sender() == _rnxV3CheckBox) {
2248 if (!_rnxPathLineEdit->text().isEmpty()) {
2249 enableWidget(enable, _rnxIntrComboBox);
2250 enable = !_rnxV3CheckBox->isChecked();
2251 enableWidget(enable, _rnxV2Priority);
2252 }
2253 }
2254
2255 // RINEX Ephemeris
2256 // ---------------
2257 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _outEphPortLineEdit) {
2258 enable = !_ephPathLineEdit->text().isEmpty() || !_outEphPortLineEdit->text().isEmpty();
2259 enableWidget(enable, _ephIntrComboBox);
2260 enableWidget(enable, _ephV3CheckBox);
2261 enableWidget(enable, _ephV3filenameCheckBox);
2262 }
2263
2264 // Broadcast Corrections
2265 // ---------------------
2266 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2267 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2268 enableWidget(enable, _corrIntrComboBox);
2269 }
2270
2271 // Feed Engine
2272 // -----------
2273 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2274 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2275 enableWidget(enable, _waitTimeSpinBox);
2276 enableWidget(enable, _binSamplSpinBox);
2277 }
2278
2279 // Serial Output
2280 // -------------
2281 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
2282 sender() == _serialAutoNMEAComboBox) {
2283 enable = !_serialMountPointLineEdit->text().isEmpty();
2284 enableWidget(enable, _serialPortNameLineEdit);
2285 enableWidget(enable, _serialBaudRateComboBox);
2286 enableWidget(enable, _serialParityComboBox);
2287 enableWidget(enable, _serialDataBitsComboBox);
2288 enableWidget(enable, _serialStopBitsComboBox);
2289 enableWidget(enable, _serialFlowControlComboBox);
2290 enableWidget(enable, _serialAutoNMEAComboBox);
2291 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() == "Auto";
2292 enableWidget(enable2, _serialFileNMEALineEdit);
2293 bool enable3 = enable && _serialAutoNMEAComboBox->currentText().contains("Manual");
2294 enableWidget(enable3, _serialHeightNMEALineEdit);
2295 enableWidget(enable3, _serialManualNMEASamplingSpinBox);
2296 }
2297
2298 // Outages
2299 // -------
2300 if (sender() == 0 || sender() == _obsRateComboBox) {
2301 enable = !_obsRateComboBox->currentText().isEmpty();
2302 enableWidget(enable, _adviseFailSpinBox);
2303 enableWidget(enable, _adviseRecoSpinBox);
2304 enableWidget(enable, _adviseScriptLineEdit);
2305 }
2306
2307 // Miscellaneous
2308 // -------------
2309 if (sender() == 0 || sender() == _miscMountLineEdit) {
2310 enable = !_miscMountLineEdit->text().isEmpty();
2311 enableWidget(enable, _perfIntrComboBox);
2312 enableWidget(enable, _scanRTCMCheckBox);
2313 enableWidget(enable, _miscPortLineEdit);
2314 }
2315
2316 // Enable/disable Broadcast Ephemerides
2317 // ------------------------------------
2318 if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2319 enable = !_uploadEphHostLineEdit->text().isEmpty();
2320 enableWidget(enable, _uploadEphPortLineEdit);
2321 enableWidget(enable, _uploadEphMountpointLineEdit);
2322 enableWidget(enable, _uploadEphPasswordLineEdit);
2323 enableWidget(enable, _uploadEphSampleSpinBox);
2324 }
2325
2326 // Combine Corrections
2327 // -------------------
2328 if (sender() == 0 || sender() == _cmbTable) {
2329 int iRow = _cmbTable->rowCount();
2330 if (iRow > 0) {
2331 enableWidget(true, _cmbMethodComboBox);
2332 enableWidget(true, _cmbMaxresLineEdit);
2333 enableWidget(true, _cmbSamplSpinBox);
2334 enableWidget(true, _cmbUseGlonass);
2335 }
2336 else {
2337 enableWidget(false, _cmbMethodComboBox);
2338 enableWidget(false, _cmbMaxresLineEdit);
2339 enableWidget(false, _cmbSamplSpinBox);
2340 enableWidget(false, _cmbUseGlonass);
2341 }
2342 }
2343
2344 // Upload(clk)
2345 // -----------
2346 int iRow = _uploadTable->rowCount();
2347 if (iRow > 0) {
2348 enableWidget(true, _uploadIntrComboBox);
2349 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2350 enableWidget(true, _uploadSamplClkRnxSpinBox);
2351 enableWidget(true, _uploadSamplSp3SpinBox);
2352 enableWidget(true, _uploadAntexFile);
2353 }
2354 else {
2355 enableWidget(false, _uploadIntrComboBox);
2356 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2357 enableWidget(false, _uploadSamplClkRnxSpinBox);
2358 enableWidget(false, _uploadSamplSp3SpinBox);
2359 enableWidget(false, _uploadAntexFile);
2360 }
2361
2362 // QC
2363 // --
2364 if (sender() == 0 || sender() == _reqcActionComboBox || sender() == _reqcSkyPlotSignals) {
2365 enable = !_reqcActionComboBox->currentText().isEmpty();
2366 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2367// bool enablePlot = !_reqcSkyPlotSignals->text().isEmpty();
2368 enableWidget(enable, _reqcObsFileChooser);
2369 enableWidget(enable, _reqcNavFileChooser);
2370 enableWidget(enable, _reqcOutLogLineEdit);
2371 enableWidget(enable && enable10, _reqcEditOptionButton);
2372 enableWidget(enable && enable10, _reqcOutObsLineEdit);
2373 enableWidget(enable && enable10, _reqcOutNavLineEdit);
2374 enableWidget(enable && !enable10, _reqcLogSummaryOnly);
2375 enableWidget(enable && !enable10, _reqcSkyPlotSignals);
2376// enableWidget(enable && !enable10 && enablePlot, _reqcPlotDirLineEdit);
2377 enableWidget(enable && !enable10, _reqcPlotDirLineEdit);
2378 }
2379
2380 // SP3 File Comparison
2381 // -------------------
2382 if (sender() == 0 || sender() == _sp3CompFileChooser) {
2383 enable = !_sp3CompFileChooser->fileName().isEmpty();
2384 enableWidget(enable, _sp3CompLogLineEdit);
2385 enableWidget(enable, _sp3CompExclude);
2386 }
2387
2388 enableStartStop();
2389}
2390
2391//
2392////////////////////////////////////////////////////////////////////////////
2393void bncWindow::slotAddCmbRow() {
2394 int iRow = _cmbTable->rowCount();
2395 _cmbTable->insertRow(iRow);
2396 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2397 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2398 }
2399}
2400
2401//
2402////////////////////////////////////////////////////////////////////////////
2403void bncWindow::slotDelCmbRow() {
2404
2405 const static QPalette paletteWhite(QColor(255, 255, 255));
2406 const static QPalette paletteGray(QColor(230, 230, 230));
2407
2408 int nRows = _cmbTable->rowCount();
2409 bool flg[nRows];
2410 for (int iRow = 0; iRow < nRows; iRow++) {
2411 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2412 flg[iRow] = true;
2413 }
2414 else {
2415 flg[iRow] = false;
2416 }
2417 }
2418 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2419 if (flg[iRow]) {
2420 _cmbTable->removeRow(iRow);
2421 }
2422 }
2423 nRows = _cmbTable->rowCount();
2424 if (nRows < 1) {
2425 enableWidget(false, _cmbMethodComboBox);
2426 enableWidget(false, _cmbMaxresLineEdit);
2427 enableWidget(false, _cmbSamplSpinBox);
2428 enableWidget(false, _cmbUseGlonass);
2429 }
2430}
2431
2432//
2433////////////////////////////////////////////////////////////////////////////
2434void bncWindow::populateCmbTable() {
2435
2436 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2437 _cmbTable->removeRow(iRow);
2438 }
2439
2440 bncSettings settings;
2441
2442 int iRow = -1;
2443 QListIterator<QString> it(settings.value("cmbStreams").toStringList());
2444 while (it.hasNext()) {
2445 QStringList hlp = it.next().split(" ");
2446 if (hlp.size() > 2) {
2447 ++iRow;
2448 _cmbTable->insertRow(iRow);
2449 }
2450 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2451 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2452 }
2453 }
2454}
2455
2456//
2457////////////////////////////////////////////////////////////////////////////
2458void bncWindow::slotAddUploadRow() {
2459 int iRow = _uploadTable->rowCount();
2460 _uploadTable->insertRow(iRow);
2461 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2462 if (iCol == 3) {
2463 QLineEdit* passwd = new QLineEdit();
2464 passwd->setFrame(false);
2465 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2466 _uploadTable->setCellWidget(iRow, iCol, passwd);
2467 }
2468 else if (iCol == 4) {
2469 QComboBox* system = new QComboBox();
2470 system->setEditable(false);
2471 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2472 system->setFrame(false);
2473 _uploadTable->setCellWidget(iRow, iCol, system);
2474 }
2475 else if (iCol == 5) {
2476 QCheckBox* com = new QCheckBox();
2477 _uploadTable->setCellWidget(iRow, iCol, com);
2478 }
2479 else if (iCol == 11) {
2480 bncTableItem* bncIt = new bncTableItem();
2481 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2482 _uploadTable->setItem(iRow, iCol, bncIt);
2483 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2484 }
2485 else {
2486 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2487 }
2488 }
2489}
2490
2491//
2492////////////////////////////////////////////////////////////////////////////
2493void bncWindow::slotDelUploadRow() {
2494 BNC_CORE->_uploadTableItems.clear();
2495 int nRows = _uploadTable->rowCount();
2496 bool flg[nRows];
2497 for (int iRow = 0; iRow < nRows; iRow++) {
2498 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2499 flg[iRow] = true;
2500 }
2501 else {
2502 flg[iRow] = false;
2503 }
2504 }
2505 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2506 if (flg[iRow]) {
2507 _uploadTable->removeRow(iRow);
2508 }
2509 }
2510 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2511 BNC_CORE->_uploadTableItems[iRow] =
2512 (bncTableItem*) _uploadTable->item(iRow, 11);
2513 }
2514 nRows = _uploadTable->rowCount();
2515 if (nRows < 1) {
2516 enableWidget(false, _uploadIntrComboBox);
2517 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2518 enableWidget(false, _uploadSamplSp3SpinBox);
2519 enableWidget(false, _uploadSamplClkRnxSpinBox);
2520 enableWidget(false, _uploadAntexFile);
2521 }
2522}
2523
2524//
2525////////////////////////////////////////////////////////////////////////////
2526void bncWindow::populateUploadTable() {
2527 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2528 _uploadTable->removeRow(iRow);
2529 }
2530
2531 bncSettings settings;
2532
2533 int iRow = -1;
2534 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2535 while (it.hasNext()) {
2536 QStringList hlp = it.next().split(",");
2537 if (hlp.size() > 6) {
2538 ++iRow;
2539 _uploadTable->insertRow(iRow);
2540 }
2541 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2542 if (iCol == 3) {
2543 QLineEdit* passwd = new QLineEdit();
2544 passwd->setFrame(false);
2545 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2546 passwd->setText(hlp[iCol]);
2547 _uploadTable->setCellWidget(iRow, iCol, passwd);
2548 }
2549 else if (iCol == 4) {
2550 QComboBox* system = new QComboBox();
2551 system->setEditable(false);
2552 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2553 system->setFrame(false);
2554 system->setCurrentIndex(system->findText(hlp[iCol]));
2555 _uploadTable->setCellWidget(iRow, iCol, system);
2556 }
2557 else if (iCol == 5) {
2558 QCheckBox* com = new QCheckBox();
2559 if (hlp[iCol].toInt() == Qt::Checked) {
2560 com->setCheckState(Qt::Checked);
2561 }
2562 _uploadTable->setCellWidget(iRow, iCol, com);
2563 }
2564 else if (iCol == 11) {
2565 bncTableItem* bncIt = new bncTableItem();
2566 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2567 _uploadTable->setItem(iRow, iCol, bncIt);
2568 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2569 }
2570 else {
2571 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2572 }
2573 }
2574 }
2575}
2576
2577//
2578////////////////////////////////////////////////////////////////////////////
2579void bncWindow::slotSetUploadTrafo() {
2580 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2581 dlg->exec();
2582 delete dlg;
2583}
2584
2585// Progress Bar Change
2586////////////////////////////////////////////////////////////////////////////
2587void bncWindow::slotPostProcessingProgress(int nEpo) {
2588 _actStart->setText(QString("%1 Epochs").arg(nEpo));
2589}
2590
2591// Post-Processing Reqc Finished
2592////////////////////////////////////////////////////////////////////////////
2593void bncWindow::slotPostProcessingFinished() {
2594 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
2595 _runningPPP = false;
2596 _runningEdit = false;
2597 _runningQC = false;
2598 _runningSp3Comp = false;
2599 _actStart->setText(tr("Sta&rt"));
2600 enableStartStop();
2601}
2602
2603// Edit teqc-like editing options
2604////////////////////////////////////////////////////////////////////////////
2605void bncWindow::slotReqcEditOption() {
2606 saveOptions();
2607 reqcDlg* dlg = new reqcDlg(this);
2608 dlg->move(this->pos().x()+50, this->pos().y()+50);
2609 dlg->exec();
2610 delete dlg;
2611}
2612
2613// Enable/Disable Start and Stop Buttons
2614////////////////////////////////////////////////////////////////////////////
2615void bncWindow::enableStartStop() {
2616 if ( running() ) {
2617 _actStart->setEnabled(false);
2618 if (_runningRealTime || _runningPPP) {
2619 _actStop->setEnabled(true);
2620 }
2621 }
2622 else {
2623 _actStart->setEnabled(true);
2624 _actStop->setEnabled(false);
2625 }
2626}
2627
2628// Show Map
2629////////////////////////////////////////////////////////////////////////////
2630void bncWindow::slotMapMountPoints() {
2631 saveOptions();
2632 t_bncMap* bncMap = new t_bncMap(this);
2633 bncMap->setMinimumSize(800, 600);
2634 bncMap->setWindowTitle("Selected Mountpoints");
2635
2636 bncSettings settings;
2637 QListIterator<QString> it(settings.value("mountPoints").toStringList());
2638 while (it.hasNext()) {
2639 QStringList hlp = it.next().split(" ");
2640 if (hlp.size() < 5) continue;
2641 QUrl url(hlp[0]);
2642 double latDeg = hlp[2].toDouble();
2643 double lonDeg = hlp[3].toDouble();
2644 bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
2645 }
2646
2647 bncMap->show();
2648}
2649
2650// Show Map
2651////////////////////////////////////////////////////////////////////////////
2652void bncWindow::slotMapPPP() {
2653#ifdef QT_WEBKIT
2654 saveOptions();
2655 enableWidget(false, _pppWidgets._mapWinButton);
2656 enableWidget(false, _pppWidgets._useGoogleMap);
2657 enableWidget(false, _pppWidgets._useOpenStreetMap);
2658 enableWidget(false, _pppWidgets._mapWinDotSize);
2659 enableWidget(false, _pppWidgets._mapWinDotColor);
2660
2661 if (!_mapWin) {
2662 _mapWin = new bncMapWin(this);
2663 connect(_mapWin, SIGNAL(mapClosed()), this, SLOT(slotMapPPPClosed()));
2664 connect(BNC_CORE, SIGNAL(newPosition(QByteArray, bncTime, QVector<double>)),
2665 _mapWin, SLOT(slotNewPosition(QByteArray, bncTime, QVector<double>)));
2666 }
2667 _mapWin->show();
2668#else
2669 QMessageBox::information(this, "Information",
2670 "Qt Library compiled without QtWebKit");
2671#endif
2672}
2673
2674// Show Map
2675////////////////////////////////////////////////////////////////////////////
2676void bncWindow::slotMapPPPClosed() {
2677#ifdef QT_WEBKIT
2678 enableWidget(true, _pppWidgets._mapWinButton);
2679 enableWidget(true, _pppWidgets._useGoogleMap);
2680 enableWidget(true, _pppWidgets._useOpenStreetMap);
2681 enableWidget(true, _pppWidgets._mapWinDotSize);
2682 enableWidget(true, _pppWidgets._mapWinDotColor);
2683 if (_mapWin) {
2684 QListIterator<bncGetThread*> it(_threads);
2685 while (it.hasNext()) {
2686 bncGetThread* thread = it.next();
2687 thread->disconnect(_mapWin);
2688 }
2689 _mapWin->deleteLater();
2690 _mapWin = 0;
2691 }
2692#endif
2693}
Note: See TracBrowser for help on using the repository browser.