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

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