source: ntrip/branches/BNC_2.12/src/bncwindow.cpp @ 9235

Last change on this file since 9235 was 9235, checked in by stuerze, 5 months ago

pppMap now with OSM only

File size: 149.2 KB
Line 
1// Part of BNC, a utility for retrieving decoding and
2// converting GNSS data streams from NTRIP broadcasters.
3//
4// Copyright (C) 2007
5// German Federal Agency for Cartography and Geodesy (BKG)
6// http://www.bkg.bund.de
7// Czech Technical University Prague, Department of Geodesy
8// http://www.fsv.cvut.cz
9//
10// Email: euref-ip@bkg.bund.de
11//
12// This program is free software; you can redistribute it and/or
13// modify it under the terms of the GNU General Public License
14// as published by the Free Software Foundation, version 2.
15//
16// This program is distributed in the hope that it will be useful,
17// but WITHOUT ANY WARRANTY; without even the implied warranty of
18// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
19// GNU General Public License for more details.
20//
21// You should have received a copy of the GNU General Public License
22// along with this program; if not, write to the Free Software
23// Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA.
24
25/* -------------------------------------------------------------------------
26 * BKG NTRIP Client
27 * -------------------------------------------------------------------------
28 *
29 * Class:      bncWindow
30 *
31 * Purpose:    This class implements the main application window.
32 *
33 * Author:     L. Mervart
34 *
35 * Created:    24-Dec-2005
36 *
37 * Changes:
38 *
39 * -----------------------------------------------------------------------*/
40
41#include <iostream>
42
43#include <unistd.h>
44#include "bncwindow.h"
45#include "bnccore.h"
46#include "bncgetthread.h"
47#include "bnctabledlg.h"
48#include "bncipport.h"
49#include "bncudpport.h"
50#include "bncserialport.h"
51#include "bnchlpdlg.h"
52#include "bnchtml.h"
53#include "bnctableitem.h"
54#include "bncsettings.h"
55#include "bncfigure.h"
56#include "bncfigurelate.h"
57#include "bncfigureppp.h"
58#include "bncversion.h"
59#include "bncbytescounter.h"
60#include "bncsslconfig.h"
61#include "upload/bnccustomtrafo.h"
62#include "upload/bncephuploadcaster.h"
63#include "qtfilechooser.h"
64#include "reqcdlg.h"
65#include "bncmap.h"
66#include "rinex/reqcedit.h"
67#include "rinex/reqcanalyze.h"
68#include "orbComp/sp3Comp.h"
69#ifdef QT_WEBKIT
70#  include "map/bncmapwin.h"
71#endif
72
73using namespace std;
74
75#ifdef GNSSCENTER_PLUGIN
76Q_EXPORT_PLUGIN2(gnsscenter_bnc, t_bncFactory)
77#endif
78
79// Constructor
80////////////////////////////////////////////////////////////////////////////
81bncWindow::bncWindow() {
82
83  const static QPalette paletteWhite(QColor(255, 255, 255));
84  const static QPalette paletteGray(QColor(230, 230, 230));
85
86#ifdef GNSSCENTER_PLUGIN
87  BNC_CORE->setConfFileName("");
88#endif
89
90  _caster    = 0;
91  _casterEph = 0;
92
93  _bncFigure     = new bncFigure(this);
94  _bncFigureLate = new bncFigureLate(this);
95  _bncFigurePPP  = new bncFigurePPP(this);
96
97  connect(BNC_CORE, SIGNAL(newPosition(QByteArray, bncTime, QVector<double>)),
98          _bncFigurePPP, SLOT(slotNewPosition(QByteArray, bncTime, QVector<double>)));
99
100  connect(BNC_CORE, SIGNAL(progressRnxPPP(int)), this, SLOT(slotPostProcessingProgress(int)));
101  connect(BNC_CORE, SIGNAL(finishedRnxPPP()),    this, SLOT(slotPostProcessingFinished()));
102
103  _runningRealTime    = false;
104  _runningPPP         = false;
105  _runningEdit        = false;
106  _runningQC          = false;
107  _runningSp3Comp     = false;
108  _reqcActionComboBox = 0; // necessary for enableStartStop()
109
110  _mapWin = 0;
111
112  int ww = QFontMetrics(this->font()).width('w');
113
114  static const QStringList labels = QString("account, Streams:   resource loader / mountpoint, decoder, country, lat, long, nmea, ntrip, bytes").split(",");
115
116  setMinimumSize(100*ww, 70*ww);
117
118  setWindowTitle(tr("BKG Ntrip Client (BNC) Version " BNCVERSION));
119
120  connect(BNC_CORE, SIGNAL(newMessage(QByteArray,bool)),
121          this, SLOT(slotWindowMessage(QByteArray,bool)));
122
123  // Create Actions
124  // --------------
125  _actHelp = new QAction(tr("&Help Contents"),this);
126  connect(_actHelp, SIGNAL(triggered()), SLOT(slotHelp()));
127
128  _actAbout = new QAction(tr("&About BNC"),this);
129  connect(_actAbout, SIGNAL(triggered()), SLOT(slotAbout()));
130
131  _actFlowchart = new QAction(tr("&Flow Chart"),this);
132  connect(_actFlowchart, SIGNAL(triggered()), SLOT(slotFlowchart()));
133
134  _actFontSel = new QAction(tr("Select &Font"),this);
135  connect(_actFontSel, SIGNAL(triggered()), SLOT(slotFontSel()));
136
137  _actSaveOpt = new QAction(tr("&Reread && Save Configuration"),this);
138  connect(_actSaveOpt, SIGNAL(triggered()), SLOT(slotSaveOptions()));
139
140  _actQuit  = new QAction(tr("&Quit"),this);
141  connect(_actQuit, SIGNAL(triggered()), SLOT(close()));
142
143  _actAddMountPoints = new QAction(tr("Add &Stream"),this);
144  connect(_actAddMountPoints, SIGNAL(triggered()), SLOT(slotAddMountPoints()));
145
146  _actDeleteMountPoints = new QAction(tr("&Delete Stream"),this);
147  connect(_actDeleteMountPoints, SIGNAL(triggered()), SLOT(slotDeleteMountPoints()));
148  _actDeleteMountPoints->setEnabled(false);
149
150  _actMapMountPoints = new QAction(tr("&Map"),this);
151  connect(_actMapMountPoints, SIGNAL(triggered()), SLOT(slotMapMountPoints()));
152
153  _actStart = new QAction(tr("Sta&rt"),this);
154  connect(_actStart, SIGNAL(triggered()), SLOT(slotStart()));
155
156  _actStop = new QAction(tr("Sto&p"),this);
157  connect(_actStop, SIGNAL(triggered()), SLOT(slotStop()));
158
159  _actwhatsthis= new QAction(tr("Help?=Shift+F1"),this);
160  connect(_actwhatsthis, SIGNAL(triggered()), SLOT(slotWhatsThis()));
161
162  CreateMenu();
163  AddToolbar();
164
165  bncSettings settings;
166
167  // Network Options
168  // ---------------
169  _proxyHostLineEdit  = new QLineEdit(settings.value("proxyHost").toString());
170  _proxyPortLineEdit  = new QLineEdit(settings.value("proxyPort").toString());
171
172  connect(_proxyHostLineEdit, SIGNAL(textChanged(const QString &)),
173          this, SLOT(slotBncTextChanged()));
174
175  _sslCaCertPathLineEdit   = new QLineEdit(settings.value("sslCaCertPath").toString());
176  _sslIgnoreErrorsCheckBox = new QCheckBox();
177  _sslIgnoreErrorsCheckBox->setCheckState(Qt::CheckState(
178                                          settings.value("sslIgnoreErrors").toInt()));
179
180  // General Options
181  // ---------------
182  _logFileLineEdit    = new QLineEdit(settings.value("logFile").toString());
183  _rawOutFileLineEdit = new QLineEdit(settings.value("rawOutFile").toString());
184  _rnxAppendCheckBox  = new QCheckBox();
185  _rnxAppendCheckBox->setCheckState(Qt::CheckState(
186                                    settings.value("rnxAppend").toInt()));
187  _onTheFlyComboBox = new QComboBox();
188  _onTheFlyComboBox->setEditable(false);
189  _onTheFlyComboBox->addItems(QString("no, 1 day,1 hour,5 min,1 min").split(","));
190  int ii = _onTheFlyComboBox->findText(settings.value("onTheFlyInterval").toString());
191  if (ii != -1) {
192    _onTheFlyComboBox->setCurrentIndex(ii);
193  }
194  _autoStartCheckBox  = new QCheckBox();
195  _autoStartCheckBox->setCheckState(Qt::CheckState(
196                                    settings.value("autoStart").toInt()));
197
198  // RINEX Observations Options
199  // --------------------------
200  _rnxPathLineEdit    = new QLineEdit(settings.value("rnxPath").toString());
201  _rnxIntrComboBox    = new QComboBox();
202  _rnxIntrComboBox->setEditable(false);
203  _rnxIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
204  ii = _rnxIntrComboBox->findText(settings.value("rnxIntr").toString());
205  if (ii != -1) {
206    _rnxIntrComboBox->setCurrentIndex(ii);
207  }
208  _rnxSamplComboBox    = new QComboBox();
209  _rnxSamplComboBox->setEditable(false);
210  _rnxSamplComboBox->addItems(QString("0.1 sec,1 sec,5 sec,10 sec,15 sec,30 sec,60 sec").split(","));
211  int ij = _rnxSamplComboBox->findText(settings.value("rnxSampl").toString());
212  if (ij != -1) {
213    _rnxSamplComboBox->setCurrentIndex(ij);
214  }
215  _rnxFileCheckBox = new QCheckBox();
216  _rnxFileCheckBox->setCheckState(Qt::CheckState(settings.value("rnxOnlyWithSKL").toInt()));
217  _rnxSkelLineEdit    = new QLineEdit(settings.value("rnxSkel").toString());
218  _rnxSkelLineEdit->setMaximumWidth(5*ww);
219  _rnxScrpLineEdit    = new QLineEdit(settings.value("rnxScript").toString());
220  _rnxV3CheckBox      = new QCheckBox();
221  _rnxV3CheckBox->setCheckState(Qt::CheckState(settings.value("rnxV3").toInt()));
222  QString hlp = settings.value("rnxV2Priority").toString();
223  if (hlp.isEmpty()) {
224    hlp = "G:12&PWCSLX G:5&IQX R:12&PC R:3&IQX R:46&ABX E:16&BCXZ E:578&IQX J:1&SLXCZ J:26&SLX J:5&IQX C:267&IQX C:128&DPX C:7&DPZ I:ABCX S:1&C S:5&IQX";
225  }
226  _rnxV2Priority = new QLineEdit(hlp);
227
228  connect(_rnxPathLineEdit, SIGNAL(textChanged(const QString &)),
229          this, SLOT(slotBncTextChanged()));
230  connect(_rnxV3CheckBox, SIGNAL(stateChanged(int)),
231          this, SLOT(slotBncTextChanged()));
232
233  // RINEX Ephemeris Options
234  // -----------------------
235  _ephPathLineEdit    = new QLineEdit(settings.value("ephPath").toString());
236  _ephIntrComboBox    = new QComboBox();
237  _ephIntrComboBox->setEditable(false);
238  _ephIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
239  int jj = _ephIntrComboBox->findText(settings.value("ephIntr").toString());
240  if (jj != -1) {
241    _ephIntrComboBox->setCurrentIndex(jj);
242  }
243  _ephOutPortLineEdit    = new QLineEdit(settings.value("ephOutPort").toString());
244  _ephV3CheckBox = new QCheckBox();
245  _ephV3CheckBox->setCheckState(Qt::CheckState(settings.value("ephV3").toInt()));
246
247  connect(_ephOutPortLineEdit, SIGNAL(textChanged(const QString &)),
248          this, SLOT(slotBncTextChanged()));
249
250  connect(_ephPathLineEdit, SIGNAL(textChanged(const QString &)),
251          this, SLOT(slotBncTextChanged()));
252
253  // Broadcast Corrections Options
254  // -----------------------------
255  _corrPathLineEdit    = new QLineEdit(settings.value("corrPath").toString());
256  _corrIntrComboBox    = new QComboBox();
257  _corrIntrComboBox->setEditable(false);
258  _corrIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
259  int mm = _corrIntrComboBox->findText(settings.value("corrIntr").toString());
260  if (mm != -1) {
261    _corrIntrComboBox->setCurrentIndex(mm);
262  }
263  _corrPortLineEdit    = new QLineEdit(settings.value("corrPort").toString());
264
265  connect(_corrPathLineEdit, SIGNAL(textChanged(const QString &)),
266          this, SLOT(slotBncTextChanged()));
267
268  connect(_corrPortLineEdit, SIGNAL(textChanged(const QString &)),
269          this, SLOT(slotBncTextChanged()));
270
271  // Feed Engine Options
272  // -------------------
273  _outPortLineEdit    = new QLineEdit(settings.value("outPort").toString());
274  _outWaitSpinBox   = new QSpinBox();
275  _outWaitSpinBox->setMinimum(0);
276  _outWaitSpinBox->setMaximum(30);
277  _outWaitSpinBox->setSingleStep(1);
278  _outWaitSpinBox->setSuffix(" sec");
279  _outWaitSpinBox->setValue(settings.value("outWait").toInt());
280  _outSamplComboBox    = new QComboBox();
281  _outSamplComboBox->addItems(QString("0.1 sec,1 sec,5 sec,10 sec,15 sec,30 sec,60 sec").split(","));
282  int nn = _outSamplComboBox->findText(settings.value("outSampl").toString());
283    if (nn != -1) {
284      _outSamplComboBox->setCurrentIndex(nn);
285    }
286  _outFileLineEdit    = new QLineEdit(settings.value("outFile").toString());
287  _outUPortLineEdit   = new QLineEdit(settings.value("outUPort").toString());
288  _outLockTimeCheckBox = new QCheckBox();
289  _outLockTimeCheckBox->setCheckState(Qt::CheckState(settings.value("outLockTime").toInt()));
290
291  connect(_outPortLineEdit, SIGNAL(textChanged(const QString &)),
292          this, SLOT(slotBncTextChanged()));
293
294  connect(_outFileLineEdit, SIGNAL(textChanged(const QString &)),
295          this, SLOT(slotBncTextChanged()));
296
297  connect(_outLockTimeCheckBox, SIGNAL(stateChanged(int)),
298          this, SLOT(slotBncTextChanged()));
299
300  // Serial Output Options
301  // ---------------------
302  _serialMountPointLineEdit = new QLineEdit(settings.value("serialMountPoint").toString());
303  _serialPortNameLineEdit = new QLineEdit(settings.value("serialPortName").toString());
304  _serialBaudRateComboBox = new QComboBox();
305  _serialBaudRateComboBox->addItems(QString("110,300,600,"
306            "1200,2400,4800,9600,19200,38400,57600,115200").split(","));
307  int kk = _serialBaudRateComboBox->findText(settings.value("serialBaudRate").toString());
308  if (kk != -1) {
309    _serialBaudRateComboBox->setCurrentIndex(kk);
310  }
311  _serialFlowControlComboBox = new QComboBox();
312  _serialFlowControlComboBox->addItems(QString("OFF,XONXOFF,HARDWARE").split(","));
313  kk = _serialFlowControlComboBox->findText(settings.value("serialFlowControl").toString());
314  if (kk != -1) {
315    _serialFlowControlComboBox->setCurrentIndex(kk);
316  }
317  _serialDataBitsComboBox = new QComboBox();
318  _serialDataBitsComboBox->addItems(QString("5,6,7,8").split(","));
319  kk = _serialDataBitsComboBox->findText(settings.value("serialDataBits").toString());
320  if (kk != -1) {
321    _serialDataBitsComboBox->setCurrentIndex(kk);
322  }
323  _serialParityComboBox   = new QComboBox();
324  _serialParityComboBox->addItems(QString("NONE,ODD,EVEN,SPACE").split(","));
325  kk = _serialParityComboBox->findText(settings.value("serialParity").toString());
326  if (kk != -1) {
327    _serialParityComboBox->setCurrentIndex(kk);
328  }
329  _serialStopBitsComboBox = new QComboBox();
330  _serialStopBitsComboBox->addItems(QString("1,2").split(","));
331  kk = _serialStopBitsComboBox->findText(settings.value("serialStopBits").toString());
332  if (kk != -1) {
333    _serialStopBitsComboBox->setCurrentIndex(kk);
334  }
335  _serialAutoNMEAComboBox  = new QComboBox();
336  _serialAutoNMEAComboBox->addItems(QString("no,Auto,Manual GPGGA,Manual GNGGA").split(","));
337  kk = _serialAutoNMEAComboBox->findText(settings.value("serialAutoNMEA").toString());
338  if (kk != -1) {
339    _serialAutoNMEAComboBox->setCurrentIndex(kk);
340  }
341  _serialFileNMEALineEdit    = new QLineEdit(settings.value("serialFileNMEA").toString());
342  _serialHeightNMEALineEdit  = new QLineEdit(settings.value("serialHeightNMEA").toString());
343
344  _serialManualNMEASamplingSpinBox = new QSpinBox();
345  _serialManualNMEASamplingSpinBox->setMinimum(0);
346  _serialManualNMEASamplingSpinBox->setMaximum(300);
347  _serialManualNMEASamplingSpinBox->setSingleStep(10);
348  _serialManualNMEASamplingSpinBox->setValue(settings.value("serialManualNMEASampling").toInt());
349  _serialManualNMEASamplingSpinBox->setSuffix(" sec");
350
351  connect(_serialMountPointLineEdit, SIGNAL(textChanged(const QString &)),
352          this, SLOT(slotBncTextChanged()));
353
354  connect(_serialAutoNMEAComboBox, SIGNAL(currentIndexChanged(const QString &)),
355          this, SLOT(slotBncTextChanged()));
356
357  // Outages Options
358  // ---------------
359  _adviseObsRateComboBox    = new QComboBox();
360  _adviseObsRateComboBox->setEditable(false);
361  _adviseObsRateComboBox->addItems(QString(",0.1 Hz,0.2 Hz,0.5 Hz,1 Hz,5 Hz").split(","));
362  kk = _adviseObsRateComboBox->findText(settings.value("adviseObsRate").toString());
363  if (kk != -1) {
364    _adviseObsRateComboBox->setCurrentIndex(kk);
365  }
366  _adviseFailSpinBox = new QSpinBox();
367  _adviseFailSpinBox->setMinimum(0);
368  _adviseFailSpinBox->setMaximum(60);
369  _adviseFailSpinBox->setSingleStep(1);
370  _adviseFailSpinBox->setSuffix(" min");
371  _adviseFailSpinBox->setValue(settings.value("adviseFail").toInt());
372  _adviseRecoSpinBox = new QSpinBox();
373  _adviseRecoSpinBox->setMinimum(0);
374  _adviseRecoSpinBox->setMaximum(60);
375  _adviseRecoSpinBox->setSingleStep(1);
376  _adviseRecoSpinBox->setSuffix(" min");
377  _adviseRecoSpinBox->setValue(settings.value("adviseReco").toInt());
378  _adviseScriptLineEdit    = new QLineEdit(settings.value("adviseScript").toString());
379
380  connect(_adviseObsRateComboBox, SIGNAL(currentIndexChanged(const QString &)),
381          this, SLOT(slotBncTextChanged()));
382
383  // Miscellaneous Options
384  // ---------------------
385  _miscMountLineEdit  = new QLineEdit(settings.value("miscMount").toString());
386  _miscPortLineEdit   = new QLineEdit(settings.value("miscPort").toString());
387  _miscIntrComboBox   = new QComboBox();
388  _miscIntrComboBox->setEditable(false);
389  _miscIntrComboBox->addItems(QString(",2 sec,10 sec,1 min,5 min,15 min,1 hour,6 hours,1 day").split(","));
390  int ll = _miscIntrComboBox->findText(settings.value("miscIntr").toString());
391  if (ll != -1) {
392    _miscIntrComboBox->setCurrentIndex(ll);
393  }
394  _miscScanRTCMCheckBox  = new QCheckBox();
395  _miscScanRTCMCheckBox->setCheckState(Qt::CheckState(
396                                    settings.value("miscScanRTCM").toInt()));
397
398  connect(_miscMountLineEdit, SIGNAL(textChanged(const QString &)),
399          this, SLOT(slotBncTextChanged()));
400
401  // Streams
402  // -------
403  _mountPointsTable   = new QTableWidget(0,9);
404
405  _mountPointsTable->horizontalHeader()->resizeSection(1,34*ww);
406  _mountPointsTable->horizontalHeader()->resizeSection(2,9*ww);
407  _mountPointsTable->horizontalHeader()->resizeSection(3,9*ww);
408  _mountPointsTable->horizontalHeader()->resizeSection(4,7*ww);
409  _mountPointsTable->horizontalHeader()->resizeSection(5,7*ww);
410  _mountPointsTable->horizontalHeader()->resizeSection(6,5*ww);
411  _mountPointsTable->horizontalHeader()->resizeSection(7,5*ww);
412  _mountPointsTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
413  _mountPointsTable->horizontalHeader()->setStretchLastSection(true);
414  _mountPointsTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
415  _mountPointsTable->setHorizontalHeaderLabels(labels);
416  _mountPointsTable->setGridStyle(Qt::NoPen);
417  _mountPointsTable->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
418  _mountPointsTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
419  _mountPointsTable->setSelectionBehavior(QAbstractItemView::SelectRows);
420  _mountPointsTable->hideColumn(0);
421  _mountPointsTable->hideColumn(3);
422  connect(_mountPointsTable, SIGNAL(itemSelectionChanged()),
423          SLOT(slotSelectionChanged()));
424  populateMountPointsTable();
425
426  _log = new QTextEdit();
427  _log->setReadOnly(true);
428  QFont msFont(""); msFont.setStyleHint(QFont::TypeWriter); // default monospace font
429  _log->setFont(msFont);
430  _log->document()->setMaximumBlockCount(1000);
431
432  // Combine Corrections
433  // -------------------
434  _cmbTable = new QTableWidget(0,3);
435  _cmbTable->setHorizontalHeaderLabels(QString("Mountpoint, AC Name, Weight").split(","));
436  _cmbTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
437  _cmbTable->setSelectionBehavior(QAbstractItemView::SelectRows);
438  _cmbTable->setMaximumWidth(30*ww);
439  _cmbTable->horizontalHeader()->resizeSection(0,10*ww);
440  _cmbTable->horizontalHeader()->resizeSection(1,8*ww);
441  _cmbTable->horizontalHeader()->resizeSection(2,8*ww);
442  _cmbTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
443  _cmbTable->horizontalHeader()->setStretchLastSection(true);
444  _cmbTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
445
446  _cmbMaxresLineEdit = new QLineEdit(settings.value("cmbMaxres").toString());
447  _cmbUseGlonass     = new QCheckBox();
448  _cmbUseGlonass->setCheckState(Qt::CheckState(settings.value("cmbUseGlonass").toInt()));
449
450  _cmbSamplSpinBox = new QSpinBox;
451  _cmbSamplSpinBox->setMinimum(10);
452  _cmbSamplSpinBox->setMaximum(60);
453  _cmbSamplSpinBox->setSingleStep(10);
454  _cmbSamplSpinBox->setMaximumWidth(9*ww);
455  _cmbSamplSpinBox->setValue(settings.value("cmbSampl").toInt());
456  _cmbSamplSpinBox->setSuffix(" sec");
457
458  QPushButton* addCmbRowButton = new QPushButton("Add Row");
459  QPushButton* delCmbRowButton = new QPushButton("Delete");
460
461  connect(_cmbTable, SIGNAL(itemSelectionChanged()),
462          SLOT(slotBncTextChanged()));
463
464  _cmbMethodComboBox = new QComboBox();
465  _cmbMethodComboBox->setEditable(false);
466  _cmbMethodComboBox->addItems(QString("Filter,Single-Epoch").split(","));
467  int im = _cmbMethodComboBox->findText(settings.value("cmbMethod").toString());
468  if (im != -1) {
469    _cmbMethodComboBox->setCurrentIndex(im);
470  }
471
472  int iRow = _cmbTable->rowCount();
473  if (iRow > 0) {
474    enableWidget(true, _cmbMethodComboBox);
475    enableWidget(true, _cmbMaxresLineEdit);
476    enableWidget(true, _cmbSamplSpinBox);
477    enableWidget(true, _cmbUseGlonass);
478  }
479  else {
480    enableWidget(false, _cmbMethodComboBox);
481    enableWidget(false, _cmbMaxresLineEdit);
482    enableWidget(false, _cmbSamplSpinBox);
483    enableWidget(false, _cmbUseGlonass);
484  }
485
486  // Upload Results
487  // -------------
488  _uploadTable = new QTableWidget(0,13);
489  _uploadTable->setHorizontalHeaderLabels(QString("Host, Port, Mount, Password, System, Format, CoM, SP3 File, RNX File, PID, SID, IOD, bytes").split(","));
490  _uploadTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
491  _uploadTable->setSelectionBehavior(QAbstractItemView::SelectRows);
492  _uploadTable->horizontalHeader()->resizeSection( 0,13*ww);
493  _uploadTable->horizontalHeader()->resizeSection( 1, 5*ww);
494  _uploadTable->horizontalHeader()->resizeSection( 2, 6*ww);
495  _uploadTable->horizontalHeader()->resizeSection( 3, 8*ww);
496  _uploadTable->horizontalHeader()->resizeSection( 4,11*ww);
497  _uploadTable->horizontalHeader()->resizeSection( 5,11*ww);
498  _uploadTable->horizontalHeader()->resizeSection( 6, 4*ww);
499  _uploadTable->horizontalHeader()->resizeSection( 7,15*ww);
500  _uploadTable->horizontalHeader()->resizeSection( 8,15*ww);
501  _uploadTable->horizontalHeader()->resizeSection( 9, 4*ww);
502  _uploadTable->horizontalHeader()->resizeSection(10, 4*ww);
503  _uploadTable->horizontalHeader()->resizeSection(11, 4*ww);
504  _uploadTable->horizontalHeader()->resizeSection(12,12*ww);
505  _uploadTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
506  _uploadTable->horizontalHeader()->setStretchLastSection(true);
507  _uploadTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
508
509  connect(_uploadTable, SIGNAL(itemSelectionChanged()),
510          SLOT(slotBncTextChanged()));
511
512  QPushButton* addUploadRowButton = new QPushButton("Add Row");
513  QPushButton* delUploadRowButton = new QPushButton("Del Row");
514  QPushButton* setUploadTrafoButton = new QPushButton("Custom Trafo");
515  _uploadIntrComboBox = new QComboBox;
516  _uploadIntrComboBox->setEditable(false);
517  _uploadIntrComboBox->addItems(QString("1 day,1 hour, 30 min,15 min,10 min,5 min,2 min,1 min").split(","));
518  ii = _uploadIntrComboBox->findText(settings.value("uploadIntr").toString());
519  if (ii != -1) {
520    _uploadIntrComboBox->setCurrentIndex(ii);
521  }
522
523  _uploadAntexFile      = new qtFileChooser(0, qtFileChooser::File);
524  _uploadAntexFile->setFileName(settings.value("uploadAntexFile").toString());
525
526  _uploadSamplRtcmEphCorrSpinBox = new QSpinBox;
527  _uploadSamplRtcmEphCorrSpinBox->setMinimum(0);
528  _uploadSamplRtcmEphCorrSpinBox->setMaximum(60);
529  _uploadSamplRtcmEphCorrSpinBox->setSingleStep(5);
530  _uploadSamplRtcmEphCorrSpinBox->setMaximumWidth(9*ww);
531  _uploadSamplRtcmEphCorrSpinBox->setValue(settings.value("uploadSamplRtcmEphCorr").toInt());
532  _uploadSamplRtcmEphCorrSpinBox->setSuffix(" sec");
533
534  _uploadSamplSp3SpinBox = new QSpinBox;
535  _uploadSamplSp3SpinBox->setMinimum(0);
536  _uploadSamplSp3SpinBox->setMaximum(15);
537  _uploadSamplSp3SpinBox->setSingleStep(1);
538  _uploadSamplSp3SpinBox->setMaximumWidth(9*ww);
539  _uploadSamplSp3SpinBox->setValue(settings.value("uploadSamplSp3").toInt());
540  _uploadSamplSp3SpinBox->setSuffix(" min");
541
542  _uploadSamplClkRnxSpinBox = new QSpinBox;
543  _uploadSamplClkRnxSpinBox->setMinimum(0);
544  _uploadSamplClkRnxSpinBox->setMaximum(60);
545  _uploadSamplClkRnxSpinBox->setSingleStep(5);
546  _uploadSamplClkRnxSpinBox->setMaximumWidth(9*ww);
547  _uploadSamplClkRnxSpinBox->setValue(settings.value("uploadSamplClkRnx").toInt());
548  _uploadSamplClkRnxSpinBox->setSuffix(" sec");
549
550  int iRowT = _uploadTable->rowCount();
551  if (iRowT > 0) {
552    enableWidget(true, _uploadIntrComboBox);
553    enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
554    enableWidget(true, _uploadSamplSp3SpinBox);
555    enableWidget(true, _uploadSamplClkRnxSpinBox);
556    enableWidget(true, _uploadAntexFile);
557  }
558  else {
559    enableWidget(false, _uploadIntrComboBox);
560    enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
561    enableWidget(false, _uploadSamplSp3SpinBox);
562    enableWidget(false, _uploadSamplClkRnxSpinBox);
563    enableWidget(false, _uploadAntexFile);
564  }
565
566  // Upload RTCM3 Ephemeris
567  // ----------------------
568  _uploadEphHostLineEdit       = new QLineEdit(settings.value("uploadEphHost").toString());
569  _uploadEphPortLineEdit       = new QLineEdit(settings.value("uploadEphPort").toString());
570  _uploadEphPasswordLineEdit   = new QLineEdit(settings.value("uploadEphPassword").toString());
571  _uploadEphPasswordLineEdit->setEchoMode(QLineEdit::PasswordEchoOnEdit);
572  _uploadEphMountpointLineEdit = new QLineEdit(settings.value("uploadEphMountpoint").toString());
573  _uploadEphSampleSpinBox      = new QSpinBox;
574  _uploadEphSampleSpinBox->setMinimum(5);
575  _uploadEphSampleSpinBox->setMaximum(60);
576  _uploadEphSampleSpinBox->setSingleStep(5);
577  _uploadEphSampleSpinBox->setMaximumWidth(9*ww);
578  _uploadEphSampleSpinBox->setValue(settings.value("uploadEphSample").toInt());
579  _uploadEphSampleSpinBox->setSuffix(" sec");
580  _uploadEphBytesCounter       = new bncBytesCounter;
581
582  // Canvas with Editable Fields
583  // ---------------------------
584  _canvas = new QWidget;
585  setCentralWidget(_canvas);
586
587  _aogroup = new QTabWidget();
588  _aogroup->setElideMode(Qt::ElideNone);
589  _aogroup->setUsesScrollButtons(true);
590  QWidget* pgroup = new QWidget();
591  QWidget* ggroup = new QWidget();
592  QWidget* sgroup = new QWidget();
593  QWidget* egroup = new QWidget();
594  QWidget* agroup = new QWidget();
595  QWidget* cgroup = new QWidget();
596  QWidget* ogroup = new QWidget();
597  QWidget* rgroup = new QWidget();
598  QWidget* sergroup = new QWidget();
599  QWidget* pppGroup1 = new QWidget();
600  QWidget* pppGroup2 = new QWidget();
601  QWidget* pppGroup3 = new QWidget();
602  QWidget* pppGroup4 = new QWidget();
603  QWidget* reqcgroup = new QWidget();
604  QWidget* sp3CompGroup = new QWidget();
605  QWidget* cmbgroup = new QWidget();
606  QWidget* uploadgroup = new QWidget();
607  QWidget* uploadEphgroup = new QWidget();
608  _aogroup->addTab(pgroup,tr("Network"));
609  _aogroup->addTab(ggroup,tr("General"));
610  _aogroup->addTab(ogroup,tr("RINEX Observations"));
611  _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
612  _aogroup->addTab(reqcgroup,tr("RINEX Editing && QC"));
613  _aogroup->addTab(sp3CompGroup,tr("SP3 Comparison"));
614  _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
615  _aogroup->addTab(sgroup,tr("Feed Engine"));
616  _aogroup->addTab(sergroup,tr("Serial Output"));
617  _aogroup->addTab(agroup,tr("Outages"));
618  _aogroup->addTab(rgroup,tr("Miscellaneous"));
619  _aogroup->addTab(pppGroup1,tr("PPP (1)"));
620  _aogroup->addTab(pppGroup2,tr("PPP (2)"));
621  _aogroup->addTab(pppGroup3,tr("PPP (3)"));
622  _aogroup->addTab(pppGroup4,tr("PPP (4)"));
623  _aogroup->addTab(cmbgroup,tr("Combine Corrections"));
624  _aogroup->addTab(uploadgroup,tr("Upload Corrections"));
625  _aogroup->addTab(uploadEphgroup,tr("Upload Ephemeris"));
626
627  // Log Tab
628  // -------
629  _loggroup = new QTabWidget();
630  _loggroup->addTab(_log,tr("Log"));
631  _loggroup->addTab(_bncFigure,tr("Throughput"));
632  _loggroup->addTab(_bncFigureLate,tr("Latency"));
633  _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
634
635  // Netowork (Proxy and SSL) Tab
636  // ----------------------------
637  QGridLayout* pLayout = new QGridLayout;
638  pLayout->setColumnMinimumWidth(0,13*ww);
639  _proxyPortLineEdit->setMaximumWidth(9*ww);
640
641  pLayout->addWidget(new QLabel("Settings for proxy in protected networks and for SSL authorization, leave boxes blank if none.<br>"),0, 0, 1, 50);
642  pLayout->addWidget(new QLabel("Proxy host"),                               1, 0);
643  pLayout->addWidget(_proxyHostLineEdit,                                     1, 1, 1,10);
644  pLayout->addWidget(new QLabel("Proxy port"),                               2, 0);
645  pLayout->addWidget(_proxyPortLineEdit,                                     2, 1);
646  pLayout->addWidget(new QLabel("Path to SSL certificates"),                 3, 0);
647  pLayout->addWidget(_sslCaCertPathLineEdit,                                 3, 1, 1,10);
648  pLayout->addWidget(new QLabel("Default:  " + bncSslConfig::defaultPath()), 3,11, 1,20);
649  pLayout->addWidget(new QLabel("Ignore SSL authorization errors"),          4, 0);
650  pLayout->addWidget(_sslIgnoreErrorsCheckBox,                               4, 1, 1,10);
651  pLayout->addWidget(new QLabel(""),                                         5, 1);
652  pLayout->setRowStretch(6, 999);
653
654  pgroup->setLayout(pLayout);
655
656  // General Tab
657  // -----------
658  QGridLayout* gLayout = new QGridLayout;
659  gLayout->setColumnMinimumWidth(0,14*ww);
660  _onTheFlyComboBox->setMaximumWidth(9*ww);
661
662  gLayout->addWidget(new QLabel("General settings for logfile, file handling, configuration on-the-fly, auto-start, and raw file output.<br>"),0, 0, 1, 50);
663  gLayout->addWidget(new QLabel("Logfile (full path)"),          1, 0);
664  gLayout->addWidget(_logFileLineEdit,                           1, 1, 1,20);
665  gLayout->addWidget(new QLabel("Append files"),                 2, 0);
666  gLayout->addWidget(_rnxAppendCheckBox,                         2, 1);
667  gLayout->addWidget(new QLabel("Reread configuration"),         3, 0);
668  gLayout->addWidget(_onTheFlyComboBox,                          3, 1);
669  gLayout->addWidget(new QLabel("Auto start"),                   4, 0);
670  gLayout->addWidget(_autoStartCheckBox,                         4, 1);
671  gLayout->addWidget(new QLabel("Raw output file (full path)"),  5, 0);
672  gLayout->addWidget(_rawOutFileLineEdit,                        5, 1, 1,20);
673  gLayout->addWidget(new QLabel(""),                             6, 1);
674  gLayout->setRowStretch(7, 999);
675
676  ggroup->setLayout(gLayout);
677
678  // RINEX Observations
679  // ------------------
680  QGridLayout* oLayout = new QGridLayout;
681  oLayout->setColumnMinimumWidth(0,14*ww);
682  _rnxIntrComboBox->setMaximumWidth(9*ww);
683  _rnxSamplComboBox->setMaximumWidth(9*ww);
684
685  oLayout->addWidget(new QLabel("Saving RINEX observation files.<br>"),0, 0, 1,50);
686  oLayout->addWidget(new QLabel("Directory"),                      1, 0);
687  oLayout->addWidget(_rnxPathLineEdit,                             1, 1, 1, 15);
688  oLayout->addWidget(new QLabel("Interval"),                       2, 0);
689  oLayout->addWidget(_rnxIntrComboBox,                             2, 1);
690  oLayout->addWidget(new QLabel("  Sampling"),                     2, 2, Qt::AlignRight);
691  oLayout->addWidget(_rnxSamplComboBox,                             2, 3, Qt::AlignLeft);
692  oLayout->addWidget(new QLabel("Skeleton extension"),             3, 0);
693  oLayout->addWidget(_rnxSkelLineEdit,                             3, 1, Qt::AlignLeft);
694  oLayout->addWidget(new QLabel("Skeleton mandatory"),             3, 2);
695  oLayout->addWidget(_rnxFileCheckBox,                             3, 3);
696  oLayout->addWidget(new QLabel("Script (full path)"),             4, 0);
697  oLayout->addWidget(_rnxScrpLineEdit,                             4, 1, 1, 15);
698  oLayout->addWidget(new QLabel("Version 2 signal priority"),      5, 0);
699  oLayout->addWidget(_rnxV2Priority,                               5, 1, 1, 15);
700  oLayout->addWidget(new QLabel("Version 3"),                      6, 0);
701  oLayout->addWidget(_rnxV3CheckBox,                               6, 1);
702  oLayout->addWidget(new QLabel(""),                               7, 1);
703  oLayout->setRowStretch(8, 999);
704
705  ogroup->setLayout(oLayout);
706
707  // RINEX Ephemeris
708  // ---------------
709  QGridLayout* eLayout = new QGridLayout;
710  eLayout->setColumnMinimumWidth(0,14*ww);
711  _ephIntrComboBox->setMaximumWidth(9*ww);
712  _ephOutPortLineEdit->setMaximumWidth(9*ww);
713
714  eLayout->addWidget(new QLabel("Saving RINEX navigation files and ephemeris output through IP port.<br>"),0,0,1,70);
715  eLayout->addWidget(new QLabel("Directory"),                     1, 0);
716  eLayout->addWidget(_ephPathLineEdit,                            1, 1, 1,30);
717  eLayout->addWidget(new QLabel("Interval"),                      2, 0);
718  eLayout->addWidget(_ephIntrComboBox,                            2, 1);
719  eLayout->addWidget(new QLabel("Port"),                          3, 0);
720  eLayout->addWidget(_ephOutPortLineEdit,                         3, 1);
721  eLayout->addWidget(new QLabel("Version 3"),                     4, 0);
722  eLayout->addWidget(_ephV3CheckBox,                              4, 1);
723  eLayout->setRowStretch(5, 999);
724
725  egroup->setLayout(eLayout);
726
727
728  // Broadcast Corrections
729  // ---------------------
730  QGridLayout* cLayout = new QGridLayout;
731  cLayout->setColumnMinimumWidth(0,14*ww);
732  _corrIntrComboBox->setMaximumWidth(9*ww);
733  _corrPortLineEdit->setMaximumWidth(9*ww);
734
735  cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port.<br>"),0,0,1,70);
736  cLayout->addWidget(new QLabel("Directory, ASCII"),              1, 0);
737  cLayout->addWidget(_corrPathLineEdit,                           1, 1, 1,30);
738  cLayout->addWidget(new QLabel("Interval"),                      2, 0);
739  cLayout->addWidget(_corrIntrComboBox,                           2, 1);
740  cLayout->addWidget(new QLabel("Port"),                          3, 0);
741  cLayout->addWidget(_corrPortLineEdit,                           3, 1);
742  cLayout->addWidget(new QLabel(""),                              4, 1);
743  cLayout->setRowStretch(7, 999);
744  cgroup->setLayout(cLayout);
745
746  // Feed Engine
747  // -----------
748  QGridLayout* sLayout = new QGridLayout;
749  sLayout->setColumnMinimumWidth(0,14*ww);
750  _outPortLineEdit->setMaximumWidth(9*ww);
751  _outWaitSpinBox->setMaximumWidth(9*ww);
752  _outSamplComboBox->setMaximumWidth(9*ww);
753  _outUPortLineEdit->setMaximumWidth(9*ww);
754
755  sLayout->addWidget(new QLabel("Output decoded observations in ASCII format to feed a real-time GNSS network engine.<br>"),0,0,1,50);
756  sLayout->addWidget(new QLabel("Port"),                            1, 0);
757  sLayout->addWidget(_outPortLineEdit,                              1, 1);
758  sLayout->addWidget(new QLabel("       Wait for full obs epoch"),  1, 2, Qt::AlignRight);
759  sLayout->addWidget(_outWaitSpinBox,                              1, 3, Qt::AlignLeft);
760  sLayout->addWidget(new QLabel("Sampling"),                        2, 0);
761  sLayout->addWidget(_outSamplComboBox,                              2, 1, Qt::AlignLeft);
762  sLayout->addWidget(new QLabel("File (full path)"),                3, 0);
763  sLayout->addWidget(_outFileLineEdit,                              3, 1, 1, 10);
764  sLayout->addWidget(new QLabel("Port (unsynchronized)"),           4, 0);
765  sLayout->addWidget(_outUPortLineEdit,                             4, 1);
766  sLayout->addWidget(new QLabel("Print lock time"),                 5, 0);
767  sLayout->addWidget(_outLockTimeCheckBox,                        5, 1);
768  sLayout->addWidget(new QLabel(""),                                6, 1);
769  sLayout->setRowStretch(7, 999);
770
771  sgroup->setLayout(sLayout);
772
773  // Serial Output
774  // -------------
775  QGridLayout* serLayout = new QGridLayout;
776  serLayout->setColumnMinimumWidth(0,12*ww);
777  _serialBaudRateComboBox->setMaximumWidth(9*ww);
778  _serialFlowControlComboBox->setMaximumWidth(11*ww);
779  _serialDataBitsComboBox->setMaximumWidth(5*ww);
780  _serialParityComboBox->setMaximumWidth(9*ww);
781  _serialStopBitsComboBox->setMaximumWidth(5*ww);
782  _serialAutoNMEAComboBox->setMaximumWidth(14*ww);
783  _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
784  _serialManualNMEASamplingSpinBox->setMaximumWidth(8*ww);
785
786  serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver.<br>"),0,0,1,30);
787  serLayout->addWidget(new QLabel("Mountpoint"),                  1, 0, Qt::AlignLeft);
788  serLayout->addWidget(_serialMountPointLineEdit,                 1, 1, 1, 2);
789  serLayout->addWidget(new QLabel("Port name"),                   2, 0, Qt::AlignLeft);
790  serLayout->addWidget(_serialPortNameLineEdit,                   2, 1, 1, 2);
791  serLayout->addWidget(new QLabel("Baud rate"),                   3, 0, Qt::AlignLeft);
792  serLayout->addWidget(_serialBaudRateComboBox,                   3, 1);
793  serLayout->addWidget(new QLabel("Flow control"),                3, 2, Qt::AlignRight);
794  serLayout->addWidget(_serialFlowControlComboBox,                3, 3);
795  serLayout->addWidget(new QLabel("Data bits"),                   4, 0, Qt::AlignLeft);
796  serLayout->addWidget(_serialDataBitsComboBox,                   4, 1);
797  serLayout->addWidget(new QLabel("Parity"),                      4, 2, Qt::AlignRight);
798  serLayout->addWidget(_serialParityComboBox,                     4, 3);
799  serLayout->addWidget(new QLabel("   Stop bits"),                4, 4, Qt::AlignRight);
800  serLayout->addWidget(_serialStopBitsComboBox,                   4, 5);
801  serLayout->addWidget(new QLabel("NMEA"),                        5, 0);
802  serLayout->addWidget(_serialAutoNMEAComboBox,                   5, 1);
803  serLayout->addWidget(new QLabel("    File (full path)"),        5, 2, Qt::AlignRight);
804  serLayout->addWidget(_serialFileNMEALineEdit,                   5, 3, 1,10);
805  serLayout->addWidget(new QLabel("Height"),                      5,14, Qt::AlignRight);
806  serLayout->addWidget(_serialHeightNMEALineEdit,                 5,15, 1,11);
807  serLayout->addWidget(new QLabel("Sampling"),                    5,25, Qt::AlignRight);
808  serLayout->addWidget(_serialManualNMEASamplingSpinBox,          5,26, 1,12);
809  serLayout->addWidget(new QLabel(""),                            6, 1);
810  serLayout->setRowStretch(7, 999);
811
812  sergroup->setLayout(serLayout);
813
814  // Outages
815  // -------
816  QGridLayout* aLayout = new QGridLayout;
817  aLayout->setColumnMinimumWidth(0,14*ww);
818  _adviseObsRateComboBox->setMaximumWidth(9*ww);
819  _adviseFailSpinBox->setMaximumWidth(9*ww);
820  _adviseRecoSpinBox->setMaximumWidth(9*ww);
821
822  aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes.<br>"),0,0,1,50,Qt::AlignLeft);
823  aLayout->addWidget(new QLabel("Observation rate"),              1, 0);
824  aLayout->addWidget(_adviseObsRateComboBox,                      1, 1);
825  aLayout->addWidget(new QLabel("Failure threshold"),             2, 0);
826  aLayout->addWidget(_adviseFailSpinBox,                          2, 1);
827  aLayout->addWidget(new QLabel("Recovery threshold"),            3, 0);
828  aLayout->addWidget(_adviseRecoSpinBox,                          3, 1);
829  aLayout->addWidget(new QLabel("Script (full path)"),            4, 0);
830  aLayout->addWidget(_adviseScriptLineEdit,                       4, 1, 1,20);
831  aLayout->addWidget(new QLabel(""),                              5, 1);
832  aLayout->setRowStretch(6, 999);
833
834  agroup->setLayout(aLayout);
835
836  // Miscellaneous
837  // -------------
838  QGridLayout* rLayout = new QGridLayout;
839  rLayout->setColumnMinimumWidth(0,14*ww);
840  _miscIntrComboBox->setMaximumWidth(9*ww);
841  _miscPortLineEdit->setMaximumWidth(9*ww);
842
843  rLayout->addWidget(new QLabel("Log latencies or scan RTCM streams for message types and antenna information or output raw data through TCP/IP port.<br>"),0, 0,1,50);
844  rLayout->addWidget(new QLabel("Mountpoint"),                    1, 0);
845  rLayout->addWidget(_miscMountLineEdit,                          1, 1, 1, 7);
846  rLayout->addWidget(new QLabel("Log latency"),                   2, 0);
847  rLayout->addWidget(_miscIntrComboBox,                           2, 1);
848  rLayout->addWidget(new QLabel("Scan RTCM"),                     3, 0);
849  rLayout->addWidget(_miscScanRTCMCheckBox,                       3, 1);
850  rLayout->addWidget(new QLabel("Port"),                          4, 0);
851  rLayout->addWidget(_miscPortLineEdit,                           4, 1);
852  rLayout->addWidget(new QLabel(""),                              5, 1);
853  rLayout->setRowStretch(6, 999);
854
855  rgroup->setLayout(rLayout);
856
857  // PPP
858  // ---
859  _pppWidgets._dataSource->setMaximumWidth(20*ww);
860  _pppWidgets._corrMount->setMaximumWidth(20*ww);
861
862  _pppWidgets._corrFile->setMaximumWidth(35*ww);
863  _pppWidgets._crdFile->setMaximumWidth(35*ww);
864  _pppWidgets._logPath->setMaximumWidth(35*ww);
865  _pppWidgets._snxtroPath->setMaximumWidth(35*ww);
866  _pppWidgets._snxtroIntr->setMaximumWidth(10*ww);
867  _pppWidgets._snxtroAc  ->setMaximumWidth(10*ww);
868  _pppWidgets._snxtroSol ->setMaximumWidth(7*ww);
869
870  QGridLayout* pppLayout1 = new QGridLayout();
871  int ir = 0;
872  pppLayout1->addWidget(new QLabel("Precise Point Positioning - Input and Output."), ir, 0, 1, 7, Qt::AlignLeft);
873  ++ir;
874  pppLayout1->addWidget(new QLabel("Data source"),           ir, 0);
875  pppLayout1->addWidget(_pppWidgets._dataSource,             ir, 1);
876  pppLayout1->addWidget(new QLabel("   RINEX Obs file"),     ir, 3);
877  pppLayout1->addWidget(_pppWidgets._rinexObs,               ir, 4, 1, 3);
878  ++ir;
879  pppLayout1->addWidget(new QLabel("Corrections stream"),    ir, 0);
880  pppLayout1->addWidget(_pppWidgets._corrMount,              ir, 1);
881  pppLayout1->addWidget(new QLabel("   RINEX Nav file"),     ir, 3);
882  pppLayout1->addWidget(_pppWidgets._rinexNav,               ir, 4, 1, 3);
883  ++ir;
884  pppLayout1->addWidget(new QLabel("Corrections file"),      ir, 0);
885  pppLayout1->addWidget(_pppWidgets._corrFile,               ir, 1);
886  pppLayout1->addWidget(new QLabel("   ANTEX file"),         ir, 3);
887  pppLayout1->addWidget(_pppWidgets._antexFile,              ir, 4, 1, 3);
888  ++ir;
889  pppLayout1->addWidget(new QLabel("Coordinates file"),      ir, 0);
890  pppLayout1->addWidget(_pppWidgets._crdFile,                ir, 1);
891  pppLayout1->addWidget(new QLabel("   Version 3 filenames"),ir, 3);
892  pppLayout1->addWidget(_pppWidgets._v3filenames,            ir, 4, 1, 3);
893  ++ir;
894  pppLayout1->addWidget(new QLabel("Logfile directory"),     ir, 0);
895  pppLayout1->addWidget(_pppWidgets._logPath,                ir, 1);
896  pppLayout1->addWidget(new QLabel("   NMEA directory"),     ir, 3);
897  pppLayout1->addWidget(_pppWidgets._nmeaPath,               ir, 4, 1, 3);
898  ++ir;
899  pppLayout1->addWidget(new QLabel("SNX TRO directory"),     ir, 0);
900  pppLayout1->addWidget(_pppWidgets._snxtroPath,             ir, 1);
901  pppLayout1->addWidget(new QLabel("   SNX TRO interval"),   ir, 3);
902  pppLayout1->addWidget(_pppWidgets._snxtroIntr,             ir, 4);
903  pppLayout1->addWidget(new QLabel("   SNX TRO sampling"),   ir, 5);
904  pppLayout1->addWidget(_pppWidgets._snxtroSampl,            ir, 6, Qt::AlignRight);
905  ++ir;
906  pppLayout1->addWidget(new QLabel("   SNX TRO AC"),         ir, 3);
907  pppLayout1->addWidget(_pppWidgets._snxtroAc,               ir, 4);
908  pppLayout1->addWidget(new QLabel("   SNX TRO solution")    ,ir, 5);
909  pppLayout1->addWidget(_pppWidgets._snxtroSol,              ir, 6, Qt::AlignRight);
910  pppLayout1->setRowStretch(ir, 999);
911
912  pppGroup1->setLayout(pppLayout1);
913
914  QVBoxLayout* pppLayout2 = new QVBoxLayout();
915  pppLayout2->addWidget(new QLabel("Precise Point Positioning - Processed Stations.<br>"));
916  pppLayout2->addWidget(_pppWidgets._staTable, 99);
917  QHBoxLayout* pppLayout2sub = new QHBoxLayout();
918  pppLayout2sub->addWidget(_pppWidgets._addStaButton);
919  pppLayout2sub->addWidget(_pppWidgets._delStaButton);
920  pppLayout2sub->addStretch(99);
921
922  pppLayout2->addLayout(pppLayout2sub);
923
924  pppGroup2->setLayout(pppLayout2);
925
926  QGridLayout* pppLayout3 = new QGridLayout();
927  ir = 0;
928  pppLayout3->addWidget(new QLabel("Precise Point Positioning - Options.<br>"), ir, 0, 1, 2, Qt::AlignLeft);
929  ++ir;
930  pppLayout3->addWidget(new QLabel("GPS LCs"),              ir, 0, Qt::AlignLeft);
931  pppLayout3->addWidget(_pppWidgets._lcGPS,                 ir, 1);
932  pppLayout3->addItem(new QSpacerItem(8*ww, 0),             ir, 2);
933  pppLayout3->addWidget(new QLabel("Sigma C1"),             ir, 3, Qt::AlignLeft);
934  pppLayout3->addWidget(_pppWidgets._sigmaC1,               ir, 4); _pppWidgets._sigmaC1->setMaximumWidth(8*ww);
935  pppLayout3->addItem(new QSpacerItem(8*ww, 0),             ir, 5);
936  pppLayout3->addWidget(new QLabel("Sigma L1"),             ir, 6, Qt::AlignLeft);
937  pppLayout3->addWidget(_pppWidgets._sigmaL1,               ir, 7); _pppWidgets._sigmaL1->setMaximumWidth(8*ww);
938  ++ir;
939  pppLayout3->addWidget(new QLabel("GLONASS LCs"),          ir, 0, Qt::AlignLeft);
940  pppLayout3->addWidget(_pppWidgets._lcGLONASS,             ir, 1);
941  pppLayout3->addWidget(new QLabel("Max Res C1"),           ir, 3, Qt::AlignLeft);
942  pppLayout3->addWidget(_pppWidgets._maxResC1,              ir, 4); _pppWidgets._maxResC1->setMaximumWidth(8*ww);
943  pppLayout3->addWidget(new QLabel("Max Res L1"),           ir, 6, Qt::AlignLeft);
944  pppLayout3->addWidget(_pppWidgets._maxResL1,              ir, 7); _pppWidgets._maxResL1->setMaximumWidth(8*ww);
945  ++ir;
946  pppLayout3->addWidget(new QLabel("Galileo LCs"),          ir, 0, Qt::AlignLeft);
947  pppLayout3->addWidget(_pppWidgets._lcGalileo,             ir, 1);
948  pppLayout3->addWidget(new QLabel("Ele Wgt Code"),         ir, 3, Qt::AlignLeft);
949  pppLayout3->addWidget(_pppWidgets._eleWgtCode,            ir, 4);
950  pppLayout3->addWidget(new QLabel("Ele Wgt Phase"),        ir, 6, Qt::AlignLeft);
951  pppLayout3->addWidget(_pppWidgets._eleWgtPhase,           ir, 7);
952  ++ir;
953  pppLayout3->addWidget(new QLabel("BDS LCs"),              ir, 0, Qt::AlignLeft);
954  pppLayout3->addWidget(_pppWidgets._lcBDS,                 ir, 1);
955  pppLayout3->addWidget(new QLabel("Min # of Obs"),         ir, 3, Qt::AlignLeft);
956  pppLayout3->addWidget(_pppWidgets._minObs,                ir, 4);
957  pppLayout3->addWidget(new QLabel("Min Elevation"),        ir, 6, Qt::AlignLeft);
958  pppLayout3->addWidget(_pppWidgets._minEle,                ir, 7);
959  ++ir;
960  pppLayout3->addWidget(new QLabel("Wait for clock corr."), ir, 0, Qt::AlignLeft);
961  pppLayout3->addWidget(_pppWidgets._corrWaitTime,          ir, 1);
962  pppLayout3->addWidget(new QLabel("Seeding (sec)"),        ir, 3, Qt::AlignLeft);
963  pppLayout3->addWidget(_pppWidgets._seedingTime,           ir, 4);
964  ++ir;
965  pppLayout3->addWidget(new QLabel(""),                     ir, 8);
966  pppLayout3->setColumnStretch(8, 999);
967  ++ir;
968  pppLayout3->addWidget(new QLabel(""),                      ir, 1);
969  pppLayout3->setRowStretch(ir, 999);
970
971  pppGroup3->setLayout(pppLayout3);
972
973  // ------------------------
974  connect(_pppWidgets._mapWinButton, SIGNAL(clicked()), SLOT(slotMapPPP()));
975  _pppWidgets._mapSpeedSlider->setMinimumWidth(33*ww);
976  _pppWidgets._audioResponse->setMaximumWidth(8*ww);
977
978  QGridLayout* pppLayout4 = new QGridLayout();
979  ir = 0;
980  pppLayout4->addWidget(new QLabel("Precise Point Positioning - Plots.<br>"), ir, 0, 1, 50, Qt::AlignLeft);
981  ++ir;
982  pppLayout4->addWidget(new QLabel("PPP Plot"),                          ir, 0, Qt::AlignLeft);
983  pppLayout4->addWidget(_pppWidgets._plotCoordinates,                    ir, 1, Qt::AlignLeft);
984  pppLayout4->addWidget(new QLabel("Mountpoint"),                        ir, 2, 1, 10, Qt::AlignLeft);
985  pppLayout4->addWidget(_pppWidgets._audioResponse,                      ir, 4, Qt::AlignLeft);
986  pppLayout4->addWidget(new QLabel("Audio response"),                    ir, 5, Qt::AlignRight);
987  ++ir;
988  pppLayout4->addWidget(new QLabel("Track map"),                         ir, 0, Qt::AlignLeft);
989  pppLayout4->addWidget(_pppWidgets._mapWinButton,                       ir, 1, Qt::AlignLeft);
990  ++ir;
991  pppLayout4->addWidget(new QLabel("Dot-properties"),                    ir, 0, Qt::AlignLeft);
992  pppLayout4->addWidget(_pppWidgets._mapWinDotSize,                      ir, 1, Qt::AlignLeft);
993  pppLayout4->addWidget(new QLabel("Size    "),                          ir, 2, Qt::AlignLeft);
994  pppLayout4->addWidget(_pppWidgets._mapWinDotColor,                     ir, 3, Qt::AlignLeft);
995  pppLayout4->addWidget(new QLabel("Color"),                             ir, 4, Qt::AlignLeft);
996  ++ir;
997  pppLayout4->addWidget(new QLabel("Post-processing speed"),             ir, 0, Qt::AlignLeft);
998  pppLayout4->addWidget(_pppWidgets._mapSpeedSlider,                     ir, 1, 1, 20, Qt::AlignLeft);
999  ++ir;
1000  pppLayout4->addWidget(new QLabel(""),                                  ir, 1);
1001  pppLayout4->setRowStretch(ir, 999);
1002
1003  pppGroup4->setLayout(pppLayout4);
1004
1005  // Reqc Processing
1006  // ---------------
1007  _reqcActionComboBox = new QComboBox();
1008  _reqcActionComboBox->setEditable(false);
1009  _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
1010  int ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
1011  if (ik != -1) {
1012    _reqcActionComboBox->setCurrentIndex(ik);
1013  }
1014  connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
1015          this, SLOT(slotBncTextChanged()));
1016
1017  QGridLayout* reqcLayout = new QGridLayout;
1018  _reqcActionComboBox->setMinimumWidth(15*ww);
1019  _reqcActionComboBox->setMaximumWidth(20*ww);
1020
1021  _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1022  _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
1023
1024  _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1025  _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
1026  _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
1027  _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
1028  _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
1029  _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
1030  _reqcSkyPlotSignals = new QLineEdit(settings.value("reqcSkyPlotSignals").toString());
1031
1032  connect(_reqcSkyPlotSignals, SIGNAL(textChanged(const QString &)),
1033          this, SLOT(slotBncTextChanged()));
1034
1035  _reqcLogSummaryOnly = new QCheckBox();
1036  _reqcLogSummaryOnly->setCheckState(Qt::CheckState(settings.value("reqcLogSummaryOnly").toInt()));
1037
1038  ir = 0;
1039  reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check.<br>"),ir, 0, 1, 8);
1040  ++ir;
1041  reqcLayout->addWidget(new QLabel("Action"),                    ir, 0);
1042  reqcLayout->addWidget(_reqcActionComboBox,                     ir, 1);
1043  _reqcEditOptionButton = new QPushButton("Set Edit Options");
1044  _reqcEditOptionButton->setMinimumWidth(15*ww);
1045  _reqcEditOptionButton->setMaximumWidth(20*ww);
1046
1047  reqcLayout->addWidget(_reqcEditOptionButton,                   ir, 3);
1048  ++ir;
1049  reqcLayout->addWidget(new QLabel("Input files (full path)"),   ir, 0);
1050  reqcLayout->addWidget(_reqcObsFileChooser,                     ir, 1);
1051  _reqcObsFileChooser->setMaximumWidth(40*ww);
1052  reqcLayout->addWidget(new QLabel("  Obs"),                     ir, 2);
1053  reqcLayout->addWidget(_reqcNavFileChooser,                     ir, 3);
1054  _reqcNavFileChooser->setMaximumWidth(40*ww);
1055  reqcLayout->addWidget(new QLabel("  Nav"),                     ir, 4);
1056  ++ir;
1057  reqcLayout->addWidget(new QLabel("Output file (full path)"),   ir, 0);
1058  reqcLayout->addWidget(_reqcOutObsLineEdit,                     ir, 1);
1059  _reqcOutObsLineEdit->setMaximumWidth(40*ww);
1060  reqcLayout->addWidget(new QLabel("  Obs"),                     ir, 2);
1061  reqcLayout->addWidget(_reqcOutNavLineEdit,                     ir, 3);
1062  _reqcOutNavLineEdit->setMaximumWidth(40*ww);
1063  reqcLayout->addWidget(new QLabel("  Nav"),                     ir, 4);
1064  ++ir;
1065  reqcLayout->addWidget(new QLabel("Logfile"),                   ir, 0);
1066  reqcLayout->addWidget(_reqcOutLogLineEdit,                     ir, 1);
1067  _reqcOutLogLineEdit->setMaximumWidth(40*ww);
1068  reqcLayout->addWidget(new QLabel("  Summary only"),            ir, 2);
1069  reqcLayout->addWidget(_reqcLogSummaryOnly,                     ir, 3);
1070  ++ir;
1071  reqcLayout->addWidget(new QLabel("Plots for signals"),         ir, 0);
1072  reqcLayout->addWidget(_reqcSkyPlotSignals,                     ir, 1);
1073  _reqcSkyPlotSignals->setMaximumWidth(40*ww);
1074  ++ir;
1075  reqcLayout->addWidget(new QLabel("Directory for plots"),       ir, 0);
1076  reqcLayout->addWidget(_reqcPlotDirLineEdit,                    ir, 1);
1077  _reqcPlotDirLineEdit->setMaximumWidth(40*ww);
1078  ++ir;
1079  reqcLayout->setRowStretch(ir, 999);
1080
1081  reqcLayout->setColumnMinimumWidth(2, 8*ww);
1082  reqcLayout->setColumnMinimumWidth(4, 8*ww);
1083
1084  reqcgroup->setLayout(reqcLayout);
1085
1086  connect(_reqcEditOptionButton, SIGNAL(clicked()),
1087          this, SLOT(slotReqcEditOption()));
1088
1089  QGridLayout* sp3CompLayout = new QGridLayout;
1090
1091  _sp3CompFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1092  _sp3CompFileChooser->setFileName(settings.value("sp3CompFile").toString());
1093  _sp3CompFileChooser->setMinimumWidth(15*ww);
1094  _sp3CompFileChooser->setMaximumWidth(40*ww);
1095
1096  _sp3CompExclude = new QLineEdit(settings.value("sp3CompExclude").toString());
1097  _sp3CompExclude->setMinimumWidth(18*ww);
1098  _sp3CompExclude->setMaximumWidth(18*ww);
1099
1100  _sp3CompLogLineEdit = new QLineEdit(settings.value("sp3CompOutLogFile").toString());
1101  _sp3CompLogLineEdit->setMinimumWidth(18*ww);
1102  _sp3CompLogLineEdit->setMaximumWidth(18*ww);
1103
1104  ir = 0;
1105  sp3CompLayout->addWidget(new QLabel("Orbit and clock comparison.<br>"),  ir, 0, 1, 40);
1106  ++ir;
1107  sp3CompLayout->addWidget(new QLabel("Input SP3 files (full path)"),  ir, 0, Qt::AlignLeft);
1108  sp3CompLayout->addWidget(_sp3CompFileChooser,                        ir, 1, 1, 20);
1109  ++ir;
1110  sp3CompLayout->addWidget(new QLabel("Exclude satellites"),           ir, 0, Qt::AlignLeft);
1111  sp3CompLayout->addWidget(_sp3CompExclude,                            ir, 1, Qt::AlignRight);
1112  ++ir;
1113  sp3CompLayout->addWidget(new QLabel("Logfile"),                      ir, 0, Qt::AlignLeft);
1114  sp3CompLayout->addWidget(_sp3CompLogLineEdit,                        ir, 1, Qt::AlignRight);
1115  ++ir;
1116  sp3CompLayout->addWidget(new QLabel(""),                             ir, 1);
1117  ++ir;
1118  sp3CompLayout->setRowStretch(ir, 999);
1119
1120  sp3CompLayout->setColumnMinimumWidth(2, 8*ww);
1121  sp3CompLayout->setColumnMinimumWidth(4, 8*ww);
1122
1123  sp3CompGroup->setLayout(sp3CompLayout);
1124
1125  connect(_sp3CompFileChooser, SIGNAL(fileNameChanged(const QString &)),
1126          this, SLOT(slotBncTextChanged()));
1127
1128  // Combine Corrections
1129  // -------------------
1130  QGridLayout* cmbLayout = new QGridLayout;
1131
1132  populateCmbTable();
1133  cmbLayout->addWidget(_cmbTable,                                            0, 0, 8, 3);
1134  cmbLayout->addWidget(new QLabel(" Combine Broadcast Correction streams.<br>"), 1, 6, 1, 10);
1135  cmbLayout->addWidget(addCmbRowButton,                                      2, 6);
1136  cmbLayout->addWidget(delCmbRowButton,                                      2, 7);
1137  cmbLayout->addWidget(new QLabel("Method"),                                 3, 6, Qt::AlignRight);
1138  cmbLayout->addWidget(_cmbMethodComboBox,                                   3, 7);
1139  cmbLayout->addWidget(new QLabel(" Maximal residuum"),                      4, 6, Qt::AlignRight);
1140  cmbLayout->addWidget(_cmbMaxresLineEdit,                                   4, 7, Qt::AlignRight);
1141  cmbLayout->addWidget(new QLabel("Sampling"),                               5, 6, Qt::AlignRight);
1142  cmbLayout->addWidget(_cmbSamplSpinBox,                                     5, 7);
1143  cmbLayout->addWidget(new QLabel("   Use GLONASS"),                         6, 6, Qt::AlignRight);
1144  cmbLayout->addWidget(_cmbUseGlonass,                                       6, 7);
1145  cmbLayout->setRowStretch(7, 999);
1146
1147  connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1148  connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
1149
1150  cmbgroup->setLayout(cmbLayout);
1151
1152  // Upload Layout (Clocks)
1153  // ----------------------
1154  QGridLayout* uploadHlpLayout = new QGridLayout();
1155
1156  connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1157  connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1158  connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
1159
1160  uploadHlpLayout->addWidget(addUploadRowButton,                  0, 0);
1161  uploadHlpLayout->addWidget(delUploadRowButton,                  0, 1);
1162  uploadHlpLayout->addWidget(new QLabel("Interval"),              0, 2, Qt::AlignRight);
1163  uploadHlpLayout->addWidget(_uploadIntrComboBox,                 0, 3);
1164  uploadHlpLayout->addWidget(new QLabel("     Sampling:    Orb"), 0, 4, Qt::AlignRight);
1165  uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox,      0, 5);
1166  uploadHlpLayout->addWidget(new QLabel("SP3"),                   0, 6, Qt::AlignRight);
1167  uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox,              0, 7);
1168  uploadHlpLayout->addWidget(new QLabel("RNX"),                   0, 8, Qt::AlignRight);
1169  uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox,           0, 9);
1170  uploadHlpLayout->addWidget(setUploadTrafoButton,                0,10);
1171  uploadHlpLayout->addWidget(new QLabel("ANTEX file"),            1, 0, Qt::AlignLeft);
1172  uploadHlpLayout->addWidget(_uploadAntexFile,                    1, 1, 1, 4);
1173
1174  QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1175  populateUploadTable();
1176
1177  uploadLayout->addWidget(new QLabel("Upload RTCM Version 3 Broadcast Corrections to caster.<br>"));
1178  uploadLayout->addWidget(_uploadTable);
1179  uploadLayout->addLayout(uploadHlpLayout);
1180
1181  uploadgroup->setLayout(uploadLayout);
1182
1183  // Upload Layout (Ephemeris)
1184  // -------------------------
1185  QGridLayout* uploadLayoutEph = new QGridLayout;
1186
1187  uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1188  _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1189  _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1190  _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1191
1192  uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster.<br>"), 0, 0, 1, 50);
1193  uploadLayoutEph->addWidget(new QLabel("Host"),                  1, 0);
1194  uploadLayoutEph->addWidget(_uploadEphHostLineEdit,              1, 1, 1, 3);
1195  uploadLayoutEph->addWidget(new QLabel("  Port"),                1, 4, Qt::AlignRight);
1196  uploadLayoutEph->addWidget(_uploadEphPortLineEdit,              1, 5, 1, 1);
1197  uploadLayoutEph->addWidget(new QLabel("Mountpoint           "), 2, 0);
1198  uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit,        2, 1);
1199  uploadLayoutEph->addWidget(new QLabel("          Password"),    2, 2, Qt::AlignRight);
1200  uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit,          2, 3);
1201  uploadLayoutEph->addWidget(new QLabel("Sampling"),              3, 0);
1202  uploadLayoutEph->addWidget(_uploadEphSampleSpinBox,             3, 1);
1203  uploadLayoutEph->addWidget(new QLabel("Uploaded"),              4, 0);
1204  uploadLayoutEph->addWidget(_uploadEphBytesCounter,              4, 1);
1205  uploadLayoutEph->setRowStretch(5, 999);
1206
1207  uploadEphgroup->setLayout(uploadLayoutEph);
1208
1209  connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1210          this, SLOT(slotBncTextChanged()));
1211
1212  // Main Layout
1213  // -----------
1214  QGridLayout* mLayout = new QGridLayout;
1215  _aogroup->setCurrentIndex(settings.value("startTab").toInt());
1216  mLayout->addWidget(_aogroup,            0,0);
1217  mLayout->addWidget(_mountPointsTable,   1,0);
1218  _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
1219  mLayout->addWidget(_loggroup,           2,0);
1220
1221  _canvas->setLayout(mLayout);
1222
1223  // WhatsThis, Network
1224  // ------------------
1225  _proxyHostLineEdit->setWhatsThis(tr("<p>If you are running BNC within a protected Local Area Network (LAN), you may 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 this is not possible, you may need to run BNC outside your LAN on a network that has unobstructed connection to the Internet.</p>"));
1226  _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1227  _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 whether this is supported by the involved Ntrip Broadcaster.</p><p>Note that SSL communication is usually done over port 443.</p>"));
1228  _sslIgnoreErrorsCheckBox->setWhatsThis(tr("<p>SSL communication may involve queries coming from the Ntrip Broadcaster. Tick 'Ignore SSL authorization errors' if you don't want to be bothered with this.</p>"));
1229
1230  // WhatsThis, General
1231  // ------------------
1232  _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 for that 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.</p>"));
1233  _rnxAppendCheckBox->setWhatsThis(tr("<p>When BNC is started, new files are created by default and file content already available under the same name will be overwritten. However, users might want to append already existing files following a regular restart or a crash of BNC or its platform.</p><p>Tick 'Append files' to continue with existing files and keep what has been recorded so far.</p>"));
1234  _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, five minutes, 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 via button 'Save & Reread Configuration'.</p>"));
1235  _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1236  _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p><p>This option is primarily meant for debugging purposes.</p>"));
1237
1238  // WhatsThis, RINEX Observations
1239  // -----------------------------
1240  _rnxPathLineEdit->setWhatsThis(tr("<p>Here you specify the path to where the RINEX Observation files will be stored.</p><p>If the specified directory does not exist, BNC will not create RINEX Observation files.</p>"));
1241  _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1242  _rnxSamplComboBox->setWhatsThis(tr("<p>Select the RINEX Observation sampling interval in seconds. </p>"));
1243  _rnxSkelLineEdit->setWhatsThis(tr("<p>BNC allows using personal RINEX skeleton files that contain the RINEX header records you would like to include. You can derive a skeleton file from information given in an up to date sitelog.</p><p>A file in the RINEX Observations 'Directory' with a 'Skeleton extension' skl or SKL is interpreted by BNC as a personal RINEX header skeleton file for the corresponding stream. In case of 'SKL'/'skl' the 4/9-char ID forming the base name has to be written in upper cases. </p>"));
1244  _rnxFileCheckBox->setWhatsThis(tr("<p>Tick check box 'Skeleton mandatory' in case you want that RINEX files are only produced if skeleton files are available for BNC. If no skeleton file is available for a particular source then no RINEX Observation file will be produced from the affected stream.</p><p>Note that a skeleton file contains RINEX header information such as receiver and antenna types. In case of stream conversion to RINEX Version 3, a skeleton file should also contain information on potentially available observation types. A missing skeleton file will therefore enforce BNC to only save a default set of RINEX 3 observation types.</p>"));
1245  _rnxScrpLineEdit->setWhatsThis(tr("<p>Whenever a RINEX Observation file is finally saved, you may want to compress, copy or upload it immediately, for example via FTP. BNC allows you to execute a script/batch file to carry out such operation.</p><p>Specify the full path of a script or batch file. BNC will pass the full RINEX Observation file path to the script as command line parameter (%1 on Windows systems, $1 on Unix/Linux/Mac systems).</p>"));
1246  _rnxV2Priority->setWhatsThis(tr("<p>Specify a priority list of characters defining signal attributes as defined in RINEX Version 3. Priorities will be used to map observations with RINEX Version 3 attributes from incoming streams to Version 2. The underscore character '_' stands for undefined attributes. A question mark '?' can be used as wildcard which represents any one character.</p><p>Signal priorities can be specified as equal for all systems, as system specific or as system and freq. specific. For example: </li><ul><li>'CWPX_?' (General signal priorities valid for all GNSS) </li><li>'I:ABCX' (System specific signal priorities for IRNSS) </li><li>'G:12&PWCSLX G:5&IQX R:12&PC R:3&IQX' (System and frequency specific signal priorities) </li></ul>Default is the following priority list 'G:12&PWCSLX G:5&IQX R:12&PC R:3&IQX R:46&ABX E:16&BCXZ E:578&IQX J:1&SLXCZ J:26&SLX J:5&IQX C:267&IQX C:128&DPX C:7&DPZ I:ABCX S:1&C S:5&IQX'. <i>[key: rnxV2Priority]</i></p>"));
1247  _rnxV3CheckBox->setWhatsThis(tr("<p>The default format for RINEX Observation files is RINEX Version 2.</p><p>Select 'Version 3' if you want to save observations in RINEX Version 3 format.</p>"));
1248
1249  // WhatsThis, RINEX Ephemeris
1250  // --------------------------
1251  _ephPathLineEdit->setWhatsThis(tr("<p>Specify the path for saving Broadcast Ephemeris data as RINEX Navigation files.</p><p>If the specified directory does not exist, BNC will not create RINEX Navigation files.</p>"));
1252  _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1253  _ephOutPortLineEdit->setWhatsThis(tr("<p>BNC can produce ephemeris data in RINEX Navigation ASCII format on your local host through an IP port.</p><p>Specify a port number here to activate this function.</p>"));
1254  _ephV3CheckBox->setWhatsThis(tr("<p>The default format for output of RINEX Navigation data containing Broadcast Ephemeris is RINEX Version 2.</p><p>Select 'Version 3' if you want to output ephemeris in RINEX Version 3 format.</p>"));
1255
1256  // WhatsThis, RINEX Editing & QC
1257  // -----------------------------
1258  _reqcActionComboBox->setWhatsThis(tr("<p>BNC allows to 'Edit or Concatenate' RINEX Version 2 or 3 files or to perform a Quality Check (QC) and 'Analyze' data following UNAVCO's famous 'teqc' program.</p>"));
1259  _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX Version 2 or 3 files.</p>"));
1260  _reqcObsFileChooser->setWhatsThis(tr("<p>Specify the full path to input observation files in RINEX Version 2 or 3 format.</p><p>Note that when in 'Analyze' mode, specifying at least one RINEX observation file is mandatory.</p>"));
1261  _reqcNavFileChooser->setWhatsThis(tr("<p>Specify the full path to input navigation files in RINEX Version 2 or 3 format.</p><p>Note that when in 'Analyze' mode, specifying at least one RINEX navigation file is mandatory.</p>"));
1262  _reqcOutObsLineEdit->setWhatsThis(tr("<p>Specify the full path to a RINEX Observation output file.</p><p>Default is an empty option field, meaning that no RINEX Observation output file will be produced.</p>"));
1263  _reqcOutNavLineEdit->setWhatsThis(tr("<p>Specify the full path to a RINEX Navigation output file.</p><p>Default is an empty option field, meaning that no RINEX Navigation output file will be produced.</p>"));
1264  _reqcOutLogLineEdit->setWhatsThis(tr("<p>Specify the full path to a logfile.</p><p>Default is an empty option field, meaning that no 'RINEX Editing & QC' logfile will be produced.</p>"));
1265  _reqcLogSummaryOnly->setWhatsThis(tr("<p>By default BNC produces a detailed 'Logfile' providing all information resulting from editing or analyzing RINEX data. If that is too much information, you can limit the logfile content to a short summary.</p><p>Tick 'Summary only' to suppress full logfile output and instead produce a logfile containing only summary information.</p>"));
1266  _reqcPlotDirLineEdit->setWhatsThis(tr("<p>Specify a directory for saving plots in PNG format.</p><p>Default is an empty option field, meaning that plots will not be saved on disk.</p>"));
1267  _reqcSkyPlotSignals->setWhatsThis(tr("<p>BNC can produce plots for multipath, signal-to-noise ratio, satellite availability, satellite elevation, and PDOP values. The 'Plots for signals' option lets you exactly specify observation signals to be used for that and also enables the plot generation. You can specify the navigation system, the frequency, and the tracking mode or channel as defined in RINEX Version 3. Specifications for frequency and tracking mode or channel must be separated by ampersand character '&'. Specifications for navigation systems must be separated by blank character ' '.</p><p>Examples for 'Plots for signals' option:<ul><li> G:1&2 R:1&2 J:1&2 E:1&7 C:1&6 S:1<br>(Plots will be based on GPS observations on 1st and 2nd frequency, GLONASS observations on 1st and 2nd frequency, QZSS observations on 1st and 2nd frequency, Galileo observations on 1st and 7th frequency, BeiDou observations on 1st and 6th frequency, SBAS observations on 1st frequency.)</li><li>G:1C&5X<br>(Plots will be based on GPS observations on 1st frequency in C tracking mode and GPS observations on 5th frequency in X tracking mode.)</li><li>C:6I&7I<br>(Plots will be based on BeiDou observations on 6th frequency in I tracking mode and BeiDou observations on 7th frequency in I tracking mode.)<li></ul></p><p>Default is 'C:2&7 E:1&5 G:1&2 J:1&2 R:1&2 S:1&5 I:5&9'. Specifying an empty option string would be overruled by this default.</p>"));
1268
1269  // WhatsThis, SP3 Comparison
1270  // -------------------------
1271  _sp3CompFileChooser->setWhatsThis(tr("<p>BNC can compare two SP3 files containing GNSS satellite orbit and clock information.</p></p>Specify the full path to two files with orbits and clocks in SP3 format, separate them by comma.</p>"));
1272  _sp3CompExclude->setWhatsThis(tr("<p>Specify satellites to exclude them from orbit and clock comparison. Example:<p>G04,G31,R</p><p>This excludes GPS satellites PRN 4 and 31 as well as all GLONASS satellites from the comparison.</p><p>Default is an empty option field, meaning that no satellite is excluded from the comparison.</p>"));
1273  _sp3CompLogLineEdit->setWhatsThis(tr("<p>Specify the full path to a logfile saving comparison results.</p><p>Specifying a logfile is mandatory. Comparing SP3 files and not saving comparison results on disk would be useless.</p>"));
1274
1275  // WhatsThis, Broadcast Corrections
1276  // --------------------------------
1277  _corrPathLineEdit->setWhatsThis(tr("<p>Specify a directory for saving Broadcast Ephemeris Correction files.</p><p>If the specified directory does not exist, BNC will not create the files.</p>"));
1278  _corrPortLineEdit->setWhatsThis(tr("<p>BNC can produce Broadcast Ephemeris Corrections on your local host through an IP port.</p><p>Specify a port number here to activate this function.</p>"));
1279  _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of Broadcast Ephemeris Correction files.</p>"));
1280
1281  // WhatsThis, Feed Engine
1282  // ----------------------
1283  _outPortLineEdit->setWhatsThis(tr("<p>BNC can produce synchronized observations in a plain ASCII format on your local host via IP port.</p><p>Specify a port number to activate this function.</p>"));
1284  _outWaitSpinBox->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.</p><p>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 product.</p>"));
1285  _outSamplComboBox->setWhatsThis(tr("<p>Select a synchronized observation sampling interval in seconds. </p>"));
1286  _outFileLineEdit->setWhatsThis(tr("<p>Specify the full path to a file where synchronized observations are saved in plain ASCII format.</p><p>Beware that the size of this file can rapidly increase depending on the number of incoming streams.</p>"));
1287  _outUPortLineEdit->setWhatsThis(tr("<p>BNC can produce unsynchronized observations in a plain ASCII format on your local host via IP port.</p><p>Specify a port number to activate this function.</p>"));
1288  _outLockTimeCheckBox->setWhatsThis(tr("<p>Print the lock time in seconds in the feed engine output.</p>"));
1289
1290  // WhatsThis, Serial Output
1291  // ------------------------
1292  _serialMountPointLineEdit->setWhatsThis(tr("<p>Enter a 'Mountpoint' to forward the corresponding stream to a serial connected receiver.</p><p>Depending on the stream content, the receiver may use it for example for Differential GNSS, Precise Point Positioning or any other purpose supported by its firmware.</p>"));
1293  _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 before you start BNC, you must plug a serial cable in the port defined here.</p>"));
1294  _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. Using a high baud rate is recommended.</p>"));
1295  _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>"));
1296  _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>"));
1297  _serialParityComboBox->setWhatsThis(tr("<p>Select a 'Parity' for the serial output link.</p><p>Note that your selection must equal the parity selection configured to the serial connected receiver. The parity is often set to 'NONE'.</p>"));
1298  _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>"));
1299  _serialAutoNMEAComboBox->setWhatsThis(tr("<p>The 'NMEA' option supports the so-called 'Virtual Reference Station' (VRS) concept which requires the receiver to send approximate position information to the Ntrip Broadcaster. Select 'no' if you don't want BNC to forward or upload any NMEA message to the Ntrip Broadcaster in support of VRS.</p><p>Select 'Auto' to automatically forward NMEA messages of type GGA from your serial connected receiver to the Ntrip Broadcaster and/or save them in a file.</p><p>Select 'Manual GPGGA' or 'Manual GNGGA' if you want BNC to produce and upload GPGGA or GNGGA NMEA messages to the Ntrip Broadcaster because your serial connected receiver doesn't generate these messages. A Talker ID 'GP' preceding the GGA string stands for GPS solutions while a Talker ID 'GN' stands for multi constellation solutions.</p><p>Note that selecting 'Auto' or 'Manual' works only for VRS streams which show up under the 'Streams' canvas on BNC's main window with 'nmea' stream attribute set to 'yes'. This attribute is either extracted from the Ntrip Broadcaster's source-table or introduced by the user via editing the BNC configuration file.</p>"));
1300  _serialFileNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where NMEA messages coming from your serial connected receiver are saved.</p><p>Default is an empty option field, meaning that NMEA messages will not be saved on disk.</p>"));
1301  _serialHeightNMEALineEdit->setWhatsThis(tr("<p>Specify an approximate 'Height' above mean sea level in meters for the reference station introduced by option 'Mountpoint'. Together with the latitude and longitude from the source-table, the height information is used to build GGA messages to be sent to the Ntrip Broadcaster.</p><p>For adjusting latitude and longitude values of a VRS stream given in the 'Streams' canvas, you can double click the latitude/longitude data fields, specify appropriate values and then hit Enter.</p><p>This option is only relevant when option 'NMEA' is set to 'Manual GPGGA' or 'Manual GNGGA' respectively.</p>"));
1302  _serialManualNMEASamplingSpinBox->setWhatsThis(tr("<p>Select a sampling interval in seconds for manual generation and upload of NMEA GGA sentences.</p><p>A sampling rate of '0' means, the a GGA sentence will be send only once to initialize the requested VRS stream. Note that some VRS systems need GGA sentences at regular intervals.</p>"));
1303
1304  // WhatsThis, Outages
1305  // ------------------
1306  _adviseObsRateComboBox->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><p>Default is an empty option field, meaning that you don't want BNC to report on stream failures or recoveries when exceeding a threshold time span.</p>"));
1307  _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>"));
1308  _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>"));
1309  _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 a comment '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.</p><p>An empty option field (default) or invalid path means that you don't want to use this option.</p>"));
1310
1311  // WhatsThis, Miscellaneous
1312  // ------------------------
1313  _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>"));
1314  _miscIntrComboBox->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>"));
1315  _miscScanRTCMCheckBox->setWhatsThis(tr("<p>Tick 'Scan RTCM' to log the numbers of incoming message types as well as contained antenna coordinates, antenna height, and antenna descriptor.</p><p>In case of RTCM Version 3 MSM streams, BNC will also log contained RINEX Version 3 observation types.</p>."));
1316  _miscPortLineEdit->setWhatsThis(tr("<p>BNC can output an incoming stream through an IP port of your local host.</p><p>Specify a port number to activate this function.</p>"));
1317
1318  // WhatsThis, PPP (1)
1319  // ------------------
1320  _pppWidgets._dataSource->setWhatsThis(tr("<p>Select 'Real-time Streams' for real-time PPP from RTCM streams or 'RINEX Files' for post processing PPP from RINEX files.</p><p><ul><li>Real-time PPP requires that you pull a RTCM stream carrying GNSS observations plus a stream providing corrections to Broadcast Ephemeris. If the observations stream does not contain Broadcast Ephemeris then you must in addition pull a Broadcast Ephemeris stream like 'RTCM3EPH' from Ntrip Broadcaster <u>products.igs-ip.net</u>.<br></li><li>Post processing PPP requires RINEX Observation files, RINEX Navigation files and a file with corrections to Broadcast Ephemeris in plain ASCII format as saved beforehand using BNC.</li></ul></p><p>Note that BNC allows to carry out PPP solutions simultaneously for several stations.</p>"));
1321  _pppWidgets._rinexObs->setWhatsThis(tr("<p>Specify the RINEX Observation file.</p>"));
1322  _pppWidgets._rinexNav->setWhatsThis(tr("<p>Specify the RINEX Navigation file.</p>"));
1323  _pppWidgets._corrMount->setWhatsThis(tr("<p>Specify a 'mountpoint' from the 'Streams' canvas below which provides corrections to Broadcast Ephemeris.</p><p>If you don't specify a corrections stream via this option, BNC will fall back to Single Point Positioning (SPP, positioning from observations and Broadcast Ephemeris only) instead of doing PPP.</p>"));
1324  _pppWidgets._corrFile->setWhatsThis(tr("<p>Specify the Broadcast Ephemeris Corrections file as saved beforehand using BNC.</p><p>If you don't specify corrections by this option, BNC will fall back to Single Point Positioning (SPP, positioning from RINEX Obs and RINEX Nav files only) instead of doing PPP.</p>"));
1325  _pppWidgets._antexFile->setWhatsThis(tr("<p>Observations in RTCM streams or RINEX files should be referred to the receiver's and to the satellite's Antenna Phase Center (APC) and therefore be corrected for<ul><li>Receiver APC offsets</li><li>Receiver APC variations</li><li>Satellite APC offsets.</li></ul> Specify the full path to an IGS 'ANTEX file' which contains APC offsets and variations.</p><p>If you don't specify an 'ANTEX file' then observations will not be corrected for APC offsets and variations.</p>"));
1326  _pppWidgets._crdFile->setWhatsThis(tr("<p>Enter the full path to an ASCII file which specifies the streams or files of those stations you want to process. Specifying a 'Coordinates file' is optional. If it exists, it should contain one record per station with the following parameters separated by blank character:<p><ul><li>Specify the station either by<ul><li>the 'Mountpoint' of the station's RTCM stream (when in real-time PPP mode), or</li><li>the 4-charater station ID of the RINEX Observations file (when in post processing PPP mode).</li></ul></li><li>Approximate X,Y,Z coordinate of station's Antenna Reference Point [m] (ARP, specify '0.0 0.0 0.0' if unknown).</li><li>North, East and Up component of antenna eccentricity [m] (specify '0.0 0.0 0.0' if unknown).</li><li>20 Characters describing the antenna type and radome following the IGS 'ANTEX file' standard (leave blank if unknown).</li><li>Receiver type following the naming conventions for IGS equipment.</li></ul></p><p>Records with exclamation mark '!' in the first column or blank records will be interpreted as comment lines and ignored.</p>"));
1327  _pppWidgets._v3filenames->setWhatsThis(tr("<p>Tick 'Version 3 filenames' to let BNC create so-called extended filenames for PPP logfiles, NMEA files and SINEX Troposphere files following the RINEX Version 3 standard.</p><p>Default is an empty check box, meaning to create filenames following the RINEX Version 2 standard. The file content is not affected by this option. It only concerns the filenames.</p>"));
1328  _pppWidgets._logPath->setWhatsThis(tr("<p>Specify a directory for saving daily PPP logfiles. If the specified directory does not exist, BNC will not create such files.</p><p>Default is an empty option field, meaning that no PPP logfiles shall be produced.</p>"));
1329  _pppWidgets._nmeaPath->setWhatsThis(tr("<p>Specify a directory for saving coordinates in daily NMEA files. If the specified directory does not exist, BNC will not create such files.</p><p>Default is an empty option field, meaning that no NMEA file shall be produced.</p>"));
1330  _pppWidgets._snxtroPath->setWhatsThis(tr("<p>Specify a directory for saving SINEX Troposphere files. If the specified directory does not exist, BNC will not create such files.</p><p>Default is an empty option field, meaning that no SINEX Troposphere files shall be produced.</p>"));
1331  _pppWidgets._snxtroIntr->setWhatsThis(tr("<p>Select a length for SINEX Troposphere files.</p><p>Default 'SNX TRO interval' for saving SINEX Troposphere files on disk is '1 hour'.</p>"));
1332  _pppWidgets._snxtroSampl->setWhatsThis(tr("<p>Select a 'Sampling' rate for saving troposphere parameters.</p>"));
1333  _pppWidgets._snxtroAc->setWhatsThis(tr("<p>Specify a 3-character abbreviation describing you as the generating Analysis Center (AC) in your SINEX troposphere files.</p>"));
1334  _pppWidgets._snxtroSol->setWhatsThis(tr("<p>Specify a 4-character solution ID to allow a distingtion between different solutions per AC.</p>"));
1335
1336  // WhatsThis, PPP (3)
1337  // ------------------
1338  _pppWidgets._lcGPS->setWhatsThis(tr("<p>Specify which kind of GPS observations you want to use and on which kind of ionosphere-free linear combination of GPS observations you want to base ambiguity resolutions.</p><p><ul><li>Specifying 'P3' means that you request BNC to use code data and so-called P3 ionosphere-free linear combination of code observations.</li><li>'P3&L3' means that you request BNC to use both, code and phase data and so-called P3 and L3 ionosphere-free linear combination of code and phase observations.</li></ul></p><p>Note that most geodetic receivers support the observation of GPS code and phase data. Hence specifying 'P3&L3' would be a good choice when processing data from such a receiver.</p><p>Specifying 'no' means that you don't want BNC to use GPS data.</p>"));
1339  _pppWidgets._lcGLONASS->setWhatsThis(tr("<p>Specify which kind of GLONASS observations you want to use and on which kind of ionosphere-free linear combination of GLONASS observations you want to base ambiguity resolutions.</p><p><ul><li>Specifying 'P3' means that you request BNC to use code data and so-called P3 ionosphere-free linear combination of code observations.</li><li>'L3' means that you request BNC to use phase data and so-called L3 ionosphere-free linear combination of phase observations.</li> <li>'P3&L3' means that you request BNC to use both, code and phase data and so-called P3 and L3 ionosphere-free linear combination of code and phase observations.</li></ul></p><p>Specifying 'no' means that you don't want BNC to use GLONASS data.</p>"));
1340  _pppWidgets._lcGalileo->setWhatsThis(tr("<p>Specify which kind of Galileo observations you want to use and on which kind of of ionosphere-free linear combination of Galileo observations you want to base ambiguity resolutions.</p><p><ul><li>Specifying 'P3' means that you request BNC to use code data and so-called P3 ionosphere-free linear combination of code observations.</li><li>'L3' means that you request BNC to use phase data and so-called L3 ionosphere-free linear combination of phase observations.</li> <li>'P3&L3' means that you request BNC to use both, code and phase data and so-called P3 and L3 ionosphere-free linear combination of code and phase observations.</li></ul></p><p>Specifying on of these options makes only sense if Galileo data are part of the processed observation stream.</p><p>Specifying 'no' means that you don't want BNC to use Galileo data.</p>"));
1341  _pppWidgets._lcBDS->setWhatsThis(tr("<p>Specify which kind of BDS observations you want to use and on which kind of ionosphere-free linear combination of BDS observations you want to base ambiguity resolutions.</p><p><ul><li>Specifying 'P3' means that you request BNC to use code data and so-called P3 ionosphere-free linear combination of code observations.</li><li>'L3' means that you request BNC to use phase data and so-called L3 ionosphere-free linear combination of phase observations.</li> <li>'P3&L3' means that you request BNC to use both, code and phase data and so-called P3 and L3 ionosphere-free linear combination of code and phase observations.</li></ul></p><p>Specifying on of these options makes only sense if BDS data are part of the processed observation stream.</p><p>Specifying 'no' means that you don't want to use BDS data.</p>"));
1342  _pppWidgets._sigmaC1->setWhatsThis(tr("<p>Enter a Sigma for GNSS C1 code observations in meters.</p><p>The higher the sigma you enter, the less the contribution of C1 code observations to a PPP solution from combined code and phase data. 2.0 is likely to be an appropriate choice.</p><p>Default is an empty option field, meaning<br>'Sigma C1 = 2.0'</p>"));
1343  _pppWidgets._sigmaL1->setWhatsThis(tr("<p>Enter a Sigma for GNSS L1 phase observations in meters.</p><p>The higher the sigma you enter, the less the contribution of L1 phase observations to a PPP solutions from combined code and phase data. 0.01 is likely to be an appropriate choice.</p><p>Default is an empty option field, meaning<br>'Sigma L1 = 0.01'</p>"));
1344  _pppWidgets._maxResC1->setWhatsThis(tr("<p>Specify a maximum for residuals from C1 code observations in a PPP solution. '3.0' meters may be an appropriate choice for that.</p><p>If the maximum is exceeded, contributions from the corresponding observation will be ignored in the PPP solution.</p><p>Default is an empty option field, meaning<br>'Max Rex C1 = 3.0'</p>"));
1345  _pppWidgets._maxResL1->setWhatsThis(tr("<p>Specify a maximum for residuals from L1 code observations in a PPP solution. '0.03' meters may be an appropriate choice for that.</p><p>If the maximum is exceeded, contributions from the corresponding observation will be ignored in the PPP solution.</p><p>Default is an empty option field, meaning<br>'Max Rex L1 = 0.03'</p>"));
1346  _pppWidgets._eleWgtCode->setWhatsThis(tr("<p>Tic 'Ele Wgt Code' to use satellite Elevation depending Weights for Code observations in the PPP solution.</p>"));
1347  _pppWidgets._eleWgtPhase->setWhatsThis(tr("<p>Tic 'Ele Wgt Phase' to use satellite Elevation depending Weights for Phase observations in the PPP solution.</p>"));
1348  _pppWidgets._minObs->setWhatsThis(tr("<p>Select a Minimum Number of Observations per epoch for a PPP solution.</p><p>BNC will only process epochs with observation numbers reaching or exceeding this minimum.</p>"));
1349  _pppWidgets._minEle->setWhatsThis(tr("<p>Select a Minimum satellite Elevation for observations.</p><p>BNC will ignore an observation if the associated satellite Elevation does not reach or exceed this minimum.</p><p>Selecting '10 deg' may be an appropriate choice in order to avoid too noisy observations.</p>"));
1350
1351  // WhatsThis, Combine Corrections
1352  // ------------------------------
1353  _cmbTable->setWhatsThis(tr("<p>BNC allows to process several orbit and clock correction streams in real-time to produce, encode, upload and save a combination of correctors coming from different providers. To add a line to the 'Combine Corrections' table hit the 'Add Row' button, double click on the 'Mountpoint' field to specify a Broadcast Ephemeris Correction 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 a weight to be applied for this stream in the combination.</p><p>Note that the orbit information in the resulting 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 orbit and clock correction streams 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 Correction stream in the 'Combine Corrections' table. Instead of combining corrections BNC will then add the corrections to the Broadcast Ephemeris with the possibility to save final orbit and clock results in SP3 and/or Clock RINEX format.</p>"));
1354  addCmbRowButton->setWhatsThis(tr("<p>Hit 'Add Row' button to add another line to the 'Combine Corrections' table.</p>"));
1355  delCmbRowButton->setWhatsThis(tr("<p>Hit 'Delete' button to delete the highlighted line(s) from the 'Combine Corrections' table.</p>"));
1356  _cmbMethodComboBox->setWhatsThis(tr("<p>Select a clock combination approach. Options are 'Single-Epoch' and Kalman 'Filter'.</p><p>It is suggested to use the Kalman filter approach for the purpose of Precise Point Positioning.</p>"));
1357  _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>"));
1358  _cmbSamplSpinBox->setWhatsThis(tr("<p>Select a combination Sampling interval for the clocks. Clock corrections will be produced following that interval.</p><p>A value of 10 sec may be an appropriate choice.</p>"));
1359  _cmbUseGlonass->setWhatsThis(tr("<p>In case the incoming orbit and clock correction stream(s) support GLONASS, you can tick 'Use GLONASS' to produce a GPS plus GLONASS combination solution.</p><p>Default is a GPS-only combination.</p>"));
1360
1361  // WhatsThis, Upload Corrections
1362  // -----------------------------
1363  _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 Host and Port</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' table.</p><p>To fill the 'Upload Corrections' table, 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. IGS14) 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 generated Broadcast Corrections plus Broadcast Ephemeris as SP3 orbit files. If the specified directory does not exist, BNC will not create such files. The following is a path example for a Linux system: /home/user/BNC${GPSWD}.sp3<br>Note that '${GPSWD}' produces the GPS Week and Day number in the filename.</p><p>Specify a path for saving 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: /home/user/BNC${GPSWD}.clk<br>Note that '${GPSWD}' produces the GPS Week and Day number in the filename.</p><p>Finally, specify a SSR Provider ID (issued by RTCM), SSR Solution ID, and SSR Issue of Data number.</p><p>In case the 'Combine Corrections' table contains only one Broadcast Correction stream, BNC will add that stream content to the Broadcast Ephemeris to save results in files specified via SP3 and/or Clock RINEX file path. You should then define only the SP3 and Clock RINEX file path and no further option in the 'Upload Corrections' table.</p>"));
1364  addUploadRowButton->setWhatsThis(tr("<p>Hit 'Add Row' button to add another line to the 'Upload Corrections' table.</p>"));
1365  delUploadRowButton->setWhatsThis(tr("<p>Hit 'Del Row' button to delete the highlighted line(s) from the Upload Corrections' table.</p>"));
1366  _uploadIntrComboBox->setWhatsThis(tr("<p>Select the length of the SP3 and Clock RINEX files.</p>"));
1367  _uploadSamplRtcmEphCorrSpinBox->setWhatsThis(tr("<p>Select a stream's orbit correction sampling interval in seconds.</p><p>A value of zero '0' tells BNC to upload all available orbit and clock correction samples together in combined messages.</p>"));
1368  _uploadSamplSp3SpinBox->setWhatsThis(tr("<p>Select a SP3 orbit file sampling interval in minutes.</p><p>A value of zero '0' tells BNC to store all available samples into SP3 orbit files.</p>"));
1369  _uploadSamplClkRnxSpinBox->setWhatsThis(tr("<p>Select a Clock RINEX file sampling interval in seconds.</p><p>A value of zero '0' tells BNC to store all available samples into Clock RINEX files.</p>"));
1370  setUploadTrafoButton->setWhatsThis(tr("<p>Hit 'Custom Trafo' to specify your own 14 parameter Helmert Transformation instead of selecting a predefined transformation via option 'System'.</p>"));
1371  _uploadAntexFile->setWhatsThis(tr("<p>When producing SP3 files or referring orbit and clock corrections to the satellite's Center of Mass (CoM) instead Antenna Phase Center (APC), an offset has to be applied which is available from the IGS 'ANTEX file'. You must therefore specify an 'ANTEX file' path if you want to save the stream content in SP3 format and/or refer correctors to CoM.</p><p>If you don't specify an 'ANTEX file' path, the SP3 file content as well as the orbit and clock correctors will be referred to satellite APCs.</p>"));
1372
1373  // WhatsThis, Upload Ephemeris
1374  // ---------------------------
1375  _uploadEphHostLineEdit->setWhatsThis(tr("<p>BNC can upload a Broadcast Ephemeris stream in RTCM Version 3 format. Specify the IP number or URL of an Ntrip Broadcaster to upload the stream.</p><p>An empty option field means that you don't want to upload Broadcast Ephemeris.</p>"));
1376  _uploadEphPortLineEdit->setWhatsThis(tr("<p>Specify the IP port of the Ntrip Broadcaster to upload the Broadcast Ephemeris stream. Default is port 80.</p>"));
1377  _uploadEphMountpointLineEdit->setWhatsThis(tr("<p>Specify a mountpoint for uploading the Broadcast Ephemeris stream.</p>"));
1378  _uploadEphPasswordLineEdit->setWhatsThis(tr("<p>Specify the stream upload password protecting the mounpoint on the Ntrip Broadcaster.</p>"));
1379  _uploadEphSampleSpinBox->setWhatsThis(tr("<p>Select the Broadcast Ephemeris sampling interval in seconds.</p><p>Default is '5', meaning that a complete set of Broadcast Ephemeris is uploaded every 5 seconds.</p>"));
1380  _uploadEphBytesCounter->setWhatsThis(tr("<p>BNC shows the amount of data uploaded via this stream.</p>"));
1381// weber
1382
1383  // WhatsThis, Streams Canvas
1384  // -------------------------
1385  _mountPointsTable->setWhatsThis(tr("<p>Streams selected for retrieval are listed in the 'Streams' section. Clicking on 'Add Stream' button opens 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 source-table. 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. Accepted decoder strings are 'RTCM_2.x', 'RTCM_3.x' and 'RTNET'.</p><p>In case you need to log raw data as is, BNC allows 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 such stream, the approximate latitude/longitude rover position is sent to the Ntrip Broadcaster together with an approximation for the height. Default values for latitude and longitude 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>"));
1386  _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
1387  _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1388  _actMapMountPoints->setWhatsThis(tr("<p> Draw distribution map of stream selection presented in the 'Streams' canvas. Use 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>"));
1389  _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1390  _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1391
1392  // WhatsThis, Log Canvas
1393  // ---------------------
1394  _log->setWhatsThis(tr("<p>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 problems that occur in the communication link, stream availability, stream delay, stream conversion etc.</p>"));
1395  _bncFigure->setWhatsThis(tr("<p>The bandwidth consumption per stream is shown in the 'Throughput' tab in bits per second (bps) or kilobits per second (kbps).</p>"));
1396  _bncFigureLate->setWhatsThis(tr("<p>The individual latency of observations of incoming streams is shown in the 'Latency' tab. Streams not carrying observations (e.g. those providing only Broadcast Ephemeris) remain unconsidered.</p><p>Note that the calculation of correct latencies requires the clock of the host computer to be properly synchronized.</p>"));
1397  _bncFigurePPP->setWhatsThis(tr("<p>PPP time series of North (red), East (green) and Up (blue) displacements are shown in the 'PPP Plot' tab when the corresponding option is selected.</p><p>Values are referred to an XYZ a priori coordinate. The sliding PPP time series window covers the period of the latest 5 minutes.</p>"));
1398
1399
1400  // Enable/Disable all Widgets
1401  // --------------------------
1402  slotBncTextChanged();
1403  enableStartStop();
1404
1405  // Auto start
1406  // ----------
1407  if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
1408    slotStart();
1409  }
1410}
1411
1412// Destructor
1413////////////////////////////////////////////////////////////////////////////
1414bncWindow::~bncWindow() {
1415  if (_caster) {
1416    delete _caster; BNC_CORE->setCaster(0);
1417  }
1418  if (_casterEph) {
1419    delete _casterEph;
1420  }
1421  delete _bncFigureLate;
1422  delete _bncFigurePPP;
1423  delete _actHelp;
1424  delete _actAbout;
1425  delete _actFlowchart;
1426  delete _actFontSel;
1427  delete _actSaveOpt;
1428  delete _actQuit;
1429  delete _actAddMountPoints;
1430  delete _actDeleteMountPoints;
1431  delete _actMapMountPoints;
1432  delete _actStart;
1433  delete _actStop;
1434  delete _actwhatsthis;
1435  delete _proxyHostLineEdit;
1436  delete _proxyPortLineEdit;
1437  delete _sslCaCertPathLineEdit;
1438  delete _sslIgnoreErrorsCheckBox;
1439  delete _logFileLineEdit;
1440  delete _rawOutFileLineEdit;
1441  delete _rnxAppendCheckBox;
1442  delete _onTheFlyComboBox;
1443  delete _autoStartCheckBox;
1444  delete _rnxPathLineEdit;
1445  delete _rnxIntrComboBox;
1446  delete _rnxSamplComboBox;
1447  delete _rnxFileCheckBox;
1448  delete _rnxSkelLineEdit;
1449  delete _rnxScrpLineEdit;
1450  delete _rnxV3CheckBox;
1451  delete _rnxV2Priority;
1452  delete _ephPathLineEdit;
1453  delete _ephIntrComboBox;
1454  delete _ephOutPortLineEdit;
1455  delete _ephV3CheckBox;
1456  delete _corrPathLineEdit;
1457  delete _corrIntrComboBox;
1458  delete _corrPortLineEdit;
1459  delete _outPortLineEdit;
1460  delete _outWaitSpinBox;
1461  delete _outSamplComboBox;
1462  delete _outFileLineEdit;
1463  delete _outUPortLineEdit;
1464  delete _outLockTimeCheckBox;
1465  delete _serialMountPointLineEdit;
1466  delete _serialPortNameLineEdit;
1467  delete _serialBaudRateComboBox;
1468  delete _serialFlowControlComboBox;
1469  delete _serialDataBitsComboBox;
1470  delete _serialParityComboBox;
1471  delete _serialStopBitsComboBox;
1472  delete _serialAutoNMEAComboBox;
1473  delete _serialFileNMEALineEdit;
1474  delete _serialHeightNMEALineEdit;
1475  delete _serialManualNMEASamplingSpinBox;
1476  delete _adviseObsRateComboBox;
1477  delete _adviseFailSpinBox;
1478  delete _adviseRecoSpinBox;
1479  delete _adviseScriptLineEdit;
1480  delete _miscMountLineEdit;
1481  delete _miscPortLineEdit;
1482  delete _miscIntrComboBox;
1483  delete _miscScanRTCMCheckBox;
1484  _mountPointsTable->deleteLater();
1485  delete _log;
1486  _cmbTable->deleteLater();
1487  delete _cmbMaxresLineEdit;
1488  delete _cmbUseGlonass;
1489  delete _cmbSamplSpinBox;
1490  delete _cmbMethodComboBox;
1491  _uploadTable->deleteLater();
1492  delete _uploadIntrComboBox;
1493  delete _uploadAntexFile;
1494  delete _uploadSamplRtcmEphCorrSpinBox;
1495  delete _uploadSamplSp3SpinBox;
1496  delete _uploadSamplClkRnxSpinBox;
1497  delete _uploadEphHostLineEdit;
1498  delete _uploadEphPortLineEdit;
1499  delete _uploadEphPasswordLineEdit;
1500  delete _uploadEphMountpointLineEdit;
1501  delete _uploadEphSampleSpinBox;
1502  delete _uploadEphBytesCounter;
1503  delete _loggroup;
1504  delete _reqcActionComboBox;
1505  delete _reqcObsFileChooser;
1506  delete _reqcNavFileChooser;
1507  delete _reqcOutObsLineEdit;
1508  delete _reqcOutNavLineEdit;
1509  delete _reqcOutLogLineEdit;
1510  delete _reqcPlotDirLineEdit;
1511  delete _reqcSkyPlotSignals;
1512  delete _reqcLogSummaryOnly;
1513  delete _reqcEditOptionButton;
1514  delete _sp3CompFileChooser;
1515  delete _sp3CompExclude;
1516  delete _sp3CompLogLineEdit;
1517  //delete _canvas;
1518}
1519
1520//
1521////////////////////////////////////////////////////////////////////////////
1522void bncWindow::populateMountPointsTable() {
1523
1524  for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1525    _mountPointsTable->removeRow(iRow);
1526  }
1527
1528  bncSettings settings;
1529
1530  QListIterator<QString> it(settings.value("mountPoints").toStringList());
1531  int iRow = 0;
1532  while (it.hasNext()) {
1533    QStringList hlp = it.next().split(" ");
1534    if (hlp.size() < 7) continue;
1535    _mountPointsTable->insertRow(iRow);
1536
1537    QUrl    url(hlp[0]);
1538
1539    QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1540    QString format(hlp[1]); QString country(hlp[2]); QString latitude(hlp[3]); QString longitude(hlp[4]);
1541    QString nmea(hlp[5]);
1542    if (hlp[6] == "S") {
1543      fullPath = hlp[0].replace(0,2,"");
1544    }
1545    QString ntripVersion = "2";
1546    if (hlp.size() >= 7) {
1547      ntripVersion = (hlp[6]);
1548    }
1549
1550    QTableWidgetItem* it;
1551    it = new QTableWidgetItem(url.userInfo());
1552    it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1553    _mountPointsTable->setItem(iRow, 0, it);
1554
1555    it = new QTableWidgetItem(fullPath);
1556    it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1557    _mountPointsTable->setItem(iRow, 1, it);
1558
1559    it = new QTableWidgetItem(format);
1560    _mountPointsTable->setItem(iRow, 2, it);
1561
1562    it = new QTableWidgetItem(country);
1563    _mountPointsTable->setItem(iRow, 3, it);
1564
1565    if      (nmea == "yes") {
1566      it = new QTableWidgetItem(latitude);
1567      _mountPointsTable->setItem(iRow, 4, it);
1568      it = new QTableWidgetItem(longitude);
1569      _mountPointsTable->setItem(iRow, 5, it);
1570    } else {
1571      it = new QTableWidgetItem(latitude);
1572      it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1573      _mountPointsTable->setItem(iRow, 4, it);
1574
1575      it = new QTableWidgetItem(longitude);
1576      it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1577      _mountPointsTable->setItem(iRow, 5, it);
1578    }
1579
1580    it = new QTableWidgetItem(nmea);
1581    it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1582    _mountPointsTable->setItem(iRow, 6, it);
1583
1584    it = new QTableWidgetItem(ntripVersion);
1585    ////    it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1586    _mountPointsTable->setItem(iRow, 7, it);
1587
1588    bncTableItem* bncIt = new bncTableItem();
1589    bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
1590    _mountPointsTable->setItem(iRow, 8, bncIt);
1591
1592    iRow++;
1593  }
1594
1595  _mountPointsTable->sortItems(1);
1596
1597  enableStartStop();
1598}
1599
1600// Retrieve Table
1601////////////////////////////////////////////////////////////////////////////
1602void bncWindow::slotAddMountPoints() {
1603
1604  bncSettings settings;
1605  QString proxyHost = settings.value("proxyHost").toString();
1606  int     proxyPort = settings.value("proxyPort").toInt();
1607  if (proxyHost != _proxyHostLineEdit->text()         ||
1608      proxyPort != _proxyPortLineEdit->text().toInt()) {
1609    int iRet = QMessageBox::question(this, "Question", "Proxy options "
1610                                     "changed. Use the new ones?",
1611                                     QMessageBox::Yes, QMessageBox::No,
1612                                     QMessageBox::NoButton);
1613    if      (iRet == QMessageBox::Yes) {
1614      settings.setValue("proxyHost",   _proxyHostLineEdit->text());
1615      settings.setValue("proxyPort",   _proxyPortLineEdit->text());
1616    }
1617  }
1618
1619  settings.setValue("sslCaCertPath",   _sslCaCertPathLineEdit->text());
1620  settings.setValue("sslIgnoreErrors", _sslIgnoreErrorsCheckBox->checkState());
1621
1622  QMessageBox msgBox;
1623  msgBox.setIcon(QMessageBox::Question);
1624  msgBox.setWindowTitle("Add Stream");
1625  msgBox.setText("Add stream(s) coming from:");
1626
1627  QPushButton* buttonNtrip  = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1628  QPushButton* buttonIP     = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1629  QPushButton* buttonUDP    = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1630  QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1631  QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1632
1633  msgBox.exec();
1634
1635  if (msgBox.clickedButton() == buttonNtrip) {
1636    bncTableDlg* dlg = new bncTableDlg(this);
1637    dlg->move(this->pos().x()+50, this->pos().y()+50);
1638    connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1639          this, SLOT(slotNewMountPoints(QStringList*)));
1640    dlg->exec();
1641    delete dlg;
1642  } else if (msgBox.clickedButton() == buttonIP) {
1643    bncIpPort* ipp = new bncIpPort(this);
1644    connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1645          this, SLOT(slotNewMountPoints(QStringList*)));
1646    ipp->exec();
1647    delete ipp;
1648  } else if (msgBox.clickedButton() == buttonUDP) {
1649    bncUdpPort* udp = new bncUdpPort(this);
1650    connect(udp, SIGNAL(newMountPoints(QStringList*)),
1651          this, SLOT(slotNewMountPoints(QStringList*)));
1652    udp->exec();
1653    delete udp;
1654  } else if (msgBox.clickedButton() == buttonSerial) {
1655    bncSerialPort* sep = new bncSerialPort(this);
1656    connect(sep, SIGNAL(newMountPoints(QStringList*)),
1657          this, SLOT(slotNewMountPoints(QStringList*)));
1658    sep->exec();
1659    delete sep;
1660  } else if (msgBox.clickedButton() == buttonCancel) {
1661    // Cancel
1662  }
1663
1664  enableStartStop();
1665}
1666
1667// Delete Selected Mount Points
1668////////////////////////////////////////////////////////////////////////////
1669void bncWindow::slotDeleteMountPoints() {
1670
1671  int nRows = _mountPointsTable->rowCount();
1672  bool flg[nRows];
1673  for (int iRow = 0; iRow < nRows; iRow++) {
1674    if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1675      flg[iRow] = true;
1676    }
1677    else {
1678      flg[iRow] = false;
1679    }
1680  }
1681  for (int iRow = nRows-1; iRow >= 0; iRow--) {
1682    if (flg[iRow]) {
1683      _mountPointsTable->removeRow(iRow);
1684    }
1685  }
1686  _actDeleteMountPoints->setEnabled(false);
1687
1688  enableStartStop();
1689}
1690
1691// New Mount Points Selected
1692////////////////////////////////////////////////////////////////////////////
1693void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1694  int iRow = 0;
1695  QListIterator<QString> it(*mountPoints);
1696  while (it.hasNext()) {
1697    QStringList hlp = it.next().split(" ");
1698    QUrl    url(hlp[0]);
1699    QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1700    QString format(hlp[1]); QString country(hlp[2]); QString latitude(hlp[3]); QString longitude(hlp[4]);
1701    QString nmea(hlp[5]);
1702    if (hlp[6] == "S") {
1703      fullPath = hlp[0].replace(0,2,"");
1704    }
1705    QString ntripVersion = "2";
1706    if (hlp.size() >= 7) {
1707      ntripVersion = (hlp[6]);
1708    }
1709
1710    _mountPointsTable->insertRow(iRow);
1711
1712    QTableWidgetItem* it;
1713    it = new QTableWidgetItem(url.userInfo());
1714    it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1715    _mountPointsTable->setItem(iRow, 0, it);
1716
1717    it = new QTableWidgetItem(fullPath);
1718    it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1719    _mountPointsTable->setItem(iRow, 1, it);
1720
1721    it = new QTableWidgetItem(format);
1722    _mountPointsTable->setItem(iRow, 2, it);
1723
1724    it = new QTableWidgetItem(country);
1725    _mountPointsTable->setItem(iRow, 3, it);
1726
1727    if      (nmea == "yes") {
1728    it = new QTableWidgetItem(latitude);
1729    _mountPointsTable->setItem(iRow, 4, it);
1730    it = new QTableWidgetItem(longitude);
1731    _mountPointsTable->setItem(iRow, 5, it);
1732    } else {
1733    it = new QTableWidgetItem(latitude);
1734    it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1735    _mountPointsTable->setItem(iRow, 4, it);
1736    it = new QTableWidgetItem(longitude);
1737    it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1738    _mountPointsTable->setItem(iRow, 5, it);
1739    }
1740
1741    it = new QTableWidgetItem(nmea);
1742    it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1743    _mountPointsTable->setItem(iRow, 6, it);
1744
1745    it = new QTableWidgetItem(ntripVersion);
1746    ////it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1747    _mountPointsTable->setItem(iRow, 7, it);
1748
1749    bncTableItem* bncIt = new bncTableItem();
1750    _mountPointsTable->setItem(iRow, 8, bncIt);
1751
1752    iRow++;
1753  }
1754  _mountPointsTable->hideColumn(0);
1755  _mountPointsTable->hideColumn(3);
1756  _mountPointsTable->sortItems(1);
1757  delete mountPoints;
1758
1759  enableStartStop();
1760}
1761
1762// Save Options (serialize)
1763////////////////////////////////////////////////////////////////////////////
1764void bncWindow::slotSaveOptions() {
1765  saveOptions();
1766  bncSettings settings;
1767  settings.sync();
1768}
1769
1770// Save Options (memory only)
1771////////////////////////////////////////////////////////////////////////////
1772void bncWindow::saveOptions() {
1773
1774  QStringList mountPoints;
1775  for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1776
1777    if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1778      QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1779                "@"  + _mountPointsTable->item(iRow, 1)->text() );
1780
1781      mountPoints.append(url.toString() + " " +
1782                         _mountPointsTable->item(iRow, 2)->text()
1783                 + " " + _mountPointsTable->item(iRow, 3)->text()
1784                 + " " + _mountPointsTable->item(iRow, 4)->text()
1785                 + " " + _mountPointsTable->item(iRow, 5)->text()
1786                 + " " + _mountPointsTable->item(iRow, 6)->text()
1787                 + " " + _mountPointsTable->item(iRow, 7)->text());
1788    } else {
1789      mountPoints.append(
1790                  "//" + _mountPointsTable->item(iRow, 1)->text()
1791                 + " " + _mountPointsTable->item(iRow, 2)->text()
1792                 + " " + _mountPointsTable->item(iRow, 3)->text()
1793                 + " " + _mountPointsTable->item(iRow, 4)->text()
1794                 + " " + _mountPointsTable->item(iRow, 5)->text()
1795                 + " " + _mountPointsTable->item(iRow, 6)->text()
1796                 + " " + _mountPointsTable->item(iRow, 7)->text());
1797    }
1798  }
1799
1800  QStringList cmbStreams;
1801  for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1802    QString hlp;
1803    for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1804      if (_cmbTable->item(iRow, iCol)) {
1805        hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1806      }
1807    }
1808    if (!hlp.isEmpty()) {
1809      cmbStreams << hlp;
1810    }
1811  }
1812
1813  QStringList uploadMountpointsOut;
1814  for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
1815    QString hlp;
1816    for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1817      if (_uploadTable->cellWidget(iRow, iCol) &&
1818          (iCol == 3 || iCol == 4 || iCol == 5 || iCol == 6)) {
1819        if      (iCol == 3) {
1820          QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
1821          hlp += passwd->text() + ",";
1822        }
1823        else if (iCol == 4) {
1824          QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1825          hlp += system->currentText() + ",";
1826        }
1827        else if (iCol == 5) {
1828          QComboBox* format = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
1829          hlp += format->currentText() + ",";
1830        }
1831        else if (iCol == 6) {
1832          QCheckBox* com    = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
1833          QString state; state.setNum(com->checkState());
1834          hlp +=  state + ",";
1835        }
1836      }
1837      else if (_uploadTable->item(iRow, iCol)) {
1838        hlp += _uploadTable->item(iRow, iCol)->text() + ",";
1839      }
1840    }
1841    if (!hlp.isEmpty()) {
1842      uploadMountpointsOut << hlp;
1843    }
1844  }
1845
1846  bncSettings settings;
1847
1848  settings.setValue("startTab",    _aogroup->currentIndex());
1849  settings.setValue("statusTab",   _loggroup->currentIndex());
1850  settings.setValue("mountPoints", mountPoints);
1851// Network
1852  settings.setValue("proxyHost",   _proxyHostLineEdit->text());
1853  settings.setValue("proxyPort",   _proxyPortLineEdit->text());
1854  settings.setValue("sslCaCertPath",   _sslCaCertPathLineEdit->text());
1855  settings.setValue("sslIgnoreErrors",  _sslIgnoreErrorsCheckBox->checkState());
1856// General
1857  settings.setValue("logFile",     _logFileLineEdit->text());
1858  settings.setValue("rnxAppend",   _rnxAppendCheckBox->checkState());
1859  settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1860  settings.setValue("autoStart",   _autoStartCheckBox->checkState());
1861  settings.setValue("rawOutFile",  _rawOutFileLineEdit->text());
1862// RINEX Observations
1863  settings.setValue("rnxPath",     _rnxPathLineEdit->text());
1864  settings.setValue("rnxIntr",     _rnxIntrComboBox->currentText());
1865  settings.setValue("rnxSampl",     _rnxSamplComboBox->currentText());
1866  settings.setValue("rnxSkel",     _rnxSkelLineEdit->text());
1867  settings.setValue("rnxOnlyWithSKL",_rnxFileCheckBox->checkState());
1868  settings.setValue("rnxScript",   _rnxScrpLineEdit->text());
1869  settings.setValue("rnxV2Priority",_rnxV2Priority->text());
1870   settings.setValue("rnxV3",        _rnxV3CheckBox->checkState());
1871// RINEX Ephemeris
1872  settings.setValue("ephPath",       _ephPathLineEdit->text());
1873  settings.setValue("ephIntr",       _ephIntrComboBox->currentText());
1874  settings.setValue("ephOutPort",    _ephOutPortLineEdit->text());
1875  settings.setValue("ephV3",         _ephV3CheckBox->checkState());
1876// Broadcast Corrections
1877  settings.setValue("corrPath",    _corrPathLineEdit->text());
1878  settings.setValue("corrIntr",    _corrIntrComboBox->currentText());
1879  settings.setValue("corrPort",    _corrPortLineEdit->text());
1880// Feed Engine
1881  settings.setValue("outPort",     _outPortLineEdit->text());
1882  settings.setValue("outWait",     _outWaitSpinBox->value());
1883  settings.setValue("outSampl",    _outSamplComboBox->currentText());
1884  settings.setValue("outFile",     _outFileLineEdit->text());
1885  settings.setValue("outUPort",    _outUPortLineEdit->text());
1886  settings.setValue("outLockTime",_outLockTimeCheckBox->checkState());
1887// Serial Output
1888  settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1889  settings.setValue("serialPortName",  _serialPortNameLineEdit->text());
1890  settings.setValue("serialBaudRate",  _serialBaudRateComboBox->currentText());
1891  settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1892  settings.setValue("serialDataBits",  _serialDataBitsComboBox->currentText());
1893  settings.setValue("serialParity",    _serialParityComboBox->currentText());
1894  settings.setValue("serialStopBits",  _serialStopBitsComboBox->currentText());
1895  settings.setValue("serialAutoNMEA",  _serialAutoNMEAComboBox->currentText());
1896  settings.setValue("serialFileNMEA",    _serialFileNMEALineEdit->text());
1897  settings.setValue("serialHeightNMEA",  _serialHeightNMEALineEdit->text());
1898  settings.setValue("serialManualNMEASampling", _serialManualNMEASamplingSpinBox->value());
1899// Outages
1900  settings.setValue("adviseObsRate", _adviseObsRateComboBox->currentText());
1901  settings.setValue("adviseFail",    _adviseFailSpinBox->value());
1902  settings.setValue("adviseReco",    _adviseRecoSpinBox->value());
1903  settings.setValue("adviseScript",  _adviseScriptLineEdit->text());
1904// Miscellaneous
1905  settings.setValue("miscMount",   _miscMountLineEdit->text());
1906  settings.setValue("miscPort",    _miscPortLineEdit->text());
1907  settings.setValue("miscIntr",    _miscIntrComboBox->currentText());
1908  settings.setValue("miscScanRTCM", _miscScanRTCMCheckBox->checkState());
1909// Reqc
1910  settings.setValue("reqcAction",     _reqcActionComboBox->currentText());
1911  settings.setValue("reqcObsFile",    _reqcObsFileChooser->fileName());
1912  settings.setValue("reqcNavFile",    _reqcNavFileChooser->fileName());
1913  settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1914  settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1915  settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
1916  settings.setValue("reqcPlotDir",    _reqcPlotDirLineEdit->text());
1917  settings.setValue("reqcSkyPlotSignals", _reqcSkyPlotSignals->text());
1918  settings.setValue("reqcLogSummaryOnly", _reqcLogSummaryOnly->checkState());
1919// SP3 Comparison
1920  settings.setValue("sp3CompFile",       _sp3CompFileChooser->fileName());
1921  settings.setValue("sp3CompExclude",    _sp3CompExclude->text());
1922  settings.setValue("sp3CompOutLogFile", _sp3CompLogLineEdit->text());
1923// Combine Corrections
1924  if (!cmbStreams.isEmpty()) {
1925    settings.setValue("cmbStreams", cmbStreams);
1926  }
1927  else {
1928    settings.setValue("cmbStreams", "");
1929  }
1930  settings.setValue("cmbMethod",     _cmbMethodComboBox->currentText());
1931  settings.setValue("cmbMaxres",     _cmbMaxresLineEdit->text());
1932  settings.setValue("cmbSampl",      _cmbSamplSpinBox->value());
1933  settings.setValue("cmbUseGlonass", _cmbUseGlonass->checkState());
1934// Upload Corrections
1935  if (!uploadMountpointsOut.isEmpty()) {
1936    settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
1937  }
1938  else {
1939    settings.setValue("uploadMountpointsOut", "");
1940  }
1941  settings.setValue("uploadIntr",             _uploadIntrComboBox->currentText());
1942  settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1943  settings.setValue("uploadSamplSp3",         _uploadSamplSp3SpinBox->value());
1944  settings.setValue("uploadSamplClkRnx",      _uploadSamplClkRnxSpinBox->value());
1945  settings.setValue("uploadAntexFile",        _uploadAntexFile->fileName());
1946// Upload Ephemeris
1947  settings.setValue("uploadEphHost",      _uploadEphHostLineEdit->text());
1948  settings.setValue("uploadEphPort",      _uploadEphPortLineEdit->text());
1949  settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
1950  settings.setValue("uploadEphPassword",  _uploadEphPasswordLineEdit->text());
1951  settings.setValue("uploadEphSample",    _uploadEphSampleSpinBox->value());
1952
1953  if (_caster) {
1954    _caster->readMountPoints();
1955  }
1956
1957  _pppWidgets.saveOptions();
1958}
1959
1960// All get slots terminated
1961////////////////////////////////////////////////////////////////////////////
1962void bncWindow::slotGetThreadsFinished() {
1963  BNC_CORE->slotMessage("All Get Threads Terminated", true);
1964  delete _caster;    _caster    = 0; BNC_CORE->setCaster(0);
1965  delete _casterEph; _casterEph = 0;
1966  _runningRealTime = false;
1967}
1968
1969// Start It!
1970////////////////////////////////////////////////////////////////////////////
1971void bncWindow::slotStart() {
1972  saveOptions();
1973  if      ( _pppWidgets._dataSource->currentText() == "RINEX Files") {
1974    _runningPPP = true;
1975    enableStartStop();
1976    _caster = new bncCaster(); BNC_CORE->setCaster(_caster);
1977    BNC_CORE->startPPP();
1978    _bncFigurePPP->reset();
1979  }
1980  else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
1981    if (_reqcActionComboBox->currentText() == "Analyze") {
1982      _runningQC = true;
1983      t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
1984      connect(reqcAnalyze, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1985      reqcAnalyze->start();
1986    }
1987    else {
1988      _runningEdit = true;
1989      t_reqcEdit* reqcEdit = new t_reqcEdit(this);
1990      connect(reqcEdit, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1991      reqcEdit->start();
1992    }
1993    enableStartStop();
1994  }
1995  else if (!_sp3CompFileChooser->fileName().isEmpty()) {
1996    _runningSp3Comp = true;
1997    t_sp3Comp* sp3Comp = new t_sp3Comp(this);
1998    connect(sp3Comp, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1999    sp3Comp->start();
2000    enableStartStop();
2001  }
2002  else {
2003    startRealTime();
2004    BNC_CORE->startPPP();
2005  }
2006}
2007
2008// Start Real-Time (Retrieve Data etc.)
2009////////////////////////////////////////////////////////////////////////////
2010void bncWindow::startRealTime() {
2011
2012  _runningRealTime = true;
2013
2014  _bncFigurePPP->reset();
2015
2016  _actDeleteMountPoints->setEnabled(false);
2017
2018  enableStartStop();
2019
2020  _caster = new bncCaster();
2021
2022  BNC_CORE->setCaster(_caster);
2023  BNC_CORE->setPortEph(_ephOutPortLineEdit->text().toInt());
2024  BNC_CORE->setPortCorr(_corrPortLineEdit->text().toInt());
2025  BNC_CORE->initCombination();
2026
2027  connect(_caster, SIGNAL(getThreadsFinished()),
2028          this, SLOT(slotGetThreadsFinished()));
2029
2030  connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
2031           this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
2032
2033  BNC_CORE->slotMessage("========== Start BNC v" BNCVERSION" ("BNC_OS") ==========", true);
2034
2035  bncSettings settings;
2036
2037  // Active panels
2038  // -------------
2039  if (!_rnxPathLineEdit->text().isEmpty())
2040      BNC_CORE->slotMessage("Panel 'RINEX Observations' active", true);
2041  if (!_ephPathLineEdit->text().isEmpty())
2042      BNC_CORE->slotMessage("Panel 'RINEX Ephemeris' active", true);
2043  if (!_corrPathLineEdit->text().isEmpty())
2044      BNC_CORE->slotMessage("Panel 'Broadcast Corrections' active", true);
2045  if (!_outPortLineEdit->text().isEmpty())
2046      BNC_CORE->slotMessage("Panel 'Feed Engine' active", true);
2047  if (!_serialMountPointLineEdit->text().isEmpty())
2048      BNC_CORE->slotMessage("Panel 'Serial Output' active", true);
2049  if (!_adviseObsRateComboBox->currentText().isEmpty())
2050      BNC_CORE->slotMessage("Panel 'Outages' active", true);
2051  if (!_miscMountLineEdit->text().isEmpty())
2052      BNC_CORE->slotMessage("Panel 'Miscellaneous' active", true);
2053  if (_pppWidgets._dataSource->currentText() == "Real-Time Streams")
2054      BNC_CORE->slotMessage("Panel 'PPP' active", true);
2055  if (_cmbTable->rowCount() > 0)
2056      BNC_CORE->slotMessage("Panel 'Combine Corrections' active", true);
2057  if (_uploadTable->rowCount() > 0)
2058      BNC_CORE->slotMessage("Panel 'Upload Corrections' active", true);
2059  if (!_uploadEphHostLineEdit->text().isEmpty())
2060      BNC_CORE->slotMessage("Panel 'UploadEphemeris' active", true);
2061
2062  QDir rnxdir(settings.value("rnxPath").toString());
2063  if (!rnxdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations directory", true);
2064
2065  QString rnx_file = settings.value("rnxScript").toString();
2066  if ( !rnx_file.isEmpty() ) {
2067    QFile rnxfile(settings.value("rnxScript").toString());
2068    if (!rnxfile.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations script", true);
2069  }
2070
2071  QDir ephdir(settings.value("ephPath").toString());
2072  if (!ephdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Ephemeris directory", true);
2073
2074  QDir corrdir(settings.value("corrPath").toString());
2075  if (!corrdir.exists()) BNC_CORE->slotMessage("Cannot find Broadcast Corrections directory", true);
2076
2077  QString advise_file = settings.value("adviseScript").toString();
2078  if ( !advise_file.isEmpty() ) {
2079    QFile advisefile(settings.value("adviseScript").toString());
2080    if (!advisefile.exists()) BNC_CORE->slotMessage("Cannot find Outages script", true);
2081  }
2082
2083  _caster->readMountPoints();
2084
2085  _casterEph = new bncEphUploadCaster();
2086  connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
2087          _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
2088}
2089
2090// Retrieve Data
2091////////////////////////////////////////////////////////////////////////////
2092void bncWindow::slotStop() {
2093  int iRet = QMessageBox::question(this, "Stop", "Stop retrieving/processing data?",
2094                                   QMessageBox::Yes, QMessageBox::No,
2095                                   QMessageBox::NoButton);
2096  if (iRet == QMessageBox::Yes) {
2097    BNC_CORE->stopPPP();
2098    BNC_CORE->stopCombination();
2099    delete _caster;    _caster    = 0; BNC_CORE->setCaster(0);
2100    delete _casterEph; _casterEph = 0;
2101    _runningRealTime = false;
2102    _runningPPP      = false;
2103    enableStartStop();
2104  }
2105}
2106
2107// Close Application gracefully
2108////////////////////////////////////////////////////////////////////////////
2109void bncWindow::closeEvent(QCloseEvent* event) {
2110
2111  int iRet = QMessageBox::question(this, "Close", "Save Options?",
2112                                   QMessageBox::Yes, QMessageBox::No,
2113                                   QMessageBox::Cancel);
2114
2115  if      (iRet == QMessageBox::Cancel) {
2116    event->ignore();
2117    return;
2118  }
2119  else if (iRet == QMessageBox::Yes) {
2120    slotSaveOptions();
2121  }
2122
2123  BNC_CORE->stopPPP();
2124
2125  QMainWindow::closeEvent(event);
2126}
2127
2128// User changed the selection of mountPoints
2129////////////////////////////////////////////////////////////////////////////
2130void bncWindow::slotSelectionChanged() {
2131  if (_mountPointsTable->selectedItems().isEmpty()) {
2132    _actDeleteMountPoints->setEnabled(false);
2133  }
2134  else {
2135    _actDeleteMountPoints->setEnabled(true);
2136  }
2137}
2138
2139// Display Program Messages
2140////////////////////////////////////////////////////////////////////////////
2141void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
2142  if (showOnScreen ) {
2143    _log->append(QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg);
2144  }
2145}
2146
2147// About Message
2148////////////////////////////////////////////////////////////////////////////
2149void bncWindow::slotAbout() {
2150 new bncAboutDlg(0);
2151}
2152
2153//Flowchart
2154////////////////////////////////////////////////////////////////////////////
2155void bncWindow::slotFlowchart() {
2156 new bncFlowchartDlg(0);
2157}
2158
2159// Help Window
2160////////////////////////////////////////////////////////////////////////////
2161void bncWindow::slotHelp() {
2162  QUrl url;
2163  url.setPath(":bnchelp.html");
2164  new bncHlpDlg(0, url);
2165}
2166
2167// Select Fonts
2168////////////////////////////////////////////////////////////////////////////
2169void bncWindow::slotFontSel() {
2170  bool ok;
2171  QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
2172  if (ok) {
2173    bncSettings settings;
2174    settings.setValue("font", newFont.toString());
2175    QApplication::setFont(newFont);
2176    int ww = QFontMetrics(newFont).width('w');
2177    setMinimumSize(60*ww, 80*ww);
2178    resize(60*ww, 80*ww);
2179  }
2180}
2181
2182// Whats This Help
2183void bncWindow::slotWhatsThis() {
2184  QWhatsThis::enterWhatsThisMode();
2185}
2186
2187//
2188////////////////////////////////////////////////////////////////////////////
2189void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
2190  _threads = threads;
2191
2192  _bncFigure->updateMountPoints();
2193  _bncFigureLate->updateMountPoints();
2194
2195  populateMountPointsTable();
2196  bncSettings settings;
2197  _outSamplComboBox->findText(settings.value("outSampl").toString());
2198  _outWaitSpinBox->setValue(settings.value("outWait").toInt());
2199  QListIterator<bncGetThread*> iTh(threads);
2200  while (iTh.hasNext()) {
2201    bncGetThread* thread = iTh.next();
2202    for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
2203      QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
2204                "@"  + _mountPointsTable->item(iRow, 1)->text() );
2205      if (url                                      == thread->mountPoint() &&
2206          _mountPointsTable->item(iRow, 4)->text() == thread->latitude()   &&
2207          _mountPointsTable->item(iRow, 5)->text() == thread->longitude() ) {
2208        ((bncTableItem*) _mountPointsTable->item(iRow, 8))->setGetThread(thread);
2209        disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
2210                  _bncFigure, SLOT(slotNewData(QByteArray, double)));
2211        connect(thread, SIGNAL(newBytes(QByteArray, double)),
2212                _bncFigure, SLOT(slotNewData(QByteArray, double)));
2213        disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
2214                   _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2215        connect(thread, SIGNAL(newLatency(QByteArray, double)),
2216                _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
2217        break;
2218      }
2219    }
2220  }
2221}
2222
2223//
2224////////////////////////////////////////////////////////////////////////////
2225void bncWindow::CreateMenu() {
2226  // Create Menus
2227  // ------------
2228  _menuFile = menuBar()->addMenu(tr("&File"));
2229  _menuFile->addAction(_actFontSel);
2230  _menuFile->addSeparator();
2231  _menuFile->addAction(_actSaveOpt);
2232  _menuFile->addSeparator();
2233  _menuFile->addAction(_actQuit);
2234
2235  _menuHlp = menuBar()->addMenu(tr("&Help"));
2236  _menuHlp->addAction(_actHelp);
2237  _menuHlp->addAction(_actFlowchart);
2238  _menuHlp->addAction(_actAbout);
2239}
2240
2241// Toolbar
2242////////////////////////////////////////////////////////////////////////////
2243void bncWindow::AddToolbar() {
2244  QToolBar* toolBar = new QToolBar;
2245  addToolBar(Qt::BottomToolBarArea, toolBar);
2246  toolBar->setMovable(false);
2247  toolBar->addAction(_actAddMountPoints);
2248  toolBar->addAction(_actDeleteMountPoints);
2249  toolBar->addAction(_actMapMountPoints);
2250  toolBar->addAction(_actStart);
2251  toolBar->addAction(_actStop);
2252  toolBar->addWidget(new QLabel("                                           "));
2253  toolBar->addAction(_actwhatsthis);
2254}
2255
2256// About
2257////////////////////////////////////////////////////////////////////////////
2258bncAboutDlg::bncAboutDlg(QWidget* parent) :
2259   QDialog(parent) {
2260
2261  QTextBrowser* tb = new QTextBrowser;
2262  QUrl url; url.setPath(":bncabout.html");
2263  tb->setSource(url);
2264  tb->setReadOnly(true);
2265
2266  int ww = QFontMetrics(font()).width('w');
2267  QPushButton* _closeButton = new QPushButton("Close");
2268  _closeButton->setMaximumWidth(10*ww);
2269  connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2270
2271  QGridLayout* dlgLayout = new QGridLayout();
2272  QLabel* img = new QLabel();
2273  img->setPixmap(QPixmap(":ntrip-logo.png"));
2274  dlgLayout->addWidget(img, 0,0);
2275  dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
2276  dlgLayout->addWidget(tb,1,0,1,2);
2277  dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2278
2279  setLayout(dlgLayout);
2280  resize(60*ww, 60*ww);
2281  setWindowTitle("About BNC");
2282  show();
2283}
2284
2285//
2286////////////////////////////////////////////////////////////////////////////
2287bncAboutDlg::~bncAboutDlg() {
2288
2289};
2290
2291// Flowchart
2292////////////////////////////////////////////////////////////////////////////
2293bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2294   QDialog(parent) {
2295
2296  int ww = QFontMetrics(font()).width('w');
2297  QPushButton* _closeButton = new QPushButton("Close");
2298  _closeButton->setMaximumWidth(10*ww);
2299  connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2300
2301  QGridLayout* dlgLayout = new QGridLayout();
2302  QLabel* img = new QLabel();
2303  img->setPixmap(QPixmap(":bncflowchart.png"));
2304  dlgLayout->addWidget(img, 0,0);
2305  dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2306
2307  setLayout(dlgLayout);
2308  setWindowTitle("Flow Chart");
2309  show();
2310}
2311
2312//
2313////////////////////////////////////////////////////////////////////////////
2314bncFlowchartDlg::~bncFlowchartDlg() {
2315};
2316
2317// Enable/Disable Widget (and change its color)
2318////////////////////////////////////////////////////////////////////////////
2319void bncWindow::enableWidget(bool enable, QWidget* widget) {
2320
2321  const static QPalette paletteWhite(QColor(255, 255, 255));
2322  const static QPalette paletteGray(QColor(230, 230, 230));
2323
2324  widget->setEnabled(enable);
2325  if (enable) {
2326    widget->setPalette(paletteWhite);
2327  }
2328  else {
2329    widget->setPalette(paletteGray);
2330  }
2331}
2332
2333//  Bnc Text
2334////////////////////////////////////////////////////////////////////////////
2335void bncWindow::slotBncTextChanged(){
2336
2337  const static QPalette paletteWhite(QColor(255, 255, 255));
2338  const static QPalette paletteGray(QColor(230, 230, 230));
2339
2340  bool enable = true;
2341
2342  // Proxy
2343  //------
2344  if (sender() == 0 || sender() == _proxyHostLineEdit) {
2345    enable = !_proxyHostLineEdit->text().isEmpty();
2346    enableWidget(enable, _proxyPortLineEdit);
2347  }
2348
2349  // RINEX Observations
2350  // ------------------
2351  if (sender() == 0 || sender() == _rnxPathLineEdit) {
2352    enable = !_rnxPathLineEdit->text().isEmpty();
2353    enableWidget(enable, _rnxIntrComboBox);
2354    enableWidget(enable, _rnxSamplComboBox);
2355    enableWidget(enable, _rnxSkelLineEdit);
2356    enableWidget(enable, _rnxFileCheckBox);
2357    enableWidget(enable, _rnxScrpLineEdit);
2358    enableWidget(enable, _rnxV2Priority);
2359    enableWidget(enable, _rnxV3CheckBox);
2360
2361    bool enable1 = true;
2362    enable1 = _rnxV3CheckBox->isChecked();
2363    if (enable && enable1) {
2364    enableWidget(false, _rnxV2Priority);
2365    }
2366    if (enable && !enable1) {
2367    enableWidget(true, _rnxV2Priority);
2368    }
2369  }
2370
2371  // RINEX Observations, Signal Priority
2372  // -----------------------------------
2373  if (sender() == 0 || sender() == _rnxV3CheckBox) {
2374    if (!_rnxPathLineEdit->text().isEmpty()) {
2375      enableWidget(enable, _rnxIntrComboBox);
2376      enable = !_rnxV3CheckBox->isChecked();
2377      enableWidget(enable, _rnxV2Priority);
2378    }
2379  }
2380
2381  // RINEX Ephemeris
2382  // ---------------
2383  if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _ephOutPortLineEdit) {
2384    enable = !_ephPathLineEdit->text().isEmpty() || !_ephOutPortLineEdit->text().isEmpty();
2385    enableWidget(enable, _ephIntrComboBox);
2386    enableWidget(enable, _ephV3CheckBox);
2387  }
2388
2389  // Broadcast Corrections
2390  // ---------------------
2391  if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2392    enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2393    enableWidget(enable, _corrIntrComboBox);
2394  }
2395
2396  // Feed Engine
2397  // -----------
2398  if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2399    enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2400    enableWidget(enable, _outWaitSpinBox);
2401    enableWidget(enable, _outSamplComboBox);
2402  }
2403
2404  // Serial Output
2405  // -------------
2406  if (sender() == 0 || sender() == _serialMountPointLineEdit ||
2407      sender() == _serialAutoNMEAComboBox) {
2408    enable = !_serialMountPointLineEdit->text().isEmpty();
2409    enableWidget(enable, _serialPortNameLineEdit);
2410    enableWidget(enable, _serialBaudRateComboBox);
2411    enableWidget(enable, _serialParityComboBox);
2412    enableWidget(enable, _serialDataBitsComboBox);
2413    enableWidget(enable, _serialStopBitsComboBox);
2414    enableWidget(enable, _serialFlowControlComboBox);
2415    enableWidget(enable, _serialAutoNMEAComboBox);
2416    bool enable2 = enable && _serialAutoNMEAComboBox->currentText() == "Auto";
2417    enableWidget(enable2, _serialFileNMEALineEdit);
2418    bool enable3 = enable && _serialAutoNMEAComboBox->currentText().contains("Manual");
2419    enableWidget(enable3, _serialHeightNMEALineEdit);
2420    enableWidget(enable3, _serialManualNMEASamplingSpinBox);
2421  }
2422
2423  // Outages
2424  // -------
2425  if (sender() == 0 || sender() == _adviseObsRateComboBox) {
2426    enable = !_adviseObsRateComboBox->currentText().isEmpty();
2427    enableWidget(enable, _adviseFailSpinBox);
2428    enableWidget(enable, _adviseRecoSpinBox);
2429    enableWidget(enable, _adviseScriptLineEdit);
2430  }
2431
2432  // Miscellaneous
2433  // -------------
2434  if (sender() == 0 || sender() == _miscMountLineEdit) {
2435    enable = !_miscMountLineEdit->text().isEmpty();
2436    enableWidget(enable, _miscIntrComboBox);
2437    enableWidget(enable, _miscScanRTCMCheckBox);
2438    enableWidget(enable, _miscPortLineEdit);
2439  }
2440
2441  // Enable/disable Broadcast Ephemerides
2442  // ------------------------------------
2443  if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2444    enable = !_uploadEphHostLineEdit->text().isEmpty();
2445    enableWidget(enable, _uploadEphPortLineEdit);
2446    enableWidget(enable, _uploadEphMountpointLineEdit);
2447    enableWidget(enable, _uploadEphPasswordLineEdit);
2448    enableWidget(enable, _uploadEphSampleSpinBox);
2449  }
2450
2451  // Combine Corrections
2452  // -------------------
2453  if (sender() == 0 || sender() == _cmbTable) {
2454    int iRow = _cmbTable->rowCount();
2455    if (iRow > 0) {
2456      enableWidget(true, _cmbMethodComboBox);
2457      enableWidget(true, _cmbMaxresLineEdit);
2458      enableWidget(true, _cmbSamplSpinBox);
2459      enableWidget(true, _cmbUseGlonass);
2460    }
2461    else {
2462      enableWidget(false, _cmbMethodComboBox);
2463      enableWidget(false, _cmbMaxresLineEdit);
2464      enableWidget(false, _cmbSamplSpinBox);
2465      enableWidget(false, _cmbUseGlonass);
2466    }
2467  }
2468
2469  // Upload(clk)
2470  // -----------
2471  int iRow = _uploadTable->rowCount();
2472  if (iRow > 0) {
2473    enableWidget(true, _uploadIntrComboBox);
2474    enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2475    enableWidget(true, _uploadSamplClkRnxSpinBox);
2476    enableWidget(true, _uploadSamplSp3SpinBox);
2477    enableWidget(true, _uploadAntexFile);
2478  }
2479  else {
2480    enableWidget(false, _uploadIntrComboBox);
2481    enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2482    enableWidget(false, _uploadSamplClkRnxSpinBox);
2483    enableWidget(false, _uploadSamplSp3SpinBox);
2484    enableWidget(false, _uploadAntexFile);
2485  }
2486
2487  // QC
2488  // --
2489  if (sender() == 0 || sender() == _reqcActionComboBox || sender() == _reqcSkyPlotSignals) {
2490    enable = !_reqcActionComboBox->currentText().isEmpty();
2491    bool enable10   = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2492//  bool enablePlot = !_reqcSkyPlotSignals->text().isEmpty();
2493    enableWidget(enable,                            _reqcObsFileChooser);
2494    enableWidget(enable,                            _reqcNavFileChooser);
2495    enableWidget(enable,                            _reqcOutLogLineEdit);
2496    enableWidget(enable &&  enable10,               _reqcEditOptionButton);
2497    enableWidget(enable &&  enable10,               _reqcOutObsLineEdit);
2498    enableWidget(enable &&  enable10,               _reqcOutNavLineEdit);
2499    enableWidget(enable && !enable10,               _reqcLogSummaryOnly);
2500    enableWidget(enable && !enable10,               _reqcSkyPlotSignals);
2501//  enableWidget(enable && !enable10 && enablePlot, _reqcPlotDirLineEdit);
2502    enableWidget(enable && !enable10,               _reqcPlotDirLineEdit);
2503  }
2504
2505  // SP3 File Comparison
2506  // -------------------
2507  if (sender() == 0 || sender() == _sp3CompFileChooser) {
2508    enable = !_sp3CompFileChooser->fileName().isEmpty();
2509    enableWidget(enable, _sp3CompLogLineEdit);
2510    enableWidget(enable, _sp3CompExclude);
2511  }
2512
2513  enableStartStop();
2514}
2515
2516//
2517////////////////////////////////////////////////////////////////////////////
2518void bncWindow::slotAddCmbRow() {
2519  int iRow = _cmbTable->rowCount();
2520  _cmbTable->insertRow(iRow);
2521  for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2522    _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2523  }
2524}
2525
2526//
2527////////////////////////////////////////////////////////////////////////////
2528void bncWindow::slotDelCmbRow() {
2529
2530  const static QPalette paletteWhite(QColor(255, 255, 255));
2531  const static QPalette paletteGray(QColor(230, 230, 230));
2532
2533  int nRows = _cmbTable->rowCount();
2534  bool flg[nRows];
2535  for (int iRow = 0; iRow < nRows; iRow++) {
2536    if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2537      flg[iRow] = true;
2538    }
2539    else {
2540      flg[iRow] = false;
2541    }
2542  }
2543  for (int iRow = nRows-1; iRow >= 0; iRow--) {
2544    if (flg[iRow]) {
2545      _cmbTable->removeRow(iRow);
2546    }
2547  }
2548  nRows = _cmbTable->rowCount();
2549  if (nRows < 1) {
2550    enableWidget(false, _cmbMethodComboBox);
2551    enableWidget(false, _cmbMaxresLineEdit);
2552    enableWidget(false, _cmbSamplSpinBox);
2553    enableWidget(false, _cmbUseGlonass);
2554  }
2555}
2556
2557//
2558////////////////////////////////////////////////////////////////////////////
2559void bncWindow::populateCmbTable() {
2560
2561  for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2562    _cmbTable->removeRow(iRow);
2563  }
2564
2565  bncSettings settings;
2566
2567  int iRow = -1;
2568  QListIterator<QString> it(settings.value("cmbStreams").toStringList());
2569  while (it.hasNext()) {
2570    QStringList hlp = it.next().split(" ");
2571    if (hlp.size() > 2) {
2572      ++iRow;
2573      _cmbTable->insertRow(iRow);
2574    }
2575    for (int iCol = 0; iCol < hlp.size(); iCol++) {
2576      _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2577    }
2578  }
2579}
2580
2581//
2582////////////////////////////////////////////////////////////////////////////
2583void bncWindow::slotAddUploadRow() {
2584  int iRow = _uploadTable->rowCount();
2585  _uploadTable->insertRow(iRow);
2586  for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
2587    if      (iCol == 3) {
2588      QLineEdit* passwd = new QLineEdit();
2589      passwd->setFrame(false);
2590      passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2591      _uploadTable->setCellWidget(iRow, iCol, passwd);
2592    }
2593    else if (iCol == 4) {
2594      QComboBox* system = new QComboBox();
2595      system->setEditable(false);
2596      system->addItems(QString("IGS14,ETRF2000,GDA2020,SIRGAS2000,DREF91,Custom").split(","));
2597      system->setFrame(false);
2598      _uploadTable->setCellWidget(iRow, iCol, system);
2599    }
2600    else if (iCol == 5) {
2601      QComboBox* format = new QComboBox();
2602      format->setEditable(false);
2603      format->addItems(QString("IGS-SSR,RTCM-SSR").split(","));
2604      format->setFrame(false);
2605      _uploadTable->setCellWidget(iRow, iCol, format);
2606    }
2607    else if (iCol == 6) {
2608      QCheckBox* com = new QCheckBox();
2609      _uploadTable->setCellWidget(iRow, iCol, com);
2610    }
2611    else if (iCol == 12) {
2612      bncTableItem* bncIt = new bncTableItem();
2613      bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2614      _uploadTable->setItem(iRow, iCol, bncIt);
2615      BNC_CORE->_uploadTableItems[iRow] = bncIt;
2616    }
2617    else {
2618      _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2619    }
2620  }
2621}
2622
2623//
2624////////////////////////////////////////////////////////////////////////////
2625void bncWindow::slotDelUploadRow() {
2626  BNC_CORE->_uploadTableItems.clear();
2627  int nRows = _uploadTable->rowCount();
2628  bool flg[nRows];
2629  for (int iRow = 0; iRow < nRows; iRow++) {
2630    if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
2631      flg[iRow] = true;
2632    }
2633    else {
2634      flg[iRow] = false;
2635    }
2636  }
2637  for (int iRow = nRows-1; iRow >= 0; iRow--) {
2638    if (flg[iRow]) {
2639      _uploadTable->removeRow(iRow);
2640    }
2641  }
2642  for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
2643    BNC_CORE->_uploadTableItems[iRow] =
2644                                (bncTableItem*) _uploadTable->item(iRow, 12);
2645  }
2646  nRows = _uploadTable->rowCount();
2647  if (nRows < 1) {
2648    enableWidget(false, _uploadIntrComboBox);
2649    enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2650    enableWidget(false, _uploadSamplSp3SpinBox);
2651    enableWidget(false, _uploadSamplClkRnxSpinBox);
2652    enableWidget(false, _uploadAntexFile);
2653  }
2654}
2655
2656//
2657////////////////////////////////////////////////////////////////////////////
2658void bncWindow::populateUploadTable() {
2659  for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2660    _uploadTable->removeRow(iRow);
2661  }
2662
2663  bncSettings settings;
2664
2665  int iRow = -1;
2666  QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
2667  while (it.hasNext()) {
2668    QStringList hlp = it.next().split(",");
2669    if (hlp.size() > 6) {
2670      ++iRow;
2671      _uploadTable->insertRow(iRow);
2672    }
2673    for (int iCol = 0; iCol < hlp.size(); iCol++) {
2674      if      (iCol == 3) {
2675        QLineEdit* passwd = new QLineEdit();
2676        passwd->setFrame(false);
2677        passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2678        passwd->setText(hlp[iCol]);
2679        _uploadTable->setCellWidget(iRow, iCol, passwd);
2680      }
2681      else if (iCol == 4) {
2682        QComboBox* system = new QComboBox();
2683        system->setEditable(false);
2684        system->addItems(QString("IGS14,ETRF2000,GDA2020,SIRGAS2000,DREF91,Custom").split(","));
2685        system->setFrame(false);
2686        system->setCurrentIndex(system->findText(hlp[iCol]));
2687        _uploadTable->setCellWidget(iRow, iCol, system);
2688      }
2689      else if (iCol == 5) {
2690        QComboBox* format = new QComboBox();
2691        format->setEditable(false);
2692        format->addItems(QString("IGS-SSR,RTCM-SSR").split(","));
2693        format->setFrame(false);
2694        format->setCurrentIndex(format->findText(hlp[iCol]));
2695        _uploadTable->setCellWidget(iRow, iCol, format);
2696      }
2697      else if (iCol == 6) {
2698        QCheckBox* com = new QCheckBox();
2699        if (hlp[iCol].toInt() == Qt::Checked) {
2700          com->setCheckState(Qt::Checked);
2701        }
2702        _uploadTable->setCellWidget(iRow, iCol, com);
2703      }
2704      else if (iCol == 12) {
2705        bncTableItem* bncIt = new bncTableItem();
2706        bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2707        _uploadTable->setItem(iRow, iCol, bncIt);
2708        BNC_CORE->_uploadTableItems[iRow] = bncIt;
2709      }
2710      else {
2711        _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2712      }
2713    }
2714  }
2715}
2716
2717//
2718////////////////////////////////////////////////////////////////////////////
2719void bncWindow::slotSetUploadTrafo() {
2720  bncCustomTrafo* dlg = new bncCustomTrafo(this);
2721  dlg->exec();
2722  delete dlg;
2723}
2724
2725// Progress Bar Change
2726////////////////////////////////////////////////////////////////////////////
2727void bncWindow::slotPostProcessingProgress(int nEpo) {
2728  _actStart->setText(QString("%1 Epochs").arg(nEpo));
2729}
2730
2731// Post-Processing Reqc Finished
2732////////////////////////////////////////////////////////////////////////////
2733void bncWindow::slotPostProcessingFinished() {
2734  delete _caster; _caster = 0; BNC_CORE->setCaster(0);
2735  _runningPPP     = false;
2736  _runningEdit    = false;
2737  _runningQC      = false;
2738  _runningSp3Comp = false;
2739  _actStart->setText(tr("Sta&rt"));
2740  enableStartStop();
2741}
2742
2743// Edit teqc-like editing options
2744////////////////////////////////////////////////////////////////////////////
2745void bncWindow::slotReqcEditOption() {
2746  saveOptions();
2747  reqcDlg* dlg = new reqcDlg(this);
2748  dlg->move(this->pos().x()+50, this->pos().y()+50);
2749  dlg->exec();
2750  delete dlg;
2751}
2752
2753// Enable/Disable Start and Stop Buttons
2754////////////////////////////////////////////////////////////////////////////
2755void bncWindow::enableStartStop() {
2756  if ( running() ) {
2757    _actStart->setEnabled(false);
2758    if (_runningRealTime || _runningPPP) {
2759      _actStop->setEnabled(true);
2760    }
2761  }
2762  else {
2763    _actStart->setEnabled(true);
2764    _actStop->setEnabled(false);
2765  }
2766}
2767
2768// Show Map
2769////////////////////////////////////////////////////////////////////////////
2770void bncWindow::slotMapMountPoints() {
2771  saveOptions();
2772  t_bncMap* bncMap = new t_bncMap(this);
2773  bncMap->setMinimumSize(800, 600);
2774  bncMap->setWindowTitle("Selected Mountpoints");
2775
2776  bncSettings settings;
2777  QListIterator<QString> it(settings.value("mountPoints").toStringList());
2778  while (it.hasNext()) {
2779    QStringList hlp = it.next().split(" ");
2780    if (hlp.size() < 5) continue;
2781    QUrl   url(hlp[0]);
2782    double latDeg = hlp[3].toDouble();
2783    double lonDeg = hlp[4].toDouble();
2784    bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
2785  }
2786
2787  bncMap->show();
2788}
2789
2790// Show Map
2791////////////////////////////////////////////////////////////////////////////
2792void bncWindow::slotMapPPP() {
2793#ifdef QT_WEBKIT
2794  saveOptions();
2795  enableWidget(false, _pppWidgets._mapWinButton);
2796  enableWidget(false, _pppWidgets._mapWinDotSize);
2797  enableWidget(false, _pppWidgets._mapWinDotColor);
2798
2799  if (!_mapWin) {
2800    _mapWin = new bncMapWin(this);
2801    connect(_mapWin, SIGNAL(mapClosed()), this, SLOT(slotMapPPPClosed()));
2802    connect(BNC_CORE, SIGNAL(newPosition(QByteArray, bncTime, QVector<double>)),
2803            _mapWin, SLOT(slotNewPosition(QByteArray, bncTime, QVector<double>)));
2804  }
2805  _mapWin->show();
2806#else
2807  QMessageBox::information(this, "Information",
2808                           "Qt Library compiled without QtWebKit");
2809#endif
2810}
2811
2812// Show Map
2813////////////////////////////////////////////////////////////////////////////
2814void bncWindow::slotMapPPPClosed() {
2815#ifdef QT_WEBKIT
2816  enableWidget(true, _pppWidgets._mapWinButton);
2817  enableWidget(true, _pppWidgets._mapWinDotSize);
2818  enableWidget(true, _pppWidgets._mapWinDotColor);
2819  if (_mapWin) {
2820    QListIterator<bncGetThread*> it(_threads);
2821    while (it.hasNext()) {
2822      bncGetThread* thread = it.next();
2823      thread->disconnect(_mapWin);
2824    }
2825    _mapWin->deleteLater();
2826    _mapWin = 0;
2827  }
2828#endif
2829}
Note: See TracBrowser for help on using the repository browser.