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

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

Tab design modified

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