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

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