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

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

some gui preparation for sinex_tro file output

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