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

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