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

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