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

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