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

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

Documentation completed

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