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

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