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

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