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

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

Documentation completed

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