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

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