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

Last change on this file since 5699 was 5699, checked in by mervart, 8 years ago
File size: 152.2 KB
Line 
1// Part of BNC, a utility for retrieving decoding and
2// converting GNSS data streams from NTRIP broadcasters.
3//
4// Copyright (C) 2007
5// German Federal Agency for Cartography and Geodesy (BKG)
6// http://www.bkg.bund.de
7// Czech Technical University Prague, Department of Geodesy
8// http://www.fsv.cvut.cz
9//
10// Email: euref-ip@bkg.bund.de
11//
12// This program is free software; you can redistribute it and/or
13// modify it under the terms of the GNU General Public License
14// as published by the Free Software Foundation, version 2.
15//
16// This program is distributed in the hope that it will be useful,
17// but WITHOUT ANY WARRANTY; without even the implied warranty of
18// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19// GNU General Public License for more details.
20//
21// You should have received a copy of the GNU General Public License
22// along with this program; if not, write to the Free Software
23// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24
25/* -------------------------------------------------------------------------
26 * BKG NTRIP Client
27 * -------------------------------------------------------------------------
28 *
29 * Class: bncWindow
30 *
31 * Purpose: This class implements the main application window.
32 *
33 * Author: L. Mervart
34 *
35 * Created: 24-Dec-2005
36 *
37 * Changes:
38 *
39 * -----------------------------------------------------------------------*/
40
41#include <iostream>
42
43#include <unistd.h>
44#include "bncwindow.h"
45#include "bnccore.h"
46#include "bncgetthread.h"
47#include "bnctabledlg.h"
48#include "bncipport.h"
49#include "bncudpport.h"
50#include "bncserialport.h"
51#include "bnchlpdlg.h"
52#include "bnchtml.h"
53#include "bnctableitem.h"
54#include "bncsettings.h"
55#include "bncfigure.h"
56#include "bncfigurelate.h"
57#include "bncfigureppp.h"
58#include "bncversion.h"
59#include "bncbytescounter.h"
60#include "bncsslconfig.h"
61#include "upload/bnccustomtrafo.h"
62#include "upload/bncephuploadcaster.h"
63#include "qtfilechooser.h"
64#include "reqcdlg.h"
65#include "bncmap.h"
66#ifdef 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._corrHostPort, 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
1155 pppGroup2->setLayout(pppLayout2);
1156
1157 QGridLayout* pppLayout3 = new QGridLayout();
1158 ir = 0;
1159 pppLayout3->addWidget(new QLabel("<b>Precise Point Positioning (Options)</b>"), ir, 0, 1, 2, Qt::AlignLeft);
1160 ++ir;
1161 pppLayout3->addWidget(new QLabel("GPS LCs"), ir, 0, Qt::AlignLeft);
1162 pppLayout3->addWidget(_pppWidgets._lcGPS, ir, 1);
1163 pppLayout3->addItem(new QSpacerItem(4*ww, 0), ir, 2);
1164 pppLayout3->addWidget(new QLabel("Sigma C1"), ir, 3, Qt::AlignLeft);
1165 pppLayout3->addWidget(_pppWidgets._sigmaC1, ir, 4); _pppWidgets._sigmaC1->setMaximumWidth(8*ww);
1166 pppLayout3->addWidget(new QLabel("Sigma L1"), ir, 5, Qt::AlignLeft);
1167 pppLayout3->addWidget(_pppWidgets._sigmaL1, ir, 6); _pppWidgets._sigmaL1->setMaximumWidth(8*ww);
1168 ++ir;
1169 pppLayout3->addWidget(new QLabel("GLONASS LCs"), ir, 0, Qt::AlignLeft);
1170 pppLayout3->addWidget(_pppWidgets._lcGLONASS, ir, 1);
1171 ++ir;
1172 pppLayout3->addWidget(new QLabel("Galileo LCs"), ir, 0, Qt::AlignLeft);
1173 pppLayout3->addWidget(_pppWidgets._lcGalileo, ir, 1);
1174 ++ir;
1175 pppLayout3->addWidget(new QLabel("Wait for corrections"), ir, 0, Qt::AlignLeft);
1176 pppLayout3->addWidget(_pppWidgets._corrWaitTime, ir, 1);
1177 ++ir;
1178 pppLayout3->addWidget(new QLabel(""), ir, 0);
1179
1180 pppGroup3->setLayout(pppLayout3);
1181
1182 // Reqc Processing
1183 // ---------------
1184 _reqcActionComboBox = new QComboBox();
1185 _reqcActionComboBox->setEditable(false);
1186 _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
1187 ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
1188 if (ik != -1) {
1189 _reqcActionComboBox->setCurrentIndex(ik);
1190 }
1191 connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
1192 this, SLOT(slotBncTextChanged()));
1193
1194 QGridLayout* reqcLayout = new QGridLayout;
1195 _reqcActionComboBox->setMinimumWidth(15*ww);
1196 _reqcActionComboBox->setMaximumWidth(15*ww);
1197
1198 _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1199 _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
1200 _reqcObsFileChooser->setWhatsThis(tr("Specify the full path to an observation file in RINEX v2 or v3 format."));
1201 _reqcObsFileChooser->setMinimumWidth(15*ww);
1202 _reqcObsFileChooser->setMaximumWidth(15*ww);
1203
1204 _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1205 _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
1206 _reqcNavFileChooser->setWhatsThis(tr("Specify the full path to a RINEX v2 or v3 navigation file."));
1207 _reqcNavFileChooser->setMinimumWidth(15*ww);
1208 _reqcNavFileChooser->setMaximumWidth(15*ww);
1209
1210 _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
1211 _reqcOutObsLineEdit->setWhatsThis(tr("Specify the full path to a RINEX observation output file."));
1212 _reqcOutObsLineEdit->setMinimumWidth(15*ww);
1213 _reqcOutObsLineEdit->setMaximumWidth(15*ww);
1214
1215 _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
1216 _reqcOutNavLineEdit->setWhatsThis(tr("Specify the full path to a RINEX navigation output file."));
1217 _reqcOutNavLineEdit->setMinimumWidth(15*ww);
1218 _reqcOutNavLineEdit->setMaximumWidth(15*ww);
1219
1220 _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
1221 _reqcOutLogLineEdit->setWhatsThis(tr("Specify the full path to a logfile."));
1222 _reqcOutLogLineEdit->setMinimumWidth(15*ww);
1223 _reqcOutLogLineEdit->setMaximumWidth(15*ww);
1224
1225 _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
1226 _reqcPlotDirLineEdit->setWhatsThis(tr("Specify the directory name for saving plots."));
1227 _reqcPlotDirLineEdit->setMinimumWidth(15*ww);
1228 _reqcPlotDirLineEdit->setMaximumWidth(15*ww);
1229
1230 _reqcSkyPlotSystems = new QComboBox();
1231 _reqcSkyPlotSystems->setEditable(false);
1232 _reqcSkyPlotSystems->addItems(QString("ALL,GPS,GLONASS,Galileo").split(","));
1233 ik = _reqcSkyPlotSystems->findText(settings.value("reqcSkyPlotSystems").toString());
1234 if (ik != -1) {
1235 _reqcSkyPlotSystems->setCurrentIndex(ik);
1236 }
1237
1238 ir = 0;
1239 reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check."),ir, 0, 1, 20);
1240 ++ir;
1241 reqcLayout->addWidget(new QLabel("Action"), ir, 0, Qt::AlignLeft);
1242 reqcLayout->addWidget(_reqcActionComboBox, ir, 1, Qt::AlignLeft);
1243 _reqcEditOptionButton = new QPushButton("Set Edit Options");
1244 reqcLayout->addWidget(_reqcEditOptionButton, ir, 3, Qt::AlignRight);
1245 ++ir;
1246 reqcLayout->addWidget(new QLabel("Input files (full path)"), ir, 0, Qt::AlignLeft);
1247 reqcLayout->addWidget(_reqcObsFileChooser, ir, 1, Qt::AlignRight);
1248 reqcLayout->addWidget(new QLabel("Obs"), ir, 2, Qt::AlignLeft);
1249 reqcLayout->addWidget(_reqcNavFileChooser, ir, 3, Qt::AlignRight);
1250 reqcLayout->addWidget(new QLabel("Nav"), ir, 4, Qt::AlignLeft);
1251 ++ir;
1252 reqcLayout->addWidget(new QLabel("Output files (full path)"), ir, 0, Qt::AlignLeft);
1253 reqcLayout->addWidget(_reqcOutObsLineEdit, ir, 1, Qt::AlignRight);
1254 reqcLayout->addWidget(new QLabel("Obs"), ir, 2, Qt::AlignLeft);
1255 reqcLayout->addWidget(_reqcOutNavLineEdit, ir, 3, Qt::AlignRight);
1256 reqcLayout->addWidget(new QLabel("Nav"), ir, 4, Qt::AlignLeft);
1257 ++ir;
1258 reqcLayout->addWidget(_reqcOutLogLineEdit, ir, 1, Qt::AlignRight);
1259 reqcLayout->addWidget(new QLabel("Log"), ir, 2, Qt::AlignLeft);
1260 ++ir;
1261 reqcLayout->addWidget(new QLabel("Directory for plots"), ir, 0, Qt::AlignLeft);
1262 reqcLayout->addWidget(_reqcPlotDirLineEdit, ir, 1, Qt::AlignRight);
1263 ++ir;
1264 reqcLayout->addWidget(new QLabel("Sky plots for"), ir, 0, Qt::AlignLeft);
1265 reqcLayout->addWidget(_reqcSkyPlotSystems, ir, 1, Qt::AlignRight);
1266 ++ir;
1267 reqcLayout->addWidget(new QLabel(""), ir, 1);
1268 reqcLayout->setRowStretch(ir, 999);
1269
1270 reqcLayout->setColumnMinimumWidth(2, 8*ww);
1271 reqcLayout->setColumnMinimumWidth(4, 8*ww);
1272
1273 reqcgroup->setLayout(reqcLayout);
1274
1275 connect(_reqcEditOptionButton, SIGNAL(clicked()),
1276 this, SLOT(slotReqcEditOption()));
1277
1278 // Combine Corrections
1279 // -------------------
1280 QGridLayout* cmbLayout = new QGridLayout;
1281
1282 populateCmbTable();
1283 cmbLayout->addWidget(_cmbTable, 0, 0, 6, 3);
1284 cmbLayout->addWidget(new QLabel(" "), 0, 5);
1285 cmbLayout->addWidget(new QLabel("Combine Broadcast Correction streams."), 0, 6, 1, 50);
1286 cmbLayout->addWidget(new QLabel(" "), 1, 5);
1287 cmbLayout->addWidget(addCmbRowButton, 1, 6);
1288 cmbLayout->addWidget(delCmbRowButton, 1, 7);
1289 cmbLayout->addWidget(new QLabel(" "), 2, 5);
1290 cmbLayout->addWidget(new QLabel("Method"), 2, 6, Qt::AlignRight);
1291 cmbLayout->addWidget(_cmbMethodComboBox, 2, 7, Qt::AlignRight);
1292 cmbLayout->addWidget(new QLabel(" "), 3, 5);
1293 cmbLayout->addWidget(new QLabel("Maximal Residuum"), 3, 6, Qt::AlignRight);
1294 cmbLayout->addWidget(_cmbMaxresLineEdit, 3, 7, Qt::AlignRight);
1295 cmbLayout->addWidget(new QLabel(" "), 4, 5);
1296 cmbLayout->addWidget(new QLabel("Sampling"), 4, 6, Qt::AlignRight);
1297 cmbLayout->addWidget(_cmbSamplSpinBox, 4, 7, Qt::AlignRight);
1298 cmbLayout->addWidget(new QLabel(" "), 5, 0);
1299
1300 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1301 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
1302
1303 cmbgroup->setLayout(cmbLayout);
1304
1305 // Upload Layout (Clocks)
1306 // ----------------------
1307 QGridLayout* uploadHlpLayout = new QGridLayout();
1308
1309 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1310 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1311 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
1312
1313 uploadHlpLayout->addWidget(addUploadRowButton, 0, 0);
1314 uploadHlpLayout->addWidget(delUploadRowButton, 0, 1);
1315 uploadHlpLayout->addWidget(new QLabel("Interval"), 0, 2, Qt::AlignRight);
1316 uploadHlpLayout->addWidget(_uploadIntrComboBox, 0, 3);
1317 uploadHlpLayout->addWidget(new QLabel(" Sampling: Orb"), 0, 4, Qt::AlignRight);
1318 uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox, 0, 5);
1319 uploadHlpLayout->addWidget(new QLabel("SP3"), 0, 6, Qt::AlignRight);
1320 uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox, 0, 7);
1321 uploadHlpLayout->addWidget(new QLabel("RNX"), 0, 8, Qt::AlignRight);
1322 uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox, 0, 9);
1323 uploadHlpLayout->addWidget(setUploadTrafoButton, 0,10);
1324
1325 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1326 populateUploadTable();
1327
1328 uploadLayout->addWidget(new QLabel("Upload RTCMv3 Broadcast Corrections to caster."));
1329 uploadLayout->addWidget(_uploadTable);
1330 uploadLayout->addLayout(uploadHlpLayout);
1331
1332 uploadgroup->setLayout(uploadLayout);
1333
1334 // Upload Layout (Ephemeris)
1335 // -------------------------
1336 QGridLayout* uploadLayoutEph = new QGridLayout;
1337
1338 uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1339 _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1340 _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1341 _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1342
1343 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster."), 0, 0, 1, 50);
1344 uploadLayoutEph->addWidget(new QLabel("Host"), 1, 0);
1345 uploadLayoutEph->addWidget(_uploadEphHostLineEdit, 1, 1, 1, 3);
1346 uploadLayoutEph->addWidget(new QLabel(" Port"), 1, 4, Qt::AlignRight);
1347 uploadLayoutEph->addWidget(_uploadEphPortLineEdit, 1, 5, 1, 1);
1348 uploadLayoutEph->addWidget(new QLabel("Mountpoint "), 2, 0);
1349 uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit, 2, 1);
1350 uploadLayoutEph->addWidget(new QLabel(" Password"), 2, 2, Qt::AlignRight);
1351 uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit, 2, 3);
1352 uploadLayoutEph->addWidget(new QLabel("Sampling"), 3, 0);
1353 uploadLayoutEph->addWidget(_uploadEphSampleSpinBox, 3, 1);
1354 uploadLayoutEph->addWidget(new QLabel("Uploaded"), 4, 0);
1355 uploadLayoutEph->addWidget(_uploadEphBytesCounter, 4, 1);
1356 uploadLayoutEph->addWidget(new QLabel(" "), 5, 0);
1357 uploadLayoutEph->addWidget(new QLabel(" "), 6, 0);
1358
1359 uploadEphgroup->setLayout(uploadLayoutEph);
1360
1361 connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1362 this, SLOT(slotBncTextChanged()));
1363
1364 // Main Layout
1365 // -----------
1366 QGridLayout* mLayout = new QGridLayout;
1367 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
1368 mLayout->addWidget(_aogroup, 0,0);
1369 mLayout->addWidget(_mountPointsTable, 1,0);
1370 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
1371 mLayout->addWidget(_loggroup, 2,0);
1372
1373 _canvas->setLayout(mLayout);
1374
1375 // WhatsThis
1376 // ---------
1377 _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>"));
1378 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1379 _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>"));
1380 _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>"));
1381 _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>"));
1382 _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."));
1383 _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."));
1384 _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."));
1385 _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."));
1386 _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."));
1387 _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>"));
1388 _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."));
1389 _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."));
1390 _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."));
1391 _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>"));
1392 _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>"));
1393 _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>"));
1394 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1395 _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p>"));
1396
1397 _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>"));
1398 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1399 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1400 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of the Broadcast Ephemeris Correction files.</p>"));
1401 _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>"));
1402 _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>"));
1403 _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>"));
1404 _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>"));
1405 _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>"));
1406 _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."));
1407 _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>"));
1408 _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>"));
1409 _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>"));
1410 _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."));
1411 _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)."));
1412 _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."));
1413 _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."));
1414 _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."));
1415 _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>"));
1416 _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."));
1417 _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>."));
1418 _serialMountPointLineEdit->setWhatsThis(tr("<p>Enter a 'Mountpoint' to forward the corresponding stream to a serial connected receiver.</p>"));
1419 _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>"));
1420 _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>"));
1421 _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>"));
1422 _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>"));
1423 _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>"));
1424 _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>"));
1425 _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>"));
1426 _serialFileNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where NMEA messages coming from your serial connected receiver are saved.</p>"));
1427 _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>"));
1428 _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>"));
1429 _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>"));
1430 _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>"));
1431 _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>"));
1432 _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX v2 or v3 files.</p>"));
1433 _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>"));
1434 _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>"));
1435 _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>"));
1436 _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>"));
1437 _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."));
1438 _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."));
1439 _gmRadioButton->setWhatsThis(tr("<p>Specify Google Maps as the background for your rover positions."));
1440 _osmRadioButton->setWhatsThis(tr("<p>Specify Open Street Map as the background for your rover positions."));
1441 _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>"));
1442 _mapWinDotColorComboBox->setWhatsThis(tr("<p>Specify the color of dots showing the rover track.</p>"));
1443 _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."));
1444 _pppNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where PPP results are saved as NMEA messages.</p>"));
1445 _pppNMEAPortLineEdit->setWhatsThis(tr("<p>Specify an IP port number to output PPP results as NMEA messages through an IP port.</p>"));
1446 _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>"));
1447 _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>"));
1448 _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>"));
1449 _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>"));
1450 _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>"));
1451 _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>"));
1452 _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."));
1453 _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>"));
1454 _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>"));
1455 _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>"));
1456 _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>"));
1457 _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>"));
1458 _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>"));
1459 _pppRefdNLineEdit->setWhatsThis(tr("<p>Enter north antenna excentricity.</p>"));
1460 _pppRefdELineEdit->setWhatsThis(tr("<p>Enter east antenna excentricity.</p>"));
1461 _pppRefdULineEdit->setWhatsThis(tr("<p>Enter up antenna excentricity.</p>"));
1462 _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."));
1463 _pppSync->setWhatsThis(tr(
1464 "<p> Zero value (or empty field, default) means that BNC processes each epoch of data "
1465 "immediately after its arrival using satellite clock corrections available at "
1466 "that time.</p><p> Non-zero value 'Sync Corr' (i.e. 5) means that the epochs of data "
1467 "are buffered and the processing of each epoch is postponed till the satellite clock "
1468 "corrections not older than 'Sync Corr' seconds are available.<p>"));
1469 _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>"));
1470 _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>"));
1471 _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."));
1472 _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>"));
1473 _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>"));
1474 _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>"));
1475 _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>"));
1476 _postObsFileChooser->setWhatsThis(tr("Full path to RINEX v2/v3 Observation file."));
1477 _postNavFileChooser->setWhatsThis(tr("Full path to RINEX v2/v3 Navigation file."));
1478 _postCorrFileChooser->setWhatsThis(tr("Full path to Broadcast Corrections file as previously saved with BNC in plain ASCII format."));
1479 _postOutLineEdit->setWhatsThis(tr("Full path to file with post processing PPP results. "));
1480 addCmbRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the mountpoints table."));
1481 delCmbRowButton->setWhatsThis(tr("Hit 'Delete' button to delete the highlighted line from the mountpoints table."));
1482 addUploadRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the stream upload table."));
1483 delUploadRowButton->setWhatsThis(tr("Hit 'Del Row' button to delete the highlighted line from the stream upload table."));
1484 _uploadIntrComboBox->setWhatsThis(tr("Select the length of the SP3 and Clock RINEX files."));
1485 _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."));
1486 _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."));
1487 _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."));
1488 setUploadTrafoButton->setWhatsThis(tr("Hit 'Custom Trafo' to specify your own 14 parameter Helmert Transformation instead of selecting a predefined transformation through 'System' button."));
1489
1490 _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."));
1491 _uploadEphPortLineEdit->setWhatsThis(tr("Specify the IP port of an NTRIP Broadcaster to upload the stream. Default is port 80."));
1492 _uploadEphMountpointLineEdit->setWhatsThis(tr("Specify the mounpoint for stream upload to an NTRIP Broadcaster."));
1493 _uploadEphPasswordLineEdit->setWhatsThis(tr("Specify the stream upload password protecting the mounpoint on an NTRIP Broadcaster."));
1494 _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."));
1495 _uploadEphBytesCounter->setWhatsThis(tr("BNC shows the amount of data uploaded through this stream."));
1496
1497 _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1498 _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
1499 _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>"));
1500
1501 _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1502 _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1503// Weber
1504
1505 // Enable/Disable all Widgets
1506 // --------------------------
1507 slotBncTextChanged();
1508 enableStartStop();
1509
1510 // Auto start
1511 // ----------
1512 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1513 slotStart();
1514 }
1515}
1516
1517// Destructor
1518////////////////////////////////////////////////////////////////////////////
1519bncWindow::~bncWindow() {
1520 delete _caster;
1521 delete _casterEph;
1522}
1523
1524//
1525////////////////////////////////////////////////////////////////////////////
1526void bncWindow::populateMountPointsTable() {
1527
1528 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1529 _mountPointsTable->removeRow(iRow);
1530 }
1531
1532 bncSettings settings;
1533
1534 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1535 int iRow = 0;
1536 while (it.hasNext()) {
1537 QStringList hlp = it.next().split(" ");
1538 if (hlp.size() < 5) continue;
1539 _mountPointsTable->insertRow(iRow);
1540
1541 QUrl url(hlp[0]);
1542
1543 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1544 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1545 QString nmea(hlp[4]);
1546 if (hlp[5] == "S") {
1547 fullPath = hlp[0].replace(0,2,"");
1548 }
1549 QString ntripVersion = "2";
1550 if (hlp.size() >= 6) {
1551 ntripVersion = (hlp[5]);
1552 }
1553
1554 QTableWidgetItem* it;
1555 it = new QTableWidgetItem(url.userInfo());
1556 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1557 _mountPointsTable->setItem(iRow, 0, it);
1558
1559 it = new QTableWidgetItem(fullPath);
1560 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1561 _mountPointsTable->setItem(iRow, 1, it);
1562
1563 it = new QTableWidgetItem(format);
1564 _mountPointsTable->setItem(iRow, 2, it);
1565
1566 if (nmea == "yes") {
1567 it = new QTableWidgetItem(latitude);
1568 _mountPointsTable->setItem(iRow, 3, it);
1569 it = new QTableWidgetItem(longitude);
1570 _mountPointsTable->setItem(iRow, 4, it);
1571 } else {
1572 it = new QTableWidgetItem(latitude);
1573 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1574 _mountPointsTable->setItem(iRow, 3, it);
1575 it = new QTableWidgetItem(longitude);
1576 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1577 _mountPointsTable->setItem(iRow, 4, it);
1578 }
1579
1580 it = new QTableWidgetItem(nmea);
1581 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1582 _mountPointsTable->setItem(iRow, 5, it);
1583
1584 it = new QTableWidgetItem(ntripVersion);
1585 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1586 _mountPointsTable->setItem(iRow, 6, it);
1587
1588 bncTableItem* bncIt = new bncTableItem();
1589 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1590 _mountPointsTable->setItem(iRow, 7, bncIt);
1591
1592 iRow++;
1593 }
1594
1595 _mountPointsTable->sortItems(1);
1596
1597 enableStartStop();
1598}
1599
1600// Retrieve Table
1601////////////////////////////////////////////////////////////////////////////
1602void bncWindow::slotAddMountPoints() {
1603
1604 bncSettings settings;
1605 QString proxyHost = settings.value("proxyHost").toString();
1606 int proxyPort = settings.value("proxyPort").toInt();
1607 if (proxyHost != _proxyHostLineEdit->text() ||
1608 proxyPort != _proxyPortLineEdit->text().toInt()) {
1609 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1610 "changed. Use the new ones?",
1611 QMessageBox::Yes, QMessageBox::No,
1612 QMessageBox::NoButton);
1613 if (iRet == QMessageBox::Yes) {
1614 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1615 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1616 }
1617 }
1618
1619 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1620 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1621
1622 QMessageBox msgBox;
1623 msgBox.setIcon(QMessageBox::Question);
1624 msgBox.setWindowTitle("Add Stream");
1625 msgBox.setText("Add stream(s) coming from:");
1626
1627 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1628 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1629 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1630 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1631 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1632
1633 msgBox.exec();
1634
1635 if (msgBox.clickedButton() == buttonNtrip) {
1636 bncTableDlg* dlg = new bncTableDlg(this);
1637 dlg->move(this->pos().x()+50, this->pos().y()+50);
1638 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1639 this, SLOT(slotNewMountPoints(QStringList*)));
1640 dlg->exec();
1641 delete dlg;
1642 } else if (msgBox.clickedButton() == buttonIP) {
1643 bncIpPort* ipp = new bncIpPort(this);
1644 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1645 this, SLOT(slotNewMountPoints(QStringList*)));
1646 ipp->exec();
1647 delete ipp;
1648 } else if (msgBox.clickedButton() == buttonUDP) {
1649 bncUdpPort* udp = new bncUdpPort(this);
1650 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1651 this, SLOT(slotNewMountPoints(QStringList*)));
1652 udp->exec();
1653 delete udp;
1654 } else if (msgBox.clickedButton() == buttonSerial) {
1655 bncSerialPort* sep = new bncSerialPort(this);
1656 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1657 this, SLOT(slotNewMountPoints(QStringList*)));
1658 sep->exec();
1659 delete sep;
1660 } else if (msgBox.clickedButton() == buttonCancel) {
1661 // Cancel
1662 }
1663
1664 enableStartStop();
1665}
1666
1667// Delete Selected Mount Points
1668////////////////////////////////////////////////////////////////////////////
1669void bncWindow::slotDeleteMountPoints() {
1670
1671 int nRows = _mountPointsTable->rowCount();
1672 bool flg[nRows];
1673 for (int iRow = 0; iRow < nRows; iRow++) {
1674 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1675 flg[iRow] = true;
1676 }
1677 else {
1678 flg[iRow] = false;
1679 }
1680 }
1681 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1682 if (flg[iRow]) {
1683 _mountPointsTable->removeRow(iRow);
1684 }
1685 }
1686 _actDeleteMountPoints->setEnabled(false);
1687
1688 enableStartStop();
1689}
1690
1691// New Mount Points Selected
1692////////////////////////////////////////////////////////////////////////////
1693void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1694 int iRow = 0;
1695 QListIterator<QString> it(*mountPoints);
1696 while (it.hasNext()) {
1697 QStringList hlp = it.next().split(" ");
1698 QUrl url(hlp[0]);
1699 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1700 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1701 QString nmea(hlp[4]);
1702 if (hlp[5] == "S") {
1703 fullPath = hlp[0].replace(0,2,"");
1704 }
1705 QString ntripVersion = "2";
1706 if (hlp.size() >= 6) {
1707 ntripVersion = (hlp[5]);
1708 }
1709
1710 _mountPointsTable->insertRow(iRow);
1711
1712 QTableWidgetItem* it;
1713 it = new QTableWidgetItem(url.userInfo());
1714 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1715 _mountPointsTable->setItem(iRow, 0, it);
1716
1717 it = new QTableWidgetItem(fullPath);
1718 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1719 _mountPointsTable->setItem(iRow, 1, it);
1720
1721 it = new QTableWidgetItem(format);
1722 _mountPointsTable->setItem(iRow, 2, it);
1723
1724 if (nmea == "yes") {
1725 it = new QTableWidgetItem(latitude);
1726 _mountPointsTable->setItem(iRow, 3, it);
1727 it = new QTableWidgetItem(longitude);
1728 _mountPointsTable->setItem(iRow, 4, it);
1729 } else {
1730 it = new QTableWidgetItem(latitude);
1731 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1732 _mountPointsTable->setItem(iRow, 3, it);
1733 it = new QTableWidgetItem(longitude);
1734 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1735 _mountPointsTable->setItem(iRow, 4, it);
1736 }
1737
1738 it = new QTableWidgetItem(nmea);
1739 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1740 _mountPointsTable->setItem(iRow, 5, it);
1741
1742 it = new QTableWidgetItem(ntripVersion);
1743 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1744 _mountPointsTable->setItem(iRow, 6, it);
1745
1746 bncTableItem* bncIt = new bncTableItem();
1747 _mountPointsTable->setItem(iRow, 7, bncIt);
1748
1749 iRow++;
1750 }
1751 _mountPointsTable->hideColumn(0);
1752 _mountPointsTable->sortItems(1);
1753 delete mountPoints;
1754
1755 enableStartStop();
1756}
1757
1758// Save Options (serialize)
1759////////////////////////////////////////////////////////////////////////////
1760void bncWindow::slotSaveOptions() {
1761 saveOptions();
1762 bncSettings settings;
1763 settings.sync();
1764}
1765
1766// Save Options (memory only)
1767////////////////////////////////////////////////////////////////////////////
1768void bncWindow::saveOptions() {
1769
1770 QStringList mountPoints;
1771 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1772
1773 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1774 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1775 "@" + _mountPointsTable->item(iRow, 1)->text() );
1776
1777 mountPoints.append(url.toString() + " " +
1778 _mountPointsTable->item(iRow, 2)->text()
1779 + " " + _mountPointsTable->item(iRow, 3)->text()
1780 + " " + _mountPointsTable->item(iRow, 4)->text()
1781 + " " + _mountPointsTable->item(iRow, 5)->text()
1782 + " " + _mountPointsTable->item(iRow, 6)->text());
1783 } else {
1784 mountPoints.append(
1785 "//" + _mountPointsTable->item(iRow, 1)->text()
1786 + " " + _mountPointsTable->item(iRow, 2)->text()
1787 + " " + _mountPointsTable->item(iRow, 3)->text()
1788 + " " + _mountPointsTable->item(iRow, 4)->text()
1789 + " " + _mountPointsTable->item(iRow, 5)->text()
1790 + " " + _mountPointsTable->item(iRow, 6)->text());
1791 }
1792 }
1793
1794 QStringList combineStreams;
1795 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1796 QString hlp;
1797 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1798 if (_cmbTable->item(iRow, iCol)) {
1799 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1800 }
1801 }
1802 if (!hlp.isEmpty()) {
1803 combineStreams << hlp;
1804 }
1805 }
1806
1807 QStringList uploadMountpointsOut;
1808 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1809 QString hlp;
1810 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1811 if (_uploadTable->cellWidget(iRow, iCol) &&
1812 (iCol == 3 || iCol == 4 || iCol == 5)) {
1813 if (iCol == 3) {
1814 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1815 hlp += passwd->text() + ",";
1816 }
1817 else if (iCol == 4) {
1818 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1819 hlp += system->currentText() + ",";
1820 }
1821 else if (iCol == 5) {
1822 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1823 QString state; state.setNum(com->checkState());
1824 hlp += state + ",";
1825 }
1826 }
1827 else if (_uploadTable->item(iRow, iCol)) {
1828 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1829 }
1830 }
1831 if (!hlp.isEmpty()) {
1832 uploadMountpointsOut << hlp;
1833 }
1834 }
1835
1836 bncSettings settings;
1837
1838 settings.setValue("startTab", _aogroup->currentIndex());
1839 settings.setValue("statusTab", _loggroup->currentIndex());
1840 settings.setValue("mountPoints", mountPoints);
1841// Network
1842 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1843 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1844 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1845 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1846// General
1847 settings.setValue("logFile", _logFileLineEdit->text());
1848 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1849 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1850 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1851 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1852// RINEX Observations
1853 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1854 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1855 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1856 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1857 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1858 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1859// RINEX Ephemeris
1860 settings.setValue("ephPath", _ephPathLineEdit->text());
1861 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1862 settings.setValue("outEphPort", _outEphPortLineEdit->text());
1863 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1864// Broadcast Corrections
1865 settings.setValue("corrPath", _corrPathLineEdit->text());
1866 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1867 settings.setValue("corrPort", _corrPortLineEdit->text());
1868 settings.setValue("corrTime", _corrTimeSpinBox->value());
1869// Feed Engine
1870 settings.setValue("outPort", _outPortLineEdit->text());
1871 settings.setValue("waitTime", _waitTimeSpinBox->value());
1872 settings.setValue("binSampl", _binSamplSpinBox->value());
1873 settings.setValue("outFile", _outFileLineEdit->text());
1874 settings.setValue("outUPort", _outUPortLineEdit->text());
1875// Serial Output
1876 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1877 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1878 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1879 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1880 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1881 settings.setValue("serialParity", _serialParityComboBox->currentText());
1882 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1883 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1884 settings.setValue("serialFileNMEA",_serialFileNMEALineEdit->text());
1885 settings.setValue("serialHeightNMEA",_serialHeightNMEALineEdit->text());
1886// Outages
1887 settings.setValue("obsRate", _obsRateComboBox->currentText());
1888 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1889 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1890 settings.setValue("adviseScript",_adviseScriptLineEdit->text());
1891// Miscellaneous
1892 settings.setValue("miscMount", _miscMountLineEdit->text());
1893 settings.setValue("miscPort", _miscPortLineEdit->text());
1894 settings.setValue("perfIntr", _perfIntrComboBox->currentText());
1895 settings.setValue("scanRTCM", _scanRTCMCheckBox->checkState());
1896// PPPP
1897 settings.setValue("pppSPP", _pppSPPComboBox->currentText());
1898 settings.setValue("pppMount", _pppMountLineEdit->text());
1899 settings.setValue("pppCorrMount",_pppCorrMountLineEdit->text());
1900 settings.setValue("pppRefCrdX", _pppRefCrdXLineEdit->text());
1901 settings.setValue("pppRefCrdY", _pppRefCrdYLineEdit->text());
1902 settings.setValue("pppRefCrdZ", _pppRefCrdZLineEdit->text());
1903 settings.setValue("pppRefdN", _pppRefdNLineEdit->text());
1904 settings.setValue("pppRefdE", _pppRefdELineEdit->text());
1905 settings.setValue("pppRefdU", _pppRefdULineEdit->text());
1906 settings.setValue("nmeaFile", _pppNMEALineEdit->text());
1907 settings.setValue("nmeaPort", _pppNMEAPortLineEdit->text());
1908 settings.setValue("pppPlotCoordinates", _pppPlotCoordinates->checkState());
1909 settings.setValue("useOsmMap", _osmRadioButton->isChecked());
1910 settings.setValue("mapWinDotSize", _mapWinDotSizeLineEdit->text());
1911 settings.setValue("mapWinDotColor", _mapWinDotColorComboBox->currentText());
1912 settings.setValue("mapSpeed", _mapSpeedSlider->value());
1913 settings.setValue("postObsFile", _postObsFileChooser->fileName());
1914 settings.setValue("postNavFile", _postNavFileChooser->fileName());
1915 settings.setValue("postCorrFile", _postCorrFileChooser->fileName());
1916 settings.setValue("postOutFile", _postOutLineEdit->text());
1917 settings.setValue("pppAntenna", _pppAntennaLineEdit->text());
1918 settings.setValue("pppAntex", _pppAntexFileChooser->fileName());
1919 settings.setValue("pppUsePhase", _pppUsePhaseCheckBox->checkState());
1920 settings.setValue("pppEstTropo", _pppEstTropoCheckBox->checkState());
1921 settings.setValue("pppGLONASS", _pppGLONASSCheckBox->checkState());
1922 settings.setValue("pppGalileo", _pppGalileoCheckBox->checkState());
1923 settings.setValue("pppSync", _pppSync->text());
1924 settings.setValue("pppAverage", _pppAverageLineEdit->text());
1925 settings.setValue("pppQuickStart", _pppQuickStartLineEdit->text());
1926 settings.setValue("pppMaxSolGap", _pppMaxSolGapLineEdit->text());
1927 settings.setValue("pppAudioResponse", _pppAudioResponseLineEdit->text());
1928 settings.setValue("pppSigmaCode",_pppSigCLineEdit->text());
1929 settings.setValue("pppSigmaPhase",_pppSigPLineEdit->text());
1930 settings.setValue("pppSigCrd0",_pppSigCrd0->text());
1931 settings.setValue("pppSigCrdP",_pppSigCrdP->text());
1932 settings.setValue("pppSigTrp0",_pppSigTrp0->text());
1933 settings.setValue("pppSigTrpP",_pppSigTrpP->text());
1934// Reqc
1935 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1936 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1937 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1938 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1939 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1940 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
1941 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
1942 settings.setValue("reqcSkyPlotSystems", _reqcSkyPlotSystems->currentText());
1943// Combine Corrections
1944 if (!combineStreams.isEmpty()) {
1945 settings.setValue("combineStreams", combineStreams);
1946 }
1947 else {
1948 settings.setValue("combineStreams", "");
1949 }
1950 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1951 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1952 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1953// Upload Corrections
1954 if (!uploadMountpointsOut.isEmpty()) {
1955 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1956 }
1957 else {
1958 settings.setValue("uploadMountpointsOut", "");
1959 }
1960 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1961 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1962 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1963 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
1964// Upload Ephemeris
1965 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1966 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
1967 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
1968 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1969 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
1970
1971 if (_caster) {
1972 _caster->readMountPoints();
1973 }
1974
1975 _pppWidgets.saveOptions();
1976}
1977
1978// All get slots terminated
1979////////////////////////////////////////////////////////////////////////////
1980void bncWindow::slotGetThreadsFinished() {
1981 BNC_CORE->slotMessage("All Get Threads Terminated", true);
1982 delete _caster; _caster = 0;
1983 delete _casterEph; _casterEph = 0;
1984 _runningRealTime = false;
1985}
1986
1987// Start It!
1988////////////////////////////////////////////////////////////////////////////
1989void bncWindow::slotStart() {
1990 saveOptions();
1991 if ( _pppSPPComboBox->currentText() == "Post-Processing" ) {
1992 startPostProcessingPPP();
1993 }
1994 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
1995 startPostProcessingReqc();
1996 }
1997 else {
1998 startRealTime();
1999 }
2000}
2001
2002// Start Real-Time (Retrieve Data etc.)
2003////////////////////////////////////////////////////////////////////////////
2004void bncWindow::startRealTime() {
2005
2006 _runningRealTime = true;
2007
2008 _bncFigurePPP->reset();
2009
2010 _actDeleteMountPoints->setEnabled(false);
2011
2012 enableStartStop();
2013
2014 _caster = new bncCaster();
2015
2016 BNC_CORE->setPort(_outEphPortLineEdit->text().toInt());
2017 BNC_CORE->setPortCorr(_corrPortLineEdit->text().toInt());
2018 BNC_CORE->initCombination();
2019
2020 connect(_caster, SIGNAL(getThreadsFinished()),
2021 this, SLOT(slotGetThreadsFinished()));
2022
2023 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
2024 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
2025
2026 BNC_CORE->slotMessage("========== Start BNC v" BNCVERSION " =========", true);
2027
2028 bncSettings settings;
2029
2030 QDir rnxdir(settings.value("rnxPath").toString());
2031 if (!rnxdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations directory", true);
2032
2033 QString rnx_file = settings.value("rnxScript").toString();
2034 if ( !rnx_file.isEmpty() ) {
2035 QFile rnxfile(settings.value("rnxScript").toString());
2036 if (!rnxfile.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations script", true);
2037 }
2038
2039 QDir ephdir(settings.value("ephPath").toString());
2040 if (!ephdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Ephemeris directory", true);
2041
2042 QDir corrdir(settings.value("corrPath").toString());
2043 if (!corrdir.exists()) BNC_CORE->slotMessage("Cannot find Broadcast Corrections directory", true);
2044
2045 QString advise_file = settings.value("adviseScript").toString();
2046 if ( !advise_file.isEmpty() ) {
2047 QFile advisefile(settings.value("adviseScript").toString());
2048 if (!advisefile.exists()) BNC_CORE->slotMessage("Cannot find Outages script", true);
2049 }
2050
2051 QString ant_file = settings.value("pppAntex").toString();
2052 if ( !ant_file.isEmpty() ) {
2053 QFile anxfile(settings.value("pppAntex").toString());
2054 if (!anxfile.exists()) BNC_CORE->slotMessage("Cannot find IGS ANTEX file", true);
2055 }
2056
2057 _caster->readMountPoints();
2058
2059 _casterEph = new bncEphUploadCaster();
2060 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
2061 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
2062}
2063
2064// Retrieve Data
2065////////////////////////////////////////////////////////////////////////////
2066void bncWindow::slotStop() {
2067 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving data?",
2068 QMessageBox::Yes, QMessageBox::No,
2069 QMessageBox::NoButton);
2070 if (iRet == QMessageBox::Yes) {
2071 BNC_CORE->stopCombination();
2072 delete _caster; _caster = 0;
2073 delete _casterEph; _casterEph = 0;
2074 _runningRealTime = false;
2075 enableStartStop();
2076 }
2077}
2078
2079// Close Application gracefully
2080////////////////////////////////////////////////////////////////////////////
2081void bncWindow::closeEvent(QCloseEvent* event) {
2082
2083 int iRet = QMessageBox::question(this, "Close", "Save Options?",
2084 QMessageBox::Yes, QMessageBox::No,
2085 QMessageBox::Cancel);
2086
2087 if (iRet == QMessageBox::Cancel) {
2088 event->ignore();
2089 return;
2090 }
2091 else if (iRet == QMessageBox::Yes) {
2092 slotSaveOptions();
2093 }
2094
2095 if (_postProcessing) {
2096 _postProcessing->terminate();
2097 }
2098
2099 QMainWindow::closeEvent(event);
2100}
2101
2102// User changed the selection of mountPoints
2103////////////////////////////////////////////////////////////////////////////
2104void bncWindow::slotSelectionChanged() {
2105 if (_mountPointsTable->selectedItems().isEmpty()) {
2106 _actDeleteMountPoints->setEnabled(false);
2107 }
2108 else {
2109 _actDeleteMountPoints->setEnabled(true);
2110 }
2111}
2112
2113// Display Program Messages
2114////////////////////////////////////////////////////////////////////////////
2115void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
2116
2117#ifdef DEBUG_RTCM2_2021
2118 const int maxBufferSize = 1000;
2119#else
2120 const int maxBufferSize = 10000;
2121#endif
2122
2123 if (! showOnScreen ) {
2124 return;
2125 }
2126
2127 QString txt = _log->toPlainText() + "\n" +
2128 QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg;
2129 _log->clear();
2130 _log->append(txt.right(maxBufferSize));
2131}
2132
2133// About Message
2134////////////////////////////////////////////////////////////////////////////
2135void bncWindow::slotAbout() {
2136 new bncAboutDlg(0);
2137}
2138
2139//Flowchart
2140////////////////////////////////////////////////////////////////////////////
2141void bncWindow::slotFlowchart() {
2142 new bncFlowchartDlg(0);
2143}
2144
2145// Help Window
2146////////////////////////////////////////////////////////////////////////////
2147void bncWindow::slotHelp() {
2148 QUrl url;
2149 url.setPath(":bnchelp.html");
2150 new bncHlpDlg(0, url);
2151}
2152
2153// Select Fonts
2154////////////////////////////////////////////////////////////////////////////
2155void bncWindow::slotFontSel() {
2156 bool ok;
2157 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
2158 if (ok) {
2159 bncSettings settings;
2160 settings.setValue("font", newFont.toString());
2161 QApplication::setFont(newFont);
2162 int ww = QFontMetrics(newFont).width('w');
2163 setMinimumSize(60*ww, 80*ww);
2164 resize(60*ww, 80*ww);
2165 }
2166}
2167
2168// Whats This Help
2169void bncWindow::slotWhatsThis() {
2170 QWhatsThis::enterWhatsThisMode();
2171}
2172
2173//
2174////////////////////////////////////////////////////////////////////////////
2175void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
2176 _threads = threads;
2177
2178 _bncFigure->updateMountPoints();
2179 _bncFigureLate->updateMountPoints();
2180
2181 populateMountPointsTable();
2182 bncSettings settings;
2183 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
2184 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
2185 QListIterator<bncGetThread*> iTh(threads);
2186 while (iTh.hasNext()) {
2187 bncGetThread* thread = iTh.next();
2188 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
2189 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
2190 "@" + _mountPointsTable->item(iRow, 1)->text() );
2191 if (url == thread->mountPoint() &&
2192 _mountPointsTable->item(iRow, 3)->text() == thread->latitude() &&
2193 _mountPointsTable->item(iRow, 4)->text() == thread->longitude() ) {
2194 ((bncTableItem*) _mountPointsTable->item(iRow, 7))->setGetThread(thread);
2195 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
2196 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2197 connect(thread, SIGNAL(newBytes(QByteArray, double)),
2198 _bncFigure, SLOT(slotNewData(QByteArray, double)));
2199 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
2200 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2201 connect(thread, SIGNAL(newLatency(QByteArray, double)),
2202 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2203 if ( Qt::CheckState(settings.value("pppPlotCoordinates").toInt()) == Qt::Checked) {
2204 disconnect(thread,
2205 SIGNAL(newPosition(bncTime, double, double, double)),
2206 _bncFigurePPP,
2207 SLOT(slotNewPosition(bncTime, double, double, double)));
2208 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2209 _bncFigurePPP,
2210 SLOT(slotNewPosition(bncTime, double, double, double)));
2211 }
2212#ifdef QT_WEBKIT
2213 if (_mapWin) {
2214 disconnect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2215 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2216 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2217 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2218 }
2219#endif
2220 break;
2221 }
2222 }
2223 }
2224}
2225
2226//
2227////////////////////////////////////////////////////////////////////////////
2228void bncWindow::CreateMenu() {
2229 // Create Menus
2230 // ------------
2231 _menuFile = menuBar()->addMenu(tr("&File"));
2232 _menuFile->addAction(_actFontSel);
2233 _menuFile->addSeparator();
2234 _menuFile->addAction(_actSaveOpt);
2235 _menuFile->addSeparator();
2236 _menuFile->addAction(_actQuit);
2237
2238 _menuHlp = menuBar()->addMenu(tr("&Help"));
2239 _menuHlp->addAction(_actHelp);
2240 _menuHlp->addAction(_actFlowchart);
2241 _menuHlp->addAction(_actAbout);
2242}
2243
2244// Toolbar
2245////////////////////////////////////////////////////////////////////////////
2246void bncWindow::AddToolbar() {
2247 QToolBar* toolBar = new QToolBar;
2248 addToolBar(Qt::BottomToolBarArea, toolBar);
2249 toolBar->setMovable(false);
2250 toolBar->addAction(_actAddMountPoints);
2251 toolBar->addAction(_actDeleteMountPoints);
2252 toolBar->addAction(_actMapMountPoints);
2253 toolBar->addAction(_actStart);
2254 toolBar->addAction(_actStop);
2255 toolBar->addWidget(new QLabel(" "));
2256 toolBar->addAction(_actwhatsthis);
2257}
2258
2259// About
2260////////////////////////////////////////////////////////////////////////////
2261bncAboutDlg::bncAboutDlg(QWidget* parent) :
2262 QDialog(parent) {
2263
2264 QTextBrowser* tb = new QTextBrowser;
2265 QUrl url; url.setPath(":bncabout.html");
2266 tb->setSource(url);
2267 tb->setReadOnly(true);
2268
2269 int ww = QFontMetrics(font()).width('w');
2270 QPushButton* _closeButton = new QPushButton("Close");
2271 _closeButton->setMaximumWidth(10*ww);
2272 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2273
2274 QGridLayout* dlgLayout = new QGridLayout();
2275 QLabel* img = new QLabel();
2276 img->setPixmap(QPixmap(":ntrip-logo.png"));
2277 dlgLayout->addWidget(img, 0,0);
2278 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
2279 dlgLayout->addWidget(tb,1,0,1,2);
2280 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2281
2282 setLayout(dlgLayout);
2283 resize(60*ww, 60*ww);
2284 setWindowTitle("About BNC");
2285 show();
2286}
2287
2288//
2289////////////////////////////////////////////////////////////////////////////
2290bncAboutDlg::~bncAboutDlg() {
2291};
2292
2293// Flowchart
2294////////////////////////////////////////////////////////////////////////////
2295bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2296 QDialog(parent) {
2297
2298 int ww = QFontMetrics(font()).width('w');
2299 QPushButton* _closeButton = new QPushButton("Close");
2300 _closeButton->setMaximumWidth(10*ww);
2301 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2302
2303 QGridLayout* dlgLayout = new QGridLayout();
2304 QLabel* img = new QLabel();
2305 img->setPixmap(QPixmap(":bncflowchart.png"));
2306 dlgLayout->addWidget(img, 0,0);
2307 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2308
2309 setLayout(dlgLayout);
2310 setWindowTitle("Flow Chart");
2311 show();
2312}
2313
2314//
2315////////////////////////////////////////////////////////////////////////////
2316bncFlowchartDlg::~bncFlowchartDlg() {
2317};
2318
2319// Enable/Disable Widget (and change its color)
2320////////////////////////////////////////////////////////////////////////////
2321void bncWindow::enableWidget(bool enable, QWidget* widget) {
2322 const static QPalette paletteWhite(QColor(255, 255, 255));
2323 const static QPalette paletteGray(QColor(230, 230, 230));
2324
2325 widget->setEnabled(enable);
2326 if (enable) {
2327 widget->setPalette(paletteWhite);
2328 }
2329 else {
2330 widget->setPalette(paletteGray);
2331 }
2332}
2333
2334// Bnc Text
2335////////////////////////////////////////////////////////////////////////////
2336void bncWindow::slotBncTextChanged(){
2337
2338 bool enable = true;
2339
2340 // Proxy
2341 //------
2342 if (sender() == 0 || sender() == _proxyHostLineEdit) {
2343 enable = !_proxyHostLineEdit->text().isEmpty();
2344 enableWidget(enable, _proxyPortLineEdit);
2345 }
2346
2347 // RINEX Observations
2348 // ------------------
2349 if (sender() == 0 || sender() == _rnxPathLineEdit) {
2350 enable = !_rnxPathLineEdit->text().isEmpty();
2351 enableWidget(enable, _rnxSamplSpinBox);
2352 enableWidget(enable, _rnxSkelLineEdit);
2353 enableWidget(enable, _rnxScrpLineEdit);
2354 enableWidget(enable, _rnxV3CheckBox);
2355 enableWidget(enable, _rnxIntrComboBox);
2356 }
2357
2358 // RINEX Ephemeris
2359 // ---------------
2360 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _outEphPortLineEdit) {
2361 enable = !_ephPathLineEdit->text().isEmpty() || !_outEphPortLineEdit->text().isEmpty();
2362 enableWidget(enable, _ephIntrComboBox);
2363 enableWidget(enable, _ephV3CheckBox);
2364 }
2365
2366 // Broadcast Corrections
2367 // ---------------------
2368 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2369 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2370 enableWidget(enable, _corrIntrComboBox);
2371 }
2372
2373 // Feed Engine
2374 // -----------
2375 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2376 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2377 enableWidget(enable, _waitTimeSpinBox);
2378 enableWidget(enable, _binSamplSpinBox);
2379 }
2380
2381 // Serial Output
2382 // -------------
2383 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
2384 sender() == _serialAutoNMEAComboBox) {
2385 enable = !_serialMountPointLineEdit->text().isEmpty();
2386 enableWidget(enable, _serialPortNameLineEdit);
2387 enableWidget(enable, _serialBaudRateComboBox);
2388 enableWidget(enable, _serialParityComboBox);
2389 enableWidget(enable, _serialDataBitsComboBox);
2390 enableWidget(enable, _serialStopBitsComboBox);
2391 enableWidget(enable, _serialFlowControlComboBox);
2392 enableWidget(enable, _serialAutoNMEAComboBox);
2393
2394 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() != "Auto";
2395 enableWidget(enable2, _serialFileNMEALineEdit);
2396 }
2397
2398 // Outages
2399 // -------
2400 if (sender() == 0 || sender() == _obsRateComboBox) {
2401 enable = !_obsRateComboBox->currentText().isEmpty();
2402 enableWidget(enable, _adviseFailSpinBox);
2403 enableWidget(enable, _adviseRecoSpinBox);
2404 enableWidget(enable, _adviseScriptLineEdit);
2405 }
2406
2407 // Miscellaneous
2408 // -------------
2409 if (sender() == 0 || sender() == _miscMountLineEdit) {
2410 enable = !_miscMountLineEdit->text().isEmpty();
2411 enableWidget(enable, _perfIntrComboBox);
2412 enableWidget(enable, _scanRTCMCheckBox);
2413 enableWidget(enable, _miscPortLineEdit);
2414 }
2415
2416 // Enable/disable Broadcast Ephemerides
2417 // ------------------------------------
2418 if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2419 if (!_uploadEphHostLineEdit->text().isEmpty()) {
2420 _uploadEphPortLineEdit->setStyleSheet("background-color: white");
2421 _uploadEphMountpointLineEdit->setStyleSheet("background-color: white");
2422 _uploadEphPasswordLineEdit->setStyleSheet("background-color: white");
2423 _uploadEphSampleSpinBox->setStyleSheet("background-color: white");
2424 _uploadEphPortLineEdit->setEnabled(true);
2425 _uploadEphMountpointLineEdit->setEnabled(true);
2426 _uploadEphPasswordLineEdit->setEnabled(true);
2427 _uploadEphSampleSpinBox->setEnabled(true);
2428 }
2429 else {
2430 _uploadEphPortLineEdit->setStyleSheet("background-color: lightGray");
2431 _uploadEphMountpointLineEdit->setStyleSheet("background-color: lightGray");
2432 _uploadEphPasswordLineEdit->setStyleSheet("background-color: lightGray");
2433 _uploadEphSampleSpinBox->setStyleSheet("background-color: lightGray");
2434 _uploadEphPortLineEdit->setEnabled(false);
2435 _uploadEphMountpointLineEdit->setEnabled(false);
2436 _uploadEphPasswordLineEdit->setEnabled(false);
2437 _uploadEphSampleSpinBox->setEnabled(false);
2438 }
2439 }
2440
2441 // Combine Corrections
2442 // -------------------
2443 if (sender() == 0 || sender() == _cmbTable) {
2444 int iRow = _cmbTable->rowCount();
2445 if (iRow > 0) {
2446 enableWidget(true, _cmbMethodComboBox);
2447 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
2448 _cmbMaxresLineEdit->setEnabled(true);
2449 _cmbSamplSpinBox->setEnabled(true);
2450 }
2451 else {
2452 enableWidget(false, _cmbMethodComboBox);
2453 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2454 _cmbMaxresLineEdit->setEnabled(false);
2455 _cmbSamplSpinBox->setEnabled(false);
2456 }
2457 }
2458
2459 // Upload(clk)
2460 // -----------
2461 int iRow = _uploadTable->rowCount();
2462 if (iRow > 0) {
2463 enableWidget(true, _uploadIntrComboBox);
2464 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2465 enableWidget(true, _uploadSamplClkRnxSpinBox);
2466 enableWidget(true, _uploadSamplSp3SpinBox);
2467 }
2468 else {
2469 enableWidget(false, _uploadIntrComboBox);
2470 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2471 enableWidget(false, _uploadSamplClkRnxSpinBox);
2472 enableWidget(false, _uploadSamplSp3SpinBox);
2473 }
2474
2475 // PPP Client
2476 // ----------
2477 if (sender() == 0
2478 || sender() == _pppMountLineEdit
2479 || sender() == _pppCorrMountLineEdit
2480 || sender() == _pppRefCrdXLineEdit
2481 || sender() == _pppRefCrdYLineEdit
2482 || sender() == _pppRefCrdZLineEdit
2483 || sender() == _pppRefdNLineEdit
2484 || sender() == _pppRefdELineEdit
2485 || sender() == _pppRefdULineEdit
2486 || sender() == _pppSync
2487 || sender() == _pppSPPComboBox
2488 || sender() == _pppQuickStartLineEdit
2489 || sender() == _pppEstTropoCheckBox
2490 || sender() == _pppUsePhaseCheckBox
2491 || sender() == _pppAntexFileChooser
2492#ifdef QT_WEBKIT
2493 || sender() == _mapWin
2494#endif
2495 ) {
2496
2497
2498 enable = !_pppSPPComboBox->currentText().isEmpty();
2499 if (enable) {
2500 enable = (!_pppMountLineEdit->text().isEmpty() && !_pppCorrMountLineEdit->text().isEmpty()) ||
2501 (!_pppMountLineEdit->text().isEmpty() && _pppSPPComboBox->currentText() == "Realtime-SPP") ||
2502 (_pppSPPComboBox->currentText() == "Post-Processing");
2503 }
2504
2505 enableWidget(enable, _pppNMEALineEdit);
2506 enableWidget(enable, _pppNMEAPortLineEdit);
2507 enableWidget(enable, _pppRefCrdXLineEdit);
2508 enableWidget(enable, _pppRefCrdYLineEdit);
2509 enableWidget(enable, _pppRefCrdZLineEdit);
2510 enableWidget(enable, _pppRefdNLineEdit);
2511 enableWidget(enable, _pppRefdELineEdit);
2512 enableWidget(enable, _pppRefdULineEdit);
2513 enableWidget(enable, _pppUsePhaseCheckBox);
2514 enableWidget(enable, _pppPlotCoordinates);
2515 enableWidget(enable, _mapWinButton);
2516 enableWidget(enable, _mapWinDotSizeLineEdit);
2517 enableWidget(enable, _mapWinDotColorComboBox);
2518 enableWidget(enable, _gmRadioButton);
2519 enableWidget(enable, _osmRadioButton);
2520 enableWidget(enable, _pppEstTropoCheckBox);
2521// enableWidget(enable, _pppGLONASSCheckBox);
2522 enableWidget(enable, _pppGalileoCheckBox);
2523// enableWidget(enable, _pppAntexFileChooser);
2524 enableWidget(enable, _pppSigCLineEdit);
2525 enableWidget(enable, _pppSigCrd0);
2526 enableWidget(enable, _pppSigCrdP);
2527
2528 bool enable2 = enable && !_pppRefCrdXLineEdit->text().isEmpty() &&
2529 !_pppRefCrdYLineEdit->text().isEmpty() &&
2530 !_pppRefCrdZLineEdit->text().isEmpty();
2531
2532 enableWidget(enable2, _pppAverageLineEdit);
2533 enableWidget(enable2, _pppQuickStartLineEdit);
2534
2535 bool enable3 = enable2 && !_pppQuickStartLineEdit->text().isEmpty();
2536 enableWidget(enable3, _pppMaxSolGapLineEdit);
2537 enableWidget(enable3, _pppAudioResponseLineEdit);
2538
2539 bool enable4 = enable && !_pppAntexFileChooser->fileName().isEmpty();
2540 enableWidget(enable4, _pppAntennaLineEdit);
2541
2542 bool enable5 = enable && _pppEstTropoCheckBox->isChecked();
2543 enableWidget(enable5, _pppSigTrp0);
2544 enableWidget(enable5, _pppSigTrpP);
2545
2546 bool enable6 = enable && _pppUsePhaseCheckBox->isChecked();
2547 enableWidget(enable6, _pppSigPLineEdit);
2548
2549 bool enable7 = enable && _pppSPPComboBox->currentText() == "Realtime-PPP";
2550 enableWidget(enable7, _pppSync);
2551
2552 bool enable8 = _pppSPPComboBox->currentText() == "Realtime-PPP";
2553 enableWidget(enable8, _pppCorrMountLineEdit);
2554
2555 bool enable9 = _pppSPPComboBox->currentText() == "Post-Processing";
2556 enableWidget(enable9, _postObsFileChooser);
2557 enableWidget(enable9, _postNavFileChooser);
2558 enableWidget(enable9, _postCorrFileChooser);
2559 enableWidget(enable9, _postOutLineEdit);
2560 enableWidget(enable9, _mapSpeedSlider);
2561
2562 bool enable10 = !_pppSPPComboBox->currentText().isEmpty() && !enable9;
2563 enableWidget(enable10, _pppMountLineEdit);
2564 }
2565
2566 if (sender() == 0 || sender() == _reqcActionComboBox) {
2567 enable = !_reqcActionComboBox->currentText().isEmpty();
2568 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2569 enableWidget(enable && enable10, _reqcEditOptionButton);
2570 enableWidget(enable, _reqcObsFileChooser);
2571 enableWidget(enable, _reqcNavFileChooser);
2572 enableWidget(enable && enable10, _reqcOutObsLineEdit);
2573 enableWidget(enable && enable10, _reqcOutNavLineEdit);
2574 enableWidget(enable, _reqcOutLogLineEdit);
2575 enableWidget(enable && !enable10, _reqcPlotDirLineEdit);
2576 enableWidget(enable && !enable10, _reqcSkyPlotSystems);
2577 }
2578
2579 enableStartStop();
2580}
2581
2582//
2583////////////////////////////////////////////////////////////////////////////
2584void bncWindow::slotAddCmbRow() {
2585 int iRow = _cmbTable->rowCount();
2586 _cmbTable->insertRow(iRow);
2587 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2588 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2589 }
2590}
2591
2592//
2593////////////////////////////////////////////////////////////////////////////
2594void bncWindow::slotDelCmbRow() {
2595 int nRows = _cmbTable->rowCount();
2596 bool flg[nRows];
2597 for (int iRow = 0; iRow < nRows; iRow++) {
2598 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2599 flg[iRow] = true;
2600 }
2601 else {
2602 flg[iRow] = false;
2603 }
2604 }
2605 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2606 if (flg[iRow]) {
2607 _cmbTable->removeRow(iRow);
2608 }
2609 }
2610 nRows = _cmbTable->rowCount();
2611 if (nRows < 1) {
2612 enableWidget(false, _cmbMethodComboBox);
2613 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2614 _cmbMaxresLineEdit->setEnabled(false);
2615 _cmbSamplSpinBox->setEnabled(false);
2616 }
2617}
2618
2619//
2620////////////////////////////////////////////////////////////////////////////
2621void bncWindow::populateCmbTable() {
2622
2623 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2624 _cmbTable->removeRow(iRow);
2625 }
2626
2627 bncSettings settings;
2628
2629 int iRow = -1;
2630 QListIterator<QString> it(settings.value("combineStreams").toStringList());
2631 while (it.hasNext()) {
2632 QStringList hlp = it.next().split(" ");
2633 if (hlp.size() > 2) {
2634 ++iRow;
2635 _cmbTable->insertRow(iRow);
2636 }
2637 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2638 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2639 }
2640 }
2641}
2642
2643//
2644////////////////////////////////////////////////////////////////////////////
2645void bncWindow::slotAddUploadRow() {
2646 int iRow = _uploadTable->rowCount();
2647 _uploadTable->insertRow(iRow);
2648 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2649 if (iCol == 3) {
2650 QLineEdit* passwd = new QLineEdit();
2651 passwd->setFrame(false);
2652 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2653 _uploadTable->setCellWidget(iRow, iCol, passwd);
2654 }
2655 else if (iCol == 4) {
2656 QComboBox* system = new QComboBox();
2657 system->setEditable(false);
2658 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2659 system->setFrame(false);
2660 _uploadTable->setCellWidget(iRow, iCol, system);
2661 }
2662 else if (iCol == 5) {
2663 QCheckBox* com = new QCheckBox();
2664 _uploadTable->setCellWidget(iRow, iCol, com);
2665 }
2666 else if (iCol == 11) {
2667 bncTableItem* bncIt = new bncTableItem();
2668 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2669 _uploadTable->setItem(iRow, iCol, bncIt);
2670 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2671 }
2672 else {
2673 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2674 }
2675 }
2676}
2677
2678//
2679////////////////////////////////////////////////////////////////////////////
2680void bncWindow::slotDelUploadRow() {
2681 BNC_CORE->_uploadTableItems.clear();
2682 int nRows = _uploadTable->rowCount();
2683 bool flg[nRows];
2684 for (int iRow = 0; iRow < nRows; iRow++) {
2685 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2686 flg[iRow] = true;
2687 }
2688 else {
2689 flg[iRow] = false;
2690 }
2691 }
2692 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2693 if (flg[iRow]) {
2694 _uploadTable->removeRow(iRow);
2695 }
2696 }
2697 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2698 BNC_CORE->_uploadTableItems[iRow] =
2699 (bncTableItem*) _uploadTable->item(iRow, 11);
2700 }
2701 nRows = _uploadTable->rowCount();
2702 if (nRows < 1) {
2703 enableWidget(false, _uploadIntrComboBox);
2704 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2705 enableWidget(false, _uploadSamplSp3SpinBox);
2706 enableWidget(false, _uploadSamplClkRnxSpinBox);
2707 }
2708}
2709
2710//
2711////////////////////////////////////////////////////////////////////////////
2712void bncWindow::populateUploadTable() {
2713 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2714 _uploadTable->removeRow(iRow);
2715 }
2716
2717 bncSettings settings;
2718
2719 int iRow = -1;
2720 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2721 while (it.hasNext()) {
2722 QStringList hlp = it.next().split(",");
2723 if (hlp.size() > 6) {
2724 ++iRow;
2725 _uploadTable->insertRow(iRow);
2726 }
2727 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2728 if (iCol == 3) {
2729 QLineEdit* passwd = new QLineEdit();
2730 passwd->setFrame(false);
2731 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2732 passwd->setText(hlp[iCol]);
2733 _uploadTable->setCellWidget(iRow, iCol, passwd);
2734 }
2735 else if (iCol == 4) {
2736 QComboBox* system = new QComboBox();
2737 system->setEditable(false);
2738 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
2739 system->setFrame(false);
2740 system->setCurrentIndex(system->findText(hlp[iCol]));
2741 _uploadTable->setCellWidget(iRow, iCol, system);
2742 }
2743 else if (iCol == 5) {
2744 QCheckBox* com = new QCheckBox();
2745 if (hlp[iCol].toInt() == Qt::Checked) {
2746 com->setCheckState(Qt::Checked);
2747 }
2748 _uploadTable->setCellWidget(iRow, iCol, com);
2749 }
2750 else if (iCol == 11) {
2751 bncTableItem* bncIt = new bncTableItem();
2752 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2753 _uploadTable->setItem(iRow, iCol, bncIt);
2754 BNC_CORE->_uploadTableItems[iRow] = bncIt;
2755 }
2756 else {
2757 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2758 }
2759 }
2760 }
2761}
2762
2763//
2764////////////////////////////////////////////////////////////////////////////
2765void bncWindow::slotSetUploadTrafo() {
2766 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2767 dlg->exec();
2768 delete dlg;
2769}
2770
2771// Start Post-Processing PPP
2772////////////////////////////////////////////////////////////////////////////
2773void bncWindow::startPostProcessingPPP() {
2774#ifdef USE_POSTPROCESSING
2775 _runningPostProcessingPPP = true;
2776 _actStart->setText("0 Epochs");
2777 enableStartStop();
2778
2779 _postProcessing = new t_postProcessing(this, _mapSpeedSlider->maximum(), _mapSpeedSlider->value());
2780 connect(_postProcessing, SIGNAL(finished()), this, SLOT(slotFinishedPostProcessingPPP()));
2781 connect(_postProcessing, SIGNAL(progress(int)), this, SLOT(slotPostProgress(int)));
2782 connect(_mapSpeedSlider, SIGNAL(valueChanged(int)), _postProcessing, SLOT(slotSetSpeed(int)));
2783 bncSettings settings;
2784 if ( Qt::CheckState(settings.value("pppPlotCoordinates").toInt()) == Qt::Checked) {
2785 _bncFigurePPP->reset();
2786 connect(_postProcessing, SIGNAL(newPosition(bncTime, double, double, double)),
2787 _bncFigurePPP, SLOT(slotNewPosition(bncTime, double, double, double)));
2788 }
2789#ifdef QT_WEBKIT
2790 if (_mapWin) {
2791 connect(_postProcessing, SIGNAL(newPosition(bncTime, double, double, double)),
2792 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2793 }
2794#endif
2795
2796 _postProcessing->start();
2797#else
2798 QMessageBox::information(this, "Information",
2799 "Post-Processing Not Permitted");
2800#endif
2801}
2802
2803// Post-Processing PPP Finished
2804////////////////////////////////////////////////////////////////////////////
2805void bncWindow::slotFinishedPostProcessingPPP() {
2806#ifdef QT_WEBKIT
2807 if (_mapWin) {
2808 _postProcessing->disconnect(_mapWin);
2809 }
2810#endif
2811 _runningPostProcessingPPP = false;
2812 delete _postProcessing;
2813 _postProcessing = 0;
2814 QMessageBox::information(this, "Information",
2815 "Post-Processing Thread Finished");
2816 _actStart->setText("Start");
2817 enableStartStop();
2818}
2819
2820// Progress Bar Change
2821////////////////////////////////////////////////////////////////////////////
2822void bncWindow::slotPostProgress(int nEpo) {
2823 if (_actStart) {
2824 _actStart->setText(QString("%1 Epochs").arg(nEpo));
2825 }
2826}
2827
2828// Start Post-Processing Reqc
2829////////////////////////////////////////////////////////////////////////////
2830void bncWindow::startPostProcessingReqc() {
2831#ifdef USE_POSTPROCESSING
2832 _runningPostProcessingReqc = true;
2833 enableStartStop();
2834 if (_reqcActionComboBox->currentText() == "Analyze") {
2835 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
2836 connect(reqcAnalyze, SIGNAL(finished()),
2837 this, SLOT(slotFinishedPostProcessingReqc()));
2838 reqcAnalyze->start();
2839 }
2840 else {
2841 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
2842 connect(reqcEdit, SIGNAL(finished()),
2843 this, SLOT(slotFinishedPostProcessingReqc()));
2844 reqcEdit->start();
2845 }
2846#else
2847 QMessageBox::information(this, "Information",
2848 "Post-Processing Not Permitted");
2849#endif
2850}
2851
2852// Post-Processing Reqc Finished
2853////////////////////////////////////////////////////////////////////////////
2854void bncWindow::slotFinishedPostProcessingReqc() {
2855 _runningPostProcessingReqc = false;
2856 if (_reqcActionComboBox->currentText() != "Analyze") {
2857 QMessageBox::information(this, "Information",
2858 "RINEX Processing Thread Finished");
2859 }
2860 enableStartStop();
2861}
2862
2863// Edit teqc-like editing options
2864////////////////////////////////////////////////////////////////////////////
2865void bncWindow::slotReqcEditOption() {
2866 reqcDlg* dlg = new reqcDlg(this);
2867 dlg->move(this->pos().x()+50, this->pos().y()+50);
2868 dlg->exec();
2869 delete dlg;
2870}
2871
2872// Enable/Disable Start and Stop Buttons
2873////////////////////////////////////////////////////////////////////////////
2874void bncWindow::enableStartStop() {
2875
2876 if ( _pppSPPComboBox && _pppSPPComboBox->currentText() == "Post-Processing" ) {
2877 if (_runningPostProcessingPPP) {
2878 _actStart->setEnabled(false);
2879 }
2880 else {
2881 _actStart->setEnabled(true);
2882 }
2883 _actStop->setEnabled(false);
2884 }
2885 else if ( _reqcActionComboBox && !_reqcActionComboBox->currentText().isEmpty() ) {
2886 if (_runningPostProcessingReqc) {
2887 _actStart->setEnabled(false);
2888 }
2889 else {
2890 _actStart->setEnabled(true);
2891 }
2892 _actStop->setEnabled(false);
2893 }
2894 else {
2895 if (_runningRealTime) {
2896 _actStart->setEnabled(false);
2897 _actStop->setEnabled(true);
2898 }
2899 else {
2900 _actStop->setEnabled(false);
2901 if (_mountPointsTable->rowCount() == 0) {
2902 _actStart->setEnabled(false);
2903 }
2904 else {
2905 _actStart->setEnabled(true);
2906 }
2907 }
2908 }
2909}
2910
2911// Show Map
2912////////////////////////////////////////////////////////////////////////////
2913void bncWindow::slotMapMountPoints() {
2914 saveOptions();
2915 t_bncMap* bncMap = new t_bncMap(this);
2916 bncMap->setMinimumSize(800, 600);
2917 bncMap->setWindowTitle("Selected Mountpoints");
2918
2919 bncSettings settings;
2920 QListIterator<QString> it(settings.value("mountPoints").toStringList());
2921 while (it.hasNext()) {
2922 QStringList hlp = it.next().split(" ");
2923 if (hlp.size() < 5) continue;
2924 QUrl url(hlp[0]);
2925 double latDeg = hlp[2].toDouble();
2926 double lonDeg = hlp[3].toDouble();
2927 bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
2928 }
2929
2930 bncMap->show();
2931}
2932
2933// Show Map
2934////////////////////////////////////////////////////////////////////////////
2935void bncWindow::slotMapPPP() {
2936#ifdef QT_WEBKIT
2937 saveOptions();
2938 enableWidget(false, _mapWinButton);
2939 enableWidget(false, _gmRadioButton);
2940 enableWidget(false, _osmRadioButton);
2941 enableWidget(false, _mapWinDotSizeLineEdit);
2942 enableWidget(false, _mapWinDotColorComboBox);
2943
2944 if (!_mapWin) {
2945 _mapWin = new bncMapWin(this);
2946 connect(_mapWin, SIGNAL(mapClosed()), this, SLOT(slotMapPPPClosed()));
2947 QListIterator<bncGetThread*> it(_threads);
2948 while (it.hasNext()) {
2949 bncGetThread* thread = it.next();
2950 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
2951 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2952 }
2953 if (_postProcessing) {
2954 connect(_postProcessing, SIGNAL(newPosition(bncTime, double, double, double)),
2955 _mapWin, SLOT(slotNewPosition(bncTime, double, double, double)));
2956 }
2957 }
2958 _mapWin->show();
2959#else
2960 QMessageBox::information(this, "Information",
2961 "Qt Library compiled without QtWebKit");
2962#endif
2963}
2964
2965// Show Map
2966////////////////////////////////////////////////////////////////////////////
2967void bncWindow::slotMapPPPClosed() {
2968#ifdef QT_WEBKIT
2969 slotBncTextChanged();
2970 if (_mapWin) {
2971 QListIterator<bncGetThread*> it(_threads);
2972 while (it.hasNext()) {
2973 bncGetThread* thread = it.next();
2974 thread->disconnect(_mapWin);
2975 }
2976 if (_postProcessing) {
2977 _postProcessing->disconnect(_mapWin);
2978 }
2979 _mapWin->deleteLater();
2980 _mapWin = 0;
2981 }
2982#endif
2983}
Note: See TracBrowser for help on using the repository browser.