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

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