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

Last change on this file since 6664 was 6664, checked in by weber, 9 years ago

Documentation completed

File size: 124.1 KB
RevLine 
[280]1// Part of BNC, a utility for retrieving decoding and
[464]2// converting GNSS data streams from NTRIP broadcasters.
[280]3//
[464]4// Copyright (C) 2007
[280]5// German Federal Agency for Cartography and Geodesy (BKG)
6// http://www.bkg.bund.de
[464]7// Czech Technical University Prague, Department of Geodesy
[280]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.
[35]24
25/* -------------------------------------------------------------------------
[93]26 * BKG NTRIP Client
[35]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
[1175]41#include <iostream>
42
[274]43#include <unistd.h>
[35]44#include "bncwindow.h"
[5070]45#include "bnccore.h"
[35]46#include "bncgetthread.h"
47#include "bnctabledlg.h"
[1610]48#include "bncipport.h"
[1780]49#include "bncudpport.h"
[1737]50#include "bncserialport.h"
[177]51#include "bnchlpdlg.h"
[168]52#include "bnchtml.h"
[366]53#include "bnctableitem.h"
[1535]54#include "bncsettings.h"
[1932]55#include "bncfigure.h"
[1972]56#include "bncfigurelate.h"
[2141]57#include "bncfigureppp.h"
[2012]58#include "bncversion.h"
[3245]59#include "bncbytescounter.h"
[3357]60#include "bncsslconfig.h"
[3239]61#include "upload/bnccustomtrafo.h"
[3249]62#include "upload/bncephuploadcaster.h"
[3602]63#include "qtfilechooser.h"
[3897]64#include "reqcdlg.h"
[4646]65#include "bncmap.h"
[5887]66#include "rinex/reqcedit.h"
67#include "rinex/reqcanalyze.h"
[6335]68#include "orbComp/sp3Comp.h"
[5186]69#ifdef QT_WEBKIT
70# include "map/bncmapwin.h"
71#endif
[35]72
73using namespace std;
74
[5063]75#ifdef GNSSCENTER_PLUGIN
76Q_EXPORT_PLUGIN2(gnsscenter_bnc, t_bncFactory)
77#endif
78
[1925]79// Constructor
80////////////////////////////////////////////////////////////////////////////
[35]81bncWindow::bncWindow() {
82
[5085]83#ifdef GNSSCENTER_PLUGIN
84 BNC_CORE->setConfFileName("");
85#endif
86
[5729]87 _caster = 0;
[3249]88 _casterEph = 0;
[609]89
[5873]90 _bncFigure = new bncFigure(this);
[1972]91 _bncFigureLate = new bncFigureLate(this);
[5873]92 _bncFigurePPP = new bncFigurePPP(this);
[5941]93
[5954]94 connect(BNC_CORE, SIGNAL(newPosition(QByteArray, bncTime, QVector<double>)),
95 _bncFigurePPP, SLOT(slotNewPosition(QByteArray, bncTime, QVector<double>)));
[5941]96
[5971]97 connect(BNC_CORE, SIGNAL(progressRnxPPP(int)), this, SLOT(slotPostProcessingProgress(int)));
98 connect(BNC_CORE, SIGNAL(finishedRnxPPP()), this, SLOT(slotPostProcessingFinished()));
[5941]99
[5971]100 _runningRealTime = false;
101 _runningPPP = false;
102 _runningEdit = false;
103 _runningQC = false;
[6332]104 _runningSp3Comp = false;
[5971]105 _reqcActionComboBox = 0; // necessary for enableStartStop()
[1912]106
[5179]107 _mapWin = 0;
108
[91]109 int ww = QFontMetrics(this->font()).width('w');
[199]110
[2269]111 static const QStringList labels = QString("account, Streams: resource loader / mountpoint, decoder, lat, long, nmea, ntrip, bytes").split(",");
[35]112
[6408]113 setMinimumSize(100*ww, 70*ww);
[375]114
[2012]115 setWindowTitle(tr("BKG Ntrip Client (BNC) Version " BNCVERSION));
[91]116
[5068]117 connect(BNC_CORE, SIGNAL(newMessage(QByteArray,bool)),
[5066]118 this, SLOT(slotWindowMessage(QByteArray,bool)));
[1171]119
[35]120 // Create Actions
121 // --------------
[108]122 _actHelp = new QAction(tr("&Help Contents"),this);
123 connect(_actHelp, SIGNAL(triggered()), SLOT(slotHelp()));
[35]124
[108]125 _actAbout = new QAction(tr("&About BNC"),this);
126 connect(_actAbout, SIGNAL(triggered()), SLOT(slotAbout()));
127
[996]128 _actFlowchart = new QAction(tr("&Flow Chart"),this);
[989]129 connect(_actFlowchart, SIGNAL(triggered()), SLOT(slotFlowchart()));
130
[261]131 _actFontSel = new QAction(tr("Select &Font"),this);
[110]132 connect(_actFontSel, SIGNAL(triggered()), SLOT(slotFontSel()));
133
[5571]134 _actSaveOpt = new QAction(tr("&Reread && Save Configuration"),this);
[35]135 connect(_actSaveOpt, SIGNAL(triggered()), SLOT(slotSaveOptions()));
136
137 _actQuit = new QAction(tr("&Quit"),this);
138 connect(_actQuit, SIGNAL(triggered()), SLOT(close()));
139
[1874]140 _actAddMountPoints = new QAction(tr("Add &Stream"),this);
[35]141 connect(_actAddMountPoints, SIGNAL(triggered()), SLOT(slotAddMountPoints()));
142
[1874]143 _actDeleteMountPoints = new QAction(tr("&Delete Stream"),this);
[35]144 connect(_actDeleteMountPoints, SIGNAL(triggered()), SLOT(slotDeleteMountPoints()));
[83]145 _actDeleteMountPoints->setEnabled(false);
[35]146
[5571]147 _actMapMountPoints = new QAction(tr("&Map"),this);
[5162]148 connect(_actMapMountPoints, SIGNAL(triggered()), SLOT(slotMapMountPoints()));
[4646]149
[3782]150 _actStart = new QAction(tr("Sta&rt"),this);
151 connect(_actStart, SIGNAL(triggered()), SLOT(slotStart()));
[35]152
[182]153 _actStop = new QAction(tr("Sto&p"),this);
154 connect(_actStop, SIGNAL(triggered()), SLOT(slotStop()));
155
[2596]156 _actwhatsthis= new QAction(tr("Help ?=Shift+F1"),this);
[399]157 connect(_actwhatsthis, SIGNAL(triggered()), SLOT(slotWhatsThis()));
158
[679]159 CreateMenu();
160 AddToolbar();
[35]161
[1535]162 bncSettings settings;
[1678]163
[3788]164 // Network Options
[3356]165 // ---------------
[35]166 _proxyHostLineEdit = new QLineEdit(settings.value("proxyHost").toString());
167 _proxyPortLineEdit = new QLineEdit(settings.value("proxyPort").toString());
[565]168
[2128]169 connect(_proxyHostLineEdit, SIGNAL(textChanged(const QString &)),
170 this, SLOT(slotBncTextChanged()));
171
[3356]172 _sslCaCertPathLineEdit = new QLineEdit(settings.value("sslCaCertPath").toString());
173 _ignoreSslErrorsCheckBox = new QCheckBox();
174 _ignoreSslErrorsCheckBox->setCheckState(Qt::CheckState(
175 settings.value("ignoreSslErrors").toInt()));
176
[1678]177 // General Options
178 // ---------------
179 _logFileLineEdit = new QLineEdit(settings.value("logFile").toString());
[2386]180 _rawOutFileLineEdit = new QLineEdit(settings.value("rawOutFile").toString());
[259]181 _rnxAppendCheckBox = new QCheckBox();
182 _rnxAppendCheckBox->setCheckState(Qt::CheckState(
183 settings.value("rnxAppend").toInt()));
[1678]184 _onTheFlyComboBox = new QComboBox();
185 _onTheFlyComboBox->setEditable(false);
[4537]186 _onTheFlyComboBox->addItems(QString("1 day,1 hour,5 min,1 min").split(","));
[1678]187 int ii = _onTheFlyComboBox->findText(settings.value("onTheFlyInterval").toString());
188 if (ii != -1) {
189 _onTheFlyComboBox->setCurrentIndex(ii);
190 }
[1333]191 _autoStartCheckBox = new QCheckBox();
192 _autoStartCheckBox->setCheckState(Qt::CheckState(
193 settings.value("autoStart").toInt()));
[1678]194
195 // RINEX Observations Options
196 // --------------------------
197 _rnxPathLineEdit = new QLineEdit(settings.value("rnxPath").toString());
[106]198 _rnxIntrComboBox = new QComboBox();
199 _rnxIntrComboBox->setEditable(false);
[405]200 _rnxIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
[1678]201 ii = _rnxIntrComboBox->findText(settings.value("rnxIntr").toString());
[106]202 if (ii != -1) {
203 _rnxIntrComboBox->setCurrentIndex(ii);
204 }
[1678]205 _rnxSamplSpinBox = new QSpinBox();
206 _rnxSamplSpinBox->setMinimum(0);
207 _rnxSamplSpinBox->setMaximum(60);
208 _rnxSamplSpinBox->setSingleStep(5);
209 _rnxSamplSpinBox->setValue(settings.value("rnxSampl").toInt());
210 _rnxSamplSpinBox->setSuffix(" sec");
211 _rnxSkelLineEdit = new QLineEdit(settings.value("rnxSkel").toString());
212 _rnxSkelLineEdit->setMaximumWidth(5*ww);
213 _rnxScrpLineEdit = new QLineEdit(settings.value("rnxScript").toString());
214 _rnxV3CheckBox = new QCheckBox();
215 _rnxV3CheckBox->setCheckState(Qt::CheckState(settings.value("rnxV3").toInt()));
[6238]216 QString hlp = settings.value("rnxV2Priority").toString();
[6237]217 if (hlp.isEmpty()) {
218 hlp = "CWPX_?";
219 }
220 _rnxV2Priority = new QLineEdit(hlp);
[1678]221
[2128]222 connect(_rnxPathLineEdit, SIGNAL(textChanged(const QString &)),
223 this, SLOT(slotBncTextChanged()));
224
[1678]225 // RINEX Ephemeris Options
226 // -----------------------
227 _ephPathLineEdit = new QLineEdit(settings.value("ephPath").toString());
[560]228 _ephIntrComboBox = new QComboBox();
229 _ephIntrComboBox->setEditable(false);
[647]230 _ephIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
[560]231 int jj = _ephIntrComboBox->findText(settings.value("ephIntr").toString());
232 if (jj != -1) {
233 _ephIntrComboBox->setCurrentIndex(jj);
234 }
[1678]235 _outEphPortLineEdit = new QLineEdit(settings.value("outEphPort").toString());
236 _ephV3CheckBox = new QCheckBox();
237 _ephV3CheckBox->setCheckState(Qt::CheckState(settings.value("ephV3").toInt()));
238
[2128]239 connect(_outEphPortLineEdit, SIGNAL(textChanged(const QString &)),
240 this, SLOT(slotBncTextChanged()));
241
242 connect(_ephPathLineEdit, SIGNAL(textChanged(const QString &)),
243 this, SLOT(slotBncTextChanged()));
244
[1682]245 // Broadcast Corrections Options
[1678]246 // -----------------------------
247 _corrPathLineEdit = new QLineEdit(settings.value("corrPath").toString());
[934]248 _corrIntrComboBox = new QComboBox();
249 _corrIntrComboBox->setEditable(false);
250 _corrIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
251 int mm = _corrIntrComboBox->findText(settings.value("corrIntr").toString());
252 if (mm != -1) {
253 _corrIntrComboBox->setCurrentIndex(mm);
254 }
[1678]255 _corrPortLineEdit = new QLineEdit(settings.value("corrPort").toString());
[740]256
[2128]257 connect(_corrPathLineEdit, SIGNAL(textChanged(const QString &)),
258 this, SLOT(slotBncTextChanged()));
259
260 connect(_corrPortLineEdit, SIGNAL(textChanged(const QString &)),
261 this, SLOT(slotBncTextChanged()));
262
[1678]263 // Feed Engine Options
264 // -------------------
265 _outPortLineEdit = new QLineEdit(settings.value("outPort").toString());
266 _waitTimeSpinBox = new QSpinBox();
267 _waitTimeSpinBox->setMinimum(1);
268 _waitTimeSpinBox->setMaximum(30);
269 _waitTimeSpinBox->setSingleStep(1);
270 _waitTimeSpinBox->setSuffix(" sec");
271 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
[740]272 _binSamplSpinBox = new QSpinBox();
273 _binSamplSpinBox->setMinimum(0);
274 _binSamplSpinBox->setMaximum(60);
275 _binSamplSpinBox->setSingleStep(5);
276 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
277 _binSamplSpinBox->setSuffix(" sec");
[1678]278 _outFileLineEdit = new QLineEdit(settings.value("outFile").toString());
279 _outUPortLineEdit = new QLineEdit(settings.value("outUPort").toString());
[740]280
[2128]281 connect(_outPortLineEdit, SIGNAL(textChanged(const QString &)),
282 this, SLOT(slotBncTextChanged()));
283
284 connect(_outFileLineEdit, SIGNAL(textChanged(const QString &)),
285 this, SLOT(slotBncTextChanged()));
286
[1746]287 // Serial Output Options
288 // ---------------------
[1678]289 _serialMountPointLineEdit = new QLineEdit(settings.value("serialMountPoint").toString());
[1327]290 _serialPortNameLineEdit = new QLineEdit(settings.value("serialPortName").toString());
[1329]291 _serialBaudRateComboBox = new QComboBox();
[1332]292 _serialBaudRateComboBox->addItems(QString("110,300,600,"
293 "1200,2400,4800,9600,19200,38400,57600,115200").split(","));
[1678]294 int kk = _serialBaudRateComboBox->findText(settings.value("serialBaudRate").toString());
[1329]295 if (kk != -1) {
296 _serialBaudRateComboBox->setCurrentIndex(kk);
297 }
[1678]298 _serialFlowControlComboBox = new QComboBox();
299 _serialFlowControlComboBox->addItems(QString("OFF,XONXOFF,HARDWARE").split(","));
300 kk = _serialFlowControlComboBox->findText(settings.value("serialFlowControl").toString());
[1329]301 if (kk != -1) {
[1678]302 _serialFlowControlComboBox->setCurrentIndex(kk);
[1329]303 }
304 _serialDataBitsComboBox = new QComboBox();
305 _serialDataBitsComboBox->addItems(QString("5,6,7,8").split(","));
306 kk = _serialDataBitsComboBox->findText(settings.value("serialDataBits").toString());
307 if (kk != -1) {
308 _serialDataBitsComboBox->setCurrentIndex(kk);
309 }
[1678]310 _serialParityComboBox = new QComboBox();
311 _serialParityComboBox->addItems(QString("NONE,ODD,EVEN,SPACE").split(","));
312 kk = _serialParityComboBox->findText(settings.value("serialParity").toString());
313 if (kk != -1) {
314 _serialParityComboBox->setCurrentIndex(kk);
315 }
[1329]316 _serialStopBitsComboBox = new QComboBox();
317 _serialStopBitsComboBox->addItems(QString("1,2").split(","));
318 kk = _serialStopBitsComboBox->findText(settings.value("serialStopBits").toString());
319 if (kk != -1) {
320 _serialStopBitsComboBox->setCurrentIndex(kk);
321 }
[1595]322 _serialAutoNMEAComboBox = new QComboBox();
323 _serialAutoNMEAComboBox->addItems(QString("Auto,Manual").split(","));
324 kk = _serialAutoNMEAComboBox->findText(settings.value("serialAutoNMEA").toString());
325 if (kk != -1) {
326 _serialAutoNMEAComboBox->setCurrentIndex(kk);
327 }
[1601]328 _serialFileNMEALineEdit = new QLineEdit(settings.value("serialFileNMEA").toString());
[1595]329 _serialHeightNMEALineEdit = new QLineEdit(settings.value("serialHeightNMEA").toString());
[1678]330
[2128]331 connect(_serialMountPointLineEdit, SIGNAL(textChanged(const QString &)),
332 this, SLOT(slotBncTextChanged()));
333
334 connect(_serialAutoNMEAComboBox, SIGNAL(currentIndexChanged(const QString &)),
335 this, SLOT(slotBncTextChanged()));
336
[1678]337 // Outages Options
338 // ---------------
339 _obsRateComboBox = new QComboBox();
340 _obsRateComboBox->setEditable(false);
341 _obsRateComboBox->addItems(QString(",0.1 Hz,0.2 Hz,0.5 Hz,1 Hz,5 Hz").split(","));
342 kk = _obsRateComboBox->findText(settings.value("obsRate").toString());
343 if (kk != -1) {
344 _obsRateComboBox->setCurrentIndex(kk);
345 }
346 _adviseFailSpinBox = new QSpinBox();
347 _adviseFailSpinBox->setMinimum(0);
348 _adviseFailSpinBox->setMaximum(60);
349 _adviseFailSpinBox->setSingleStep(1);
350 _adviseFailSpinBox->setSuffix(" min");
351 _adviseFailSpinBox->setValue(settings.value("adviseFail").toInt());
352 _adviseRecoSpinBox = new QSpinBox();
353 _adviseRecoSpinBox->setMinimum(0);
354 _adviseRecoSpinBox->setMaximum(60);
355 _adviseRecoSpinBox->setSingleStep(1);
356 _adviseRecoSpinBox->setSuffix(" min");
357 _adviseRecoSpinBox->setValue(settings.value("adviseReco").toInt());
358 _adviseScriptLineEdit = new QLineEdit(settings.value("adviseScript").toString());
359
[2128]360 connect(_obsRateComboBox, SIGNAL(currentIndexChanged(const QString &)),
361 this, SLOT(slotBncTextChanged()));
362
[1678]363 // Miscellaneous Options
364 // ---------------------
365 _miscMountLineEdit = new QLineEdit(settings.value("miscMount").toString());
[5644]366 _miscPortLineEdit = new QLineEdit(settings.value("miscPort").toString());
[2003]367 _perfIntrComboBox = new QComboBox();
[728]368 _perfIntrComboBox->setEditable(false);
[1472]369 _perfIntrComboBox->addItems(QString(",2 sec, 10 sec,1 min,5 min,15 min,1 hour,6 hours,1 day").split(","));
[728]370 int ll = _perfIntrComboBox->findText(settings.value("perfIntr").toString());
[709]371 if (ll != -1) {
[728]372 _perfIntrComboBox->setCurrentIndex(ll);
[709]373 }
[1678]374 _scanRTCMCheckBox = new QCheckBox();
375 _scanRTCMCheckBox->setCheckState(Qt::CheckState(
376 settings.value("scanRTCM").toInt()));
[709]377
[2128]378 connect(_miscMountLineEdit, SIGNAL(textChanged(const QString &)),
379 this, SLOT(slotBncTextChanged()));
380
[1678]381 // Streams
382 // -------
[1352]383 _mountPointsTable = new QTableWidget(0,8);
[375]384
[679]385 _mountPointsTable->horizontalHeader()->resizeSection(1,34*ww);
[366]386 _mountPointsTable->horizontalHeader()->resizeSection(2,9*ww);
387 _mountPointsTable->horizontalHeader()->resizeSection(3,7*ww);
388 _mountPointsTable->horizontalHeader()->resizeSection(4,7*ww);
389 _mountPointsTable->horizontalHeader()->resizeSection(5,5*ww);
[1678]390 _mountPointsTable->horizontalHeader()->resizeSection(6,5*ww);
[199]391 _mountPointsTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
[203]392 _mountPointsTable->horizontalHeader()->setStretchLastSection(true);
[2269]393 _mountPointsTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
[5716]394 _mountPointsTable->setHorizontalHeaderLabels(labels);
[115]395 _mountPointsTable->setGridStyle(Qt::NoPen);
396 _mountPointsTable->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
[35]397 _mountPointsTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
398 _mountPointsTable->setSelectionBehavior(QAbstractItemView::SelectRows);
[111]399 _mountPointsTable->hideColumn(0);
[83]400 connect(_mountPointsTable, SIGNAL(itemSelectionChanged()),
401 SLOT(slotSelectionChanged()));
[1178]402 populateMountPointsTable();
[35]403
[5947]404 _log = new QTextEdit();
[83]405 _log->setReadOnly(true);
[5947]406 QFont msFont(""); msFont.setStyleHint(QFont::TypeWriter); // default monospace font
407 _log->setFont(msFont);
408 _log->document()->setMaximumBlockCount(1000);
[35]409
[4185]410 // Combine Corrections
411 // -------------------
[3059]412 _cmbTable = new QTableWidget(0,3);
413 _cmbTable->setHorizontalHeaderLabels(QString("Mountpoint, AC Name, Weight").split(","));
414 _cmbTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
415 _cmbTable->setSelectionBehavior(QAbstractItemView::SelectRows);
416 _cmbTable->setMaximumWidth(30*ww);
417 _cmbTable->horizontalHeader()->resizeSection(0,10*ww);
418 _cmbTable->horizontalHeader()->resizeSection(1,8*ww);
419 _cmbTable->horizontalHeader()->resizeSection(2,8*ww);
420 _cmbTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
421 _cmbTable->horizontalHeader()->setStretchLastSection(true);
422 _cmbTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
[3328]423
424 _cmbMaxresLineEdit = new QLineEdit(settings.value("cmbMaxres").toString());
[6172]425 _cmbAntexFile = new qtFileChooser(0, qtFileChooser::File);
426 _cmbAntexFile->setFileName(settings.value("cmbAntexFile").toString());
427 _cmbUseGlonass = new QCheckBox();
428 _cmbUseGlonass->setCheckState(Qt::CheckState(settings.value("cmbUseGlonass").toInt()));
[3059]429
[4179]430 _cmbSamplSpinBox = new QSpinBox;
[4181]431 _cmbSamplSpinBox->setMinimum(10);
[4179]432 _cmbSamplSpinBox->setMaximum(60);
[4181]433 _cmbSamplSpinBox->setSingleStep(10);
[4179]434 _cmbSamplSpinBox->setMaximumWidth(9*ww);
435 _cmbSamplSpinBox->setValue(settings.value("cmbSampl").toInt());
436 _cmbSamplSpinBox->setSuffix(" sec");
437
[3059]438 QPushButton* addCmbRowButton = new QPushButton("Add Row");
439 QPushButton* delCmbRowButton = new QPushButton("Delete");
440
[3813]441 connect(_cmbTable, SIGNAL(itemSelectionChanged()),
442 SLOT(slotBncTextChanged()));
[3066]443
[3469]444 _cmbMethodComboBox = new QComboBox();
445 _cmbMethodComboBox->setEditable(false);
[3480]446 _cmbMethodComboBox->addItems(QString("Filter,Single-Epoch").split(","));
[3469]447 int im = _cmbMethodComboBox->findText(settings.value("cmbMethod").toString());
448 if (im != -1) {
449 _cmbMethodComboBox->setCurrentIndex(im);
450 }
451
[3813]452 int iRow = _cmbTable->rowCount();
453 if (iRow > 0) {
454 enableWidget(true, _cmbMethodComboBox);
455 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
[6664]456 _cmbAntexFile->setStyleSheet("background-color: white");
457 _cmbSamplSpinBox->setStyleSheet("background-color: white");
[3813]458 _cmbMaxresLineEdit->setEnabled(true);
[4179]459 _cmbSamplSpinBox->setEnabled(true);
[6172]460 _cmbAntexFile->setEnabled(true);
461 _cmbUseGlonass->setEnabled(true);
[3813]462 }
463 else {
464 enableWidget(false, _cmbMethodComboBox);
465 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
[6664]466 _cmbAntexFile->setStyleSheet("background-color: lightGray");
467 _cmbSamplSpinBox->setStyleSheet("background-color: lightGray");
[3813]468 _cmbMaxresLineEdit->setEnabled(false);
[4179]469 _cmbSamplSpinBox->setEnabled(false);
[6172]470 _cmbAntexFile->setEnabled(false);
471 _cmbUseGlonass->setEnabled(false);
[3813]472 }
473
[3164]474 // Upload Results
[3152]475 // -------------
[4111]476 _uploadTable = new QTableWidget(0,12);
477 _uploadTable->setHorizontalHeaderLabels(QString("Host, Port, Mount, Password, System, CoM, SP3 File, RNX File, PID, SID, IOD, bytes").split(","));
[3164]478 _uploadTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
479 _uploadTable->setSelectionBehavior(QAbstractItemView::SelectRows);
[4111]480 _uploadTable->horizontalHeader()->resizeSection( 0,13*ww);
481 _uploadTable->horizontalHeader()->resizeSection( 1, 5*ww);
482 _uploadTable->horizontalHeader()->resizeSection( 2, 6*ww);
483 _uploadTable->horizontalHeader()->resizeSection( 3, 8*ww);
484 _uploadTable->horizontalHeader()->resizeSection( 4,11*ww);
485 _uploadTable->horizontalHeader()->resizeSection( 5, 4*ww);
486 _uploadTable->horizontalHeader()->resizeSection( 6,15*ww);
487 _uploadTable->horizontalHeader()->resizeSection( 7,15*ww);
488 _uploadTable->horizontalHeader()->resizeSection( 8, 4*ww);
489 _uploadTable->horizontalHeader()->resizeSection( 9, 4*ww);
490 _uploadTable->horizontalHeader()->resizeSection(10, 4*ww);
491 _uploadTable->horizontalHeader()->resizeSection(11,12*ww);
[3164]492 _uploadTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
[4185]493 _uploadTable->horizontalHeader()->setStretchLastSection(true);
[3164]494 _uploadTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
[3152]495
[3585]496 connect(_uploadTable, SIGNAL(itemSelectionChanged()),
497 SLOT(slotBncTextChanged()));
498
[3164]499 QPushButton* addUploadRowButton = new QPushButton("Add Row");
[3193]500 QPushButton* delUploadRowButton = new QPushButton("Del Row");
501 QPushButton* setUploadTrafoButton = new QPushButton("Custom Trafo");
[3197]502 _uploadIntrComboBox = new QComboBox;
503 _uploadIntrComboBox->setEditable(false);
[3271]504 _uploadIntrComboBox->addItems(QString("1 day,1 hour, 30 min,15 min,10 min,5 min,2 min,1 min").split(","));
[3197]505 ii = _uploadIntrComboBox->findText(settings.value("uploadIntr").toString());
506 if (ii != -1) {
507 _uploadIntrComboBox->setCurrentIndex(ii);
508 }
[3152]509
[4172]510 _uploadSamplRtcmEphCorrSpinBox = new QSpinBox;
511 _uploadSamplRtcmEphCorrSpinBox->setMinimum(0);
512 _uploadSamplRtcmEphCorrSpinBox->setMaximum(60);
513 _uploadSamplRtcmEphCorrSpinBox->setSingleStep(5);
514 _uploadSamplRtcmEphCorrSpinBox->setMaximumWidth(9*ww);
515 _uploadSamplRtcmEphCorrSpinBox->setValue(settings.value("uploadSamplRtcmEphCorr").toInt());
516 _uploadSamplRtcmEphCorrSpinBox->setSuffix(" sec");
[3152]517
[4172]518 _uploadSamplSp3SpinBox = new QSpinBox;
519 _uploadSamplSp3SpinBox->setMinimum(0);
[4173]520 _uploadSamplSp3SpinBox->setMaximum(15);
521 _uploadSamplSp3SpinBox->setSingleStep(1);
[4172]522 _uploadSamplSp3SpinBox->setMaximumWidth(9*ww);
523 _uploadSamplSp3SpinBox->setValue(settings.value("uploadSamplSp3").toInt());
[4173]524 _uploadSamplSp3SpinBox->setSuffix(" min");
[4172]525
526 _uploadSamplClkRnxSpinBox = new QSpinBox;
527 _uploadSamplClkRnxSpinBox->setMinimum(0);
528 _uploadSamplClkRnxSpinBox->setMaximum(60);
529 _uploadSamplClkRnxSpinBox->setSingleStep(5);
530 _uploadSamplClkRnxSpinBox->setMaximumWidth(9*ww);
531 _uploadSamplClkRnxSpinBox->setValue(settings.value("uploadSamplClkRnx").toInt());
532 _uploadSamplClkRnxSpinBox->setSuffix(" sec");
533
[3813]534 int iRowT = _uploadTable->rowCount();
535 if (iRowT > 0) {
536 enableWidget(true, _uploadIntrComboBox);
[4172]537 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
538 enableWidget(true, _uploadSamplSp3SpinBox);
539 enableWidget(true, _uploadSamplClkRnxSpinBox);
[3813]540 }
541 else {
542 enableWidget(false, _uploadIntrComboBox);
[4172]543 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
544 enableWidget(false, _uploadSamplSp3SpinBox);
545 enableWidget(false, _uploadSamplClkRnxSpinBox);
[3813]546 }
547
[3240]548 // Upload RTCM3 Ephemeris
549 // ----------------------
550 _uploadEphHostLineEdit = new QLineEdit(settings.value("uploadEphHost").toString());
551 _uploadEphPortLineEdit = new QLineEdit(settings.value("uploadEphPort").toString());
552 _uploadEphPasswordLineEdit = new QLineEdit(settings.value("uploadEphPassword").toString());
553 _uploadEphPasswordLineEdit->setEchoMode(QLineEdit::PasswordEchoOnEdit);
554 _uploadEphMountpointLineEdit = new QLineEdit(settings.value("uploadEphMountpoint").toString());
555 _uploadEphSampleSpinBox = new QSpinBox;
[3271]556 _uploadEphSampleSpinBox->setMinimum(5);
[3240]557 _uploadEphSampleSpinBox->setMaximum(60);
558 _uploadEphSampleSpinBox->setSingleStep(5);
559 _uploadEphSampleSpinBox->setMaximumWidth(9*ww);
560 _uploadEphSampleSpinBox->setValue(settings.value("uploadEphSample").toInt());
561 _uploadEphSampleSpinBox->setSuffix(" sec");
[3245]562 _uploadEphBytesCounter = new bncBytesCounter;
[3240]563
[679]564 // Canvas with Editable Fields
565 // ---------------------------
566 _canvas = new QWidget;
567 setCentralWidget(_canvas);
[143]568
[1925]569 _aogroup = new QTabWidget();
[6661]570 _aogroup->setElideMode(Qt::ElideNone);
571 _aogroup->setUsesScrollButtons(true);
[679]572 QWidget* pgroup = new QWidget();
573 QWidget* ggroup = new QWidget();
574 QWidget* sgroup = new QWidget();
575 QWidget* egroup = new QWidget();
576 QWidget* agroup = new QWidget();
[934]577 QWidget* cgroup = new QWidget();
[679]578 QWidget* ogroup = new QWidget();
[1030]579 QWidget* rgroup = new QWidget();
[1327]580 QWidget* sergroup = new QWidget();
[5686]581 QWidget* pppGroup1 = new QWidget();
582 QWidget* pppGroup2 = new QWidget();
[5690]583 QWidget* pppGroup3 = new QWidget();
[5861]584 QWidget* pppGroup4 = new QWidget();
[3897]585 QWidget* reqcgroup = new QWidget();
[6332]586 QWidget* sp3CompGroup = new QWidget();
[2868]587 QWidget* cmbgroup = new QWidget();
[3164]588 QWidget* uploadgroup = new QWidget();
[3241]589 QWidget* uploadEphgroup = new QWidget();
[3356]590 _aogroup->addTab(pgroup,tr("Network"));
[1925]591 _aogroup->addTab(ggroup,tr("General"));
592 _aogroup->addTab(ogroup,tr("RINEX Observations"));
593 _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
[3897]594 _aogroup->addTab(reqcgroup,tr("RINEX Editing && QC"));
[6332]595 _aogroup->addTab(sp3CompGroup,tr("SP3 Comparison"));
[1925]596 _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
597 _aogroup->addTab(sgroup,tr("Feed Engine"));
598 _aogroup->addTab(sergroup,tr("Serial Output"));
599 _aogroup->addTab(agroup,tr("Outages"));
600 _aogroup->addTab(rgroup,tr("Miscellaneous"));
[5861]601 _aogroup->addTab(pppGroup1,tr("PPP (1)"));
602 _aogroup->addTab(pppGroup2,tr("PPP (2)"));
603 _aogroup->addTab(pppGroup3,tr("PPP (3)"));
[5865]604 _aogroup->addTab(pppGroup4,tr("PPP (4)"));
[5686]605
[2907]606#ifdef USE_COMBINATION
[4185]607 _aogroup->addTab(cmbgroup,tr("Combine Corrections"));
[2907]608#endif
[4185]609 _aogroup->addTab(uploadgroup,tr("Upload Corrections"));
610 _aogroup->addTab(uploadEphgroup,tr("Upload Ephemeris"));
[143]611
[1957]612 // Log Tab
613 // -------
[1925]614 _loggroup = new QTabWidget();
[1957]615 _loggroup->addTab(_log,tr("Log"));
616 _loggroup->addTab(_bncFigure,tr("Throughput"));
[1972]617 _loggroup->addTab(_bncFigureLate,tr("Latency"));
[2303]618 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
[1912]619
[3356]620 // Netowork (Proxy and SSL) Tab
621 // ----------------------------
[679]622 QGridLayout* pLayout = new QGridLayout;
[1409]623 pLayout->setColumnMinimumWidth(0,13*ww);
[1678]624 _proxyPortLineEdit->setMaximumWidth(9*ww);
625
[6650]626 pLayout->addWidget(new QLabel("Settings for proxy in protected networks and for SSL authorization, leave boxes blank if none."),0, 0, 1, 50);
[3766]627 pLayout->addWidget(new QLabel("Proxy host"), 1, 0);
628 pLayout->addWidget(_proxyHostLineEdit, 1, 1, 1,10);
629 pLayout->addWidget(new QLabel("Proxy port"), 2, 0);
630 pLayout->addWidget(_proxyPortLineEdit, 2, 1);
[6633]631 pLayout->addWidget(new QLabel("Path to SSL certificates"), 3, 0);
[3766]632 pLayout->addWidget(_sslCaCertPathLineEdit, 3, 1, 1,10);
[3778]633 pLayout->addWidget(new QLabel("Default: " + bncSslConfig::defaultPath()), 3,11, 1,20);
[6633]634 pLayout->addWidget(new QLabel("Ignore SSL authorization errors"), 4, 0);
[3766]635 pLayout->addWidget(_ignoreSslErrorsCheckBox, 4, 1, 1,10);
[6637]636 pLayout->addWidget(new QLabel(""), 5, 1);
637 pLayout->setRowStretch(6, 999);
638
[679]639 pgroup->setLayout(pLayout);
[1439]640
[1678]641 // General Tab
642 // -----------
[679]643 QGridLayout* gLayout = new QGridLayout;
[1042]644 gLayout->setColumnMinimumWidth(0,14*ww);
[1678]645 _onTheFlyComboBox->setMaximumWidth(9*ww);
646
[3766]647 gLayout->addWidget(new QLabel("General settings for logfile, file handling, configuration on-the-fly, and auto-start."),0, 0, 1, 50);
648 gLayout->addWidget(new QLabel("Logfile (full path)"), 1, 0);
[6662]649 gLayout->addWidget(_logFileLineEdit, 1, 1, 1,20);
[3766]650 gLayout->addWidget(new QLabel("Append files"), 2, 0);
651 gLayout->addWidget(_rnxAppendCheckBox, 2, 1);
652 gLayout->addWidget(new QLabel("Reread configuration"), 3, 0);
653 gLayout->addWidget(_onTheFlyComboBox, 3, 1);
654 gLayout->addWidget(new QLabel("Auto start"), 4, 0);
655 gLayout->addWidget(_autoStartCheckBox, 4, 1);
656 gLayout->addWidget(new QLabel("Raw output file (full path)"), 5, 0);
[6662]657 gLayout->addWidget(_rawOutFileLineEdit, 5, 1, 1,20);
[6637]658 gLayout->addWidget(new QLabel(""), 6, 1);
659 gLayout->setRowStretch(7, 999);
660
[679]661 ggroup->setLayout(gLayout);
[533]662
[1678]663 // RINEX Observations
664 // ------------------
665 QGridLayout* oLayout = new QGridLayout;
666 oLayout->setColumnMinimumWidth(0,14*ww);
667 _rnxIntrComboBox->setMaximumWidth(9*ww);
[6649]668//_rnxSamplSpinBox->setMaximumWidth(9*ww);
[143]669
[3766]670 oLayout->addWidget(new QLabel("Saving RINEX observation files."),0, 0, 1,50);
671 oLayout->addWidget(new QLabel("Directory"), 1, 0);
[6662]672 oLayout->addWidget(_rnxPathLineEdit, 1, 1, 1, 15);
[3766]673 oLayout->addWidget(new QLabel("Interval"), 2, 0);
674 oLayout->addWidget(_rnxIntrComboBox, 2, 1);
675 oLayout->addWidget(new QLabel(" Sampling"), 2, 2, Qt::AlignRight);
676 oLayout->addWidget(_rnxSamplSpinBox, 2, 3, Qt::AlignLeft);
677 oLayout->addWidget(new QLabel("Skeleton extension"), 3, 0);
[6649]678 oLayout->addWidget(_rnxSkelLineEdit, 3, 1, Qt::AlignLeft);
[3766]679 oLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
[6662]680 oLayout->addWidget(_rnxScrpLineEdit, 4, 1, 1, 15);
[6266]681 oLayout->addWidget(new QLabel("Version 2"), 5, 0);
[6649]682 oLayout->addWidget(_rnxV2Priority, 5, 1, 1, 2);
683 oLayout->addWidget(new QLabel(" Signal priority"), 5, 3);
[6266]684 oLayout->addWidget(new QLabel("Version 3"), 6, 0);
685 oLayout->addWidget(_rnxV3CheckBox, 6, 1);
[6637]686 oLayout->addWidget(new QLabel(""), 7, 1);
687 oLayout->setRowStretch(8, 999);
688
[1678]689 ogroup->setLayout(oLayout);
690
[1439]691 // RINEX Ephemeris
692 // ---------------
[679]693 QGridLayout* eLayout = new QGridLayout;
[1042]694 eLayout->setColumnMinimumWidth(0,14*ww);
[1678]695 _ephIntrComboBox->setMaximumWidth(9*ww);
696 _outEphPortLineEdit->setMaximumWidth(9*ww);
697
[6655]698 eLayout->addWidget(new QLabel("Saving RINEX navigation files and ephemeris output through IP port."),0,0,1,70);
[3766]699 eLayout->addWidget(new QLabel("Directory"), 1, 0);
700 eLayout->addWidget(_ephPathLineEdit, 1, 1, 1,30);
701 eLayout->addWidget(new QLabel("Interval"), 2, 0);
702 eLayout->addWidget(_ephIntrComboBox, 2, 1);
703 eLayout->addWidget(new QLabel("Port"), 3, 0);
704 eLayout->addWidget(_outEphPortLineEdit, 3, 1);
705 eLayout->addWidget(new QLabel("Version 3"), 4, 0);
706 eLayout->addWidget(_ephV3CheckBox, 4, 1);
[6650]707 eLayout->setRowStretch(5, 999);
[6637]708
[679]709 egroup->setLayout(eLayout);
[560]710
[1454]711
[1682]712 // Broadcast Corrections
[1439]713 // ---------------------
[934]714 QGridLayout* cLayout = new QGridLayout;
[1042]715 cLayout->setColumnMinimumWidth(0,14*ww);
[1678]716 _corrIntrComboBox->setMaximumWidth(9*ww);
717 _corrPortLineEdit->setMaximumWidth(9*ww);
718
[6637]719 cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port."),0,0,1,70);
[3766]720 cLayout->addWidget(new QLabel("Directory, ASCII"), 1, 0);
[6662]721 cLayout->addWidget(_corrPathLineEdit, 1, 1, 1,30);
[3766]722 cLayout->addWidget(new QLabel("Interval"), 2, 0);
723 cLayout->addWidget(_corrIntrComboBox, 2, 1);
724 cLayout->addWidget(new QLabel("Port"), 3, 0);
725 cLayout->addWidget(_corrPortLineEdit, 3, 1);
[6637]726 cLayout->addWidget(new QLabel(""), 4, 1);
727 cLayout->setRowStretch(7, 999);
[934]728 cgroup->setLayout(cLayout);
729
[1678]730 // Feed Engine
731 // -----------
732 QGridLayout* sLayout = new QGridLayout;
733 sLayout->setColumnMinimumWidth(0,14*ww);
734 _outPortLineEdit->setMaximumWidth(9*ww);
735 _waitTimeSpinBox->setMaximumWidth(9*ww);
736 _binSamplSpinBox->setMaximumWidth(9*ww);
737 _outUPortLineEdit->setMaximumWidth(9*ww);
738
[4040]739 sLayout->addWidget(new QLabel("Output decoded observations in ASCII format to feed a real-time GNSS network engine."),0,0,1,50);
[6655]740 sLayout->addWidget(new QLabel("Port"), 1, 0);
741 sLayout->addWidget(_outPortLineEdit, 1, 1);
742 sLayout->addWidget(new QLabel(" Wait for full obs epoch"), 1, 2, Qt::AlignRight);
743 sLayout->addWidget(_waitTimeSpinBox, 1, 3, Qt::AlignLeft);
744 sLayout->addWidget(new QLabel("Sampling"), 2, 0);
745 sLayout->addWidget(_binSamplSpinBox, 2, 1, Qt::AlignLeft);
746 sLayout->addWidget(new QLabel("File (full path)"), 3, 0);
[6662]747 sLayout->addWidget(_outFileLineEdit, 3, 1, 1, 10);
[6655]748 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 4, 0);
749 sLayout->addWidget(_outUPortLineEdit, 4, 1);
750 sLayout->addWidget(new QLabel(""), 5, 1);
[6637]751 sLayout->setRowStretch(6, 999);
752
[1678]753 sgroup->setLayout(sLayout);
754
[1746]755 // Serial Output
756 // -------------
[1327]757 QGridLayout* serLayout = new QGridLayout;
[1339]758 serLayout->setColumnMinimumWidth(0,14*ww);
[1678]759 _serialBaudRateComboBox->setMaximumWidth(9*ww);
760 _serialFlowControlComboBox->setMaximumWidth(11*ww);
761 _serialDataBitsComboBox->setMaximumWidth(5*ww);
762 _serialParityComboBox->setMaximumWidth(9*ww);
763 _serialStopBitsComboBox->setMaximumWidth(5*ww);
764 _serialAutoNMEAComboBox->setMaximumWidth(9*ww);
[1595]765 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
[1678]766
[3766]767 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver."),0,0,1,30);
768 serLayout->addWidget(new QLabel("Mountpoint"), 1, 0, Qt::AlignLeft);
769 serLayout->addWidget(_serialMountPointLineEdit, 1, 1, 1, 2);
770 serLayout->addWidget(new QLabel("Port name"), 2, 0, Qt::AlignLeft);
771 serLayout->addWidget(_serialPortNameLineEdit, 2, 1, 1, 2);
772 serLayout->addWidget(new QLabel("Baud rate"), 3, 0, Qt::AlignLeft);
773 serLayout->addWidget(_serialBaudRateComboBox, 3, 1);
774 serLayout->addWidget(new QLabel("Flow control"), 3, 2, Qt::AlignRight);
775 serLayout->addWidget(_serialFlowControlComboBox, 3, 3);
776 serLayout->addWidget(new QLabel("Data bits"), 4, 0, Qt::AlignLeft);
777 serLayout->addWidget(_serialDataBitsComboBox, 4, 1);
778 serLayout->addWidget(new QLabel("Parity"), 4, 2, Qt::AlignRight);
779 serLayout->addWidget(_serialParityComboBox, 4, 3);
780 serLayout->addWidget(new QLabel(" Stop bits"), 4, 4, Qt::AlignRight);
781 serLayout->addWidget(_serialStopBitsComboBox, 4, 5);
782 serLayout->addWidget(new QLabel("NMEA"), 5, 0);
783 serLayout->addWidget(_serialAutoNMEAComboBox, 5, 1);
784 serLayout->addWidget(new QLabel(" File (full path)"), 5, 2, Qt::AlignRight);
[6663]785 serLayout->addWidget(_serialFileNMEALineEdit, 5, 3, 1,10);
786 serLayout->addWidget(new QLabel("Height"), 5,14, Qt::AlignRight); // 20
787 serLayout->addWidget(_serialHeightNMEALineEdit, 5,15, 1,11);
[6637]788 serLayout->addWidget(new QLabel(""), 6, 1);
789 serLayout->setRowStretch(7, 999);
[1329]790
[1327]791 sergroup->setLayout(serLayout);
792
[1678]793 // Outages
794 // -------
795 QGridLayout* aLayout = new QGridLayout;
796 aLayout->setColumnMinimumWidth(0,14*ww);
797 _obsRateComboBox->setMaximumWidth(9*ww);
798 _adviseFailSpinBox->setMaximumWidth(9*ww);
799 _adviseRecoSpinBox->setMaximumWidth(9*ww);
800
[3766]801 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes."),0,0,1,50,Qt::AlignLeft);
802 aLayout->addWidget(new QLabel("Observation rate"), 1, 0);
803 aLayout->addWidget(_obsRateComboBox, 1, 1);
804 aLayout->addWidget(new QLabel("Failure threshold"), 2, 0);
805 aLayout->addWidget(_adviseFailSpinBox, 2, 1);
806 aLayout->addWidget(new QLabel("Recovery threshold"), 3, 0);
807 aLayout->addWidget(_adviseRecoSpinBox, 3, 1);
808 aLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
[6655]809 aLayout->addWidget(_adviseScriptLineEdit, 4, 1, 1,20);
[6637]810 aLayout->addWidget(new QLabel(""), 5, 1);
811 aLayout->setRowStretch(6, 999);
812
[1678]813 agroup->setLayout(aLayout);
814
815 // Miscellaneous
816 // -------------
817 QGridLayout* rLayout = new QGridLayout;
818 rLayout->setColumnMinimumWidth(0,14*ww);
819 _perfIntrComboBox->setMaximumWidth(9*ww);
[5644]820 _miscPortLineEdit->setMaximumWidth(9*ww);
[1678]821
[6650]822 rLayout->addWidget(new QLabel("Log latencies or scan RTCM streams for message types and antenna information or output raw data through TCP/IP port."),0, 0,1,50);
[3766]823 rLayout->addWidget(new QLabel("Mountpoint"), 1, 0);
[6655]824 rLayout->addWidget(_miscMountLineEdit, 1, 1, 1, 7);
[3766]825 rLayout->addWidget(new QLabel("Log latency"), 2, 0);
826 rLayout->addWidget(_perfIntrComboBox, 2, 1);
827 rLayout->addWidget(new QLabel("Scan RTCM"), 3, 0);
828 rLayout->addWidget(_scanRTCMCheckBox, 3, 1);
[5644]829 rLayout->addWidget(new QLabel("Port"), 4, 0);
830 rLayout->addWidget(_miscPortLineEdit, 4, 1);
[6637]831 rLayout->addWidget(new QLabel(""), 5, 1);
832 rLayout->setRowStretch(6, 999);
833
[1678]834 rgroup->setLayout(rLayout);
835
[5861]836 // PPP
837 // ---
[6660]838 _pppWidgets._nmeaPort->setMaximumWidth(8*ww);
839 _pppWidgets._dataSource->setMaximumWidth(20*ww);
840 _pppWidgets._corrMount->setMaximumWidth(20*ww);
841
[5861]842 QGridLayout* pppLayout1 = new QGridLayout();
[3731]843 int ir = 0;
[6637]844 pppLayout1->addWidget(new QLabel("Precise Point Positioning - Input and Output"), ir, 0, 1, 7, Qt::AlignLeft);
[5687]845 ++ir;
[6660]846 pppLayout1->addWidget(new QLabel("Data source"), ir, 0);
847 pppLayout1->addWidget(_pppWidgets._dataSource, ir, 1);
848//pppLayout1->addItem(new QSpacerItem(4*ww, 0), ir, 2);
849 pppLayout1->addWidget(new QLabel(" RINEX observations"), ir, 3);
850 pppLayout1->addWidget(_pppWidgets._rinexObs, ir, 4);
[5687]851 ++ir;
[6660]852 pppLayout1->addWidget(new QLabel(" RINEX orbits"), ir, 3);
853 pppLayout1->addWidget(_pppWidgets._rinexNav, ir, 4);
[5687]854 ++ir;
[6660]855 pppLayout1->addWidget(new QLabel("Corrections"), ir, 0);
856 pppLayout1->addWidget(_pppWidgets._corrMount, ir, 1);
857 pppLayout1->addWidget(new QLabel(" Corrections"), ir, 3);
858 pppLayout1->addWidget(_pppWidgets._corrFile, ir, 4);
[5687]859 ++ir;
[6660]860 pppLayout1->addWidget(new QLabel("Input:"), ir, 0);
861 pppLayout1->addWidget(new QLabel(" Output:"), ir, 3);
[5687]862 ++ir;
[6660]863 pppLayout1->addWidget(new QLabel("Coordinates"), ir, 0);
864 pppLayout1->addWidget(_pppWidgets._crdFile, ir, 1);
865 pppLayout1->addWidget(new QLabel(" Logfile"), ir, 3);
866 pppLayout1->addWidget(_pppWidgets._logFile, ir, 4);
[5687]867 ++ir;
[6662]868 pppLayout1->addWidget(new QLabel("ANTEX file"), ir, 0);
[6660]869 pppLayout1->addWidget(_pppWidgets._antexFile, ir, 1);
[6607]870
[6660]871 pppLayout1->addWidget(new QLabel(" NMEA file"), ir, 3);
872 pppLayout1->addWidget(_pppWidgets._nmeaFile, ir, 4);
873 pppLayout1->addWidget(new QLabel(" Port"), ir, 5);
874 pppLayout1->addWidget(_pppWidgets._nmeaPort, ir, 6);
[6607]875 ++ir;
[6660]876 pppLayout1->addWidget(new QLabel(" SNX TRO file"), ir, 3);
877 pppLayout1->addWidget(_pppWidgets._snxtroFile, ir, 4);
878 pppLayout1->addWidget(new QLabel(" Sampling"), ir, 5);
879 pppLayout1->addWidget(_pppWidgets._snxtroSampl, ir, 6);
[6662]880 pppLayout1->addWidget(new QLabel(""), ir, 7);
[6637]881 ++ir;
[6662]882 ++ir;
[6637]883 pppLayout1->setRowStretch(ir, 999);
[5964]884
[6637]885
[5686]886 pppGroup1->setLayout(pppLayout1);
887
[5689]888 QVBoxLayout* pppLayout2 = new QVBoxLayout();
[6637]889 pppLayout2->addWidget(new QLabel("Precise Point Positioning - Processed Stations"));
[5689]890 pppLayout2->addWidget(_pppWidgets._staTable, 99);
[5704]891 QHBoxLayout* pppLayout2sub = new QHBoxLayout();
892 pppLayout2sub->addWidget(_pppWidgets._addStaButton);
893 pppLayout2sub->addWidget(_pppWidgets._delStaButton);
[5705]894 pppLayout2sub->addStretch(99);
895
[5704]896 pppLayout2->addLayout(pppLayout2sub);
[5686]897
898 pppGroup2->setLayout(pppLayout2);
899
[5690]900 QGridLayout* pppLayout3 = new QGridLayout();
901 ir = 0;
[6637]902 pppLayout3->addWidget(new QLabel("Precise Point Positioning - Options"), ir, 0, 1, 2, Qt::AlignLeft);
[5690]903 ++ir;
904 pppLayout3->addWidget(new QLabel("GPS LCs"), ir, 0, Qt::AlignLeft);
905 pppLayout3->addWidget(_pppWidgets._lcGPS, ir, 1);
[5965]906 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 2);
[5690]907 pppLayout3->addWidget(new QLabel("Sigma C1"), ir, 3, Qt::AlignLeft);
908 pppLayout3->addWidget(_pppWidgets._sigmaC1, ir, 4); _pppWidgets._sigmaC1->setMaximumWidth(8*ww);
[5965]909 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 5);
910 pppLayout3->addWidget(new QLabel("Sigma L1"), ir, 6, Qt::AlignLeft);
911 pppLayout3->addWidget(_pppWidgets._sigmaL1, ir, 7); _pppWidgets._sigmaL1->setMaximumWidth(8*ww);
[5690]912 ++ir;
913 pppLayout3->addWidget(new QLabel("GLONASS LCs"), ir, 0, Qt::AlignLeft);
914 pppLayout3->addWidget(_pppWidgets._lcGLONASS, ir, 1);
[5963]915 pppLayout3->addWidget(new QLabel("Max Res C1"), ir, 3, Qt::AlignLeft);
916 pppLayout3->addWidget(_pppWidgets._maxResC1, ir, 4); _pppWidgets._maxResC1->setMaximumWidth(8*ww);
[5965]917 pppLayout3->addWidget(new QLabel("Max Res L1"), ir, 6, Qt::AlignLeft);
918 pppLayout3->addWidget(_pppWidgets._maxResL1, ir, 7); _pppWidgets._maxResL1->setMaximumWidth(8*ww);
[5690]919 ++ir;
920 pppLayout3->addWidget(new QLabel("Galileo LCs"), ir, 0, Qt::AlignLeft);
921 pppLayout3->addWidget(_pppWidgets._lcGalileo, ir, 1);
[5963]922 pppLayout3->addWidget(new QLabel("Ele Wgt Code"), ir, 3, Qt::AlignLeft);
923 pppLayout3->addWidget(_pppWidgets._eleWgtCode, ir, 4);
[5965]924 pppLayout3->addWidget(new QLabel("Ele Wgt Phase"), ir, 6, Qt::AlignLeft);
925 pppLayout3->addWidget(_pppWidgets._eleWgtPhase, ir, 7);
[5690]926 ++ir;
927 pppLayout3->addWidget(new QLabel("Wait for corrections"), ir, 0, Qt::AlignLeft);
928 pppLayout3->addWidget(_pppWidgets._corrWaitTime, ir, 1);
[5963]929 pppLayout3->addWidget(new QLabel("Min # of Obs"), ir, 3, Qt::AlignLeft);
930 pppLayout3->addWidget(_pppWidgets._minObs, ir, 4);
[5965]931 pppLayout3->addWidget(new QLabel("Min Elevation"), ir, 6, Qt::AlignLeft);
932 pppLayout3->addWidget(_pppWidgets._minEle, ir, 7);
[5691]933 ++ir;
[5968]934 pppLayout3->addWidget(new QLabel("Seeding (seconds)"), ir, 0, Qt::AlignLeft);
[5963]935 pppLayout3->addWidget(_pppWidgets._seedingTime, ir, 1);
936 ++ir;
[5965]937 pppLayout3->addWidget(new QLabel(""), ir, 8);
938 pppLayout3->setColumnStretch(8, 999);
[6637]939 ++ir;
940 pppLayout3->addWidget(new QLabel(""), ir, 1);
941 pppLayout3->setRowStretch(ir, 999);
[5690]942
943 pppGroup3->setLayout(pppLayout3);
944
[5861]945 // ------------------------
[5895]946 connect(_pppWidgets._mapWinButton, SIGNAL(clicked()), SLOT(slotMapPPP()));
[6639]947 _pppWidgets._mapSpeedSlider->setMinimumWidth(28*ww);
[5861]948
[6639]949 QGridLayout* pppLayout4 = new QGridLayout();
950 ir = 0;
951 pppLayout4->addWidget(new QLabel("Precise Point Positioning - Plots"), ir, 0, 1, 50, Qt::AlignLeft);
952 ++ir;
953 pppLayout4->addWidget(new QLabel("PPP Plot"), ir, 0, Qt::AlignLeft);
954 pppLayout4->addWidget(_pppWidgets._plotCoordinates, ir, 1, Qt::AlignLeft);
[6641]955 pppLayout4->addWidget(new QLabel("Mountpoint"), ir, 2, 1, 10, Qt::AlignLeft);
[6639]956 ++ir;
957 pppLayout4->addWidget(new QLabel("Track map"), ir, 0, Qt::AlignLeft);
958 pppLayout4->addWidget(_pppWidgets._mapWinButton, ir, 1, Qt::AlignLeft);
959 pppLayout4->addWidget(new QLabel("OSM"), ir, 2, Qt::AlignLeft);
960 pppLayout4->addWidget(_pppWidgets._useOpenStreetMap, ir, 3, Qt::AlignLeft);
961 pppLayout4->addWidget(new QLabel("Google"), ir, 3, Qt::AlignRight);
962 pppLayout4->addWidget(_pppWidgets._useGoogleMap, ir, 4, Qt::AlignLeft);
963 ++ir;
[6647]964 pppLayout4->addWidget(new QLabel("Dot-properties"), ir, 0, Qt::AlignLeft);
[6639]965 pppLayout4->addWidget(_pppWidgets._mapWinDotSize, ir, 1, Qt::AlignLeft);
966 pppLayout4->addWidget(new QLabel("Size "), ir, 2, Qt::AlignLeft);
967 pppLayout4->addWidget(_pppWidgets._mapWinDotColor, ir, 3, Qt::AlignLeft);
968 pppLayout4->addWidget(new QLabel("Color"), ir, 4, Qt::AlignLeft);
969 ++ir;
[6642]970 pppLayout4->addWidget(new QLabel("Post-processing speed"), ir, 0, Qt::AlignLeft);
[6639]971 pppLayout4->addWidget(_pppWidgets._mapSpeedSlider, ir, 1, 1, 20, Qt::AlignLeft);
972 ++ir;
973 pppLayout4->addWidget(new QLabel(""), ir, 1);
974 pppLayout4->setRowStretch(ir, 999);
[5861]975
976 pppGroup4->setLayout(pppLayout4);
977
[3897]978 // Reqc Processing
[3729]979 // ---------------
[3897]980 _reqcActionComboBox = new QComboBox();
981 _reqcActionComboBox->setEditable(false);
982 _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
[5861]983 int ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
[3731]984 if (ik != -1) {
[3897]985 _reqcActionComboBox->setCurrentIndex(ik);
[3731]986 }
[3897]987 connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
[3739]988 this, SLOT(slotBncTextChanged()));
[3729]989
[3897]990 QGridLayout* reqcLayout = new QGridLayout;
991 _reqcActionComboBox->setMinimumWidth(15*ww);
[6663]992 _reqcActionComboBox->setMaximumWidth(20*ww);
[3612]993
[3897]994 _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
995 _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
996 _reqcObsFileChooser->setWhatsThis(tr("Specify the full path to an observation file in RINEX v2 or v3 format."));
[3612]997
[3897]998 _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
999 _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
1000 _reqcNavFileChooser->setWhatsThis(tr("Specify the full path to a RINEX v2 or v3 navigation file."));
[3602]1001
[3897]1002 _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
[4530]1003 _reqcOutObsLineEdit->setWhatsThis(tr("Specify the full path to a RINEX observation output file."));
[2473]1004
[3897]1005 _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
[4530]1006 _reqcOutNavLineEdit->setWhatsThis(tr("Specify the full path to a RINEX navigation output file."));
[3823]1007
[3897]1008 _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
[4530]1009 _reqcOutLogLineEdit->setWhatsThis(tr("Specify the full path to a logfile."));
[3823]1010
[4449]1011 _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
[4530]1012 _reqcPlotDirLineEdit->setWhatsThis(tr("Specify the directory name for saving plots."));
[4449]1013
[6436]1014 _reqcSkyPlotSignals = new QLineEdit(settings.value("reqcSkyPlotSignals").toString());
[6411]1015 connect(_reqcSkyPlotSignals, SIGNAL(textChanged(const QString &)),
[6318]1016 this, SLOT(slotBncTextChanged()));
[5144]1017
[6299]1018 _reqcLogSummaryOnly = new QCheckBox();
1019 _reqcLogSummaryOnly->setCheckState(Qt::CheckState(settings.value("reqcLogSummaryOnly").toInt()));
1020
[3738]1021 ir = 0;
[6663]1022 reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check."),ir, 0, 1, 12);
[3768]1023 ++ir;
[6650]1024 reqcLayout->addWidget(new QLabel("Action"), ir, 0);
1025 reqcLayout->addWidget(_reqcActionComboBox, ir, 1);
[3897]1026 _reqcEditOptionButton = new QPushButton("Set Edit Options");
[6650]1027 _reqcEditOptionButton->setMinimumWidth(15*ww);
[6663]1028 _reqcEditOptionButton->setMaximumWidth(20*ww);
[6650]1029
1030 reqcLayout->addWidget(_reqcEditOptionButton, ir, 3);
[3738]1031 ++ir;
[6650]1032 reqcLayout->addWidget(new QLabel("Input files (full path)"), ir, 0);
1033 reqcLayout->addWidget(_reqcObsFileChooser, ir, 1);
1034 reqcLayout->addWidget(new QLabel(" Obs"), ir, 2);
1035 reqcLayout->addWidget(_reqcNavFileChooser, ir, 3);
1036 reqcLayout->addWidget(new QLabel(" Nav"), ir, 4);
[3738]1037 ++ir;
[6650]1038 reqcLayout->addWidget(new QLabel("Output files (full path)"), ir, 0);
1039 reqcLayout->addWidget(_reqcOutObsLineEdit, ir, 1);
1040 reqcLayout->addWidget(new QLabel(" Obs"), ir, 2);
1041 reqcLayout->addWidget(_reqcOutNavLineEdit, ir, 3);
1042 reqcLayout->addWidget(new QLabel(" Nav"), ir, 4);
[3768]1043 ++ir;
[6650]1044 reqcLayout->addWidget(new QLabel("Logfile"), ir, 0);
1045 reqcLayout->addWidget(_reqcOutLogLineEdit, ir, 1);
1046 reqcLayout->addWidget(new QLabel(" Summary only"), ir, 2);
1047 reqcLayout->addWidget(_reqcLogSummaryOnly, ir, 3);
[3768]1048 ++ir;
[6650]1049 reqcLayout->addWidget(new QLabel("Plots for signals"), ir, 0);
1050 reqcLayout->addWidget(_reqcSkyPlotSignals, ir, 1);
[6411]1051 ++ir;
[6650]1052 reqcLayout->addWidget(new QLabel("Directory for plots"), ir, 0);
1053 reqcLayout->addWidget(_reqcPlotDirLineEdit, ir, 1);
[4449]1054 ++ir;
[3897]1055 reqcLayout->setRowStretch(ir, 999);
[2876]1056
[3897]1057 reqcLayout->setColumnMinimumWidth(2, 8*ww);
1058 reqcLayout->setColumnMinimumWidth(4, 8*ww);
[3823]1059
[3897]1060 reqcgroup->setLayout(reqcLayout);
[3731]1061
[3897]1062 connect(_reqcEditOptionButton, SIGNAL(clicked()),
1063 this, SLOT(slotReqcEditOption()));
[3740]1064
[6332]1065 QGridLayout* sp3CompLayout = new QGridLayout;
1066
1067 _sp3CompFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1068 _sp3CompFileChooser->setFileName(settings.value("sp3CompFile").toString());
[6636]1069 _sp3CompFileChooser->setWhatsThis(tr("Specify the full path to two files with orbits and clocks in SP3 format, separate them by comma."));
[6332]1070 _sp3CompFileChooser->setMinimumWidth(15*ww);
[6662]1071 _sp3CompFileChooser->setMaximumWidth(40*ww);
[6332]1072
[6430]1073 _sp3CompExclude = new QLineEdit(settings.value("sp3CompExclude").toString());
1074 _sp3CompExclude->setMinimumWidth(15*ww);
1075 _sp3CompExclude->setMaximumWidth(15*ww);
[6636]1076 _sp3CompExclude->setWhatsThis(tr("<p>Specify satellites to exclude them from orbit and clock comparision. Example:<p>G04,G31,R</p><p>This excludes GPS satellites RPN 4 and 31 as well as all GLONASS satellites from the comparision.</p><p>Default is an empty option field, meaning that no satellite is excluded from the comparison.</p>"));
[6430]1077
[6332]1078 _sp3CompLogLineEdit = new QLineEdit(settings.value("sp3CompOutLogFile").toString());
1079 _sp3CompLogLineEdit->setWhatsThis(tr("Specify the full path to a logfile."));
1080 _sp3CompLogLineEdit->setMinimumWidth(15*ww);
1081 _sp3CompLogLineEdit->setMaximumWidth(15*ww);
1082
1083 ir = 0;
[6650]1084 sp3CompLayout->addWidget(new QLabel("Orbit and clock comparison."), ir, 0, 1, 40);
[6332]1085 ++ir;
1086 sp3CompLayout->addWidget(new QLabel("Input SP3 files (full path)"), ir, 0, Qt::AlignLeft);
[6636]1087 sp3CompLayout->addWidget(_sp3CompFileChooser, ir, 1, 1, 20);
[6332]1088 ++ir;
[6633]1089 sp3CompLayout->addWidget(new QLabel("Exclude satellites"), ir, 0, Qt::AlignLeft);
[6430]1090 sp3CompLayout->addWidget(_sp3CompExclude, ir, 1, Qt::AlignRight);
1091 ++ir;
[6633]1092 sp3CompLayout->addWidget(new QLabel("Logfile"), ir, 0, Qt::AlignLeft);
[6332]1093 sp3CompLayout->addWidget(_sp3CompLogLineEdit, ir, 1, Qt::AlignRight);
1094 ++ir;
[6637]1095 sp3CompLayout->addWidget(new QLabel(""), ir, 1);
1096 ++ir;
[6332]1097 sp3CompLayout->setRowStretch(ir, 999);
1098
1099 sp3CompLayout->setColumnMinimumWidth(2, 8*ww);
1100 sp3CompLayout->setColumnMinimumWidth(4, 8*ww);
1101
1102 sp3CompGroup->setLayout(sp3CompLayout);
1103
[6648]1104 connect(_sp3CompFileChooser, SIGNAL(fileNameChanged(const QString &)),
1105 this, SLOT(slotBncTextChanged()));
1106
[4185]1107 // Combine Corrections
1108 // -------------------
[2868]1109 QGridLayout* cmbLayout = new QGridLayout;
1110
[3731]1111 populateCmbTable();
[6662]1112 cmbLayout->addWidget(_cmbTable, 0, 0, 7, 3);
1113 cmbLayout->addWidget(new QLabel(" Combine Broadcast Correction streams."), 1, 6, 1, 10);
1114 cmbLayout->addWidget(addCmbRowButton, 2, 6);
1115 cmbLayout->addWidget(delCmbRowButton, 2, 7);
1116 cmbLayout->addWidget(new QLabel("Method"), 3, 6, Qt::AlignRight);
1117 cmbLayout->addWidget(_cmbMethodComboBox, 3, 7, Qt::AlignRight);
1118 cmbLayout->addWidget(new QLabel(" Maximal residuum"), 4, 6, Qt::AlignRight);
1119 cmbLayout->addWidget(_cmbMaxresLineEdit, 4, 7, Qt::AlignRight);
1120 cmbLayout->addWidget(new QLabel("ANTEX file"), 4, 8, Qt::AlignRight);
1121 cmbLayout->addWidget(_cmbAntexFile, 4, 9, 1, 7);
1122 cmbLayout->addWidget(new QLabel("Sampling"), 5, 6, Qt::AlignRight);
1123 cmbLayout->addWidget(_cmbSamplSpinBox, 5, 7, Qt::AlignRight);
1124 cmbLayout->addWidget(new QLabel(" Use GLONASS"), 5, 8, Qt::AlignRight);
1125 cmbLayout->addWidget(_cmbUseGlonass, 5, 9);
1126 cmbLayout->setRowStretch(6, 999);
[3729]1127
[2869]1128 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1129 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
[2868]1130
1131 cmbgroup->setLayout(cmbLayout);
1132
[3241]1133 // Upload Layout (Clocks)
1134 // ----------------------
[3193]1135 QGridLayout* uploadHlpLayout = new QGridLayout();
[3152]1136
[3164]1137 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1138 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1139 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
[3160]1140
[4175]1141 uploadHlpLayout->addWidget(addUploadRowButton, 0, 0);
1142 uploadHlpLayout->addWidget(delUploadRowButton, 0, 1);
1143 uploadHlpLayout->addWidget(new QLabel("Interval"), 0, 2, Qt::AlignRight);
1144 uploadHlpLayout->addWidget(_uploadIntrComboBox, 0, 3);
1145 uploadHlpLayout->addWidget(new QLabel(" Sampling: Orb"), 0, 4, Qt::AlignRight);
1146 uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox, 0, 5);
1147 uploadHlpLayout->addWidget(new QLabel("SP3"), 0, 6, Qt::AlignRight);
1148 uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox, 0, 7);
1149 uploadHlpLayout->addWidget(new QLabel("RNX"), 0, 8, Qt::AlignRight);
1150 uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox, 0, 9);
1151 uploadHlpLayout->addWidget(setUploadTrafoButton, 0,10);
[3197]1152
[3193]1153 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1154 populateUploadTable();
[3767]1155
[6633]1156 uploadLayout->addWidget(new QLabel("Upload RTCM Version 3 Broadcast Corrections to caster."));
[3193]1157 uploadLayout->addWidget(_uploadTable);
1158 uploadLayout->addLayout(uploadHlpLayout);
[3152]1159
[3164]1160 uploadgroup->setLayout(uploadLayout);
[3152]1161
[3241]1162 // Upload Layout (Ephemeris)
1163 // -------------------------
1164 QGridLayout* uploadLayoutEph = new QGridLayout;
1165
1166 uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1167 _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1168 _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1169 _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1170
[3779]1171 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster."), 0, 0, 1, 50);
[3768]1172 uploadLayoutEph->addWidget(new QLabel("Host"), 1, 0);
1173 uploadLayoutEph->addWidget(_uploadEphHostLineEdit, 1, 1, 1, 3);
1174 uploadLayoutEph->addWidget(new QLabel(" Port"), 1, 4, Qt::AlignRight);
1175 uploadLayoutEph->addWidget(_uploadEphPortLineEdit, 1, 5, 1, 1);
1176 uploadLayoutEph->addWidget(new QLabel("Mountpoint "), 2, 0);
1177 uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit, 2, 1);
1178 uploadLayoutEph->addWidget(new QLabel(" Password"), 2, 2, Qt::AlignRight);
1179 uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit, 2, 3);
1180 uploadLayoutEph->addWidget(new QLabel("Sampling"), 3, 0);
1181 uploadLayoutEph->addWidget(_uploadEphSampleSpinBox, 3, 1);
1182 uploadLayoutEph->addWidget(new QLabel("Uploaded"), 4, 0);
1183 uploadLayoutEph->addWidget(_uploadEphBytesCounter, 4, 1);
[6662]1184 uploadLayoutEph->setRowStretch(5, 999);
[3241]1185
[3731]1186 uploadEphgroup->setLayout(uploadLayoutEph);
[3241]1187
1188 connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1189 this, SLOT(slotBncTextChanged()));
1190
[1678]1191 // Main Layout
1192 // -----------
[1409]1193 QGridLayout* mLayout = new QGridLayout;
[1925]1194 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
[1926]1195 mLayout->addWidget(_aogroup, 0,0);
[1409]1196 mLayout->addWidget(_mountPointsTable, 1,0);
[1947]1197 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
[1926]1198 mLayout->addWidget(_loggroup, 2,0);
[106]1199
[679]1200 _canvas->setLayout(mLayout);
[1333]1201
[3731]1202 // WhatsThis
1203 // ---------
1204 _proxyHostLineEdit->setWhatsThis(tr("<p>If you are running BNC within a protected Local Area Network (LAN), you might need to use a proxy server to access the Internet. Enter your proxy server IP and port number in case one is operated in front of BNC. If you do not know the IP and port of your proxy server, check the proxy server settings in your Internet browser or ask your network administrator.</p><p>Note that IP streaming is sometimes not allowed in a LAN. In this case you need to ask your network administrator for an appropriate modification of the local security policy or for the installation of a TCP relay to the NTRIP broadcasters. If these are not possible, you might need to run BNC outside your LAN on a network that has unobstructed connection to the Internet.</p>"));
1205 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1206 _sslCaCertPathLineEdit->setWhatsThis(tr("<p>Communication with an NTRIP broadcaster over SSL requires the exchange of client and/or server certificates. Specify the path to a directory where you save certificates on your system. Don't try communication via SSL if you are not sure wheter this is supported by the involved NTRIP broadcaster. Note that SSL communication is usually done over port 443.</p>"));
1207 _ignoreSslErrorsCheckBox->setWhatsThis(tr("<p>SSL communication may involve queries coming from the NTRIP broadcaster. Tick 'Ignore SSL authorization erros' if you don't want to be bothered with this.</p>"));
[4202]1208 _waitTimeSpinBox->setWhatsThis(tr("<p>When feeding a real-time GNSS network engine waiting for synchronized input epoch by epoch, BNC drops whatever is received later than 'Wait for full obs epoch' seconds. A value of 3 to 5 seconds is recommended, depending on the latency of the incoming streams and the delay acceptable to your real-time GNSS network engine or products.</p>"));
[3731]1209 _outFileLineEdit->setWhatsThis(tr("Specify the full path to a file where synchronized observations are saved in plain ASCII format. Beware that the size of this file can rapidly increase depending on the number of incoming streams."));
1210 _outPortLineEdit->setWhatsThis(tr("BNC can produce synchronized observations in a plain ASCII format on your local host through an IP port. Specify a port number here to activate this function."));
1211 _outUPortLineEdit->setWhatsThis(tr("BNC can produce unsynchronized observations in a plain ASCII format on your local host through an IP port. Specify a port number here to activate this function."));
1212 _outEphPortLineEdit->setWhatsThis(tr("BNC can produce ephemeris data in RINEX ASCII format on your local host through an IP port. Specify a port number here to activate this function."));
1213 _corrPortLineEdit->setWhatsThis(tr("BNC can produce Broadcast Ephemeris Corrections on your local host through an IP port. Specify a port number here to activate this function."));
1214 _rnxPathLineEdit->setWhatsThis(tr("Here you specify the path to where the RINEX Observation files will be stored. If the specified directory does not exist, BNC will not create RINEX Observation files."));
1215 _ephPathLineEdit->setWhatsThis(tr("Specify the path for saving Broadcast Ephemeris data as RINEX Navigation files. If the specified directory does not exist, BNC will not create RINEX Navigation files."));
1216 _corrPathLineEdit->setWhatsThis(tr("Specify a directory for saving Broadcast Ephemeris Correction files. If the specified directory does not exist, BNC will not create the files."));
1217 _rnxScrpLineEdit->setWhatsThis(tr("<p>Whenever a RINEX Observation file is saved, you might want to compress, copy or upload it immediately via FTP. BNC allows you to execute a script/batch file to carry out these operations. To do that specify the full path of the script/batch file here. BNC will pass the full RINEX Observation file path to the script as a command line parameter (%1 on Windows systems, $1 onUnix/Linux systems).</p>"));
1218 _rnxSkelLineEdit->setWhatsThis(tr("<p>BNC allows using personal skeleton files that contain the header records you would like to include. You can derive a personal RINEX header skeleton file from the information given in an up to date sitelog.</p><p>A file in the RINEX Observations 'Directory' with a 'Skeleton extension' suffix is interpreted by BNC as a personal RINEX header skeleton file for the corresponding stream.</p>"));
1219 _rnxAppendCheckBox->setWhatsThis(tr("<p>When BNC is started, new files are created by default and any existing files with the same name will be overwritten. However, users might want to append already existing files following a restart of BNC, a system crash or when BNC crashed. Tick 'Append files' to continue with existing files and keep what has been recorded so far.</p>"));
1220 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1221 _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p>"));
[4537]1222 _onTheFlyComboBox->setWhatsThis(tr("<p>When operating BNC online in 'no window' mode, some configuration parameters can be changed on-the-fly without interrupting the running process. For that BNC rereads parts of its configuration in pre-defined intervals.<p></p>Select '1 min', '5 min', '1 hour', or '1 day' to force BNC to reread its configuration every full minute, hour, or day and let in between edited configuration options become effective on-the-fly without terminating uninvolved threads.</p><p>Note that when operating BNC in window mode, on-the-fly changeable configuration options become effective immediately through 'Save & Reread Configuration'.</p>"));
[3731]1223 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1224 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1225 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of the Broadcast Ephemeris Correction files.</p>"));
1226 _rnxSamplSpinBox->setWhatsThis(tr("<p>Select the RINEX Observation sampling interval in seconds. A value of zero '0' tells BNC to store all received epochs into RINEX.</p>"));
1227 _binSamplSpinBox->setWhatsThis(tr("<p>Select the synchronized observation sampling interval in seconds. A value of zero '0' tells BNC to send/store all received epochs.</p>"));
1228 _obsRateComboBox->setWhatsThis(tr("<p>BNC can collect all returns (success or failure) coming from a decoder within a certain short time span to then decide whether a stream has an outage or its content is corrupted. The procedure needs a rough estimate of the expected 'Observation rate' of the incoming streams. When a continuous problem is detected, BNC can inform its operator about this event through an advisory note.</p>"));
1229 _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>"));
1230 _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>"));
1231 _logFileLineEdit->setWhatsThis(tr("<p>Records of BNC's activities are shown in the 'Log' tab on the bottom of this window. They can be saved into a file when a valid path is specified in the 'Logfile (full path)' field.</p><p>The logfile name will automatically be extended by a string '_YYMMDD' carrying the current date."));
1232 _adviseScriptLineEdit->setWhatsThis(tr("<p>Specify the full path to a script or batch file to handle advisory notes generated in the event of corrupted streams or stream outages. The affected mountpoint and one of the comments 'Begin_Outage', 'End_Outage', 'Begin_Corrupted', or 'End_Corrupted' are passed on to the script as command line parameters.</p><p>The script may have the task to send the advisory notes by email to BNC's operator and/or to the affected stream provider. An empty option field (default) or invalid path means that you don't want to use this option.</p>"));
1233 _perfIntrComboBox->setWhatsThis(tr("<p>BNC can average latencies per stream over a certain period of GPS time. The resulting mean latencies are recorded in the 'Log' tab at the end of each 'Log latency' interval together with results of a statistical evaluation (approximate number of covered epochs, data gaps).</p><p>Select a 'Log latency' interval or select the empty option field if you do not want BNC to log latencies and statistical information.</p>"));
[3820]1234 _mountPointsTable->setWhatsThis(tr("<p>Streams selected for retrieval are listed in the 'Streams' section. Clicking on 'Add Stream' button will open a window that allows the user to select data streams from an NTRIP broadcaster according to their mountpoints. To remove a stream from the 'Streams' list, highlight it by clicking on it and hit the 'Delete Stream' button. You can also remove multiple streams by highlighting them using +Shift and +Ctrl.</p><p>BNC automatically allocates one of its internal decoders to a stream based on the stream's 'format' as given in the sourcetable. BNC allows users to change this selection by editing the decoder string. Double click on the 'decoder' field, enter your preferred decoder and then hit Enter. The accepted decoder strings are 'RTCM_2.x', 'RTCM_3.x' and 'RTNET'.</p><p>In case you need to log the raw data as is, BNC allows users to by-pass its decoders and directly save the input in daily log files. To do this specify the decoder string as 'ZERO'.</p><p>BNC can also retrieve streams from virtual reference stations (VRS). VRS streams are indicated by a 'yes' in the 'nmea' column. To initiate these streams, the approximate latitude/longitude rover position is sent to the NTRIP broadcaster. The default values can be change according to your requirement. Double click on 'lat' and 'long' fields, enter the values you wish to send and then hit Enter.</p>"));
[3731]1235 _log->setWhatsThis(tr("Records of BNC's activities are shown in the 'Log' tab. The message log covers the communication status between BNC and the NTRIP broadcaster as well as any problems that occur in the communication link, stream availability, stream delay, stream conversion etc."));
1236 _bncFigure->setWhatsThis(tr("The bandwidth consumtion per stream is shown in the 'Throughput' tab in bits per second (bps) or kilo bits per second (kbps)."));
1237 _bncFigureLate->setWhatsThis(tr("The individual latency of observations in each incoming stream is shown in the 'Latency' tab. Streams not carrying observations (i.e. those providing only broadcast ephemeris messages) are not considered here. Note that the calculation of correct latencies requires the clock of the host computer to be properly synchronized."));
[5376]1238 _ephV3CheckBox->setWhatsThis(tr("The default format for output of RINEX Navigation data containing Broadcast Ephemeris is RINEX Version 2. Select 'Version 3' if you want to output the ephemeris in RINEX Version 3 format."));
1239 _rnxV3CheckBox->setWhatsThis(tr("The default format for RINEX Observation files is RINEX Version 2. Select 'Version 3' if you want to save the observations in RINEX Version 3 format."));
[6628]1240 _rnxV2Priority->setWhatsThis(tr("<p>Specify a priority list of characters defining signal generation attributes as defined in RINEX Version 3. Priorities will be used to map RINEX Version 3 observations 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>Default is priority list 'CWPX_?'.</p>"));
[3731]1241 _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>"));
[5652]1242 _miscPortLineEdit->setWhatsThis(tr("BNC can output an incoming stream through a TCP/IP port of your local host. Specify a port number here to activate this function."));
[4509]1243 _scanRTCMCheckBox->setWhatsThis(tr("<p>Tick 'Scan RTCM' to log the numbers of incomming message types as well as contained antenna coordinates, antenna heigt, and antenna descriptor.</p><p>In case of RTCM Version 3 MSM streams, BNC will also log contained RINEX Version 3 observation types.</p>."));
[3731]1244 _serialMountPointLineEdit->setWhatsThis(tr("<p>Enter a 'Mountpoint' to forward the corresponding stream to a serial connected receiver.</p>"));
1245 _serialPortNameLineEdit->setWhatsThis(tr("<p>Enter the serial 'Port name' selected for communication with your serial connected receiver. Valid port names are</p><pre>Windows: COM1, COM2<br>Linux: /dev/ttyS0, /dev/ttyS1<br>FreeBSD: /dev/ttyd0, /dev/ttyd1<br>Digital Unix: /dev/tty01, /dev/tty02<br>HP-UX: /dev/tty1p0, /dev/tty2p0<br>SGI/IRIX: /dev/ttyf1, /dev/ttyf2<br>SunOS/Solaris: /dev/ttya, /dev/ttyb</pre><p>Note that you must plug a serial cable in the port defined here before you start BNC.</p>"));
1246 _serialBaudRateComboBox->setWhatsThis(tr("<p>Select a 'Baud rate' for the serial output link.</p><p>Note that your selection must equal the baud rate configured to the serial connected receiver. Note further that using a high baud rate is recommended.</p>"));
1247 _serialParityComboBox->setWhatsThis(tr("<p>Select the 'Parity' for the serial output link.</p><p>Note that your selection must equal the parity selection configured to the serial connected receiver. Note further that parity is often set to 'NONE'.</p>"));
1248 _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>"));
1249 _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>"));
1250 _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>"));
1251 _serialAutoNMEAComboBox->setWhatsThis(tr("<p>Select 'Auto' to automatically forward NMEA-GGA messages coming from your serial connected receiver to the NTRIP broadcaster and/or save them in a file.</p><p>Select 'Manual' only when handling a VRS stream and your serial connected receiver doesn't generate NMEA-GGA messages.</p>"));
1252 _serialFileNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where NMEA messages coming from your serial connected receiver are saved.</p>"));
1253 _serialHeightNMEALineEdit->setWhatsThis(tr("<p>Specify an approximate 'Height' above mean sea level in meter for your VRS to simulate an inital NMEA-GGA message.</p><p>The setting of this option is ignored in case of streams coming from physical reference stations.</p>"));
[4530]1254 _reqcActionComboBox->setWhatsThis(tr("<p>BNC allows to edit or concatenate RINEX v2 or v3 files or to perform a quality check following UNAVCO's famous 'teqc' program.</p>"));
[3897]1255 _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX v2 or v3 files.</p>"));
[3731]1256 _bncFigurePPP->setWhatsThis(tr("PPP time series of North (red), East (green) and Up (blue) coordinate components are shown in the 'PPP Plot' tab when the corresponting option is selected above. Values are either referred to an XYZ reference coordinate (if specified) or referred to the first estimated set of coordinate compoments. The sliding PPP time series window covers the period of the latest 5 minutes."));
[4202]1257 _cmbTable->setWhatsThis(tr("<p>BNC allows to process several orbit and clock corrections streams in real-time to produce, encode, upload and save a combination of correctors coming from various providers. Hit the 'Add Row' button, double click on the 'Mountpoint' field to enter a Broadcast Ephemeris corrections mountpoint from the 'Streams' section below and hit Enter. Then double click on the 'AC Name' field to enter your choice of an abbreviation for the Analysis Center (AC) providing the stream. Finally, double click on the 'Weight' field to enter the weight to be applied for this stream in the combination.<ul><li>Note that an appropriate 'Wait for full corr epoch' value needs to be specified for the combination under the 'Broadcast Corrections' tab. A value of 15 seconds would make sense there if the update rate of incoming clock corrections is i.e. 10 seconds.</li><li>Note also that you need to tick 'Use GLONASS' which is part ot the 'PPP (2)' panel in case you want to produce an GPS plus GLONASS combination.</li></ul></p><p>Note further that the orbit information in the final combination stream is just copied from one of the incoming streams. The stream used for providing the orbits may vary over time: if the orbit providing stream has an outage then BNC switches to the next remaining stream for getting hold of the orbit information.</p><p>The combination process requires Broadcast Ephemeris. Besides the orbit and clock corrections stream(s) BNC should therefore pull a stream carrying Broadcast Ephemeris in the form of RTCM Version 3 messages.</p><p>It is possible to specify only one Broadcast Ephemeris corrections stream in the combination table. Instead of combining corrections BNC will then merge them with Broadcast Ephemeris to save results in SP3 and/or Clock RINEX format."));
[3731]1258 _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>"));
[6558]1259 _cmbSamplSpinBox->setWhatsThis(tr("<p>Specify a combination sampling interval for the Clocks. The clock corrections will be produced following that interval. A value of 10 sec may be an appropriate choice.</p>"));
[3731]1260 _cmbMethodComboBox->setWhatsThis(tr("<p>Select a clock combination approach. Options are 'Single-Epoch' and Kalman 'Filter'. It is suggested to use the Kalman filter approach for the purpose of Precise Point Positioning.</p>"));
[4185]1261 _uploadTable->setWhatsThis(tr("<p>BNC can upload clock and orbit corrections to broadcast ephemeris (Broadcast Corrections) in RTCM Version 3 SSR format. You may have a situation where clocks and orbits come from an external Real-time Network Engine (1) or a situation where clock and orbit corrections are combined within BNC (2).</p><p>(1) BNC identifies a stream as coming from a Real-time Network Engine if its format is specified as 'RTNET' and hence its decoder string in the 'Streams' canvas is 'RTNET'. It encodes and uploads that stream to the specified NTRIP broadcaster</p><p>(2) BNC understands that it is expected to encode and upload combined Broadcast Ephemeris corrections if you specify correction streams in the 'Combine Corrections' stream table.</p><p>Hit the 'Add Row' button, double click on the 'Host' field to enter the IP or URL of an NTRIP broadcaster and hit Enter. Then double click on the 'Port', 'Mount' and 'Password' fields to enter the NTRIP broadcaster IP port (default is 80), the mountpoint and the stream upload password. An empty 'Host' option field means that you don't want to upload corrections.</p><p>Select a target coordinate reference system (e.g. IGS08) for outgoing clock and orbit corrections.</p><p>By default orbit and clock corrections refer to Antenna Phase Center (APC). Tick 'CoM' to refer uploaded corrections to Center of Mass instead of APC.</p><p>Specify a path for saving the generated Broadcast Corrections plus Broadcast Ephemeris as SP3 orbit files. If the specified directory does not exist, BNC will not create SP3 orbit files. The following is a path example for a Linux system:<br>/home/user/BNC${GPSWD}.sp3<br>Note that '${GPSWD}' produces the GPS Week and Day number in the file name.</p><ul><li>As an SP3 file contents should be referred to the satellites Center of Mass (CoM) while correctors are referred to the satellites Antenna Phase Center (APC), an offset has to be applied which is available from an IGS ANTEX file. You should therefore specify the 'ANTEX File' path under tab 'PPP (2)' if you want to save the stream contents in SP3 format. If you don't specify an 'ANTEX File' path there, the SP3 file contents will be referred to the satellites APCs.</li></ul></p><p>Specify a path for saving the generated Broadcast Correction clocks plus Broadcast Ephemeris clocks as Clock RINEX files. If the specified directory does not exist, BNC will not create Clock RINEX files. The following is a path example for a Linux system:<br>/home/user/BNC${GPSWD}.clk<br>Note that '${GPSWD}' produces the GPS Week and Day number in the file name.</p><p>Specify finally an SSR Provider ID number, an SSR Solution ID number and an Issue of Data SSR number.</p><p>In case the 'Combine Corrections' table contains only one Broadcast Corrections stream, BNC will merge that stream with Broadcast Ephemeris to save results in files specified here through SP3 and/or Clock RINEX file path. In such a case you should define only the SP3 and Clock RINEX file path and no further options in the 'Upload Corrections' table.</p>"));
[3731]1262 addCmbRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the mountpoints table."));
1263 delCmbRowButton->setWhatsThis(tr("Hit 'Delete' button to delete the highlighted line from the mountpoints table."));
[3797]1264 addUploadRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the stream upload table."));
1265 delUploadRowButton->setWhatsThis(tr("Hit 'Del Row' button to delete the highlighted line from the stream upload table."));
1266 _uploadIntrComboBox->setWhatsThis(tr("Select the length of the SP3 and Clock RINEX files."));
[4237]1267 _uploadSamplRtcmEphCorrSpinBox->setWhatsThis(tr("Select the stream's orbit correction sampling interval in seconds. A value of zero '0' tells BNC to upload all available orbit and clock correction samples together in combined messages."));
[4172]1268 _uploadSamplClkRnxSpinBox->setWhatsThis(tr("Select the Clock RINEX file sampling interval in seconds. A value of zero '0' tells BNC to store all available samples into Clock RINEX files."));
[4173]1269 _uploadSamplSp3SpinBox->setWhatsThis(tr("Select the SP3 orbit file sampling interval in minutes. A value of zero '0' tells BNC to store all available samples into SP3 orbit files."));
[3797]1270 setUploadTrafoButton->setWhatsThis(tr("Hit 'Custom Trafo' to specify your own 14 parameter Helmert Transformation instead of selecting a predefined transformation through 'System' button."));
[3800]1271 _uploadEphHostLineEdit->setWhatsThis(tr("BNC can upload a Broadcast Ephemeris stream in RTCM Version 3 format. Specify the host IP of an NTRIP Broadcaster to upload the stream. An empty option field means that you don't want to upload Broadcast Ephemeris."));
1272 _uploadEphPortLineEdit->setWhatsThis(tr("Specify the IP port of an NTRIP Broadcaster to upload the stream. Default is port 80."));
1273 _uploadEphMountpointLineEdit->setWhatsThis(tr("Specify the mounpoint for stream upload to an NTRIP Broadcaster."));
1274 _uploadEphPasswordLineEdit->setWhatsThis(tr("Specify the stream upload password protecting the mounpoint on an NTRIP Broadcaster."));
1275 _uploadEphSampleSpinBox->setWhatsThis(tr("Select the Broadcast Ephemeris sampling interval in seconds. Defaut is '5' meaning that a complete set of Broadcast Ephemeris is uploaded every 5 seconds."));
1276 _uploadEphBytesCounter->setWhatsThis(tr("BNC shows the amount of data uploaded through this stream."));
[4655]1277 _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1278 _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
[5162]1279 _actMapMountPoints->setWhatsThis(tr("<p> Draw distribution map of stream selection presented in the 'Streams' canvas. Use the mouse to zoom in or out.</p><p>Left button: Draw rectangle to zoom in.<br>Right button: Zoom out.<br>Middle button: Zoom back.</p>"));
[4655]1280 _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1281 _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1282
[2129]1283 // Enable/Disable all Widgets
1284 // --------------------------
1285 slotBncTextChanged();
[3788]1286 enableStartStop();
[2129]1287
[1333]1288 // Auto start
1289 // ----------
1290 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
[3782]1291 slotStart();
[1333]1292 }
[35]1293}
1294
1295// Destructor
1296////////////////////////////////////////////////////////////////////////////
1297bncWindow::~bncWindow() {
[5729]1298 delete _caster; BNC_CORE->setCaster(0);
[3249]1299 delete _casterEph;
[35]1300}
1301
[1178]1302//
1303////////////////////////////////////////////////////////////////////////////
1304void bncWindow::populateMountPointsTable() {
1305
1306 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1307 _mountPointsTable->removeRow(iRow);
1308 }
1309
[1535]1310 bncSettings settings;
[1178]1311
1312 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1313 int iRow = 0;
1314 while (it.hasNext()) {
1315 QStringList hlp = it.next().split(" ");
1316 if (hlp.size() < 5) continue;
1317 _mountPointsTable->insertRow(iRow);
1318
1319 QUrl url(hlp[0]);
1320
1321 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1322 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1323 QString nmea(hlp[4]);
[1738]1324 if (hlp[5] == "S") {
1325 fullPath = hlp[0].replace(0,2,"");
1326 }
[3333]1327 QString ntripVersion = "2";
[1352]1328 if (hlp.size() >= 6) {
1329 ntripVersion = (hlp[5]);
1330 }
[1178]1331
1332 QTableWidgetItem* it;
1333 it = new QTableWidgetItem(url.userInfo());
1334 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1335 _mountPointsTable->setItem(iRow, 0, it);
1336
1337 it = new QTableWidgetItem(fullPath);
1338 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1339 _mountPointsTable->setItem(iRow, 1, it);
1340
1341 it = new QTableWidgetItem(format);
1342 _mountPointsTable->setItem(iRow, 2, it);
1343
1344 if (nmea == "yes") {
1345 it = new QTableWidgetItem(latitude);
1346 _mountPointsTable->setItem(iRow, 3, it);
1347 it = new QTableWidgetItem(longitude);
1348 _mountPointsTable->setItem(iRow, 4, it);
1349 } else {
1350 it = new QTableWidgetItem(latitude);
1351 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1352 _mountPointsTable->setItem(iRow, 3, it);
1353 it = new QTableWidgetItem(longitude);
1354 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1355 _mountPointsTable->setItem(iRow, 4, it);
1356 }
1357
1358 it = new QTableWidgetItem(nmea);
1359 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1360 _mountPointsTable->setItem(iRow, 5, it);
1361
[1352]1362 it = new QTableWidgetItem(ntripVersion);
[1511]1363 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
[1352]1364 _mountPointsTable->setItem(iRow, 6, it);
1365
[1178]1366 bncTableItem* bncIt = new bncTableItem();
1367 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
[1352]1368 _mountPointsTable->setItem(iRow, 7, bncIt);
[1178]1369
1370 iRow++;
1371 }
1372
1373 _mountPointsTable->sortItems(1);
[3787]1374
1375 enableStartStop();
[1178]1376}
1377
[35]1378// Retrieve Table
1379////////////////////////////////////////////////////////////////////////////
1380void bncWindow::slotAddMountPoints() {
[101]1381
[1535]1382 bncSettings settings;
[101]1383 QString proxyHost = settings.value("proxyHost").toString();
1384 int proxyPort = settings.value("proxyPort").toInt();
1385 if (proxyHost != _proxyHostLineEdit->text() ||
1386 proxyPort != _proxyPortLineEdit->text().toInt()) {
[102]1387 int iRet = QMessageBox::question(this, "Question", "Proxy options "
[101]1388 "changed. Use the new ones?",
1389 QMessageBox::Yes, QMessageBox::No,
1390 QMessageBox::NoButton);
1391 if (iRet == QMessageBox::Yes) {
1392 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1393 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1394 }
1395 }
1396
[3367]1397 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1398 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1399
[1609]1400 QMessageBox msgBox;
1401 msgBox.setIcon(QMessageBox::Question);
[1874]1402 msgBox.setWindowTitle("Add Stream");
[1609]1403 msgBox.setText("Add stream(s) coming from:");
1404
[1780]1405 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1406 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1407 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1408 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1409 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
[1609]1410
1411 msgBox.exec();
1412
1413 if (msgBox.clickedButton() == buttonNtrip) {
[1737]1414 bncTableDlg* dlg = new bncTableDlg(this);
[1609]1415 dlg->move(this->pos().x()+50, this->pos().y()+50);
[1737]1416 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
[35]1417 this, SLOT(slotNewMountPoints(QStringList*)));
[1609]1418 dlg->exec();
1419 delete dlg;
1420 } else if (msgBox.clickedButton() == buttonIP) {
[1737]1421 bncIpPort* ipp = new bncIpPort(this);
1422 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
[1609]1423 this, SLOT(slotNewMountPoints(QStringList*)));
1424 ipp->exec();
1425 delete ipp;
[1780]1426 } else if (msgBox.clickedButton() == buttonUDP) {
1427 bncUdpPort* udp = new bncUdpPort(this);
1428 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1429 this, SLOT(slotNewMountPoints(QStringList*)));
1430 udp->exec();
1431 delete udp;
[1737]1432 } else if (msgBox.clickedButton() == buttonSerial) {
1433 bncSerialPort* sep = new bncSerialPort(this);
1434 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1435 this, SLOT(slotNewMountPoints(QStringList*)));
1436 sep->exec();
1437 delete sep;
[1609]1438 } else if (msgBox.clickedButton() == buttonCancel) {
1439 // Cancel
1440 }
[3787]1441
1442 enableStartStop();
[35]1443}
1444
1445// Delete Selected Mount Points
1446////////////////////////////////////////////////////////////////////////////
1447void bncWindow::slotDeleteMountPoints() {
[117]1448
1449 int nRows = _mountPointsTable->rowCount();
1450 bool flg[nRows];
1451 for (int iRow = 0; iRow < nRows; iRow++) {
[116]1452 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
[117]1453 flg[iRow] = true;
1454 }
1455 else {
1456 flg[iRow] = false;
1457 }
1458 }
1459 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1460 if (flg[iRow]) {
[116]1461 _mountPointsTable->removeRow(iRow);
[83]1462 }
1463 }
1464 _actDeleteMountPoints->setEnabled(false);
[183]1465
[3787]1466 enableStartStop();
[35]1467}
1468
1469// New Mount Points Selected
1470////////////////////////////////////////////////////////////////////////////
1471void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1472 int iRow = 0;
1473 QListIterator<QString> it(*mountPoints);
1474 while (it.hasNext()) {
[59]1475 QStringList hlp = it.next().split(" ");
[110]1476 QUrl url(hlp[0]);
1477 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
[366]1478 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1479 QString nmea(hlp[4]);
[1738]1480 if (hlp[5] == "S") {
1481 fullPath = hlp[0].replace(0,2,"");
1482 }
[3333]1483 QString ntripVersion = "2";
[1352]1484 if (hlp.size() >= 6) {
1485 ntripVersion = (hlp[5]);
1486 }
[110]1487
[35]1488 _mountPointsTable->insertRow(iRow);
[110]1489
1490 QTableWidgetItem* it;
1491 it = new QTableWidgetItem(url.userInfo());
[115]1492 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
[110]1493 _mountPointsTable->setItem(iRow, 0, it);
1494
1495 it = new QTableWidgetItem(fullPath);
[115]1496 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
[110]1497 _mountPointsTable->setItem(iRow, 1, it);
1498
1499 it = new QTableWidgetItem(format);
1500 _mountPointsTable->setItem(iRow, 2, it);
[184]1501
[410]1502 if (nmea == "yes") {
[366]1503 it = new QTableWidgetItem(latitude);
1504 _mountPointsTable->setItem(iRow, 3, it);
1505 it = new QTableWidgetItem(longitude);
1506 _mountPointsTable->setItem(iRow, 4, it);
1507 } else {
1508 it = new QTableWidgetItem(latitude);
1509 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1510 _mountPointsTable->setItem(iRow, 3, it);
1511 it = new QTableWidgetItem(longitude);
1512 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1513 _mountPointsTable->setItem(iRow, 4, it);
1514 }
1515
1516 it = new QTableWidgetItem(nmea);
1517 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1518 _mountPointsTable->setItem(iRow, 5, it);
1519
[1352]1520 it = new QTableWidgetItem(ntripVersion);
1521 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1522 _mountPointsTable->setItem(iRow, 6, it);
1523
[184]1524 bncTableItem* bncIt = new bncTableItem();
[1352]1525 _mountPointsTable->setItem(iRow, 7, bncIt);
[184]1526
[35]1527 iRow++;
1528 }
[111]1529 _mountPointsTable->hideColumn(0);
[110]1530 _mountPointsTable->sortItems(1);
[35]1531 delete mountPoints;
[3787]1532
1533 enableStartStop();
[35]1534}
1535
[4076]1536// Save Options (serialize)
[35]1537////////////////////////////////////////////////////////////////////////////
1538void bncWindow::slotSaveOptions() {
[4076]1539 saveOptions();
1540 bncSettings settings;
1541 settings.sync();
1542}
[1504]1543
[4076]1544// Save Options (memory only)
1545////////////////////////////////////////////////////////////////////////////
1546void bncWindow::saveOptions() {
1547
[1504]1548 QStringList mountPoints;
1549 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1550
[1739]1551 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1552 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1553 "@" + _mountPointsTable->item(iRow, 1)->text() );
1554
1555 mountPoints.append(url.toString() + " " +
1556 _mountPointsTable->item(iRow, 2)->text()
1557 + " " + _mountPointsTable->item(iRow, 3)->text()
1558 + " " + _mountPointsTable->item(iRow, 4)->text()
1559 + " " + _mountPointsTable->item(iRow, 5)->text()
1560 + " " + _mountPointsTable->item(iRow, 6)->text());
1561 } else {
1562 mountPoints.append(
1563 "//" + _mountPointsTable->item(iRow, 1)->text()
1564 + " " + _mountPointsTable->item(iRow, 2)->text()
1565 + " " + _mountPointsTable->item(iRow, 3)->text()
1566 + " " + _mountPointsTable->item(iRow, 4)->text()
1567 + " " + _mountPointsTable->item(iRow, 5)->text()
1568 + " " + _mountPointsTable->item(iRow, 6)->text());
1569 }
[1504]1570 }
1571
[2870]1572 QStringList combineStreams;
1573 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1574 QString hlp;
1575 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
[2965]1576 if (_cmbTable->item(iRow, iCol)) {
1577 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1578 }
[2870]1579 }
[2965]1580 if (!hlp.isEmpty()) {
1581 combineStreams << hlp;
1582 }
[2870]1583 }
1584
[3164]1585 QStringList uploadMountpointsOut;
1586 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
[3153]1587 QString hlp;
[3164]1588 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1589 if (_uploadTable->cellWidget(iRow, iCol) &&
[3158]1590 (iCol == 3 || iCol == 4 || iCol == 5)) {
1591 if (iCol == 3) {
[3164]1592 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
[3158]1593 hlp += passwd->text() + ",";
1594 }
1595 else if (iCol == 4) {
[3164]1596 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
[3158]1597 hlp += system->currentText() + ",";
1598 }
1599 else if (iCol == 5) {
[3164]1600 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
[3158]1601 QString state; state.setNum(com->checkState());
1602 hlp += state + ",";
1603 }
[3153]1604 }
[3164]1605 else if (_uploadTable->item(iRow, iCol)) {
1606 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
[3158]1607 }
[3153]1608 }
1609 if (!hlp.isEmpty()) {
[3164]1610 uploadMountpointsOut << hlp;
[3153]1611 }
1612 }
1613
[1535]1614 bncSettings settings;
[1504]1615
[3881]1616 settings.setValue("startTab", _aogroup->currentIndex());
1617 settings.setValue("statusTab", _loggroup->currentIndex());
1618 settings.setValue("mountPoints", mountPoints);
1619// Network
1620 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1621 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1622 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1623 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1624// General
1625 settings.setValue("logFile", _logFileLineEdit->text());
1626 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1627 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
[1503]1628 settings.setValue("autoStart", _autoStartCheckBox->checkState());
[3881]1629 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1630// RINEX Observations
1631 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1632 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1633 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1634 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1635 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1636 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
[6237]1637 settings.setValue("rnxV2Priority",_rnxV2Priority->text());
[3881]1638// RINEX Ephemeris
1639 settings.setValue("ephPath", _ephPathLineEdit->text());
1640 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1641 settings.setValue("outEphPort", _outEphPortLineEdit->text());
1642 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1643// Broadcast Corrections
1644 settings.setValue("corrPath", _corrPathLineEdit->text());
[1503]1645 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1646 settings.setValue("corrPort", _corrPortLineEdit->text());
[3881]1647// Feed Engine
1648 settings.setValue("outPort", _outPortLineEdit->text());
1649 settings.setValue("waitTime", _waitTimeSpinBox->value());
1650 settings.setValue("binSampl", _binSamplSpinBox->value());
1651 settings.setValue("outFile", _outFileLineEdit->text());
1652 settings.setValue("outUPort", _outUPortLineEdit->text());
1653// Serial Output
1654 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1655 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1656 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1657 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1658 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1659 settings.setValue("serialParity", _serialParityComboBox->currentText());
1660 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1661 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1662 settings.setValue("serialFileNMEA",_serialFileNMEALineEdit->text());
1663 settings.setValue("serialHeightNMEA",_serialHeightNMEALineEdit->text());
1664// Outages
1665 settings.setValue("obsRate", _obsRateComboBox->currentText());
1666 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1667 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1668 settings.setValue("adviseScript",_adviseScriptLineEdit->text());
1669// Miscellaneous
[1503]1670 settings.setValue("miscMount", _miscMountLineEdit->text());
[5644]1671 settings.setValue("miscPort", _miscPortLineEdit->text());
[3881]1672 settings.setValue("perfIntr", _perfIntrComboBox->currentText());
1673 settings.setValue("scanRTCM", _scanRTCMCheckBox->checkState());
[3897]1674// Reqc
1675 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1676 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1677 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1678 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1679 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1680 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
[4449]1681 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
[6410]1682 settings.setValue("reqcSkyPlotSignals", _reqcSkyPlotSignals->text());
[6299]1683 settings.setValue("reqcLogSummaryOnly", _reqcLogSummaryOnly->checkState());
[6337]1684// SP3 Comparison
1685 settings.setValue("sp3CompFile", _sp3CompFileChooser->fileName());
[6430]1686 settings.setValue("sp3CompExclude", _sp3CompExclude->text());
[6337]1687 settings.setValue("sp3CompOutLogFile", _sp3CompLogLineEdit->text());
[4185]1688// Combine Corrections
[2965]1689 if (!combineStreams.isEmpty()) {
1690 settings.setValue("combineStreams", combineStreams);
1691 }
[3075]1692 else {
1693 settings.setValue("combineStreams", "");
1694 }
[6173]1695 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1696 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1697 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1698 settings.setValue("cmbAntexFile", _cmbAntexFile->fileName());
1699 settings.setValue("cmbUseGlonass", _cmbUseGlonass->checkState());
[4185]1700// Upload Corrections
[3164]1701 if (!uploadMountpointsOut.isEmpty()) {
1702 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
[3153]1703 }
1704 else {
[3164]1705 settings.setValue("uploadMountpointsOut", "");
[3153]1706 }
[4172]1707 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1708 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1709 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1710 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
[4185]1711// Upload Ephemeris
[3242]1712 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1713 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
[3881]1714 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
[3242]1715 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1716 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
[4766]1717
[1200]1718 if (_caster) {
[4250]1719 _caster->readMountPoints();
[1200]1720 }
[5694]1721
1722 _pppWidgets.saveOptions();
[35]1723}
1724
1725// All get slots terminated
1726////////////////////////////////////////////////////////////////////////////
[1556]1727void bncWindow::slotGetThreadsFinished() {
[5068]1728 BNC_CORE->slotMessage("All Get Threads Terminated", true);
[5729]1729 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
[3249]1730 delete _casterEph; _casterEph = 0;
[3787]1731 _runningRealTime = false;
[35]1732}
1733
[3783]1734// Start It!
[35]1735////////////////////////////////////////////////////////////////////////////
[3782]1736void bncWindow::slotStart() {
[4076]1737 saveOptions();
[5926]1738 if ( _pppWidgets._dataSource->currentText() == "RINEX Files") {
[5971]1739 _runningPPP = true;
1740 enableStartStop();
[5993]1741 _caster = new bncCaster(); BNC_CORE->setCaster(_caster);
[5946]1742 BNC_CORE->startPPP();
[5926]1743 }
1744 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
[5971]1745 if (_reqcActionComboBox->currentText() == "Analyze") {
1746 _runningQC = true;
1747 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
1748 connect(reqcAnalyze, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1749 reqcAnalyze->start();
1750 }
1751 else {
1752 _runningEdit = true;
1753 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
1754 connect(reqcEdit, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1755 reqcEdit->start();
1756 }
1757 enableStartStop();
[3783]1758 }
[6333]1759 else if (!_sp3CompFileChooser->fileName().isEmpty()) {
1760 _runningSp3Comp = true;
[6335]1761 t_sp3Comp* sp3Comp = new t_sp3Comp(this);
1762 connect(sp3Comp, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1763 sp3Comp->start();
[6333]1764 enableStartStop();
1765 }
[3783]1766 else {
1767 startRealTime();
[5946]1768 BNC_CORE->startPPP();
[3783]1769 }
1770}
[128]1771
[3783]1772// Start Real-Time (Retrieve Data etc.)
1773////////////////////////////////////////////////////////////////////////////
1774void bncWindow::startRealTime() {
1775
[3787]1776 _runningRealTime = true;
1777
[2177]1778 _bncFigurePPP->reset();
1779
[35]1780 _actDeleteMountPoints->setEnabled(false);
1781
[3787]1782 enableStartStop();
1783
[5729]1784 _caster = new bncCaster();
[35]1785
[5725]1786 BNC_CORE->setCaster(_caster);
[6451]1787 BNC_CORE->setPortEph(_outEphPortLineEdit->text().toInt());
[5068]1788 BNC_CORE->setPortCorr(_corrPortLineEdit->text().toInt());
1789 BNC_CORE->initCombination();
[592]1790
[5729]1791 connect(_caster, SIGNAL(getThreadsFinished()),
[1556]1792 this, SLOT(slotGetThreadsFinished()));
[35]1793
[5729]1794 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
[1179]1795 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
[1173]1796
[6570]1797 BNC_CORE->slotMessage("========== Start BNC v" BNCVERSION " ("BNC_OS") ==========", true);
[1188]1798
[1875]1799 bncSettings settings;
[1880]1800
[1875]1801 QDir rnxdir(settings.value("rnxPath").toString());
[5068]1802 if (!rnxdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations directory", true);
[1880]1803
1804 QString rnx_file = settings.value("rnxScript").toString();
1805 if ( !rnx_file.isEmpty() ) {
1806 QFile rnxfile(settings.value("rnxScript").toString());
[5068]1807 if (!rnxfile.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations script", true);
[1880]1808 }
1809
[1875]1810 QDir ephdir(settings.value("ephPath").toString());
[5068]1811 if (!ephdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Ephemeris directory", true);
[1880]1812
[1875]1813 QDir corrdir(settings.value("corrPath").toString());
[5068]1814 if (!corrdir.exists()) BNC_CORE->slotMessage("Cannot find Broadcast Corrections directory", true);
[1880]1815
1816 QString advise_file = settings.value("adviseScript").toString();
1817 if ( !advise_file.isEmpty() ) {
[1875]1818 QFile advisefile(settings.value("adviseScript").toString());
[5068]1819 if (!advisefile.exists()) BNC_CORE->slotMessage("Cannot find Outages script", true);
[1875]1820 }
1821
[4250]1822 _caster->readMountPoints();
[3249]1823
[3250]1824 _casterEph = new bncEphUploadCaster();
[3254]1825 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
1826 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
[35]1827}
[83]1828
[182]1829// Retrieve Data
1830////////////////////////////////////////////////////////////////////////////
1831void bncWindow::slotStop() {
[5971]1832 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving/processing data?",
[182]1833 QMessageBox::Yes, QMessageBox::No,
1834 QMessageBox::NoButton);
1835 if (iRet == QMessageBox::Yes) {
[5900]1836 BNC_CORE->stopPPP();
[5068]1837 BNC_CORE->stopCombination();
[5729]1838 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
[3249]1839 delete _casterEph; _casterEph = 0;
[3787]1840 _runningRealTime = false;
[5971]1841 _runningPPP = false;
[3790]1842 enableStartStop();
[182]1843 }
1844}
1845
[83]1846// Close Application gracefully
1847////////////////////////////////////////////////////////////////////////////
1848void bncWindow::closeEvent(QCloseEvent* event) {
1849
1850 int iRet = QMessageBox::question(this, "Close", "Save Options?",
1851 QMessageBox::Yes, QMessageBox::No,
1852 QMessageBox::Cancel);
1853
1854 if (iRet == QMessageBox::Cancel) {
1855 event->ignore();
1856 return;
1857 }
1858 else if (iRet == QMessageBox::Yes) {
1859 slotSaveOptions();
1860 }
1861
[5900]1862 BNC_CORE->stopPPP();
[5716]1863
[608]1864 QMainWindow::closeEvent(event);
[83]1865}
1866
1867// User changed the selection of mountPoints
1868////////////////////////////////////////////////////////////////////////////
1869void bncWindow::slotSelectionChanged() {
1870 if (_mountPointsTable->selectedItems().isEmpty()) {
1871 _actDeleteMountPoints->setEnabled(false);
1872 }
1873 else {
1874 _actDeleteMountPoints->setEnabled(true);
1875 }
1876}
1877
1878// Display Program Messages
1879////////////////////////////////////////////////////////////////////////////
[1299]1880void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
[5947]1881 if (showOnScreen ) {
[5980]1882 _log->append(QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg);
[1299]1883 }
[83]1884}
1885
[108]1886// About Message
1887////////////////////////////////////////////////////////////////////////////
1888void bncWindow::slotAbout() {
[679]1889 new bncAboutDlg(0);
[108]1890}
1891
[989]1892//Flowchart
1893////////////////////////////////////////////////////////////////////////////
1894void bncWindow::slotFlowchart() {
1895 new bncFlowchartDlg(0);
1896}
1897
[108]1898// Help Window
1899////////////////////////////////////////////////////////////////////////////
1900void bncWindow::slotHelp() {
[177]1901 QUrl url;
1902 url.setPath(":bnchelp.html");
[676]1903 new bncHlpDlg(0, url);
[108]1904}
[110]1905
1906// Select Fonts
1907////////////////////////////////////////////////////////////////////////////
1908void bncWindow::slotFontSel() {
1909 bool ok;
1910 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
1911 if (ok) {
[1535]1912 bncSettings settings;
[113]1913 settings.setValue("font", newFont.toString());
[110]1914 QApplication::setFont(newFont);
[113]1915 int ww = QFontMetrics(newFont).width('w');
[152]1916 setMinimumSize(60*ww, 80*ww);
1917 resize(60*ww, 80*ww);
[110]1918 }
1919}
[399]1920
1921// Whats This Help
1922void bncWindow::slotWhatsThis() {
[1173]1923 QWhatsThis::enterWhatsThisMode();
[399]1924}
1925
[1173]1926//
1927////////////////////////////////////////////////////////////////////////////
[1179]1928void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
[5187]1929 _threads = threads;
1930
[1998]1931 _bncFigure->updateMountPoints();
1932 _bncFigureLate->updateMountPoints();
1933
[1178]1934 populateMountPointsTable();
[1535]1935 bncSettings settings;
[1180]1936 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
1937 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
[1179]1938 QListIterator<bncGetThread*> iTh(threads);
1939 while (iTh.hasNext()) {
1940 bncGetThread* thread = iTh.next();
1941 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1942 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1943 "@" + _mountPointsTable->item(iRow, 1)->text() );
1944 if (url == thread->mountPoint() &&
1945 _mountPointsTable->item(iRow, 3)->text() == thread->latitude() &&
1946 _mountPointsTable->item(iRow, 4)->text() == thread->longitude() ) {
[1352]1947 ((bncTableItem*) _mountPointsTable->item(iRow, 7))->setGetThread(thread);
[2010]1948 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
1949 _bncFigure, SLOT(slotNewData(QByteArray, double)));
[1926]1950 connect(thread, SIGNAL(newBytes(QByteArray, double)),
[1932]1951 _bncFigure, SLOT(slotNewData(QByteArray, double)));
[2010]1952 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
1953 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
[1972]1954 connect(thread, SIGNAL(newLatency(QByteArray, double)),
[1975]1955 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
[1179]1956 break;
1957 }
1958 }
1959 }
[1173]1960}
1961
1962//
1963////////////////////////////////////////////////////////////////////////////
[679]1964void bncWindow::CreateMenu() {
1965 // Create Menus
1966 // ------------
1967 _menuFile = menuBar()->addMenu(tr("&File"));
1968 _menuFile->addAction(_actFontSel);
1969 _menuFile->addSeparator();
1970 _menuFile->addAction(_actSaveOpt);
1971 _menuFile->addSeparator();
1972 _menuFile->addAction(_actQuit);
[399]1973
[679]1974 _menuHlp = menuBar()->addMenu(tr("&Help"));
1975 _menuHlp->addAction(_actHelp);
[989]1976 _menuHlp->addAction(_actFlowchart);
[679]1977 _menuHlp->addAction(_actAbout);
1978}
1979
[1439]1980// Toolbar
[1173]1981////////////////////////////////////////////////////////////////////////////
[679]1982void bncWindow::AddToolbar() {
1983 QToolBar* toolBar = new QToolBar;
1984 addToolBar(Qt::BottomToolBarArea, toolBar);
1985 toolBar->setMovable(false);
1986 toolBar->addAction(_actAddMountPoints);
1987 toolBar->addAction(_actDeleteMountPoints);
[5162]1988 toolBar->addAction(_actMapMountPoints);
[3782]1989 toolBar->addAction(_actStart);
[679]1990 toolBar->addAction(_actStop);
[3610]1991 toolBar->addWidget(new QLabel(" "));
[679]1992 toolBar->addAction(_actwhatsthis);
[1439]1993}
[679]1994
[1439]1995// About
[1173]1996////////////////////////////////////////////////////////////////////////////
[679]1997bncAboutDlg::bncAboutDlg(QWidget* parent) :
1998 QDialog(parent) {
1999
2000 QTextBrowser* tb = new QTextBrowser;
2001 QUrl url; url.setPath(":bncabout.html");
2002 tb->setSource(url);
2003 tb->setReadOnly(true);
2004
2005 int ww = QFontMetrics(font()).width('w');
2006 QPushButton* _closeButton = new QPushButton("Close");
2007 _closeButton->setMaximumWidth(10*ww);
2008 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2009
2010 QGridLayout* dlgLayout = new QGridLayout();
2011 QLabel* img = new QLabel();
2012 img->setPixmap(QPixmap(":ntrip-logo.png"));
2013 dlgLayout->addWidget(img, 0,0);
[2012]2014 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
[679]2015 dlgLayout->addWidget(tb,1,0,1,2);
2016 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2017
2018 setLayout(dlgLayout);
2019 resize(60*ww, 60*ww);
[1545]2020 setWindowTitle("About BNC");
[679]2021 show();
2022}
2023
[1173]2024//
2025////////////////////////////////////////////////////////////////////////////
[679]2026bncAboutDlg::~bncAboutDlg() {
2027};
2028
[1439]2029// Flowchart
[1173]2030////////////////////////////////////////////////////////////////////////////
[989]2031bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2032 QDialog(parent) {
2033
2034 int ww = QFontMetrics(font()).width('w');
2035 QPushButton* _closeButton = new QPushButton("Close");
2036 _closeButton->setMaximumWidth(10*ww);
2037 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2038
2039 QGridLayout* dlgLayout = new QGridLayout();
2040 QLabel* img = new QLabel();
[997]2041 img->setPixmap(QPixmap(":bncflowchart.png"));
[989]2042 dlgLayout->addWidget(img, 0,0);
2043 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2044
2045 setLayout(dlgLayout);
[1545]2046 setWindowTitle("Flow Chart");
[989]2047 show();
2048}
2049
[1173]2050//
2051////////////////////////////////////////////////////////////////////////////
[989]2052bncFlowchartDlg::~bncFlowchartDlg() {
2053};
2054
[3605]2055// Enable/Disable Widget (and change its color)
2056////////////////////////////////////////////////////////////////////////////
2057void bncWindow::enableWidget(bool enable, QWidget* widget) {
2058 const static QPalette paletteWhite(QColor(255, 255, 255));
2059 const static QPalette paletteGray(QColor(230, 230, 230));
2060
2061 widget->setEnabled(enable);
2062 if (enable) {
2063 widget->setPalette(paletteWhite);
2064 }
2065 else {
2066 widget->setPalette(paletteGray);
2067 }
2068}
2069
[1439]2070// Bnc Text
2071////////////////////////////////////////////////////////////////////////////
[2128]2072void bncWindow::slotBncTextChanged(){
[1439]2073
[3605]2074 bool enable = true;
2075
[1439]2076 // Proxy
2077 //------
[2129]2078 if (sender() == 0 || sender() == _proxyHostLineEdit) {
[3605]2079 enable = !_proxyHostLineEdit->text().isEmpty();
2080 enableWidget(enable, _proxyPortLineEdit);
[1439]2081 }
2082
2083 // RINEX Observations
2084 // ------------------
[2129]2085 if (sender() == 0 || sender() == _rnxPathLineEdit) {
[3605]2086 enable = !_rnxPathLineEdit->text().isEmpty();
2087 enableWidget(enable, _rnxSamplSpinBox);
2088 enableWidget(enable, _rnxSkelLineEdit);
2089 enableWidget(enable, _rnxScrpLineEdit);
2090 enableWidget(enable, _rnxV3CheckBox);
2091 enableWidget(enable, _rnxIntrComboBox);
[1439]2092 }
2093
2094 // RINEX Ephemeris
2095 // ---------------
[3605]2096 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _outEphPortLineEdit) {
2097 enable = !_ephPathLineEdit->text().isEmpty() || !_outEphPortLineEdit->text().isEmpty();
2098 enableWidget(enable, _ephIntrComboBox);
2099 enableWidget(enable, _ephV3CheckBox);
[1439]2100 }
2101
[1682]2102 // Broadcast Corrections
[1439]2103 // ---------------------
[3605]2104 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2105 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2106 enableWidget(enable, _corrIntrComboBox);
[1439]2107 }
2108
2109 // Feed Engine
2110 // -----------
[3605]2111 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2112 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2113 enableWidget(enable, _waitTimeSpinBox);
2114 enableWidget(enable, _binSamplSpinBox);
[1439]2115 }
2116
[1746]2117 // Serial Output
2118 // -------------
[2129]2119 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
[2128]2120 sender() == _serialAutoNMEAComboBox) {
[3605]2121 enable = !_serialMountPointLineEdit->text().isEmpty();
2122 enableWidget(enable, _serialPortNameLineEdit);
2123 enableWidget(enable, _serialBaudRateComboBox);
2124 enableWidget(enable, _serialParityComboBox);
2125 enableWidget(enable, _serialDataBitsComboBox);
2126 enableWidget(enable, _serialStopBitsComboBox);
2127 enableWidget(enable, _serialFlowControlComboBox);
2128 enableWidget(enable, _serialAutoNMEAComboBox);
2129
2130 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() != "Auto";
2131 enableWidget(enable2, _serialFileNMEALineEdit);
[1439]2132 }
2133
2134 // Outages
2135 // -------
[2129]2136 if (sender() == 0 || sender() == _obsRateComboBox) {
[3605]2137 enable = !_obsRateComboBox->currentText().isEmpty();
2138 enableWidget(enable, _adviseFailSpinBox);
2139 enableWidget(enable, _adviseRecoSpinBox);
2140 enableWidget(enable, _adviseScriptLineEdit);
[1439]2141 }
2142
2143 // Miscellaneous
2144 // -------------
[2129]2145 if (sender() == 0 || sender() == _miscMountLineEdit) {
[3605]2146 enable = !_miscMountLineEdit->text().isEmpty();
2147 enableWidget(enable, _perfIntrComboBox);
2148 enableWidget(enable, _scanRTCMCheckBox);
[5644]2149 enableWidget(enable, _miscPortLineEdit);
[1439]2150 }
[2090]2151
[3813]2152 // Enable/disable Broadcast Ephemerides
[3810]2153 // ------------------------------------
2154 if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2155 if (!_uploadEphHostLineEdit->text().isEmpty()) {
2156 _uploadEphPortLineEdit->setStyleSheet("background-color: white");
2157 _uploadEphMountpointLineEdit->setStyleSheet("background-color: white");
2158 _uploadEphPasswordLineEdit->setStyleSheet("background-color: white");
2159 _uploadEphSampleSpinBox->setStyleSheet("background-color: white");
2160 _uploadEphPortLineEdit->setEnabled(true);
2161 _uploadEphMountpointLineEdit->setEnabled(true);
2162 _uploadEphPasswordLineEdit->setEnabled(true);
2163 _uploadEphSampleSpinBox->setEnabled(true);
2164 }
2165 else {
2166 _uploadEphPortLineEdit->setStyleSheet("background-color: lightGray");
2167 _uploadEphMountpointLineEdit->setStyleSheet("background-color: lightGray");
2168 _uploadEphPasswordLineEdit->setStyleSheet("background-color: lightGray");
2169 _uploadEphSampleSpinBox->setStyleSheet("background-color: lightGray");
2170 _uploadEphPortLineEdit->setEnabled(false);
2171 _uploadEphMountpointLineEdit->setEnabled(false);
2172 _uploadEphPasswordLineEdit->setEnabled(false);
2173 _uploadEphSampleSpinBox->setEnabled(false);
2174 }
2175 }
2176
[4185]2177 // Combine Corrections
2178 // -------------------
[3813]2179 if (sender() == 0 || sender() == _cmbTable) {
2180 int iRow = _cmbTable->rowCount();
2181 if (iRow > 0) {
2182 enableWidget(true, _cmbMethodComboBox);
2183 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
[6664]2184 _cmbAntexFile->setStyleSheet("background-color: white");
2185 _cmbSamplSpinBox->setStyleSheet("background-color: white");
[3813]2186 _cmbMaxresLineEdit->setEnabled(true);
[6664]2187 _cmbAntexFile->setEnabled(true);
[4179]2188 _cmbSamplSpinBox->setEnabled(true);
[6172]2189 _cmbUseGlonass->setEnabled(true);
[3813]2190 }
2191 else {
2192 enableWidget(false, _cmbMethodComboBox);
2193 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
[6664]2194 _cmbAntexFile->setStyleSheet("background-color: lightGray");
2195 _cmbSamplSpinBox->setStyleSheet("background-color: lightGray");
[3813]2196 _cmbMaxresLineEdit->setEnabled(false);
[6664]2197 _cmbAntexFile->setEnabled(false);
[4179]2198 _cmbSamplSpinBox->setEnabled(false);
[6172]2199 _cmbUseGlonass->setEnabled(false);
[3813]2200 }
2201 }
2202
2203 // Upload(clk)
2204 // -----------
2205 int iRow = _uploadTable->rowCount();
2206 if (iRow > 0) {
2207 enableWidget(true, _uploadIntrComboBox);
[4172]2208 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2209 enableWidget(true, _uploadSamplClkRnxSpinBox);
2210 enableWidget(true, _uploadSamplSp3SpinBox);
[3813]2211 }
2212 else {
2213 enableWidget(false, _uploadIntrComboBox);
[4172]2214 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2215 enableWidget(false, _uploadSamplClkRnxSpinBox);
2216 enableWidget(false, _uploadSamplSp3SpinBox);
[3813]2217 }
2218
[5861]2219 // QC
2220 // --
[6411]2221 if (sender() == 0 || sender() == _reqcActionComboBox || sender() == _reqcSkyPlotSignals) {
[3897]2222 enable = !_reqcActionComboBox->currentText().isEmpty();
[6411]2223 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
2224 bool enablePlot = !_reqcSkyPlotSignals->text().isEmpty();
2225 enableWidget(enable, _reqcObsFileChooser);
2226 enableWidget(enable, _reqcNavFileChooser);
2227 enableWidget(enable, _reqcOutLogLineEdit);
2228 enableWidget(enable && enable10, _reqcEditOptionButton);
2229 enableWidget(enable && enable10, _reqcOutObsLineEdit);
2230 enableWidget(enable && enable10, _reqcOutNavLineEdit);
2231 enableWidget(enable && !enable10, _reqcLogSummaryOnly);
2232 enableWidget(enable && !enable10, _reqcSkyPlotSignals);
[6318]2233 enableWidget(enable && !enable10 && enablePlot, _reqcPlotDirLineEdit);
[3739]2234 }
[4085]2235
[6648]2236 // SP3 File Comparison
2237 // -------------------
2238 if (sender() == 0 || sender() == _sp3CompFileChooser) {
2239 enable = !_sp3CompFileChooser->fileName().isEmpty();
2240 enableWidget(enable, _sp3CompLogLineEdit);
2241 enableWidget(enable, _sp3CompExclude);
2242 }
2243
[4085]2244 enableStartStop();
[1439]2245}
[2869]2246
2247//
2248////////////////////////////////////////////////////////////////////////////
2249void bncWindow::slotAddCmbRow() {
2250 int iRow = _cmbTable->rowCount();
2251 _cmbTable->insertRow(iRow);
2252 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2253 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2254 }
2255}
2256
2257//
2258////////////////////////////////////////////////////////////////////////////
2259void bncWindow::slotDelCmbRow() {
2260 int nRows = _cmbTable->rowCount();
2261 bool flg[nRows];
2262 for (int iRow = 0; iRow < nRows; iRow++) {
2263 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2264 flg[iRow] = true;
2265 }
2266 else {
2267 flg[iRow] = false;
2268 }
2269 }
2270 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2271 if (flg[iRow]) {
2272 _cmbTable->removeRow(iRow);
2273 }
2274 }
[3813]2275 nRows = _cmbTable->rowCount();
2276 if (nRows < 1) {
2277 enableWidget(false, _cmbMethodComboBox);
2278 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
[6664]2279 _cmbAntexFile->setStyleSheet("background-color: lightGray");
2280 _cmbSamplSpinBox->setStyleSheet("background-color: lightGray");
[3813]2281 _cmbMaxresLineEdit->setEnabled(false);
[6664]2282 _cmbAntexFile->setEnabled(false);
[4179]2283 _cmbSamplSpinBox->setEnabled(false);
[6172]2284 _cmbUseGlonass->setEnabled(false);
[3813]2285 }
[2869]2286}
[2870]2287
2288//
2289////////////////////////////////////////////////////////////////////////////
2290void bncWindow::populateCmbTable() {
2291
2292 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2293 _cmbTable->removeRow(iRow);
2294 }
2295
2296 bncSettings settings;
2297
2298 int iRow = -1;
2299 QListIterator<QString> it(settings.value("combineStreams").toStringList());
2300 while (it.hasNext()) {
2301 QStringList hlp = it.next().split(" ");
[2965]2302 if (hlp.size() > 2) {
[2870]2303 ++iRow;
2304 _cmbTable->insertRow(iRow);
2305 }
2306 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2307 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2308 }
2309 }
2310}
[3152]2311
2312//
2313////////////////////////////////////////////////////////////////////////////
[3164]2314void bncWindow::slotAddUploadRow() {
2315 int iRow = _uploadTable->rowCount();
2316 _uploadTable->insertRow(iRow);
2317 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
[3156]2318 if (iCol == 3) {
2319 QLineEdit* passwd = new QLineEdit();
2320 passwd->setFrame(false);
2321 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
[3164]2322 _uploadTable->setCellWidget(iRow, iCol, passwd);
[3156]2323 }
2324 else if (iCol == 4) {
[3158]2325 QComboBox* system = new QComboBox();
2326 system->setEditable(false);
[5341]2327 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
[3158]2328 system->setFrame(false);
[3164]2329 _uploadTable->setCellWidget(iRow, iCol, system);
[3155]2330 }
2331 else if (iCol == 5) {
2332 QCheckBox* com = new QCheckBox();
[3164]2333 _uploadTable->setCellWidget(iRow, iCol, com);
[3155]2334 }
[4111]2335 else if (iCol == 11) {
[3196]2336 bncTableItem* bncIt = new bncTableItem();
2337 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2338 _uploadTable->setItem(iRow, iCol, bncIt);
[5068]2339 BNC_CORE->_uploadTableItems[iRow] = bncIt;
[3196]2340 }
[3155]2341 else {
[3164]2342 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
[3155]2343 }
[3152]2344 }
2345}
2346
2347//
2348////////////////////////////////////////////////////////////////////////////
[3164]2349void bncWindow::slotDelUploadRow() {
[5068]2350 BNC_CORE->_uploadTableItems.clear();
[3164]2351 int nRows = _uploadTable->rowCount();
[3152]2352 bool flg[nRows];
2353 for (int iRow = 0; iRow < nRows; iRow++) {
[3164]2354 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
[3152]2355 flg[iRow] = true;
2356 }
2357 else {
2358 flg[iRow] = false;
2359 }
2360 }
2361 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2362 if (flg[iRow]) {
[3164]2363 _uploadTable->removeRow(iRow);
[3152]2364 }
2365 }
[3232]2366 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
[5068]2367 BNC_CORE->_uploadTableItems[iRow] =
[4111]2368 (bncTableItem*) _uploadTable->item(iRow, 11);
[3232]2369 }
[3813]2370 nRows = _uploadTable->rowCount();
2371 if (nRows < 1) {
2372 enableWidget(false, _uploadIntrComboBox);
[4172]2373 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2374 enableWidget(false, _uploadSamplSp3SpinBox);
2375 enableWidget(false, _uploadSamplClkRnxSpinBox);
[3813]2376 }
[3152]2377}
2378
2379//
2380////////////////////////////////////////////////////////////////////////////
[3164]2381void bncWindow::populateUploadTable() {
2382 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2383 _uploadTable->removeRow(iRow);
[3153]2384 }
2385
2386 bncSettings settings;
2387
2388 int iRow = -1;
[3164]2389 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
[3153]2390 while (it.hasNext()) {
[3159]2391 QStringList hlp = it.next().split(",");
2392 if (hlp.size() > 6) {
[3153]2393 ++iRow;
[3164]2394 _uploadTable->insertRow(iRow);
[3153]2395 }
2396 for (int iCol = 0; iCol < hlp.size(); iCol++) {
[3159]2397 if (iCol == 3) {
2398 QLineEdit* passwd = new QLineEdit();
2399 passwd->setFrame(false);
2400 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2401 passwd->setText(hlp[iCol]);
[3164]2402 _uploadTable->setCellWidget(iRow, iCol, passwd);
[3159]2403 }
2404 else if (iCol == 4) {
2405 QComboBox* system = new QComboBox();
2406 system->setEditable(false);
[5342]2407 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
[3159]2408 system->setFrame(false);
2409 system->setCurrentIndex(system->findText(hlp[iCol]));
[3164]2410 _uploadTable->setCellWidget(iRow, iCol, system);
[3159]2411 }
2412 else if (iCol == 5) {
2413 QCheckBox* com = new QCheckBox();
2414 if (hlp[iCol].toInt() == Qt::Checked) {
2415 com->setCheckState(Qt::Checked);
2416 }
[3164]2417 _uploadTable->setCellWidget(iRow, iCol, com);
[3159]2418 }
[4111]2419 else if (iCol == 11) {
[3196]2420 bncTableItem* bncIt = new bncTableItem();
2421 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2422 _uploadTable->setItem(iRow, iCol, bncIt);
[5068]2423 BNC_CORE->_uploadTableItems[iRow] = bncIt;
[3196]2424 }
[3159]2425 else {
[3164]2426 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
[3159]2427 }
[3153]2428 }
2429 }
[3152]2430}
[3153]2431
2432//
2433////////////////////////////////////////////////////////////////////////////
[3164]2434void bncWindow::slotSetUploadTrafo() {
[3239]2435 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2436 dlg->exec();
2437 delete dlg;
[3153]2438}
[3608]2439
[3626]2440// Progress Bar Change
2441////////////////////////////////////////////////////////////////////////////
[5971]2442void bncWindow::slotPostProcessingProgress(int nEpo) {
2443 _actStart->setText(QString("%1 Epochs").arg(nEpo));
[3626]2444}
[3731]2445
[3897]2446// Post-Processing Reqc Finished
[3731]2447////////////////////////////////////////////////////////////////////////////
[5971]2448void bncWindow::slotPostProcessingFinished() {
[5993]2449 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
[6333]2450 _runningPPP = false;
2451 _runningEdit = false;
2452 _runningQC = false;
2453 _runningSp3Comp = false;
[5974]2454 _actStart->setText(tr("Sta&rt"));
[3792]2455 enableStartStop();
[3731]2456}
[3736]2457
[3740]2458// Edit teqc-like editing options
2459////////////////////////////////////////////////////////////////////////////
[3897]2460void bncWindow::slotReqcEditOption() {
[6239]2461 saveOptions();
[3897]2462 reqcDlg* dlg = new reqcDlg(this);
[3740]2463 dlg->move(this->pos().x()+50, this->pos().y()+50);
2464 dlg->exec();
2465 delete dlg;
2466}
[3787]2467
2468// Enable/Disable Start and Stop Buttons
2469////////////////////////////////////////////////////////////////////////////
2470void bncWindow::enableStartStop() {
[5971]2471 if ( running() ) {
2472 _actStart->setEnabled(false);
[5976]2473 if (_runningRealTime || _runningPPP) {
[5971]2474 _actStop->setEnabled(true);
[3792]2475 }
[3787]2476 }
2477 else {
[5971]2478 _actStart->setEnabled(true);
2479 _actStop->setEnabled(false);
[3787]2480 }
2481}
[4646]2482
2483// Show Map
2484////////////////////////////////////////////////////////////////////////////
[5162]2485void bncWindow::slotMapMountPoints() {
[4646]2486 saveOptions();
2487 t_bncMap* bncMap = new t_bncMap(this);
[4714]2488 bncMap->setMinimumSize(800, 600);
[4649]2489 bncMap->setWindowTitle("Selected Mountpoints");
[4647]2490
2491 bncSettings settings;
2492 QListIterator<QString> it(settings.value("mountPoints").toStringList());
2493 while (it.hasNext()) {
2494 QStringList hlp = it.next().split(" ");
2495 if (hlp.size() < 5) continue;
2496 QUrl url(hlp[0]);
2497 double latDeg = hlp[2].toDouble();
2498 double lonDeg = hlp[3].toDouble();
[4648]2499 bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
[4647]2500 }
2501
[4646]2502 bncMap->show();
2503}
[5162]2504
2505// Show Map
2506////////////////////////////////////////////////////////////////////////////
2507void bncWindow::slotMapPPP() {
[5186]2508#ifdef QT_WEBKIT
[5233]2509 saveOptions();
[5895]2510 enableWidget(false, _pppWidgets._mapWinButton);
[5955]2511 enableWidget(false, _pppWidgets._useGoogleMap);
2512 enableWidget(false, _pppWidgets._useOpenStreetMap);
2513 enableWidget(false, _pppWidgets._mapWinDotSize);
2514 enableWidget(false, _pppWidgets._mapWinDotColor);
[5299]2515
[5179]2516 if (!_mapWin) {
2517 _mapWin = new bncMapWin(this);
[5235]2518 connect(_mapWin, SIGNAL(mapClosed()), this, SLOT(slotMapPPPClosed()));
[5954]2519 connect(BNC_CORE, SIGNAL(newPosition(QByteArray, bncTime, QVector<double>)),
2520 _mapWin, SLOT(slotNewPosition(QByteArray, bncTime, QVector<double>)));
[5179]2521 }
2522 _mapWin->show();
[5186]2523#else
2524 QMessageBox::information(this, "Information",
2525 "Qt Library compiled without QtWebKit");
2526#endif
[5162]2527}
[5235]2528
2529// Show Map
2530////////////////////////////////////////////////////////////////////////////
2531void bncWindow::slotMapPPPClosed() {
2532#ifdef QT_WEBKIT
[5896]2533 enableWidget(true, _pppWidgets._mapWinButton);
[5955]2534 enableWidget(true, _pppWidgets._useGoogleMap);
2535 enableWidget(true, _pppWidgets._useOpenStreetMap);
2536 enableWidget(true, _pppWidgets._mapWinDotSize);
2537 enableWidget(true, _pppWidgets._mapWinDotColor);
[5237]2538 if (_mapWin) {
2539 QListIterator<bncGetThread*> it(_threads);
2540 while (it.hasNext()) {
2541 bncGetThread* thread = it.next();
2542 thread->disconnect(_mapWin);
2543 }
[5242]2544 _mapWin->deleteLater();
[5237]2545 _mapWin = 0;
2546 }
[5235]2547#endif
2548}
Note: See TracBrowser for help on using the repository browser.