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

Last change on this file since 6398 was 6337, checked in by mervart, 10 years ago
File size: 122.7 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
[5983]113 setMinimumSize(90*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");
456 _cmbMaxresLineEdit->setEnabled(true);
[4179]457 _cmbSamplSpinBox->setEnabled(true);
[6172]458 _cmbAntexFile->setEnabled(true);
459 _cmbUseGlonass->setEnabled(true);
[3813]460 }
461 else {
462 enableWidget(false, _cmbMethodComboBox);
463 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
464 _cmbMaxresLineEdit->setEnabled(false);
[4179]465 _cmbSamplSpinBox->setEnabled(false);
[6172]466 _cmbAntexFile->setEnabled(false);
467 _cmbUseGlonass->setEnabled(false);
[3813]468 }
469
[3164]470 // Upload Results
[3152]471 // -------------
[4111]472 _uploadTable = new QTableWidget(0,12);
473 _uploadTable->setHorizontalHeaderLabels(QString("Host, Port, Mount, Password, System, CoM, SP3 File, RNX File, PID, SID, IOD, bytes").split(","));
[3164]474 _uploadTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
475 _uploadTable->setSelectionBehavior(QAbstractItemView::SelectRows);
[4111]476 _uploadTable->horizontalHeader()->resizeSection( 0,13*ww);
477 _uploadTable->horizontalHeader()->resizeSection( 1, 5*ww);
478 _uploadTable->horizontalHeader()->resizeSection( 2, 6*ww);
479 _uploadTable->horizontalHeader()->resizeSection( 3, 8*ww);
480 _uploadTable->horizontalHeader()->resizeSection( 4,11*ww);
481 _uploadTable->horizontalHeader()->resizeSection( 5, 4*ww);
482 _uploadTable->horizontalHeader()->resizeSection( 6,15*ww);
483 _uploadTable->horizontalHeader()->resizeSection( 7,15*ww);
484 _uploadTable->horizontalHeader()->resizeSection( 8, 4*ww);
485 _uploadTable->horizontalHeader()->resizeSection( 9, 4*ww);
486 _uploadTable->horizontalHeader()->resizeSection(10, 4*ww);
487 _uploadTable->horizontalHeader()->resizeSection(11,12*ww);
[3164]488 _uploadTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
[4185]489 _uploadTable->horizontalHeader()->setStretchLastSection(true);
[3164]490 _uploadTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
[3152]491
[3585]492 connect(_uploadTable, SIGNAL(itemSelectionChanged()),
493 SLOT(slotBncTextChanged()));
494
[3164]495 QPushButton* addUploadRowButton = new QPushButton("Add Row");
[3193]496 QPushButton* delUploadRowButton = new QPushButton("Del Row");
497 QPushButton* setUploadTrafoButton = new QPushButton("Custom Trafo");
[3197]498 _uploadIntrComboBox = new QComboBox;
499 _uploadIntrComboBox->setEditable(false);
[3271]500 _uploadIntrComboBox->addItems(QString("1 day,1 hour, 30 min,15 min,10 min,5 min,2 min,1 min").split(","));
[3197]501 ii = _uploadIntrComboBox->findText(settings.value("uploadIntr").toString());
502 if (ii != -1) {
503 _uploadIntrComboBox->setCurrentIndex(ii);
504 }
[3152]505
[4172]506 _uploadSamplRtcmEphCorrSpinBox = new QSpinBox;
507 _uploadSamplRtcmEphCorrSpinBox->setMinimum(0);
508 _uploadSamplRtcmEphCorrSpinBox->setMaximum(60);
509 _uploadSamplRtcmEphCorrSpinBox->setSingleStep(5);
510 _uploadSamplRtcmEphCorrSpinBox->setMaximumWidth(9*ww);
511 _uploadSamplRtcmEphCorrSpinBox->setValue(settings.value("uploadSamplRtcmEphCorr").toInt());
512 _uploadSamplRtcmEphCorrSpinBox->setSuffix(" sec");
[3152]513
[4172]514 _uploadSamplSp3SpinBox = new QSpinBox;
515 _uploadSamplSp3SpinBox->setMinimum(0);
[4173]516 _uploadSamplSp3SpinBox->setMaximum(15);
517 _uploadSamplSp3SpinBox->setSingleStep(1);
[4172]518 _uploadSamplSp3SpinBox->setMaximumWidth(9*ww);
519 _uploadSamplSp3SpinBox->setValue(settings.value("uploadSamplSp3").toInt());
[4173]520 _uploadSamplSp3SpinBox->setSuffix(" min");
[4172]521
522 _uploadSamplClkRnxSpinBox = new QSpinBox;
523 _uploadSamplClkRnxSpinBox->setMinimum(0);
524 _uploadSamplClkRnxSpinBox->setMaximum(60);
525 _uploadSamplClkRnxSpinBox->setSingleStep(5);
526 _uploadSamplClkRnxSpinBox->setMaximumWidth(9*ww);
527 _uploadSamplClkRnxSpinBox->setValue(settings.value("uploadSamplClkRnx").toInt());
528 _uploadSamplClkRnxSpinBox->setSuffix(" sec");
529
[3813]530 int iRowT = _uploadTable->rowCount();
531 if (iRowT > 0) {
532 enableWidget(true, _uploadIntrComboBox);
[4172]533 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
534 enableWidget(true, _uploadSamplSp3SpinBox);
535 enableWidget(true, _uploadSamplClkRnxSpinBox);
[3813]536 }
537 else {
538 enableWidget(false, _uploadIntrComboBox);
[4172]539 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
540 enableWidget(false, _uploadSamplSp3SpinBox);
541 enableWidget(false, _uploadSamplClkRnxSpinBox);
[3813]542 }
543
[3240]544 // Upload RTCM3 Ephemeris
545 // ----------------------
546 _uploadEphHostLineEdit = new QLineEdit(settings.value("uploadEphHost").toString());
547 _uploadEphPortLineEdit = new QLineEdit(settings.value("uploadEphPort").toString());
548 _uploadEphPasswordLineEdit = new QLineEdit(settings.value("uploadEphPassword").toString());
549 _uploadEphPasswordLineEdit->setEchoMode(QLineEdit::PasswordEchoOnEdit);
550 _uploadEphMountpointLineEdit = new QLineEdit(settings.value("uploadEphMountpoint").toString());
551 _uploadEphSampleSpinBox = new QSpinBox;
[3271]552 _uploadEphSampleSpinBox->setMinimum(5);
[3240]553 _uploadEphSampleSpinBox->setMaximum(60);
554 _uploadEphSampleSpinBox->setSingleStep(5);
555 _uploadEphSampleSpinBox->setMaximumWidth(9*ww);
556 _uploadEphSampleSpinBox->setValue(settings.value("uploadEphSample").toInt());
557 _uploadEphSampleSpinBox->setSuffix(" sec");
[3245]558 _uploadEphBytesCounter = new bncBytesCounter;
[3240]559
[679]560 // Canvas with Editable Fields
561 // ---------------------------
562 _canvas = new QWidget;
563 setCentralWidget(_canvas);
[143]564
[1925]565 _aogroup = new QTabWidget();
[679]566 QWidget* pgroup = new QWidget();
567 QWidget* ggroup = new QWidget();
568 QWidget* sgroup = new QWidget();
569 QWidget* egroup = new QWidget();
570 QWidget* agroup = new QWidget();
[934]571 QWidget* cgroup = new QWidget();
[679]572 QWidget* ogroup = new QWidget();
[1030]573 QWidget* rgroup = new QWidget();
[1327]574 QWidget* sergroup = new QWidget();
[5686]575 QWidget* pppGroup1 = new QWidget();
576 QWidget* pppGroup2 = new QWidget();
[5690]577 QWidget* pppGroup3 = new QWidget();
[5861]578 QWidget* pppGroup4 = new QWidget();
[3897]579 QWidget* reqcgroup = new QWidget();
[6332]580 QWidget* sp3CompGroup = new QWidget();
[2868]581 QWidget* cmbgroup = new QWidget();
[3164]582 QWidget* uploadgroup = new QWidget();
[3241]583 QWidget* uploadEphgroup = new QWidget();
[3356]584 _aogroup->addTab(pgroup,tr("Network"));
[1925]585 _aogroup->addTab(ggroup,tr("General"));
586 _aogroup->addTab(ogroup,tr("RINEX Observations"));
587 _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
[3897]588 _aogroup->addTab(reqcgroup,tr("RINEX Editing && QC"));
[6332]589 _aogroup->addTab(sp3CompGroup,tr("SP3 Comparison"));
[1925]590 _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
591 _aogroup->addTab(sgroup,tr("Feed Engine"));
592 _aogroup->addTab(sergroup,tr("Serial Output"));
593 _aogroup->addTab(agroup,tr("Outages"));
594 _aogroup->addTab(rgroup,tr("Miscellaneous"));
[5861]595 _aogroup->addTab(pppGroup1,tr("PPP (1)"));
596 _aogroup->addTab(pppGroup2,tr("PPP (2)"));
597 _aogroup->addTab(pppGroup3,tr("PPP (3)"));
[5865]598 _aogroup->addTab(pppGroup4,tr("PPP (4)"));
[5686]599
[2907]600#ifdef USE_COMBINATION
[4185]601 _aogroup->addTab(cmbgroup,tr("Combine Corrections"));
[2907]602#endif
[4185]603 _aogroup->addTab(uploadgroup,tr("Upload Corrections"));
604 _aogroup->addTab(uploadEphgroup,tr("Upload Ephemeris"));
[143]605
[1957]606 // Log Tab
607 // -------
[1925]608 _loggroup = new QTabWidget();
[1957]609 _loggroup->addTab(_log,tr("Log"));
610 _loggroup->addTab(_bncFigure,tr("Throughput"));
[1972]611 _loggroup->addTab(_bncFigureLate,tr("Latency"));
[2303]612 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
[1912]613
[3356]614 // Netowork (Proxy and SSL) Tab
615 // ----------------------------
[679]616 QGridLayout* pLayout = new QGridLayout;
[1409]617 pLayout->setColumnMinimumWidth(0,13*ww);
[1678]618 _proxyPortLineEdit->setMaximumWidth(9*ww);
619
[3766]620 pLayout->addWidget(new QLabel("Settings for proxy in protected networks and for SSL authorization, leave boxes blank if none."),0, 0, 1, 50);
621 pLayout->addWidget(new QLabel("Proxy host"), 1, 0);
622 pLayout->addWidget(_proxyHostLineEdit, 1, 1, 1,10);
623 pLayout->addWidget(new QLabel("Proxy port"), 2, 0);
624 pLayout->addWidget(_proxyPortLineEdit, 2, 1);
625 pLayout->addWidget(new QLabel("Path to SSL Certificates"), 3, 0);
626 pLayout->addWidget(_sslCaCertPathLineEdit, 3, 1, 1,10);
[3778]627 pLayout->addWidget(new QLabel("Default: " + bncSslConfig::defaultPath()), 3,11, 1,20);
[3766]628 pLayout->addWidget(new QLabel("Ignore SSL Authorization Errors"), 4, 0);
629 pLayout->addWidget(_ignoreSslErrorsCheckBox, 4, 1, 1,10);
630 pLayout->addWidget(new QLabel(" "), 4, 0);
631 pLayout->addWidget(new QLabel(" "), 5, 0);
632 pLayout->addWidget(new QLabel(" "), 6, 0);
[679]633 pgroup->setLayout(pLayout);
[1439]634
[1678]635 // General Tab
636 // -----------
[679]637 QGridLayout* gLayout = new QGridLayout;
[1042]638 gLayout->setColumnMinimumWidth(0,14*ww);
[1678]639 _onTheFlyComboBox->setMaximumWidth(9*ww);
640
[3766]641 gLayout->addWidget(new QLabel("General settings for logfile, file handling, configuration on-the-fly, and auto-start."),0, 0, 1, 50);
642 gLayout->addWidget(new QLabel("Logfile (full path)"), 1, 0);
643 gLayout->addWidget(_logFileLineEdit, 1, 1, 1,30);
644 gLayout->addWidget(new QLabel("Append files"), 2, 0);
645 gLayout->addWidget(_rnxAppendCheckBox, 2, 1);
646 gLayout->addWidget(new QLabel("Reread configuration"), 3, 0);
647 gLayout->addWidget(_onTheFlyComboBox, 3, 1);
648 gLayout->addWidget(new QLabel("Auto start"), 4, 0);
649 gLayout->addWidget(_autoStartCheckBox, 4, 1);
650 gLayout->addWidget(new QLabel("Raw output file (full path)"), 5, 0);
651 gLayout->addWidget(_rawOutFileLineEdit, 5, 1, 1,30);
652 gLayout->addWidget(new QLabel(" "), 6, 0);
[679]653 ggroup->setLayout(gLayout);
[533]654
[1678]655 // RINEX Observations
656 // ------------------
657 QGridLayout* oLayout = new QGridLayout;
658 oLayout->setColumnMinimumWidth(0,14*ww);
659 _rnxIntrComboBox->setMaximumWidth(9*ww);
660 _rnxSamplSpinBox->setMaximumWidth(9*ww);
[143]661
[3766]662 oLayout->addWidget(new QLabel("Saving RINEX observation files."),0, 0, 1,50);
663 oLayout->addWidget(new QLabel("Directory"), 1, 0);
664 oLayout->addWidget(_rnxPathLineEdit, 1, 1, 1,24);
665 oLayout->addWidget(new QLabel("Interval"), 2, 0);
666 oLayout->addWidget(_rnxIntrComboBox, 2, 1);
667 oLayout->addWidget(new QLabel(" Sampling"), 2, 2, Qt::AlignRight);
668 oLayout->addWidget(_rnxSamplSpinBox, 2, 3, Qt::AlignLeft);
669 oLayout->addWidget(new QLabel("Skeleton extension"), 3, 0);
670 oLayout->addWidget(_rnxSkelLineEdit, 3, 1, 1, 1, Qt::AlignLeft);
671 oLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
672 oLayout->addWidget(_rnxScrpLineEdit, 4, 1, 1,24);
[6266]673 oLayout->addWidget(new QLabel("Version 2"), 5, 0);
674 oLayout->addWidget(_rnxV2Priority, 5, 1);
675 oLayout->addWidget(new QLabel(" Signal Priority"), 5, 2, 1,15);
676 oLayout->addWidget(new QLabel("Version 3"), 6, 0);
677 oLayout->addWidget(_rnxV3CheckBox, 6, 1);
678 oLayout->addWidget(new QLabel(" "), 7, 0);
[1678]679 ogroup->setLayout(oLayout);
680
[1439]681 // RINEX Ephemeris
682 // ---------------
[679]683 QGridLayout* eLayout = new QGridLayout;
[1042]684 eLayout->setColumnMinimumWidth(0,14*ww);
[1678]685 _ephIntrComboBox->setMaximumWidth(9*ww);
686 _outEphPortLineEdit->setMaximumWidth(9*ww);
687
[3766]688 eLayout->addWidget(new QLabel("Saving RINEX ephemeris files and ephemeris output through IP port."),0,0,1,50);
689 eLayout->addWidget(new QLabel("Directory"), 1, 0);
690 eLayout->addWidget(_ephPathLineEdit, 1, 1, 1,30);
691 eLayout->addWidget(new QLabel("Interval"), 2, 0);
692 eLayout->addWidget(_ephIntrComboBox, 2, 1);
693 eLayout->addWidget(new QLabel("Port"), 3, 0);
694 eLayout->addWidget(_outEphPortLineEdit, 3, 1);
695 eLayout->addWidget(new QLabel("Version 3"), 4, 0);
696 eLayout->addWidget(_ephV3CheckBox, 4, 1);
697 eLayout->addWidget(new QLabel(" "), 5, 0);
698 eLayout->addWidget(new QLabel(" "), 6, 0);
[679]699 egroup->setLayout(eLayout);
[560]700
[1454]701
[1682]702 // Broadcast Corrections
[1439]703 // ---------------------
[934]704 QGridLayout* cLayout = new QGridLayout;
[1042]705 cLayout->setColumnMinimumWidth(0,14*ww);
[1678]706 _corrIntrComboBox->setMaximumWidth(9*ww);
707 _corrPortLineEdit->setMaximumWidth(9*ww);
708
[3766]709 cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port."),0,0,1,50);
710 cLayout->addWidget(new QLabel("Directory, ASCII"), 1, 0);
711 cLayout->addWidget(_corrPathLineEdit, 1, 1, 1,20);
712 cLayout->addWidget(new QLabel("Interval"), 2, 0);
713 cLayout->addWidget(_corrIntrComboBox, 2, 1);
714 cLayout->addWidget(new QLabel("Port"), 3, 0);
715 cLayout->addWidget(_corrPortLineEdit, 3, 1);
716 cLayout->addWidget(new QLabel(" "), 4, 0);
717 cLayout->addWidget(new QLabel(" "), 5, 0);
718 cLayout->addWidget(new QLabel(" "), 6, 0);
[934]719 cgroup->setLayout(cLayout);
720
[1678]721 // Feed Engine
722 // -----------
723 QGridLayout* sLayout = new QGridLayout;
724 sLayout->setColumnMinimumWidth(0,14*ww);
725 _outPortLineEdit->setMaximumWidth(9*ww);
726 _waitTimeSpinBox->setMaximumWidth(9*ww);
727 _binSamplSpinBox->setMaximumWidth(9*ww);
728 _outUPortLineEdit->setMaximumWidth(9*ww);
729
[4040]730 sLayout->addWidget(new QLabel("Output decoded observations in ASCII format to feed a real-time GNSS network engine."),0,0,1,50);
[3766]731 sLayout->addWidget(new QLabel("Port"), 1, 0);
732 sLayout->addWidget(_outPortLineEdit, 1, 1);
[4202]733 sLayout->addWidget(new QLabel("Wait for full obs epoch"), 1, 2, Qt::AlignRight);
[3766]734 sLayout->addWidget(_waitTimeSpinBox, 1, 3, Qt::AlignLeft);
735 sLayout->addWidget(new QLabel("Sampling"), 2, 0);
736 sLayout->addWidget(_binSamplSpinBox, 2, 1, Qt::AlignLeft);
737 sLayout->addWidget(new QLabel("File (full path)"), 3, 0);
738 sLayout->addWidget(_outFileLineEdit, 3, 1, 1, 20);
739 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 4, 0);
740 sLayout->addWidget(_outUPortLineEdit, 4, 1);
741 sLayout->addWidget(new QLabel(" "), 5, 0);
742 sLayout->addWidget(new QLabel(" "), 6, 0);
[1678]743 sgroup->setLayout(sLayout);
744
[1746]745 // Serial Output
746 // -------------
[1327]747 QGridLayout* serLayout = new QGridLayout;
[1339]748 serLayout->setColumnMinimumWidth(0,14*ww);
[1678]749 _serialBaudRateComboBox->setMaximumWidth(9*ww);
750 _serialFlowControlComboBox->setMaximumWidth(11*ww);
751 _serialDataBitsComboBox->setMaximumWidth(5*ww);
752 _serialParityComboBox->setMaximumWidth(9*ww);
753 _serialStopBitsComboBox->setMaximumWidth(5*ww);
754 _serialAutoNMEAComboBox->setMaximumWidth(9*ww);
[1595]755 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
[1678]756
[3766]757 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver."),0,0,1,30);
758 serLayout->addWidget(new QLabel("Mountpoint"), 1, 0, Qt::AlignLeft);
759 serLayout->addWidget(_serialMountPointLineEdit, 1, 1, 1, 2);
760 serLayout->addWidget(new QLabel("Port name"), 2, 0, Qt::AlignLeft);
761 serLayout->addWidget(_serialPortNameLineEdit, 2, 1, 1, 2);
762 serLayout->addWidget(new QLabel("Baud rate"), 3, 0, Qt::AlignLeft);
763 serLayout->addWidget(_serialBaudRateComboBox, 3, 1);
764 serLayout->addWidget(new QLabel("Flow control"), 3, 2, Qt::AlignRight);
765 serLayout->addWidget(_serialFlowControlComboBox, 3, 3);
766 serLayout->addWidget(new QLabel("Data bits"), 4, 0, Qt::AlignLeft);
767 serLayout->addWidget(_serialDataBitsComboBox, 4, 1);
768 serLayout->addWidget(new QLabel("Parity"), 4, 2, Qt::AlignRight);
769 serLayout->addWidget(_serialParityComboBox, 4, 3);
770 serLayout->addWidget(new QLabel(" Stop bits"), 4, 4, Qt::AlignRight);
771 serLayout->addWidget(_serialStopBitsComboBox, 4, 5);
772 serLayout->addWidget(new QLabel("NMEA"), 5, 0);
773 serLayout->addWidget(_serialAutoNMEAComboBox, 5, 1);
774 serLayout->addWidget(new QLabel(" File (full path)"), 5, 2, Qt::AlignRight);
775 serLayout->addWidget(_serialFileNMEALineEdit, 5, 3, 1,15);
776 serLayout->addWidget(new QLabel("Height"), 5,20, Qt::AlignRight);
777 serLayout->addWidget(_serialHeightNMEALineEdit, 5,21, 1,11);
778 serLayout->addWidget(new QLabel(" "), 6, 0);
[1329]779
[1327]780 sergroup->setLayout(serLayout);
781
[1678]782 // Outages
783 // -------
784 QGridLayout* aLayout = new QGridLayout;
785 aLayout->setColumnMinimumWidth(0,14*ww);
786 _obsRateComboBox->setMaximumWidth(9*ww);
787 _adviseFailSpinBox->setMaximumWidth(9*ww);
788 _adviseRecoSpinBox->setMaximumWidth(9*ww);
789
[3766]790 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes."),0,0,1,50,Qt::AlignLeft);
791 aLayout->addWidget(new QLabel("Observation rate"), 1, 0);
792 aLayout->addWidget(_obsRateComboBox, 1, 1);
793 aLayout->addWidget(new QLabel("Failure threshold"), 2, 0);
794 aLayout->addWidget(_adviseFailSpinBox, 2, 1);
795 aLayout->addWidget(new QLabel("Recovery threshold"), 3, 0);
796 aLayout->addWidget(_adviseRecoSpinBox, 3, 1);
797 aLayout->addWidget(new QLabel("Script (full path)"), 4, 0);
798 aLayout->addWidget(_adviseScriptLineEdit, 4, 1, 1,30);
[2199]799 aLayout->addWidget(new QLabel(" "), 5, 0);
[3766]800 aLayout->addWidget(new QLabel(" "), 6, 0);
[1678]801 agroup->setLayout(aLayout);
802
803 // Miscellaneous
804 // -------------
805 QGridLayout* rLayout = new QGridLayout;
806 rLayout->setColumnMinimumWidth(0,14*ww);
807 _perfIntrComboBox->setMaximumWidth(9*ww);
[5644]808 _miscPortLineEdit->setMaximumWidth(9*ww);
[1678]809
[5653]810 rLayout->addWidget(new QLabel("Log latencies or scan RTCM streams for message types and antenna information or output raw data through TCP/IP port."),0, 0,1,30);
[3766]811 rLayout->addWidget(new QLabel("Mountpoint"), 1, 0);
812 rLayout->addWidget(_miscMountLineEdit, 1, 1, 1,7);
813 rLayout->addWidget(new QLabel("Log latency"), 2, 0);
814 rLayout->addWidget(_perfIntrComboBox, 2, 1);
815 rLayout->addWidget(new QLabel("Scan RTCM"), 3, 0);
816 rLayout->addWidget(_scanRTCMCheckBox, 3, 1);
[5644]817 rLayout->addWidget(new QLabel("Port"), 4, 0);
818 rLayout->addWidget(_miscPortLineEdit, 4, 1);
[3766]819 rLayout->addWidget(new QLabel(" "), 5, 0);
820 rLayout->addWidget(new QLabel(" "), 6, 0);
[1678]821 rgroup->setLayout(rLayout);
822
[5861]823 // PPP
824 // ---
825 QGridLayout* pppLayout1 = new QGridLayout();
[3731]826 int ir = 0;
[5699]827 pppLayout1->addWidget(new QLabel("<b>Precise Point Positioning (Input and Output)</b>"), ir, 0, 1, 7, Qt::AlignLeft);
[5687]828 ++ir;
829 pppLayout1->addWidget(new QLabel("Data Source"), ir, 0, Qt::AlignLeft);
830 pppLayout1->addWidget(_pppWidgets._dataSource, ir, 1);
[5688]831 pppLayout1->addItem(new QSpacerItem(4*ww, 0), ir, 2);
832 pppLayout1->addWidget(new QLabel("RINEX Observations"), ir, 3, Qt::AlignLeft);
833 pppLayout1->addWidget(_pppWidgets._rinexObs, ir, 4, 1, 2);
[5687]834 ++ir;
[5688]835 pppLayout1->addWidget(new QLabel("RINEX Orbits"), ir, 3, Qt::AlignLeft);
836 pppLayout1->addWidget(_pppWidgets._rinexNav, ir, 4, 1, 2);
[5687]837 ++ir;
838 pppLayout1->addWidget(new QLabel("Corrections"), ir, 0, Qt::AlignLeft);
[5967]839 pppLayout1->addWidget(_pppWidgets._corrMount, ir, 1);
[5688]840 pppLayout1->addWidget(new QLabel("Corrections"), ir, 3, Qt::AlignLeft);
841 pppLayout1->addWidget(_pppWidgets._corrFile, ir, 4, 1, 2);
[5687]842 ++ir;
843 pppLayout1->addWidget(new QLabel("<b>Input</b>"), ir, 0, Qt::AlignLeft);
[5688]844 pppLayout1->addWidget(new QLabel("<b>Output</b>"), ir, 4, 1, 2, Qt::AlignLeft);
[5687]845 ++ir;
846 pppLayout1->addWidget(new QLabel("Coordinates"), ir, 0, Qt::AlignLeft);
[5688]847 pppLayout1->addWidget(_pppWidgets._crdFile, ir, 1, 1, 2);
848 pppLayout1->addWidget(new QLabel("Log File"), ir, 4, Qt::AlignLeft);
849 pppLayout1->addWidget(_pppWidgets._logFile, ir, 5);
[5687]850 ++ir;
851 pppLayout1->addWidget(new QLabel("ANTEX"), ir, 0, Qt::AlignLeft);
[5688]852 pppLayout1->addWidget(_pppWidgets._antexFile, ir, 1, 1, 2);
853 pppLayout1->addWidget(new QLabel("NMEA File"), ir, 4, Qt::AlignLeft);
854 pppLayout1->addWidget(_pppWidgets._nmeaFile, ir, 5);
855 pppLayout1->addWidget(new QLabel("Port"), ir, 6, Qt::AlignLeft);
[5963]856 pppLayout1->addWidget(_pppWidgets._nmeaPort, ir, 7); _pppWidgets._nmeaPort->setMaximumWidth(8*ww);
[5686]857
[5964]858 pppLayout1->addItem(new QSpacerItem(4*ww, 0), ir, 8);
859
[5686]860 pppGroup1->setLayout(pppLayout1);
861
[5689]862 QVBoxLayout* pppLayout2 = new QVBoxLayout();
[5699]863 pppLayout2->addWidget(new QLabel("<b>Precise Point Positioning (Processed Stations)</b>"));
[5689]864 pppLayout2->addWidget(_pppWidgets._staTable, 99);
[5704]865 QHBoxLayout* pppLayout2sub = new QHBoxLayout();
866 pppLayout2sub->addWidget(_pppWidgets._addStaButton);
867 pppLayout2sub->addWidget(_pppWidgets._delStaButton);
[5705]868 pppLayout2sub->addStretch(99);
869
[5704]870 pppLayout2->addLayout(pppLayout2sub);
[5686]871
872 pppGroup2->setLayout(pppLayout2);
873
[5690]874 QGridLayout* pppLayout3 = new QGridLayout();
875 ir = 0;
[5699]876 pppLayout3->addWidget(new QLabel("<b>Precise Point Positioning (Options)</b>"), ir, 0, 1, 2, Qt::AlignLeft);
[5690]877 ++ir;
878 pppLayout3->addWidget(new QLabel("GPS LCs"), ir, 0, Qt::AlignLeft);
879 pppLayout3->addWidget(_pppWidgets._lcGPS, ir, 1);
[5965]880 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 2);
[5690]881 pppLayout3->addWidget(new QLabel("Sigma C1"), ir, 3, Qt::AlignLeft);
882 pppLayout3->addWidget(_pppWidgets._sigmaC1, ir, 4); _pppWidgets._sigmaC1->setMaximumWidth(8*ww);
[5965]883 pppLayout3->addItem(new QSpacerItem(8*ww, 0), ir, 5);
884 pppLayout3->addWidget(new QLabel("Sigma L1"), ir, 6, Qt::AlignLeft);
885 pppLayout3->addWidget(_pppWidgets._sigmaL1, ir, 7); _pppWidgets._sigmaL1->setMaximumWidth(8*ww);
[5690]886 ++ir;
887 pppLayout3->addWidget(new QLabel("GLONASS LCs"), ir, 0, Qt::AlignLeft);
888 pppLayout3->addWidget(_pppWidgets._lcGLONASS, ir, 1);
[5963]889 pppLayout3->addWidget(new QLabel("Max Res C1"), ir, 3, Qt::AlignLeft);
890 pppLayout3->addWidget(_pppWidgets._maxResC1, ir, 4); _pppWidgets._maxResC1->setMaximumWidth(8*ww);
[5965]891 pppLayout3->addWidget(new QLabel("Max Res L1"), ir, 6, Qt::AlignLeft);
892 pppLayout3->addWidget(_pppWidgets._maxResL1, ir, 7); _pppWidgets._maxResL1->setMaximumWidth(8*ww);
[5690]893 ++ir;
894 pppLayout3->addWidget(new QLabel("Galileo LCs"), ir, 0, Qt::AlignLeft);
895 pppLayout3->addWidget(_pppWidgets._lcGalileo, ir, 1);
[5963]896 pppLayout3->addWidget(new QLabel("Ele Wgt Code"), ir, 3, Qt::AlignLeft);
897 pppLayout3->addWidget(_pppWidgets._eleWgtCode, ir, 4);
[5965]898 pppLayout3->addWidget(new QLabel("Ele Wgt Phase"), ir, 6, Qt::AlignLeft);
899 pppLayout3->addWidget(_pppWidgets._eleWgtPhase, ir, 7);
[5690]900 ++ir;
901 pppLayout3->addWidget(new QLabel("Wait for corrections"), ir, 0, Qt::AlignLeft);
902 pppLayout3->addWidget(_pppWidgets._corrWaitTime, ir, 1);
[5963]903 pppLayout3->addWidget(new QLabel("Min # of Obs"), ir, 3, Qt::AlignLeft);
904 pppLayout3->addWidget(_pppWidgets._minObs, ir, 4);
[5965]905 pppLayout3->addWidget(new QLabel("Min Elevation"), ir, 6, Qt::AlignLeft);
906 pppLayout3->addWidget(_pppWidgets._minEle, ir, 7);
[5691]907 ++ir;
[5968]908 pppLayout3->addWidget(new QLabel("Seeding (seconds)"), ir, 0, Qt::AlignLeft);
[5963]909 pppLayout3->addWidget(_pppWidgets._seedingTime, ir, 1);
910 ++ir;
[5965]911 pppLayout3->addWidget(new QLabel(""), ir, 8);
912 pppLayout3->setColumnStretch(8, 999);
[5690]913
914 pppGroup3->setLayout(pppLayout3);
915
[5861]916 // ------------------------
917 QVBoxLayout* pppLayout4 = new QVBoxLayout;
[5893]918 pppLayout4->addWidget(new QLabel("<b>Precise Point Positioning (Plots)</b>"));
[5861]919 pppLayout4->addSpacing(ww);
920
921 QHBoxLayout* pppLayout4Hlp1 = new QHBoxLayout;
[5896]922 pppLayout4Hlp1->addWidget(new QLabel("PPP Station "));
923 _pppWidgets._plotCoordinates->setMaximumWidth(8*ww);
[5895]924 pppLayout4Hlp1->addWidget(_pppWidgets._plotCoordinates);
[5861]925 pppLayout4Hlp1->addWidget(new QLabel("Nort-East-Up Time Series"));
926 pppLayout4Hlp1->addStretch();
927 pppLayout4->addLayout(pppLayout4Hlp1);
928 pppLayout4->addSpacing(ww);
929
930 QHBoxLayout* pppLayout4Hlp2 = new QHBoxLayout;
931 pppLayout4Hlp2->addWidget(new QLabel("Track Plot "));
[5895]932 connect(_pppWidgets._mapWinButton, SIGNAL(clicked()), SLOT(slotMapPPP()));
933 pppLayout4Hlp2->addWidget(_pppWidgets._mapWinButton);
[5861]934
935 pppLayout4Hlp2->addSpacing(1*ww);
936
937 pppLayout4Hlp2->addWidget(new QLabel("Google"));
[5955]938 pppLayout4Hlp2->addWidget(_pppWidgets._useGoogleMap);
[5861]939
940 pppLayout4Hlp2->addWidget(new QLabel("OSM"));
[5955]941 pppLayout4Hlp2->addWidget(_pppWidgets._useOpenStreetMap);
[5861]942
943 pppLayout4Hlp2->addSpacing(3*ww);
944
[5955]945 _pppWidgets._mapWinDotSize->setMaximumWidth(5*ww);
946 pppLayout4Hlp2->addWidget(_pppWidgets._mapWinDotSize);
[5861]947
948 pppLayout4Hlp2->addSpacing(3*ww);
949
[5955]950 pppLayout4Hlp2->addWidget(_pppWidgets._mapWinDotColor);
[5861]951
952 pppLayout4Hlp2->addSpacing(3*ww);
953
954 pppLayout4Hlp2->addWidget(new QLabel("Speed"));
[5895]955 pppLayout4Hlp2->addWidget(_pppWidgets._mapSpeedSlider);
[5861]956
957 pppLayout4Hlp2->addStretch();
958 pppLayout4->addLayout(pppLayout4Hlp2);
959
960 pppLayout4->addStretch();
961 pppGroup4->setLayout(pppLayout4);
962
[3897]963 // Reqc Processing
[3729]964 // ---------------
[3897]965 _reqcActionComboBox = new QComboBox();
966 _reqcActionComboBox->setEditable(false);
967 _reqcActionComboBox->addItems(QString(",Edit/Concatenate,Analyze").split(","));
[5861]968 int ik = _reqcActionComboBox->findText(settings.value("reqcAction").toString());
[3731]969 if (ik != -1) {
[3897]970 _reqcActionComboBox->setCurrentIndex(ik);
[3731]971 }
[3897]972 connect(_reqcActionComboBox, SIGNAL(currentIndexChanged(const QString &)),
[3739]973 this, SLOT(slotBncTextChanged()));
[3729]974
[3897]975 QGridLayout* reqcLayout = new QGridLayout;
976 _reqcActionComboBox->setMinimumWidth(15*ww);
977 _reqcActionComboBox->setMaximumWidth(15*ww);
[3612]978
[3897]979 _reqcObsFileChooser = new qtFileChooser(0, qtFileChooser::Files);
980 _reqcObsFileChooser->setFileName(settings.value("reqcObsFile").toString());
981 _reqcObsFileChooser->setWhatsThis(tr("Specify the full path to an observation file in RINEX v2 or v3 format."));
982 _reqcObsFileChooser->setMinimumWidth(15*ww);
983 _reqcObsFileChooser->setMaximumWidth(15*ww);
[3612]984
[3897]985 _reqcNavFileChooser = new qtFileChooser(0, qtFileChooser::Files);
986 _reqcNavFileChooser->setFileName(settings.value("reqcNavFile").toString());
987 _reqcNavFileChooser->setWhatsThis(tr("Specify the full path to a RINEX v2 or v3 navigation file."));
988 _reqcNavFileChooser->setMinimumWidth(15*ww);
989 _reqcNavFileChooser->setMaximumWidth(15*ww);
[3602]990
[3897]991 _reqcOutObsLineEdit = new QLineEdit(settings.value("reqcOutObsFile").toString());
[4530]992 _reqcOutObsLineEdit->setWhatsThis(tr("Specify the full path to a RINEX observation output file."));
[3897]993 _reqcOutObsLineEdit->setMinimumWidth(15*ww);
994 _reqcOutObsLineEdit->setMaximumWidth(15*ww);
[2473]995
[3897]996 _reqcOutNavLineEdit = new QLineEdit(settings.value("reqcOutNavFile").toString());
[4530]997 _reqcOutNavLineEdit->setWhatsThis(tr("Specify the full path to a RINEX navigation output file."));
[3897]998 _reqcOutNavLineEdit->setMinimumWidth(15*ww);
999 _reqcOutNavLineEdit->setMaximumWidth(15*ww);
[3823]1000
[3897]1001 _reqcOutLogLineEdit = new QLineEdit(settings.value("reqcOutLogFile").toString());
[4530]1002 _reqcOutLogLineEdit->setWhatsThis(tr("Specify the full path to a logfile."));
[3897]1003 _reqcOutLogLineEdit->setMinimumWidth(15*ww);
1004 _reqcOutLogLineEdit->setMaximumWidth(15*ww);
[3823]1005
[4449]1006 _reqcPlotDirLineEdit = new QLineEdit(settings.value("reqcPlotDir").toString());
[4530]1007 _reqcPlotDirLineEdit->setWhatsThis(tr("Specify the directory name for saving plots."));
[4449]1008 _reqcPlotDirLineEdit->setMinimumWidth(15*ww);
1009 _reqcPlotDirLineEdit->setMaximumWidth(15*ww);
1010
[5144]1011 _reqcSkyPlotSystems = new QComboBox();
1012 _reqcSkyPlotSystems->setEditable(false);
[6320]1013 _reqcSkyPlotSystems->addItems(QString(",ALL,GPS,GLONASS,Galileo,QZSS,SBAS,BDS").split(","));
[5144]1014 ik = _reqcSkyPlotSystems->findText(settings.value("reqcSkyPlotSystems").toString());
1015 if (ik != -1) {
1016 _reqcSkyPlotSystems->setCurrentIndex(ik);
1017 }
[6318]1018 connect(_reqcSkyPlotSystems, SIGNAL(currentIndexChanged(const QString &)),
1019 this, SLOT(slotBncTextChanged()));
[5144]1020
[6299]1021 _reqcLogSummaryOnly = new QCheckBox();
1022 _reqcLogSummaryOnly->setCheckState(Qt::CheckState(settings.value("reqcLogSummaryOnly").toInt()));
1023
[3738]1024 ir = 0;
[3904]1025 reqcLayout->addWidget(new QLabel("RINEX file editing, concatenation and quality check."),ir, 0, 1, 20);
[3768]1026 ++ir;
[3897]1027 reqcLayout->addWidget(new QLabel("Action"), ir, 0, Qt::AlignLeft);
1028 reqcLayout->addWidget(_reqcActionComboBox, ir, 1, Qt::AlignLeft);
1029 _reqcEditOptionButton = new QPushButton("Set Edit Options");
1030 reqcLayout->addWidget(_reqcEditOptionButton, ir, 3, Qt::AlignRight);
[3738]1031 ++ir;
[3897]1032 reqcLayout->addWidget(new QLabel("Input files (full path)"), ir, 0, Qt::AlignLeft);
1033 reqcLayout->addWidget(_reqcObsFileChooser, ir, 1, Qt::AlignRight);
1034 reqcLayout->addWidget(new QLabel("Obs"), ir, 2, Qt::AlignLeft);
1035 reqcLayout->addWidget(_reqcNavFileChooser, ir, 3, Qt::AlignRight);
1036 reqcLayout->addWidget(new QLabel("Nav"), ir, 4, Qt::AlignLeft);
[3738]1037 ++ir;
[3897]1038 reqcLayout->addWidget(new QLabel("Output files (full path)"), ir, 0, Qt::AlignLeft);
1039 reqcLayout->addWidget(_reqcOutObsLineEdit, ir, 1, Qt::AlignRight);
1040 reqcLayout->addWidget(new QLabel("Obs"), ir, 2, Qt::AlignLeft);
1041 reqcLayout->addWidget(_reqcOutNavLineEdit, ir, 3, Qt::AlignRight);
1042 reqcLayout->addWidget(new QLabel("Nav"), ir, 4, Qt::AlignLeft);
[3768]1043 ++ir;
[6299]1044 reqcLayout->addWidget(new QLabel("Log File"), ir, 0, Qt::AlignLeft);
[3897]1045 reqcLayout->addWidget(_reqcOutLogLineEdit, ir, 1, Qt::AlignRight);
[6299]1046 reqcLayout->addWidget(new QLabel("summary only"), ir, 3, Qt::AlignRight);
1047 reqcLayout->addWidget(_reqcLogSummaryOnly, ir, 4, Qt::AlignLeft);
[3768]1048 ++ir;
[4460]1049 reqcLayout->addWidget(new QLabel("Directory for plots"), ir, 0, Qt::AlignLeft);
[4449]1050 reqcLayout->addWidget(_reqcPlotDirLineEdit, ir, 1, Qt::AlignRight);
1051 ++ir;
[5147]1052 reqcLayout->addWidget(new QLabel("Sky plots for"), ir, 0, Qt::AlignLeft);
[5145]1053 reqcLayout->addWidget(_reqcSkyPlotSystems, ir, 1, Qt::AlignRight);
1054 ++ir;
[3897]1055 reqcLayout->addWidget(new QLabel(""), ir, 1);
1056 reqcLayout->setRowStretch(ir, 999);
[2876]1057
[3897]1058 reqcLayout->setColumnMinimumWidth(2, 8*ww);
1059 reqcLayout->setColumnMinimumWidth(4, 8*ww);
[3823]1060
[3897]1061 reqcgroup->setLayout(reqcLayout);
[3731]1062
[3897]1063 connect(_reqcEditOptionButton, SIGNAL(clicked()),
1064 this, SLOT(slotReqcEditOption()));
[3740]1065
[6332]1066 QGridLayout* sp3CompLayout = new QGridLayout;
1067
1068 _sp3CompFileChooser = new qtFileChooser(0, qtFileChooser::Files);
1069 _sp3CompFileChooser->setFileName(settings.value("sp3CompFile").toString());
1070 _sp3CompFileChooser->setWhatsThis(tr("Specify the full path to orbits in SP3 format"));
1071 _sp3CompFileChooser->setMinimumWidth(15*ww);
1072 _sp3CompFileChooser->setMaximumWidth(15*ww);
1073
1074 _sp3CompLogLineEdit = new QLineEdit(settings.value("sp3CompOutLogFile").toString());
1075 _sp3CompLogLineEdit->setWhatsThis(tr("Specify the full path to a logfile."));
1076 _sp3CompLogLineEdit->setMinimumWidth(15*ww);
1077 _sp3CompLogLineEdit->setMaximumWidth(15*ww);
1078
1079 ir = 0;
1080 sp3CompLayout->addWidget(new QLabel("Orbit and Clock Comparison"), ir, 0, 1, 20);
1081 ++ir;
1082 sp3CompLayout->addWidget(new QLabel("Input SP3 files (full path)"), ir, 0, Qt::AlignLeft);
1083 sp3CompLayout->addWidget(_sp3CompFileChooser, ir, 1, Qt::AlignRight);
1084 ++ir;
1085 sp3CompLayout->addWidget(new QLabel("Log File"), ir, 0, Qt::AlignLeft);
1086 sp3CompLayout->addWidget(_sp3CompLogLineEdit, ir, 1, Qt::AlignRight);
1087 ++ir;
1088 sp3CompLayout->addWidget(new QLabel(""), ir, 1);
1089 sp3CompLayout->setRowStretch(ir, 999);
1090
1091 sp3CompLayout->setColumnMinimumWidth(2, 8*ww);
1092 sp3CompLayout->setColumnMinimumWidth(4, 8*ww);
1093
1094 sp3CompGroup->setLayout(sp3CompLayout);
1095
[4185]1096 // Combine Corrections
1097 // -------------------
[2868]1098 QGridLayout* cmbLayout = new QGridLayout;
1099
[3731]1100 populateCmbTable();
[4106]1101 cmbLayout->addWidget(_cmbTable, 0, 0, 6, 3);
1102 cmbLayout->addWidget(new QLabel(" "), 0, 5);
[6172]1103 cmbLayout->addWidget(new QLabel("Combine Broadcast Correction streams."), 0, 6, 1, 10);
[4106]1104 cmbLayout->addWidget(new QLabel(" "), 1, 5);
1105 cmbLayout->addWidget(addCmbRowButton, 1, 6);
1106 cmbLayout->addWidget(delCmbRowButton, 1, 7);
1107 cmbLayout->addWidget(new QLabel(" "), 2, 5);
1108 cmbLayout->addWidget(new QLabel("Method"), 2, 6, Qt::AlignRight);
1109 cmbLayout->addWidget(_cmbMethodComboBox, 2, 7, Qt::AlignRight);
1110 cmbLayout->addWidget(new QLabel(" "), 3, 5);
1111 cmbLayout->addWidget(new QLabel("Maximal Residuum"), 3, 6, Qt::AlignRight);
1112 cmbLayout->addWidget(_cmbMaxresLineEdit, 3, 7, Qt::AlignRight);
[6172]1113 cmbLayout->addWidget(new QLabel("ANTEX"), 3, 9, Qt::AlignRight);
1114 cmbLayout->addWidget(_cmbAntexFile, 3, 10);
[4180]1115 cmbLayout->addWidget(new QLabel(" "), 4, 5);
1116 cmbLayout->addWidget(new QLabel("Sampling"), 4, 6, Qt::AlignRight);
1117 cmbLayout->addWidget(_cmbSamplSpinBox, 4, 7, Qt::AlignRight);
[6172]1118 cmbLayout->addWidget(new QLabel("Use Glonass"), 4, 9, Qt::AlignRight);
1119 cmbLayout->addWidget(_cmbUseGlonass, 4, 10);
[4180]1120 cmbLayout->addWidget(new QLabel(" "), 5, 0);
[3729]1121
[2869]1122 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
1123 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
[2868]1124
1125 cmbgroup->setLayout(cmbLayout);
1126
[3241]1127 // Upload Layout (Clocks)
1128 // ----------------------
[3193]1129 QGridLayout* uploadHlpLayout = new QGridLayout();
[3152]1130
[3164]1131 connect(addUploadRowButton, SIGNAL(clicked()), this, SLOT(slotAddUploadRow()));
1132 connect(delUploadRowButton, SIGNAL(clicked()), this, SLOT(slotDelUploadRow()));
1133 connect(setUploadTrafoButton, SIGNAL(clicked()), this, SLOT(slotSetUploadTrafo()));
[3160]1134
[4175]1135 uploadHlpLayout->addWidget(addUploadRowButton, 0, 0);
1136 uploadHlpLayout->addWidget(delUploadRowButton, 0, 1);
1137 uploadHlpLayout->addWidget(new QLabel("Interval"), 0, 2, Qt::AlignRight);
1138 uploadHlpLayout->addWidget(_uploadIntrComboBox, 0, 3);
1139 uploadHlpLayout->addWidget(new QLabel(" Sampling: Orb"), 0, 4, Qt::AlignRight);
1140 uploadHlpLayout->addWidget(_uploadSamplRtcmEphCorrSpinBox, 0, 5);
1141 uploadHlpLayout->addWidget(new QLabel("SP3"), 0, 6, Qt::AlignRight);
1142 uploadHlpLayout->addWidget(_uploadSamplSp3SpinBox, 0, 7);
1143 uploadHlpLayout->addWidget(new QLabel("RNX"), 0, 8, Qt::AlignRight);
1144 uploadHlpLayout->addWidget(_uploadSamplClkRnxSpinBox, 0, 9);
1145 uploadHlpLayout->addWidget(setUploadTrafoButton, 0,10);
[3197]1146
[3193]1147 QBoxLayout* uploadLayout = new QBoxLayout(QBoxLayout::TopToBottom);
1148 populateUploadTable();
[3767]1149
[4186]1150 uploadLayout->addWidget(new QLabel("Upload RTCMv3 Broadcast Corrections to caster."));
[3193]1151 uploadLayout->addWidget(_uploadTable);
1152 uploadLayout->addLayout(uploadHlpLayout);
[3152]1153
[3164]1154 uploadgroup->setLayout(uploadLayout);
[3152]1155
[3241]1156 // Upload Layout (Ephemeris)
1157 // -------------------------
1158 QGridLayout* uploadLayoutEph = new QGridLayout;
1159
1160 uploadLayoutEph->setColumnMinimumWidth(0, 9*ww);
1161 _uploadEphPortLineEdit->setMaximumWidth(9*ww);
1162 _uploadEphPasswordLineEdit->setMaximumWidth(9*ww);
1163 _uploadEphMountpointLineEdit->setMaximumWidth(12*ww);
1164
[3779]1165 uploadLayoutEph->addWidget(new QLabel("Upload concatenated RTCMv3 Broadcast Ephemeris to caster."), 0, 0, 1, 50);
[3768]1166 uploadLayoutEph->addWidget(new QLabel("Host"), 1, 0);
1167 uploadLayoutEph->addWidget(_uploadEphHostLineEdit, 1, 1, 1, 3);
1168 uploadLayoutEph->addWidget(new QLabel(" Port"), 1, 4, Qt::AlignRight);
1169 uploadLayoutEph->addWidget(_uploadEphPortLineEdit, 1, 5, 1, 1);
1170 uploadLayoutEph->addWidget(new QLabel("Mountpoint "), 2, 0);
1171 uploadLayoutEph->addWidget(_uploadEphMountpointLineEdit, 2, 1);
1172 uploadLayoutEph->addWidget(new QLabel(" Password"), 2, 2, Qt::AlignRight);
1173 uploadLayoutEph->addWidget(_uploadEphPasswordLineEdit, 2, 3);
1174 uploadLayoutEph->addWidget(new QLabel("Sampling"), 3, 0);
1175 uploadLayoutEph->addWidget(_uploadEphSampleSpinBox, 3, 1);
1176 uploadLayoutEph->addWidget(new QLabel("Uploaded"), 4, 0);
1177 uploadLayoutEph->addWidget(_uploadEphBytesCounter, 4, 1);
1178 uploadLayoutEph->addWidget(new QLabel(" "), 5, 0);
1179 uploadLayoutEph->addWidget(new QLabel(" "), 6, 0);
[3241]1180
[3731]1181 uploadEphgroup->setLayout(uploadLayoutEph);
[3241]1182
1183 connect(_uploadEphHostLineEdit, SIGNAL(textChanged(const QString &)),
1184 this, SLOT(slotBncTextChanged()));
1185
[1678]1186 // Main Layout
1187 // -----------
[1409]1188 QGridLayout* mLayout = new QGridLayout;
[1925]1189 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
[1926]1190 mLayout->addWidget(_aogroup, 0,0);
[1409]1191 mLayout->addWidget(_mountPointsTable, 1,0);
[1947]1192 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
[1926]1193 mLayout->addWidget(_loggroup, 2,0);
[106]1194
[679]1195 _canvas->setLayout(mLayout);
[1333]1196
[3731]1197 // WhatsThis
1198 // ---------
1199 _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>"));
1200 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
1201 _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>"));
1202 _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]1203 _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]1204 _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."));
1205 _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."));
1206 _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."));
1207 _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."));
1208 _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."));
1209 _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."));
1210 _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."));
1211 _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."));
1212 _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>"));
1213 _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>"));
1214 _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>"));
1215 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
1216 _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p>"));
[4537]1217 _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]1218 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
1219 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
1220 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of the Broadcast Ephemeris Correction files.</p>"));
1221 _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>"));
1222 _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>"));
1223 _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>"));
1224 _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>"));
1225 _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>"));
1226 _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."));
1227 _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>"));
1228 _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]1229 _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]1230 _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."));
1231 _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)."));
1232 _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]1233 _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."));
1234 _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."));
[6266]1235
1236 _rnxV2Priority->setWhatsThis(tr("Test."));
1237
[3731]1238 _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]1239 _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]1240 _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]1241 _serialMountPointLineEdit->setWhatsThis(tr("<p>Enter a 'Mountpoint' to forward the corresponding stream to a serial connected receiver.</p>"));
1242 _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>"));
1243 _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>"));
1244 _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>"));
1245 _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>"));
1246 _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>"));
1247 _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>"));
1248 _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>"));
1249 _serialFileNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where NMEA messages coming from your serial connected receiver are saved.</p>"));
1250 _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]1251 _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]1252 _reqcEditOptionButton->setWhatsThis(tr("<p>Specify options for editing RINEX v2 or v3 files.</p>"));
[3731]1253 _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]1254 _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]1255 _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>"));
[4185]1256 _cmbSamplSpinBox->setWhatsThis(tr("<p>Specify a combination sampling interval. Clock and orbit corrections will be produced following that interval. A value of 10 sec may be an appropriate choice.</p>"));
[3731]1257 _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]1258 _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]1259 addCmbRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the mountpoints table."));
1260 delCmbRowButton->setWhatsThis(tr("Hit 'Delete' button to delete the highlighted line from the mountpoints table."));
[3797]1261 addUploadRowButton->setWhatsThis(tr("Hit 'Add Row' button to add another line to the stream upload table."));
1262 delUploadRowButton->setWhatsThis(tr("Hit 'Del Row' button to delete the highlighted line from the stream upload table."));
1263 _uploadIntrComboBox->setWhatsThis(tr("Select the length of the SP3 and Clock RINEX files."));
[4237]1264 _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]1265 _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]1266 _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]1267 setUploadTrafoButton->setWhatsThis(tr("Hit 'Custom Trafo' to specify your own 14 parameter Helmert Transformation instead of selecting a predefined transformation through 'System' button."));
[3800]1268 _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."));
1269 _uploadEphPortLineEdit->setWhatsThis(tr("Specify the IP port of an NTRIP Broadcaster to upload the stream. Default is port 80."));
1270 _uploadEphMountpointLineEdit->setWhatsThis(tr("Specify the mounpoint for stream upload to an NTRIP Broadcaster."));
1271 _uploadEphPasswordLineEdit->setWhatsThis(tr("Specify the stream upload password protecting the mounpoint on an NTRIP Broadcaster."));
1272 _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."));
1273 _uploadEphBytesCounter->setWhatsThis(tr("BNC shows the amount of data uploaded through this stream."));
[4655]1274 _actDeleteMountPoints->setWhatsThis(tr("<p>Delete stream(s) from selection presented in the 'Streams' canvas.</p>"));
1275 _actAddMountPoints->setWhatsThis(tr("<p>Add stream(s) to selection presented in the 'Streams' canvas.</p>"));
[5162]1276 _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]1277 _actStart->setWhatsThis(tr("<p> Start running BNC.</p>"));
1278 _actStop->setWhatsThis(tr("<p> Stop running BNC.</p>"));
1279// Weber
1280
[2129]1281 // Enable/Disable all Widgets
1282 // --------------------------
1283 slotBncTextChanged();
[3788]1284 enableStartStop();
[2129]1285
[1333]1286 // Auto start
1287 // ----------
1288 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
[3782]1289 slotStart();
[1333]1290 }
[35]1291}
1292
1293// Destructor
1294////////////////////////////////////////////////////////////////////////////
1295bncWindow::~bncWindow() {
[5729]1296 delete _caster; BNC_CORE->setCaster(0);
[3249]1297 delete _casterEph;
[35]1298}
1299
[1178]1300//
1301////////////////////////////////////////////////////////////////////////////
1302void bncWindow::populateMountPointsTable() {
1303
1304 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
1305 _mountPointsTable->removeRow(iRow);
1306 }
1307
[1535]1308 bncSettings settings;
[1178]1309
1310 QListIterator<QString> it(settings.value("mountPoints").toStringList());
1311 int iRow = 0;
1312 while (it.hasNext()) {
1313 QStringList hlp = it.next().split(" ");
1314 if (hlp.size() < 5) continue;
1315 _mountPointsTable->insertRow(iRow);
1316
1317 QUrl url(hlp[0]);
1318
1319 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1320 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1321 QString nmea(hlp[4]);
[1738]1322 if (hlp[5] == "S") {
1323 fullPath = hlp[0].replace(0,2,"");
1324 }
[3333]1325 QString ntripVersion = "2";
[1352]1326 if (hlp.size() >= 6) {
1327 ntripVersion = (hlp[5]);
1328 }
[1178]1329
1330 QTableWidgetItem* it;
1331 it = new QTableWidgetItem(url.userInfo());
1332 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1333 _mountPointsTable->setItem(iRow, 0, it);
1334
1335 it = new QTableWidgetItem(fullPath);
1336 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1337 _mountPointsTable->setItem(iRow, 1, it);
1338
1339 it = new QTableWidgetItem(format);
1340 _mountPointsTable->setItem(iRow, 2, it);
1341
1342 if (nmea == "yes") {
1343 it = new QTableWidgetItem(latitude);
1344 _mountPointsTable->setItem(iRow, 3, it);
1345 it = new QTableWidgetItem(longitude);
1346 _mountPointsTable->setItem(iRow, 4, it);
1347 } else {
1348 it = new QTableWidgetItem(latitude);
1349 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1350 _mountPointsTable->setItem(iRow, 3, it);
1351 it = new QTableWidgetItem(longitude);
1352 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1353 _mountPointsTable->setItem(iRow, 4, it);
1354 }
1355
1356 it = new QTableWidgetItem(nmea);
1357 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1358 _mountPointsTable->setItem(iRow, 5, it);
1359
[1352]1360 it = new QTableWidgetItem(ntripVersion);
[1511]1361 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
[1352]1362 _mountPointsTable->setItem(iRow, 6, it);
1363
[1178]1364 bncTableItem* bncIt = new bncTableItem();
1365 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
[1352]1366 _mountPointsTable->setItem(iRow, 7, bncIt);
[1178]1367
1368 iRow++;
1369 }
1370
1371 _mountPointsTable->sortItems(1);
[3787]1372
1373 enableStartStop();
[1178]1374}
1375
[35]1376// Retrieve Table
1377////////////////////////////////////////////////////////////////////////////
1378void bncWindow::slotAddMountPoints() {
[101]1379
[1535]1380 bncSettings settings;
[101]1381 QString proxyHost = settings.value("proxyHost").toString();
1382 int proxyPort = settings.value("proxyPort").toInt();
1383 if (proxyHost != _proxyHostLineEdit->text() ||
1384 proxyPort != _proxyPortLineEdit->text().toInt()) {
[102]1385 int iRet = QMessageBox::question(this, "Question", "Proxy options "
[101]1386 "changed. Use the new ones?",
1387 QMessageBox::Yes, QMessageBox::No,
1388 QMessageBox::NoButton);
1389 if (iRet == QMessageBox::Yes) {
1390 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1391 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1392 }
1393 }
1394
[3367]1395 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1396 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1397
[1609]1398 QMessageBox msgBox;
1399 msgBox.setIcon(QMessageBox::Question);
[1874]1400 msgBox.setWindowTitle("Add Stream");
[1609]1401 msgBox.setText("Add stream(s) coming from:");
1402
[1780]1403 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1404 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1405 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1406 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1407 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
[1609]1408
1409 msgBox.exec();
1410
1411 if (msgBox.clickedButton() == buttonNtrip) {
[1737]1412 bncTableDlg* dlg = new bncTableDlg(this);
[1609]1413 dlg->move(this->pos().x()+50, this->pos().y()+50);
[1737]1414 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
[35]1415 this, SLOT(slotNewMountPoints(QStringList*)));
[1609]1416 dlg->exec();
1417 delete dlg;
1418 } else if (msgBox.clickedButton() == buttonIP) {
[1737]1419 bncIpPort* ipp = new bncIpPort(this);
1420 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
[1609]1421 this, SLOT(slotNewMountPoints(QStringList*)));
1422 ipp->exec();
1423 delete ipp;
[1780]1424 } else if (msgBox.clickedButton() == buttonUDP) {
1425 bncUdpPort* udp = new bncUdpPort(this);
1426 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1427 this, SLOT(slotNewMountPoints(QStringList*)));
1428 udp->exec();
1429 delete udp;
[1737]1430 } else if (msgBox.clickedButton() == buttonSerial) {
1431 bncSerialPort* sep = new bncSerialPort(this);
1432 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1433 this, SLOT(slotNewMountPoints(QStringList*)));
1434 sep->exec();
1435 delete sep;
[1609]1436 } else if (msgBox.clickedButton() == buttonCancel) {
1437 // Cancel
1438 }
[3787]1439
1440 enableStartStop();
[35]1441}
1442
1443// Delete Selected Mount Points
1444////////////////////////////////////////////////////////////////////////////
1445void bncWindow::slotDeleteMountPoints() {
[117]1446
1447 int nRows = _mountPointsTable->rowCount();
1448 bool flg[nRows];
1449 for (int iRow = 0; iRow < nRows; iRow++) {
[116]1450 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
[117]1451 flg[iRow] = true;
1452 }
1453 else {
1454 flg[iRow] = false;
1455 }
1456 }
1457 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1458 if (flg[iRow]) {
[116]1459 _mountPointsTable->removeRow(iRow);
[83]1460 }
1461 }
1462 _actDeleteMountPoints->setEnabled(false);
[183]1463
[3787]1464 enableStartStop();
[35]1465}
1466
1467// New Mount Points Selected
1468////////////////////////////////////////////////////////////////////////////
1469void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1470 int iRow = 0;
1471 QListIterator<QString> it(*mountPoints);
1472 while (it.hasNext()) {
[59]1473 QStringList hlp = it.next().split(" ");
[110]1474 QUrl url(hlp[0]);
1475 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
[366]1476 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1477 QString nmea(hlp[4]);
[1738]1478 if (hlp[5] == "S") {
1479 fullPath = hlp[0].replace(0,2,"");
1480 }
[3333]1481 QString ntripVersion = "2";
[1352]1482 if (hlp.size() >= 6) {
1483 ntripVersion = (hlp[5]);
1484 }
[110]1485
[35]1486 _mountPointsTable->insertRow(iRow);
[110]1487
1488 QTableWidgetItem* it;
1489 it = new QTableWidgetItem(url.userInfo());
[115]1490 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
[110]1491 _mountPointsTable->setItem(iRow, 0, it);
1492
1493 it = new QTableWidgetItem(fullPath);
[115]1494 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
[110]1495 _mountPointsTable->setItem(iRow, 1, it);
1496
1497 it = new QTableWidgetItem(format);
1498 _mountPointsTable->setItem(iRow, 2, it);
[184]1499
[410]1500 if (nmea == "yes") {
[366]1501 it = new QTableWidgetItem(latitude);
1502 _mountPointsTable->setItem(iRow, 3, it);
1503 it = new QTableWidgetItem(longitude);
1504 _mountPointsTable->setItem(iRow, 4, it);
1505 } else {
1506 it = new QTableWidgetItem(latitude);
1507 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1508 _mountPointsTable->setItem(iRow, 3, it);
1509 it = new QTableWidgetItem(longitude);
1510 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1511 _mountPointsTable->setItem(iRow, 4, it);
1512 }
1513
1514 it = new QTableWidgetItem(nmea);
1515 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1516 _mountPointsTable->setItem(iRow, 5, it);
1517
[1352]1518 it = new QTableWidgetItem(ntripVersion);
1519 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1520 _mountPointsTable->setItem(iRow, 6, it);
1521
[184]1522 bncTableItem* bncIt = new bncTableItem();
[1352]1523 _mountPointsTable->setItem(iRow, 7, bncIt);
[184]1524
[35]1525 iRow++;
1526 }
[111]1527 _mountPointsTable->hideColumn(0);
[110]1528 _mountPointsTable->sortItems(1);
[35]1529 delete mountPoints;
[3787]1530
1531 enableStartStop();
[35]1532}
1533
[4076]1534// Save Options (serialize)
[35]1535////////////////////////////////////////////////////////////////////////////
1536void bncWindow::slotSaveOptions() {
[4076]1537 saveOptions();
1538 bncSettings settings;
1539 settings.sync();
1540}
[1504]1541
[4076]1542// Save Options (memory only)
1543////////////////////////////////////////////////////////////////////////////
1544void bncWindow::saveOptions() {
1545
[1504]1546 QStringList mountPoints;
1547 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1548
[1739]1549 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1550 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1551 "@" + _mountPointsTable->item(iRow, 1)->text() );
1552
1553 mountPoints.append(url.toString() + " " +
1554 _mountPointsTable->item(iRow, 2)->text()
1555 + " " + _mountPointsTable->item(iRow, 3)->text()
1556 + " " + _mountPointsTable->item(iRow, 4)->text()
1557 + " " + _mountPointsTable->item(iRow, 5)->text()
1558 + " " + _mountPointsTable->item(iRow, 6)->text());
1559 } else {
1560 mountPoints.append(
1561 "//" + _mountPointsTable->item(iRow, 1)->text()
1562 + " " + _mountPointsTable->item(iRow, 2)->text()
1563 + " " + _mountPointsTable->item(iRow, 3)->text()
1564 + " " + _mountPointsTable->item(iRow, 4)->text()
1565 + " " + _mountPointsTable->item(iRow, 5)->text()
1566 + " " + _mountPointsTable->item(iRow, 6)->text());
1567 }
[1504]1568 }
1569
[2870]1570 QStringList combineStreams;
1571 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1572 QString hlp;
1573 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
[2965]1574 if (_cmbTable->item(iRow, iCol)) {
1575 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1576 }
[2870]1577 }
[2965]1578 if (!hlp.isEmpty()) {
1579 combineStreams << hlp;
1580 }
[2870]1581 }
1582
[3164]1583 QStringList uploadMountpointsOut;
1584 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
[3153]1585 QString hlp;
[3164]1586 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
1587 if (_uploadTable->cellWidget(iRow, iCol) &&
[3158]1588 (iCol == 3 || iCol == 4 || iCol == 5)) {
1589 if (iCol == 3) {
[3164]1590 QLineEdit* passwd = (QLineEdit*)(_uploadTable->cellWidget(iRow, iCol));
[3158]1591 hlp += passwd->text() + ",";
1592 }
1593 else if (iCol == 4) {
[3164]1594 QComboBox* system = (QComboBox*)(_uploadTable->cellWidget(iRow, iCol));
[3158]1595 hlp += system->currentText() + ",";
1596 }
1597 else if (iCol == 5) {
[3164]1598 QCheckBox* com = (QCheckBox*)(_uploadTable->cellWidget(iRow, iCol));
[3158]1599 QString state; state.setNum(com->checkState());
1600 hlp += state + ",";
1601 }
[3153]1602 }
[3164]1603 else if (_uploadTable->item(iRow, iCol)) {
1604 hlp += _uploadTable->item(iRow, iCol)->text() + ",";
[3158]1605 }
[3153]1606 }
1607 if (!hlp.isEmpty()) {
[3164]1608 uploadMountpointsOut << hlp;
[3153]1609 }
1610 }
1611
[1535]1612 bncSettings settings;
[1504]1613
[3881]1614 settings.setValue("startTab", _aogroup->currentIndex());
1615 settings.setValue("statusTab", _loggroup->currentIndex());
1616 settings.setValue("mountPoints", mountPoints);
1617// Network
1618 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1619 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1620 settings.setValue("sslCaCertPath", _sslCaCertPathLineEdit->text());
1621 settings.setValue("ignoreSslErrors", _ignoreSslErrorsCheckBox->checkState());
1622// General
1623 settings.setValue("logFile", _logFileLineEdit->text());
1624 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1625 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
[1503]1626 settings.setValue("autoStart", _autoStartCheckBox->checkState());
[3881]1627 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1628// RINEX Observations
1629 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1630 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1631 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1632 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1633 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1634 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
[6237]1635 settings.setValue("rnxV2Priority",_rnxV2Priority->text());
[3881]1636// RINEX Ephemeris
1637 settings.setValue("ephPath", _ephPathLineEdit->text());
1638 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1639 settings.setValue("outEphPort", _outEphPortLineEdit->text());
1640 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1641// Broadcast Corrections
1642 settings.setValue("corrPath", _corrPathLineEdit->text());
[1503]1643 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1644 settings.setValue("corrPort", _corrPortLineEdit->text());
[3881]1645// Feed Engine
1646 settings.setValue("outPort", _outPortLineEdit->text());
1647 settings.setValue("waitTime", _waitTimeSpinBox->value());
1648 settings.setValue("binSampl", _binSamplSpinBox->value());
1649 settings.setValue("outFile", _outFileLineEdit->text());
1650 settings.setValue("outUPort", _outUPortLineEdit->text());
1651// Serial Output
1652 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1653 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1654 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1655 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1656 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1657 settings.setValue("serialParity", _serialParityComboBox->currentText());
1658 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1659 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1660 settings.setValue("serialFileNMEA",_serialFileNMEALineEdit->text());
1661 settings.setValue("serialHeightNMEA",_serialHeightNMEALineEdit->text());
1662// Outages
1663 settings.setValue("obsRate", _obsRateComboBox->currentText());
1664 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1665 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1666 settings.setValue("adviseScript",_adviseScriptLineEdit->text());
1667// Miscellaneous
[1503]1668 settings.setValue("miscMount", _miscMountLineEdit->text());
[5644]1669 settings.setValue("miscPort", _miscPortLineEdit->text());
[3881]1670 settings.setValue("perfIntr", _perfIntrComboBox->currentText());
1671 settings.setValue("scanRTCM", _scanRTCMCheckBox->checkState());
[3897]1672// Reqc
1673 settings.setValue("reqcAction", _reqcActionComboBox->currentText());
1674 settings.setValue("reqcObsFile", _reqcObsFileChooser->fileName());
1675 settings.setValue("reqcNavFile", _reqcNavFileChooser->fileName());
1676 settings.setValue("reqcOutObsFile", _reqcOutObsLineEdit->text());
1677 settings.setValue("reqcOutNavFile", _reqcOutNavLineEdit->text());
1678 settings.setValue("reqcOutLogFile", _reqcOutLogLineEdit->text());
[4449]1679 settings.setValue("reqcPlotDir", _reqcPlotDirLineEdit->text());
[5144]1680 settings.setValue("reqcSkyPlotSystems", _reqcSkyPlotSystems->currentText());
[6299]1681 settings.setValue("reqcLogSummaryOnly", _reqcLogSummaryOnly->checkState());
[6337]1682// SP3 Comparison
1683 settings.setValue("sp3CompFile", _sp3CompFileChooser->fileName());
1684 settings.setValue("sp3CompOutLogFile", _sp3CompLogLineEdit->text());
[4185]1685// Combine Corrections
[2965]1686 if (!combineStreams.isEmpty()) {
1687 settings.setValue("combineStreams", combineStreams);
1688 }
[3075]1689 else {
1690 settings.setValue("combineStreams", "");
1691 }
[6173]1692 settings.setValue("cmbMethod", _cmbMethodComboBox->currentText());
1693 settings.setValue("cmbMaxres", _cmbMaxresLineEdit->text());
1694 settings.setValue("cmbSampl", _cmbSamplSpinBox->value());
1695 settings.setValue("cmbAntexFile", _cmbAntexFile->fileName());
1696 settings.setValue("cmbUseGlonass", _cmbUseGlonass->checkState());
[4185]1697// Upload Corrections
[3164]1698 if (!uploadMountpointsOut.isEmpty()) {
1699 settings.setValue("uploadMountpointsOut", uploadMountpointsOut);
[3153]1700 }
1701 else {
[3164]1702 settings.setValue("uploadMountpointsOut", "");
[3153]1703 }
[4172]1704 settings.setValue("uploadIntr", _uploadIntrComboBox->currentText());
1705 settings.setValue("uploadSamplRtcmEphCorr", _uploadSamplRtcmEphCorrSpinBox->value());
1706 settings.setValue("uploadSamplSp3", _uploadSamplSp3SpinBox->value());
1707 settings.setValue("uploadSamplClkRnx", _uploadSamplClkRnxSpinBox->value());
[4185]1708// Upload Ephemeris
[3242]1709 settings.setValue("uploadEphHost", _uploadEphHostLineEdit->text());
1710 settings.setValue("uploadEphPort", _uploadEphPortLineEdit->text());
[3881]1711 settings.setValue("uploadEphMountpoint",_uploadEphMountpointLineEdit->text());
[3242]1712 settings.setValue("uploadEphPassword", _uploadEphPasswordLineEdit->text());
1713 settings.setValue("uploadEphSample", _uploadEphSampleSpinBox->value());
[4766]1714
[1200]1715 if (_caster) {
[4250]1716 _caster->readMountPoints();
[1200]1717 }
[5694]1718
1719 _pppWidgets.saveOptions();
[35]1720}
1721
1722// All get slots terminated
1723////////////////////////////////////////////////////////////////////////////
[1556]1724void bncWindow::slotGetThreadsFinished() {
[5068]1725 BNC_CORE->slotMessage("All Get Threads Terminated", true);
[5729]1726 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
[3249]1727 delete _casterEph; _casterEph = 0;
[3787]1728 _runningRealTime = false;
[35]1729}
1730
[3783]1731// Start It!
[35]1732////////////////////////////////////////////////////////////////////////////
[3782]1733void bncWindow::slotStart() {
[4076]1734 saveOptions();
[5926]1735 if ( _pppWidgets._dataSource->currentText() == "RINEX Files") {
[5971]1736 _runningPPP = true;
1737 enableStartStop();
[5993]1738 _caster = new bncCaster(); BNC_CORE->setCaster(_caster);
[5946]1739 BNC_CORE->startPPP();
[5926]1740 }
1741 else if ( !_reqcActionComboBox->currentText().isEmpty() ) {
[5971]1742 if (_reqcActionComboBox->currentText() == "Analyze") {
1743 _runningQC = true;
1744 t_reqcAnalyze* reqcAnalyze = new t_reqcAnalyze(this);
1745 connect(reqcAnalyze, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1746 reqcAnalyze->start();
1747 }
1748 else {
1749 _runningEdit = true;
1750 t_reqcEdit* reqcEdit = new t_reqcEdit(this);
1751 connect(reqcEdit, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1752 reqcEdit->start();
1753 }
1754 enableStartStop();
[3783]1755 }
[6333]1756 else if (!_sp3CompFileChooser->fileName().isEmpty()) {
1757 _runningSp3Comp = true;
[6335]1758 t_sp3Comp* sp3Comp = new t_sp3Comp(this);
1759 connect(sp3Comp, SIGNAL(finished()), this, SLOT(slotPostProcessingFinished()));
1760 sp3Comp->start();
[6333]1761 enableStartStop();
1762 }
[3783]1763 else {
1764 startRealTime();
[5946]1765 BNC_CORE->startPPP();
[3783]1766 }
1767}
[128]1768
[3783]1769// Start Real-Time (Retrieve Data etc.)
1770////////////////////////////////////////////////////////////////////////////
1771void bncWindow::startRealTime() {
1772
[3787]1773 _runningRealTime = true;
1774
[2177]1775 _bncFigurePPP->reset();
1776
[35]1777 _actDeleteMountPoints->setEnabled(false);
1778
[3787]1779 enableStartStop();
1780
[5729]1781 _caster = new bncCaster();
[35]1782
[5725]1783 BNC_CORE->setCaster(_caster);
[5068]1784 BNC_CORE->setPort(_outEphPortLineEdit->text().toInt());
1785 BNC_CORE->setPortCorr(_corrPortLineEdit->text().toInt());
1786 BNC_CORE->initCombination();
[592]1787
[5729]1788 connect(_caster, SIGNAL(getThreadsFinished()),
[1556]1789 this, SLOT(slotGetThreadsFinished()));
[35]1790
[5729]1791 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
[1179]1792 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
[1173]1793
[5068]1794 BNC_CORE->slotMessage("========== Start BNC v" BNCVERSION " =========", true);
[1188]1795
[1875]1796 bncSettings settings;
[1880]1797
[1875]1798 QDir rnxdir(settings.value("rnxPath").toString());
[5068]1799 if (!rnxdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations directory", true);
[1880]1800
1801 QString rnx_file = settings.value("rnxScript").toString();
1802 if ( !rnx_file.isEmpty() ) {
1803 QFile rnxfile(settings.value("rnxScript").toString());
[5068]1804 if (!rnxfile.exists()) BNC_CORE->slotMessage("Cannot find RINEX Observations script", true);
[1880]1805 }
1806
[1875]1807 QDir ephdir(settings.value("ephPath").toString());
[5068]1808 if (!ephdir.exists()) BNC_CORE->slotMessage("Cannot find RINEX Ephemeris directory", true);
[1880]1809
[1875]1810 QDir corrdir(settings.value("corrPath").toString());
[5068]1811 if (!corrdir.exists()) BNC_CORE->slotMessage("Cannot find Broadcast Corrections directory", true);
[1880]1812
1813 QString advise_file = settings.value("adviseScript").toString();
1814 if ( !advise_file.isEmpty() ) {
[1875]1815 QFile advisefile(settings.value("adviseScript").toString());
[5068]1816 if (!advisefile.exists()) BNC_CORE->slotMessage("Cannot find Outages script", true);
[1875]1817 }
1818
[4250]1819 _caster->readMountPoints();
[3249]1820
[3250]1821 _casterEph = new bncEphUploadCaster();
[3254]1822 connect(_casterEph, SIGNAL(newBytes(QByteArray,double)),
1823 _uploadEphBytesCounter, SLOT(slotNewBytes(QByteArray,double)));
[35]1824}
[83]1825
[182]1826// Retrieve Data
1827////////////////////////////////////////////////////////////////////////////
1828void bncWindow::slotStop() {
[5971]1829 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving/processing data?",
[182]1830 QMessageBox::Yes, QMessageBox::No,
1831 QMessageBox::NoButton);
1832 if (iRet == QMessageBox::Yes) {
[5900]1833 BNC_CORE->stopPPP();
[5068]1834 BNC_CORE->stopCombination();
[5729]1835 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
[3249]1836 delete _casterEph; _casterEph = 0;
[3787]1837 _runningRealTime = false;
[5971]1838 _runningPPP = false;
[3790]1839 enableStartStop();
[182]1840 }
1841}
1842
[83]1843// Close Application gracefully
1844////////////////////////////////////////////////////////////////////////////
1845void bncWindow::closeEvent(QCloseEvent* event) {
1846
1847 int iRet = QMessageBox::question(this, "Close", "Save Options?",
1848 QMessageBox::Yes, QMessageBox::No,
1849 QMessageBox::Cancel);
1850
1851 if (iRet == QMessageBox::Cancel) {
1852 event->ignore();
1853 return;
1854 }
1855 else if (iRet == QMessageBox::Yes) {
1856 slotSaveOptions();
1857 }
1858
[5900]1859 BNC_CORE->stopPPP();
[5716]1860
[608]1861 QMainWindow::closeEvent(event);
[83]1862}
1863
1864// User changed the selection of mountPoints
1865////////////////////////////////////////////////////////////////////////////
1866void bncWindow::slotSelectionChanged() {
1867 if (_mountPointsTable->selectedItems().isEmpty()) {
1868 _actDeleteMountPoints->setEnabled(false);
1869 }
1870 else {
1871 _actDeleteMountPoints->setEnabled(true);
1872 }
1873}
1874
1875// Display Program Messages
1876////////////////////////////////////////////////////////////////////////////
[1299]1877void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
[5947]1878 if (showOnScreen ) {
[5980]1879 _log->append(QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg);
[1299]1880 }
[83]1881}
1882
[108]1883// About Message
1884////////////////////////////////////////////////////////////////////////////
1885void bncWindow::slotAbout() {
[679]1886 new bncAboutDlg(0);
[108]1887}
1888
[989]1889//Flowchart
1890////////////////////////////////////////////////////////////////////////////
1891void bncWindow::slotFlowchart() {
1892 new bncFlowchartDlg(0);
1893}
1894
[108]1895// Help Window
1896////////////////////////////////////////////////////////////////////////////
1897void bncWindow::slotHelp() {
[177]1898 QUrl url;
1899 url.setPath(":bnchelp.html");
[676]1900 new bncHlpDlg(0, url);
[108]1901}
[110]1902
1903// Select Fonts
1904////////////////////////////////////////////////////////////////////////////
1905void bncWindow::slotFontSel() {
1906 bool ok;
1907 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
1908 if (ok) {
[1535]1909 bncSettings settings;
[113]1910 settings.setValue("font", newFont.toString());
[110]1911 QApplication::setFont(newFont);
[113]1912 int ww = QFontMetrics(newFont).width('w');
[152]1913 setMinimumSize(60*ww, 80*ww);
1914 resize(60*ww, 80*ww);
[110]1915 }
1916}
[399]1917
1918// Whats This Help
1919void bncWindow::slotWhatsThis() {
[1173]1920 QWhatsThis::enterWhatsThisMode();
[399]1921}
1922
[1173]1923//
1924////////////////////////////////////////////////////////////////////////////
[1179]1925void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
[5187]1926 _threads = threads;
1927
[1998]1928 _bncFigure->updateMountPoints();
1929 _bncFigureLate->updateMountPoints();
1930
[1178]1931 populateMountPointsTable();
[1535]1932 bncSettings settings;
[1180]1933 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
1934 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
[1179]1935 QListIterator<bncGetThread*> iTh(threads);
1936 while (iTh.hasNext()) {
1937 bncGetThread* thread = iTh.next();
1938 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1939 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1940 "@" + _mountPointsTable->item(iRow, 1)->text() );
1941 if (url == thread->mountPoint() &&
1942 _mountPointsTable->item(iRow, 3)->text() == thread->latitude() &&
1943 _mountPointsTable->item(iRow, 4)->text() == thread->longitude() ) {
[1352]1944 ((bncTableItem*) _mountPointsTable->item(iRow, 7))->setGetThread(thread);
[2010]1945 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
1946 _bncFigure, SLOT(slotNewData(QByteArray, double)));
[1926]1947 connect(thread, SIGNAL(newBytes(QByteArray, double)),
[1932]1948 _bncFigure, SLOT(slotNewData(QByteArray, double)));
[2010]1949 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
1950 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
[1972]1951 connect(thread, SIGNAL(newLatency(QByteArray, double)),
[1975]1952 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
[1179]1953 break;
1954 }
1955 }
1956 }
[1173]1957}
1958
1959//
1960////////////////////////////////////////////////////////////////////////////
[679]1961void bncWindow::CreateMenu() {
1962 // Create Menus
1963 // ------------
1964 _menuFile = menuBar()->addMenu(tr("&File"));
1965 _menuFile->addAction(_actFontSel);
1966 _menuFile->addSeparator();
1967 _menuFile->addAction(_actSaveOpt);
1968 _menuFile->addSeparator();
1969 _menuFile->addAction(_actQuit);
[399]1970
[679]1971 _menuHlp = menuBar()->addMenu(tr("&Help"));
1972 _menuHlp->addAction(_actHelp);
[989]1973 _menuHlp->addAction(_actFlowchart);
[679]1974 _menuHlp->addAction(_actAbout);
1975}
1976
[1439]1977// Toolbar
[1173]1978////////////////////////////////////////////////////////////////////////////
[679]1979void bncWindow::AddToolbar() {
1980 QToolBar* toolBar = new QToolBar;
1981 addToolBar(Qt::BottomToolBarArea, toolBar);
1982 toolBar->setMovable(false);
1983 toolBar->addAction(_actAddMountPoints);
1984 toolBar->addAction(_actDeleteMountPoints);
[5162]1985 toolBar->addAction(_actMapMountPoints);
[3782]1986 toolBar->addAction(_actStart);
[679]1987 toolBar->addAction(_actStop);
[3610]1988 toolBar->addWidget(new QLabel(" "));
[679]1989 toolBar->addAction(_actwhatsthis);
[1439]1990}
[679]1991
[1439]1992// About
[1173]1993////////////////////////////////////////////////////////////////////////////
[679]1994bncAboutDlg::bncAboutDlg(QWidget* parent) :
1995 QDialog(parent) {
1996
1997 QTextBrowser* tb = new QTextBrowser;
1998 QUrl url; url.setPath(":bncabout.html");
1999 tb->setSource(url);
2000 tb->setReadOnly(true);
2001
2002 int ww = QFontMetrics(font()).width('w');
2003 QPushButton* _closeButton = new QPushButton("Close");
2004 _closeButton->setMaximumWidth(10*ww);
2005 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2006
2007 QGridLayout* dlgLayout = new QGridLayout();
2008 QLabel* img = new QLabel();
2009 img->setPixmap(QPixmap(":ntrip-logo.png"));
2010 dlgLayout->addWidget(img, 0,0);
[2012]2011 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
[679]2012 dlgLayout->addWidget(tb,1,0,1,2);
2013 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
2014
2015 setLayout(dlgLayout);
2016 resize(60*ww, 60*ww);
[1545]2017 setWindowTitle("About BNC");
[679]2018 show();
2019}
2020
[1173]2021//
2022////////////////////////////////////////////////////////////////////////////
[679]2023bncAboutDlg::~bncAboutDlg() {
2024};
2025
[1439]2026// Flowchart
[1173]2027////////////////////////////////////////////////////////////////////////////
[989]2028bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
2029 QDialog(parent) {
2030
2031 int ww = QFontMetrics(font()).width('w');
2032 QPushButton* _closeButton = new QPushButton("Close");
2033 _closeButton->setMaximumWidth(10*ww);
2034 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
2035
2036 QGridLayout* dlgLayout = new QGridLayout();
2037 QLabel* img = new QLabel();
[997]2038 img->setPixmap(QPixmap(":bncflowchart.png"));
[989]2039 dlgLayout->addWidget(img, 0,0);
2040 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
2041
2042 setLayout(dlgLayout);
[1545]2043 setWindowTitle("Flow Chart");
[989]2044 show();
2045}
2046
[1173]2047//
2048////////////////////////////////////////////////////////////////////////////
[989]2049bncFlowchartDlg::~bncFlowchartDlg() {
2050};
2051
[3605]2052// Enable/Disable Widget (and change its color)
2053////////////////////////////////////////////////////////////////////////////
2054void bncWindow::enableWidget(bool enable, QWidget* widget) {
2055 const static QPalette paletteWhite(QColor(255, 255, 255));
2056 const static QPalette paletteGray(QColor(230, 230, 230));
2057
2058 widget->setEnabled(enable);
2059 if (enable) {
2060 widget->setPalette(paletteWhite);
2061 }
2062 else {
2063 widget->setPalette(paletteGray);
2064 }
2065}
2066
[1439]2067// Bnc Text
2068////////////////////////////////////////////////////////////////////////////
[2128]2069void bncWindow::slotBncTextChanged(){
[1439]2070
[3605]2071 bool enable = true;
2072
[1439]2073 // Proxy
2074 //------
[2129]2075 if (sender() == 0 || sender() == _proxyHostLineEdit) {
[3605]2076 enable = !_proxyHostLineEdit->text().isEmpty();
2077 enableWidget(enable, _proxyPortLineEdit);
[1439]2078 }
2079
2080 // RINEX Observations
2081 // ------------------
[2129]2082 if (sender() == 0 || sender() == _rnxPathLineEdit) {
[3605]2083 enable = !_rnxPathLineEdit->text().isEmpty();
2084 enableWidget(enable, _rnxSamplSpinBox);
2085 enableWidget(enable, _rnxSkelLineEdit);
2086 enableWidget(enable, _rnxScrpLineEdit);
2087 enableWidget(enable, _rnxV3CheckBox);
2088 enableWidget(enable, _rnxIntrComboBox);
[1439]2089 }
2090
2091 // RINEX Ephemeris
2092 // ---------------
[3605]2093 if (sender() == 0 || sender() == _ephPathLineEdit || sender() == _outEphPortLineEdit) {
2094 enable = !_ephPathLineEdit->text().isEmpty() || !_outEphPortLineEdit->text().isEmpty();
2095 enableWidget(enable, _ephIntrComboBox);
2096 enableWidget(enable, _ephV3CheckBox);
[1439]2097 }
2098
[1682]2099 // Broadcast Corrections
[1439]2100 // ---------------------
[3605]2101 if (sender() == 0 || sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
2102 enable = !_corrPathLineEdit->text().isEmpty() || !_corrPortLineEdit->text().isEmpty();
2103 enableWidget(enable, _corrIntrComboBox);
[1439]2104 }
2105
2106 // Feed Engine
2107 // -----------
[3605]2108 if (sender() == 0 || sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
2109 enable = !_outPortLineEdit->text().isEmpty() || !_outFileLineEdit->text().isEmpty();
2110 enableWidget(enable, _waitTimeSpinBox);
2111 enableWidget(enable, _binSamplSpinBox);
[1439]2112 }
2113
[1746]2114 // Serial Output
2115 // -------------
[2129]2116 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
[2128]2117 sender() == _serialAutoNMEAComboBox) {
[3605]2118 enable = !_serialMountPointLineEdit->text().isEmpty();
2119 enableWidget(enable, _serialPortNameLineEdit);
2120 enableWidget(enable, _serialBaudRateComboBox);
2121 enableWidget(enable, _serialParityComboBox);
2122 enableWidget(enable, _serialDataBitsComboBox);
2123 enableWidget(enable, _serialStopBitsComboBox);
2124 enableWidget(enable, _serialFlowControlComboBox);
2125 enableWidget(enable, _serialAutoNMEAComboBox);
2126
2127 bool enable2 = enable && _serialAutoNMEAComboBox->currentText() != "Auto";
2128 enableWidget(enable2, _serialFileNMEALineEdit);
[1439]2129 }
2130
2131 // Outages
2132 // -------
[2129]2133 if (sender() == 0 || sender() == _obsRateComboBox) {
[3605]2134 enable = !_obsRateComboBox->currentText().isEmpty();
2135 enableWidget(enable, _adviseFailSpinBox);
2136 enableWidget(enable, _adviseRecoSpinBox);
2137 enableWidget(enable, _adviseScriptLineEdit);
[1439]2138 }
2139
2140 // Miscellaneous
2141 // -------------
[2129]2142 if (sender() == 0 || sender() == _miscMountLineEdit) {
[3605]2143 enable = !_miscMountLineEdit->text().isEmpty();
2144 enableWidget(enable, _perfIntrComboBox);
2145 enableWidget(enable, _scanRTCMCheckBox);
[5644]2146 enableWidget(enable, _miscPortLineEdit);
[1439]2147 }
[2090]2148
[3813]2149 // Enable/disable Broadcast Ephemerides
[3810]2150 // ------------------------------------
2151 if (sender() == 0 || sender() == _uploadEphHostLineEdit) {
2152 if (!_uploadEphHostLineEdit->text().isEmpty()) {
2153 _uploadEphPortLineEdit->setStyleSheet("background-color: white");
2154 _uploadEphMountpointLineEdit->setStyleSheet("background-color: white");
2155 _uploadEphPasswordLineEdit->setStyleSheet("background-color: white");
2156 _uploadEphSampleSpinBox->setStyleSheet("background-color: white");
2157 _uploadEphPortLineEdit->setEnabled(true);
2158 _uploadEphMountpointLineEdit->setEnabled(true);
2159 _uploadEphPasswordLineEdit->setEnabled(true);
2160 _uploadEphSampleSpinBox->setEnabled(true);
2161 }
2162 else {
2163 _uploadEphPortLineEdit->setStyleSheet("background-color: lightGray");
2164 _uploadEphMountpointLineEdit->setStyleSheet("background-color: lightGray");
2165 _uploadEphPasswordLineEdit->setStyleSheet("background-color: lightGray");
2166 _uploadEphSampleSpinBox->setStyleSheet("background-color: lightGray");
2167 _uploadEphPortLineEdit->setEnabled(false);
2168 _uploadEphMountpointLineEdit->setEnabled(false);
2169 _uploadEphPasswordLineEdit->setEnabled(false);
2170 _uploadEphSampleSpinBox->setEnabled(false);
2171 }
2172 }
2173
[4185]2174 // Combine Corrections
2175 // -------------------
[3813]2176 if (sender() == 0 || sender() == _cmbTable) {
2177 int iRow = _cmbTable->rowCount();
2178 if (iRow > 0) {
2179 enableWidget(true, _cmbMethodComboBox);
2180 _cmbMaxresLineEdit->setStyleSheet("background-color: white");
2181 _cmbMaxresLineEdit->setEnabled(true);
[4179]2182 _cmbSamplSpinBox->setEnabled(true);
[6172]2183 _cmbAntexFile->setEnabled(true);
2184 _cmbUseGlonass->setEnabled(true);
[3813]2185 }
2186 else {
2187 enableWidget(false, _cmbMethodComboBox);
2188 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2189 _cmbMaxresLineEdit->setEnabled(false);
[4179]2190 _cmbSamplSpinBox->setEnabled(false);
[6172]2191 _cmbAntexFile->setEnabled(false);
2192 _cmbUseGlonass->setEnabled(false);
[3813]2193 }
2194 }
2195
2196 // Upload(clk)
2197 // -----------
2198 int iRow = _uploadTable->rowCount();
2199 if (iRow > 0) {
2200 enableWidget(true, _uploadIntrComboBox);
[4172]2201 enableWidget(true, _uploadSamplRtcmEphCorrSpinBox);
2202 enableWidget(true, _uploadSamplClkRnxSpinBox);
2203 enableWidget(true, _uploadSamplSp3SpinBox);
[3813]2204 }
2205 else {
2206 enableWidget(false, _uploadIntrComboBox);
[4172]2207 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2208 enableWidget(false, _uploadSamplClkRnxSpinBox);
2209 enableWidget(false, _uploadSamplSp3SpinBox);
[3813]2210 }
2211
[5861]2212 // QC
2213 // --
[6318]2214 if (sender() == 0 || sender() == _reqcActionComboBox || sender() == _reqcSkyPlotSystems) {
[3897]2215 enable = !_reqcActionComboBox->currentText().isEmpty();
2216 bool enable10 = _reqcActionComboBox->currentText() == "Edit/Concatenate";
[6318]2217 bool enablePlot = !_reqcSkyPlotSystems->currentText().isEmpty();
[3897]2218 enableWidget(enable && enable10, _reqcEditOptionButton);
2219 enableWidget(enable, _reqcObsFileChooser);
[4213]2220 enableWidget(enable, _reqcNavFileChooser);
[3897]2221 enableWidget(enable && enable10, _reqcOutObsLineEdit);
[4213]2222 enableWidget(enable && enable10, _reqcOutNavLineEdit);
[4515]2223 enableWidget(enable, _reqcOutLogLineEdit);
[6318]2224 enableWidget(enable && !enable10 && enablePlot, _reqcPlotDirLineEdit);
[5144]2225 enableWidget(enable && !enable10, _reqcSkyPlotSystems);
[6299]2226 enableWidget(enable && !enable10, _reqcLogSummaryOnly);
[3739]2227 }
[4085]2228
2229 enableStartStop();
[1439]2230}
[2869]2231
2232//
2233////////////////////////////////////////////////////////////////////////////
2234void bncWindow::slotAddCmbRow() {
2235 int iRow = _cmbTable->rowCount();
2236 _cmbTable->insertRow(iRow);
2237 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
2238 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
2239 }
2240}
2241
2242//
2243////////////////////////////////////////////////////////////////////////////
2244void bncWindow::slotDelCmbRow() {
2245 int nRows = _cmbTable->rowCount();
2246 bool flg[nRows];
2247 for (int iRow = 0; iRow < nRows; iRow++) {
2248 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
2249 flg[iRow] = true;
2250 }
2251 else {
2252 flg[iRow] = false;
2253 }
2254 }
2255 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2256 if (flg[iRow]) {
2257 _cmbTable->removeRow(iRow);
2258 }
2259 }
[3813]2260 nRows = _cmbTable->rowCount();
2261 if (nRows < 1) {
2262 enableWidget(false, _cmbMethodComboBox);
2263 _cmbMaxresLineEdit->setStyleSheet("background-color: lightGray");
2264 _cmbMaxresLineEdit->setEnabled(false);
[4179]2265 _cmbSamplSpinBox->setEnabled(false);
[6172]2266 _cmbAntexFile->setEnabled(false);
2267 _cmbUseGlonass->setEnabled(false);
[3813]2268 }
[2869]2269}
[2870]2270
2271//
2272////////////////////////////////////////////////////////////////////////////
2273void bncWindow::populateCmbTable() {
2274
2275 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
2276 _cmbTable->removeRow(iRow);
2277 }
2278
2279 bncSettings settings;
2280
2281 int iRow = -1;
2282 QListIterator<QString> it(settings.value("combineStreams").toStringList());
2283 while (it.hasNext()) {
2284 QStringList hlp = it.next().split(" ");
[2965]2285 if (hlp.size() > 2) {
[2870]2286 ++iRow;
2287 _cmbTable->insertRow(iRow);
2288 }
2289 for (int iCol = 0; iCol < hlp.size(); iCol++) {
2290 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
2291 }
2292 }
2293}
[3152]2294
2295//
2296////////////////////////////////////////////////////////////////////////////
[3164]2297void bncWindow::slotAddUploadRow() {
2298 int iRow = _uploadTable->rowCount();
2299 _uploadTable->insertRow(iRow);
2300 for (int iCol = 0; iCol < _uploadTable->columnCount(); iCol++) {
[3156]2301 if (iCol == 3) {
2302 QLineEdit* passwd = new QLineEdit();
2303 passwd->setFrame(false);
2304 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
[3164]2305 _uploadTable->setCellWidget(iRow, iCol, passwd);
[3156]2306 }
2307 else if (iCol == 4) {
[3158]2308 QComboBox* system = new QComboBox();
2309 system->setEditable(false);
[5341]2310 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
[3158]2311 system->setFrame(false);
[3164]2312 _uploadTable->setCellWidget(iRow, iCol, system);
[3155]2313 }
2314 else if (iCol == 5) {
2315 QCheckBox* com = new QCheckBox();
[3164]2316 _uploadTable->setCellWidget(iRow, iCol, com);
[3155]2317 }
[4111]2318 else if (iCol == 11) {
[3196]2319 bncTableItem* bncIt = new bncTableItem();
2320 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2321 _uploadTable->setItem(iRow, iCol, bncIt);
[5068]2322 BNC_CORE->_uploadTableItems[iRow] = bncIt;
[3196]2323 }
[3155]2324 else {
[3164]2325 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(""));
[3155]2326 }
[3152]2327 }
2328}
2329
2330//
2331////////////////////////////////////////////////////////////////////////////
[3164]2332void bncWindow::slotDelUploadRow() {
[5068]2333 BNC_CORE->_uploadTableItems.clear();
[3164]2334 int nRows = _uploadTable->rowCount();
[3152]2335 bool flg[nRows];
2336 for (int iRow = 0; iRow < nRows; iRow++) {
[3164]2337 if (_uploadTable->isItemSelected(_uploadTable->item(iRow,1))) {
[3152]2338 flg[iRow] = true;
2339 }
2340 else {
2341 flg[iRow] = false;
2342 }
2343 }
2344 for (int iRow = nRows-1; iRow >= 0; iRow--) {
2345 if (flg[iRow]) {
[3164]2346 _uploadTable->removeRow(iRow);
[3152]2347 }
2348 }
[3232]2349 for (int iRow = 0; iRow < _uploadTable->rowCount(); iRow++) {
[5068]2350 BNC_CORE->_uploadTableItems[iRow] =
[4111]2351 (bncTableItem*) _uploadTable->item(iRow, 11);
[3232]2352 }
[3813]2353 nRows = _uploadTable->rowCount();
2354 if (nRows < 1) {
2355 enableWidget(false, _uploadIntrComboBox);
[4172]2356 enableWidget(false, _uploadSamplRtcmEphCorrSpinBox);
2357 enableWidget(false, _uploadSamplSp3SpinBox);
2358 enableWidget(false, _uploadSamplClkRnxSpinBox);
[3813]2359 }
[3152]2360}
2361
2362//
2363////////////////////////////////////////////////////////////////////////////
[3164]2364void bncWindow::populateUploadTable() {
2365 for (int iRow = _uploadTable->rowCount()-1; iRow >=0; iRow--) {
2366 _uploadTable->removeRow(iRow);
[3153]2367 }
2368
2369 bncSettings settings;
2370
2371 int iRow = -1;
[3164]2372 QListIterator<QString> it(settings.value("uploadMountpointsOut").toStringList());
[3153]2373 while (it.hasNext()) {
[3159]2374 QStringList hlp = it.next().split(",");
2375 if (hlp.size() > 6) {
[3153]2376 ++iRow;
[3164]2377 _uploadTable->insertRow(iRow);
[3153]2378 }
2379 for (int iCol = 0; iCol < hlp.size(); iCol++) {
[3159]2380 if (iCol == 3) {
2381 QLineEdit* passwd = new QLineEdit();
2382 passwd->setFrame(false);
2383 passwd->setEchoMode(QLineEdit::PasswordEchoOnEdit);
2384 passwd->setText(hlp[iCol]);
[3164]2385 _uploadTable->setCellWidget(iRow, iCol, passwd);
[3159]2386 }
2387 else if (iCol == 4) {
2388 QComboBox* system = new QComboBox();
2389 system->setEditable(false);
[5342]2390 system->addItems(QString(",IGS08,ETRF2000,NAD83,GDA94,SIRGAS95,SIRGAS2000,DREF91,Custom").split(","));
[3159]2391 system->setFrame(false);
2392 system->setCurrentIndex(system->findText(hlp[iCol]));
[3164]2393 _uploadTable->setCellWidget(iRow, iCol, system);
[3159]2394 }
2395 else if (iCol == 5) {
2396 QCheckBox* com = new QCheckBox();
2397 if (hlp[iCol].toInt() == Qt::Checked) {
2398 com->setCheckState(Qt::Checked);
2399 }
[3164]2400 _uploadTable->setCellWidget(iRow, iCol, com);
[3159]2401 }
[4111]2402 else if (iCol == 11) {
[3196]2403 bncTableItem* bncIt = new bncTableItem();
2404 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
2405 _uploadTable->setItem(iRow, iCol, bncIt);
[5068]2406 BNC_CORE->_uploadTableItems[iRow] = bncIt;
[3196]2407 }
[3159]2408 else {
[3164]2409 _uploadTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
[3159]2410 }
[3153]2411 }
2412 }
[3152]2413}
[3153]2414
2415//
2416////////////////////////////////////////////////////////////////////////////
[3164]2417void bncWindow::slotSetUploadTrafo() {
[3239]2418 bncCustomTrafo* dlg = new bncCustomTrafo(this);
2419 dlg->exec();
2420 delete dlg;
[3153]2421}
[3608]2422
[3626]2423// Progress Bar Change
2424////////////////////////////////////////////////////////////////////////////
[5971]2425void bncWindow::slotPostProcessingProgress(int nEpo) {
2426 _actStart->setText(QString("%1 Epochs").arg(nEpo));
[3626]2427}
[3731]2428
[3897]2429// Post-Processing Reqc Finished
[3731]2430////////////////////////////////////////////////////////////////////////////
[5971]2431void bncWindow::slotPostProcessingFinished() {
[5993]2432 delete _caster; _caster = 0; BNC_CORE->setCaster(0);
[6333]2433 _runningPPP = false;
2434 _runningEdit = false;
2435 _runningQC = false;
2436 _runningSp3Comp = false;
[5974]2437 _actStart->setText(tr("Sta&rt"));
[3792]2438 enableStartStop();
[3731]2439}
[3736]2440
[3740]2441// Edit teqc-like editing options
2442////////////////////////////////////////////////////////////////////////////
[3897]2443void bncWindow::slotReqcEditOption() {
[6239]2444 saveOptions();
[3897]2445 reqcDlg* dlg = new reqcDlg(this);
[3740]2446 dlg->move(this->pos().x()+50, this->pos().y()+50);
2447 dlg->exec();
2448 delete dlg;
2449}
[3787]2450
2451// Enable/Disable Start and Stop Buttons
2452////////////////////////////////////////////////////////////////////////////
2453void bncWindow::enableStartStop() {
[5971]2454 if ( running() ) {
2455 _actStart->setEnabled(false);
[5976]2456 if (_runningRealTime || _runningPPP) {
[5971]2457 _actStop->setEnabled(true);
[3792]2458 }
[3787]2459 }
2460 else {
[5971]2461 _actStart->setEnabled(true);
2462 _actStop->setEnabled(false);
[3787]2463 }
2464}
[4646]2465
2466// Show Map
2467////////////////////////////////////////////////////////////////////////////
[5162]2468void bncWindow::slotMapMountPoints() {
[4646]2469 saveOptions();
2470 t_bncMap* bncMap = new t_bncMap(this);
[4714]2471 bncMap->setMinimumSize(800, 600);
[4649]2472 bncMap->setWindowTitle("Selected Mountpoints");
[4647]2473
2474 bncSettings settings;
2475 QListIterator<QString> it(settings.value("mountPoints").toStringList());
2476 while (it.hasNext()) {
2477 QStringList hlp = it.next().split(" ");
2478 if (hlp.size() < 5) continue;
2479 QUrl url(hlp[0]);
2480 double latDeg = hlp[2].toDouble();
2481 double lonDeg = hlp[3].toDouble();
[4648]2482 bncMap->slotNewPoint(QFileInfo(url.path()).fileName(), latDeg, lonDeg);
[4647]2483 }
2484
[4646]2485 bncMap->show();
2486}
[5162]2487
2488// Show Map
2489////////////////////////////////////////////////////////////////////////////
2490void bncWindow::slotMapPPP() {
[5186]2491#ifdef QT_WEBKIT
[5233]2492 saveOptions();
[5895]2493 enableWidget(false, _pppWidgets._mapWinButton);
[5955]2494 enableWidget(false, _pppWidgets._useGoogleMap);
2495 enableWidget(false, _pppWidgets._useOpenStreetMap);
2496 enableWidget(false, _pppWidgets._mapWinDotSize);
2497 enableWidget(false, _pppWidgets._mapWinDotColor);
[5299]2498
[5179]2499 if (!_mapWin) {
2500 _mapWin = new bncMapWin(this);
[5235]2501 connect(_mapWin, SIGNAL(mapClosed()), this, SLOT(slotMapPPPClosed()));
[5954]2502 connect(BNC_CORE, SIGNAL(newPosition(QByteArray, bncTime, QVector<double>)),
2503 _mapWin, SLOT(slotNewPosition(QByteArray, bncTime, QVector<double>)));
[5179]2504 }
2505 _mapWin->show();
[5186]2506#else
2507 QMessageBox::information(this, "Information",
2508 "Qt Library compiled without QtWebKit");
2509#endif
[5162]2510}
[5235]2511
2512// Show Map
2513////////////////////////////////////////////////////////////////////////////
2514void bncWindow::slotMapPPPClosed() {
2515#ifdef QT_WEBKIT
[5896]2516 enableWidget(true, _pppWidgets._mapWinButton);
[5955]2517 enableWidget(true, _pppWidgets._useGoogleMap);
2518 enableWidget(true, _pppWidgets._useOpenStreetMap);
2519 enableWidget(true, _pppWidgets._mapWinDotSize);
2520 enableWidget(true, _pppWidgets._mapWinDotColor);
[5237]2521 if (_mapWin) {
2522 QListIterator<bncGetThread*> it(_threads);
2523 while (it.hasNext()) {
2524 bncGetThread* thread = it.next();
2525 thread->disconnect(_mapWin);
2526 }
[5242]2527 _mapWin->deleteLater();
[5237]2528 _mapWin = 0;
2529 }
[5235]2530#endif
2531}
Note: See TracBrowser for help on using the repository browser.