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

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

Design of option fields modified

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