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

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