source: ntrip/trunk/BNC/bncwindow.cpp@ 2898

Last change on this file since 2898 was 2895, checked in by mervart, 14 years ago
File size: 97.1 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 "bncapp.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
60using namespace std;
61
62// Constructor
63////////////////////////////////////////////////////////////////////////////
64bncWindow::bncWindow() {
65
66 _caster = 0;
67
68 _bncFigure = new bncFigure(this);
69 _bncFigureLate = new bncFigureLate(this);
70 _bncFigurePPP = new bncFigurePPP(this);
71
72 int ww = QFontMetrics(this->font()).width('w');
73
74 static const QStringList labels = QString("account, Streams: resource loader / mountpoint, decoder, lat, long, nmea, ntrip, bytes").split(",");
75
76 setMinimumSize(85*ww, 65*ww);
77
78 setWindowTitle(tr("BKG Ntrip Client (BNC) Version " BNCVERSION));
79
80 connect((bncApp*)qApp, SIGNAL(newMessage(QByteArray,bool)),
81 this, SLOT(slotWindowMessage(QByteArray,bool)));
82
83 // Create Actions
84 // --------------
85 _actHelp = new QAction(tr("&Help Contents"),this);
86 connect(_actHelp, SIGNAL(triggered()), SLOT(slotHelp()));
87
88 _actAbout = new QAction(tr("&About BNC"),this);
89 connect(_actAbout, SIGNAL(triggered()), SLOT(slotAbout()));
90
91 _actFlowchart = new QAction(tr("&Flow Chart"),this);
92 connect(_actFlowchart, SIGNAL(triggered()), SLOT(slotFlowchart()));
93
94 _actFontSel = new QAction(tr("Select &Font"),this);
95 connect(_actFontSel, SIGNAL(triggered()), SLOT(slotFontSel()));
96
97 _actSaveOpt = new QAction(tr("&Save && Reread Configuration"),this);
98 connect(_actSaveOpt, SIGNAL(triggered()), SLOT(slotSaveOptions()));
99
100 _actQuit = new QAction(tr("&Quit"),this);
101 connect(_actQuit, SIGNAL(triggered()), SLOT(close()));
102
103 _actAddMountPoints = new QAction(tr("Add &Stream"),this);
104 connect(_actAddMountPoints, SIGNAL(triggered()), SLOT(slotAddMountPoints()));
105
106 _actDeleteMountPoints = new QAction(tr("&Delete Stream"),this);
107 connect(_actDeleteMountPoints, SIGNAL(triggered()), SLOT(slotDeleteMountPoints()));
108 _actDeleteMountPoints->setEnabled(false);
109
110 _actGetData = new QAction(tr("Sta&rt"),this);
111 connect(_actGetData, SIGNAL(triggered()), SLOT(slotGetData()));
112
113 _actStop = new QAction(tr("Sto&p"),this);
114 connect(_actStop, SIGNAL(triggered()), SLOT(slotStop()));
115 _actStop->setEnabled(false);
116
117 _actwhatsthis= new QAction(tr("Help ?=Shift+F1"),this);
118 connect(_actwhatsthis, SIGNAL(triggered()), SLOT(slotWhatsThis()));
119
120 CreateMenu();
121 AddToolbar();
122
123 bncSettings settings;
124
125 // Proxy Options
126 // -------------
127 _proxyHostLineEdit = new QLineEdit(settings.value("proxyHost").toString());
128 _proxyPortLineEdit = new QLineEdit(settings.value("proxyPort").toString());
129
130 connect(_proxyHostLineEdit, SIGNAL(textChanged(const QString &)),
131 this, SLOT(slotBncTextChanged()));
132
133 // General Options
134 // ---------------
135 _logFileLineEdit = new QLineEdit(settings.value("logFile").toString());
136 _rawOutFileLineEdit = new QLineEdit(settings.value("rawOutFile").toString());
137 _rnxAppendCheckBox = new QCheckBox();
138 _rnxAppendCheckBox->setCheckState(Qt::CheckState(
139 settings.value("rnxAppend").toInt()));
140 _onTheFlyComboBox = new QComboBox();
141 _onTheFlyComboBox->setEditable(false);
142 _onTheFlyComboBox->addItems(QString("1 day,1 hour,1 min").split(","));
143 int ii = _onTheFlyComboBox->findText(settings.value("onTheFlyInterval").toString());
144 if (ii != -1) {
145 _onTheFlyComboBox->setCurrentIndex(ii);
146 }
147 _autoStartCheckBox = new QCheckBox();
148 _autoStartCheckBox->setCheckState(Qt::CheckState(
149 settings.value("autoStart").toInt()));
150
151 // RINEX Observations Options
152 // --------------------------
153 _rnxPathLineEdit = new QLineEdit(settings.value("rnxPath").toString());
154 _rnxIntrComboBox = new QComboBox();
155 _rnxIntrComboBox->setEditable(false);
156 _rnxIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
157 ii = _rnxIntrComboBox->findText(settings.value("rnxIntr").toString());
158 if (ii != -1) {
159 _rnxIntrComboBox->setCurrentIndex(ii);
160 }
161 _rnxSamplSpinBox = new QSpinBox();
162 _rnxSamplSpinBox->setMinimum(0);
163 _rnxSamplSpinBox->setMaximum(60);
164 _rnxSamplSpinBox->setSingleStep(5);
165 _rnxSamplSpinBox->setValue(settings.value("rnxSampl").toInt());
166 _rnxSamplSpinBox->setSuffix(" sec");
167 _rnxSkelLineEdit = new QLineEdit(settings.value("rnxSkel").toString());
168 _rnxSkelLineEdit->setMaximumWidth(5*ww);
169 _rnxScrpLineEdit = new QLineEdit(settings.value("rnxScript").toString());
170 _rnxV3CheckBox = new QCheckBox();
171 _rnxV3CheckBox->setCheckState(Qt::CheckState(settings.value("rnxV3").toInt()));
172
173 connect(_rnxPathLineEdit, SIGNAL(textChanged(const QString &)),
174 this, SLOT(slotBncTextChanged()));
175
176 // RINEX Ephemeris Options
177 // -----------------------
178 _ephPathLineEdit = new QLineEdit(settings.value("ephPath").toString());
179 _ephIntrComboBox = new QComboBox();
180 _ephIntrComboBox->setEditable(false);
181 _ephIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
182 int jj = _ephIntrComboBox->findText(settings.value("ephIntr").toString());
183 if (jj != -1) {
184 _ephIntrComboBox->setCurrentIndex(jj);
185 }
186 _outEphPortLineEdit = new QLineEdit(settings.value("outEphPort").toString());
187 _ephV3CheckBox = new QCheckBox();
188 _ephV3CheckBox->setCheckState(Qt::CheckState(settings.value("ephV3").toInt()));
189
190 connect(_outEphPortLineEdit, SIGNAL(textChanged(const QString &)),
191 this, SLOT(slotBncTextChanged()));
192
193 connect(_ephPathLineEdit, SIGNAL(textChanged(const QString &)),
194 this, SLOT(slotBncTextChanged()));
195
196 // Broadcast Corrections Options
197 // -----------------------------
198 _corrPathLineEdit = new QLineEdit(settings.value("corrPath").toString());
199 _corrIntrComboBox = new QComboBox();
200 _corrIntrComboBox->setEditable(false);
201 _corrIntrComboBox->addItems(QString("1 min,2 min,5 min,10 min,15 min,30 min,1 hour,1 day").split(","));
202 int mm = _corrIntrComboBox->findText(settings.value("corrIntr").toString());
203 if (mm != -1) {
204 _corrIntrComboBox->setCurrentIndex(mm);
205 }
206 _corrPortLineEdit = new QLineEdit(settings.value("corrPort").toString());
207 _corrTimeSpinBox = new QSpinBox();
208 _corrTimeSpinBox->setMinimum(1);
209 _corrTimeSpinBox->setMaximum(60);
210 _corrTimeSpinBox->setSingleStep(1);
211 _corrTimeSpinBox->setSuffix(" sec");
212 _corrTimeSpinBox->setValue(settings.value("corrTime").toInt());
213
214 connect(_corrPathLineEdit, SIGNAL(textChanged(const QString &)),
215 this, SLOT(slotBncTextChanged()));
216
217 connect(_corrPortLineEdit, SIGNAL(textChanged(const QString &)),
218 this, SLOT(slotBncTextChanged()));
219
220 // Feed Engine Options
221 // -------------------
222 _outPortLineEdit = new QLineEdit(settings.value("outPort").toString());
223 _waitTimeSpinBox = new QSpinBox();
224 _waitTimeSpinBox->setMinimum(1);
225 _waitTimeSpinBox->setMaximum(30);
226 _waitTimeSpinBox->setSingleStep(1);
227 _waitTimeSpinBox->setSuffix(" sec");
228 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
229 _binSamplSpinBox = new QSpinBox();
230 _binSamplSpinBox->setMinimum(0);
231 _binSamplSpinBox->setMaximum(60);
232 _binSamplSpinBox->setSingleStep(5);
233 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
234 _binSamplSpinBox->setSuffix(" sec");
235 _outFileLineEdit = new QLineEdit(settings.value("outFile").toString());
236 _outUPortLineEdit = new QLineEdit(settings.value("outUPort").toString());
237
238 connect(_outPortLineEdit, SIGNAL(textChanged(const QString &)),
239 this, SLOT(slotBncTextChanged()));
240
241 connect(_outFileLineEdit, SIGNAL(textChanged(const QString &)),
242 this, SLOT(slotBncTextChanged()));
243
244 // Serial Output Options
245 // ---------------------
246 _serialMountPointLineEdit = new QLineEdit(settings.value("serialMountPoint").toString());
247 _serialPortNameLineEdit = new QLineEdit(settings.value("serialPortName").toString());
248 _serialBaudRateComboBox = new QComboBox();
249 _serialBaudRateComboBox->addItems(QString("110,300,600,"
250 "1200,2400,4800,9600,19200,38400,57600,115200").split(","));
251 int kk = _serialBaudRateComboBox->findText(settings.value("serialBaudRate").toString());
252 if (kk != -1) {
253 _serialBaudRateComboBox->setCurrentIndex(kk);
254 }
255 _serialFlowControlComboBox = new QComboBox();
256 _serialFlowControlComboBox->addItems(QString("OFF,XONXOFF,HARDWARE").split(","));
257 kk = _serialFlowControlComboBox->findText(settings.value("serialFlowControl").toString());
258 if (kk != -1) {
259 _serialFlowControlComboBox->setCurrentIndex(kk);
260 }
261 _serialDataBitsComboBox = new QComboBox();
262 _serialDataBitsComboBox->addItems(QString("5,6,7,8").split(","));
263 kk = _serialDataBitsComboBox->findText(settings.value("serialDataBits").toString());
264 if (kk != -1) {
265 _serialDataBitsComboBox->setCurrentIndex(kk);
266 }
267 _serialParityComboBox = new QComboBox();
268 _serialParityComboBox->addItems(QString("NONE,ODD,EVEN,SPACE").split(","));
269 kk = _serialParityComboBox->findText(settings.value("serialParity").toString());
270 if (kk != -1) {
271 _serialParityComboBox->setCurrentIndex(kk);
272 }
273 _serialStopBitsComboBox = new QComboBox();
274 _serialStopBitsComboBox->addItems(QString("1,2").split(","));
275 kk = _serialStopBitsComboBox->findText(settings.value("serialStopBits").toString());
276 if (kk != -1) {
277 _serialStopBitsComboBox->setCurrentIndex(kk);
278 }
279 _serialAutoNMEAComboBox = new QComboBox();
280 _serialAutoNMEAComboBox->addItems(QString("Auto,Manual").split(","));
281 kk = _serialAutoNMEAComboBox->findText(settings.value("serialAutoNMEA").toString());
282 if (kk != -1) {
283 _serialAutoNMEAComboBox->setCurrentIndex(kk);
284 }
285 _serialFileNMEALineEdit = new QLineEdit(settings.value("serialFileNMEA").toString());
286 _serialHeightNMEALineEdit = new QLineEdit(settings.value("serialHeightNMEA").toString());
287
288 connect(_serialMountPointLineEdit, SIGNAL(textChanged(const QString &)),
289 this, SLOT(slotBncTextChanged()));
290
291 connect(_serialAutoNMEAComboBox, SIGNAL(currentIndexChanged(const QString &)),
292 this, SLOT(slotBncTextChanged()));
293
294 // Outages Options
295 // ---------------
296 _obsRateComboBox = new QComboBox();
297 _obsRateComboBox->setEditable(false);
298 _obsRateComboBox->addItems(QString(",0.1 Hz,0.2 Hz,0.5 Hz,1 Hz,5 Hz").split(","));
299 kk = _obsRateComboBox->findText(settings.value("obsRate").toString());
300 if (kk != -1) {
301 _obsRateComboBox->setCurrentIndex(kk);
302 }
303 _adviseFailSpinBox = new QSpinBox();
304 _adviseFailSpinBox->setMinimum(0);
305 _adviseFailSpinBox->setMaximum(60);
306 _adviseFailSpinBox->setSingleStep(1);
307 _adviseFailSpinBox->setSuffix(" min");
308 _adviseFailSpinBox->setValue(settings.value("adviseFail").toInt());
309 _adviseRecoSpinBox = new QSpinBox();
310 _adviseRecoSpinBox->setMinimum(0);
311 _adviseRecoSpinBox->setMaximum(60);
312 _adviseRecoSpinBox->setSingleStep(1);
313 _adviseRecoSpinBox->setSuffix(" min");
314 _adviseRecoSpinBox->setValue(settings.value("adviseReco").toInt());
315 _adviseScriptLineEdit = new QLineEdit(settings.value("adviseScript").toString());
316
317 connect(_obsRateComboBox, SIGNAL(currentIndexChanged(const QString &)),
318 this, SLOT(slotBncTextChanged()));
319
320 // Miscellaneous Options
321 // ---------------------
322 _miscMountLineEdit = new QLineEdit(settings.value("miscMount").toString());
323 _perfIntrComboBox = new QComboBox();
324 _perfIntrComboBox->setEditable(false);
325 _perfIntrComboBox->addItems(QString(",2 sec, 10 sec,1 min,5 min,15 min,1 hour,6 hours,1 day").split(","));
326 int ll = _perfIntrComboBox->findText(settings.value("perfIntr").toString());
327 if (ll != -1) {
328 _perfIntrComboBox->setCurrentIndex(ll);
329 }
330 _scanRTCMCheckBox = new QCheckBox();
331 _scanRTCMCheckBox->setCheckState(Qt::CheckState(
332 settings.value("scanRTCM").toInt()));
333
334 connect(_miscMountLineEdit, SIGNAL(textChanged(const QString &)),
335 this, SLOT(slotBncTextChanged()));
336
337 // PPP Options
338 // -----------
339 _pppMountLineEdit = new QLineEdit(settings.value("pppMount").toString());
340 _pppNMEALineEdit = new QLineEdit(settings.value("nmeaFile").toString());
341 _pppNMEAPortLineEdit = new QLineEdit(settings.value("nmeaPort").toString());
342 _pppSigCLineEdit = new QLineEdit(settings.value("pppSigmaCode").toString());
343 _pppSigPLineEdit = new QLineEdit(settings.value("pppSigmaPhase").toString());
344 _pppSigCrd0 = new QLineEdit(settings.value("pppSigCrd0").toString());
345 _pppSigCrdP = new QLineEdit(settings.value("pppSigCrdP").toString());
346 _pppSigTrp0 = new QLineEdit(settings.value("pppSigTrp0").toString());
347 _pppSigTrpP = new QLineEdit(settings.value("pppSigTrpP").toString());
348 _pppAverageLineEdit = new QLineEdit(settings.value("pppAverage").toString());
349 _pppQuickStartLineEdit = new QLineEdit(settings.value("pppQuickStart").toString());
350 _pppRefCrdXLineEdit = new QLineEdit(settings.value("pppRefCrdX").toString());
351 _pppRefCrdYLineEdit = new QLineEdit(settings.value("pppRefCrdY").toString());
352 _pppRefCrdZLineEdit = new QLineEdit(settings.value("pppRefCrdZ").toString());
353 _pppSync = new QLineEdit(settings.value("pppSync").toString());
354
355 _pppSPPComboBox = new QComboBox();
356 _pppSPPComboBox->setEditable(false);
357 _pppSPPComboBox->addItems(QString("PPP,SPP").split(","));
358 int ik = _pppSPPComboBox->findText(settings.value("pppSPP").toString());
359 if (ik != -1) {
360 _pppSPPComboBox->setCurrentIndex(ik);
361 }
362 _pppUsePhaseCheckBox = new QCheckBox();
363 _pppUsePhaseCheckBox->setCheckState(Qt::CheckState(
364 settings.value("pppUsePhase").toInt()));
365 _pppEstTropoCheckBox = new QCheckBox();
366 _pppEstTropoCheckBox->setCheckState(Qt::CheckState(
367 settings.value("pppEstTropo").toInt()));
368 _pppGLONASSCheckBox = new QCheckBox();
369 _pppGLONASSCheckBox->setCheckState(Qt::CheckState(
370 settings.value("pppGLONASS").toInt()));
371 _pppGalileoCheckBox = new QCheckBox();
372 _pppGalileoCheckBox->setCheckState(Qt::CheckState(
373 settings.value("pppGalileo").toInt()));
374
375 _pppPlotCoordinates = new QCheckBox();
376 _pppPlotCoordinates->setCheckState(Qt::CheckState(
377 settings.value("pppPlotCoordinates").toInt()));
378
379 connect(_pppMountLineEdit, SIGNAL(textChanged(const QString &)),
380 this, SLOT(slotBncTextChanged()));
381
382 connect(_pppUsePhaseCheckBox, SIGNAL(stateChanged(int)),
383 this, SLOT(slotBncTextChanged()));
384
385 connect(_pppRefCrdXLineEdit, SIGNAL(textChanged(const QString &)),
386 this, SLOT(slotBncTextChanged()));
387 connect(_pppRefCrdYLineEdit, SIGNAL(textChanged(const QString &)),
388 this, SLOT(slotBncTextChanged()));
389 connect(_pppRefCrdZLineEdit, SIGNAL(textChanged(const QString &)),
390 this, SLOT(slotBncTextChanged()));
391
392 connect(_pppEstTropoCheckBox, SIGNAL(stateChanged(int)),
393 this, SLOT(slotBncTextChanged()));
394
395 connect(_pppSync, SIGNAL(textChanged(const QString &)),
396 this, SLOT(slotBncTextChanged()));
397
398 connect(_pppSPPComboBox, SIGNAL(currentIndexChanged(const QString &)),
399 this, SLOT(slotBncTextChanged()));
400
401 // Streams
402 // -------
403 _mountPointsTable = new QTableWidget(0,8);
404
405 _mountPointsTable->horizontalHeader()->resizeSection(1,34*ww);
406 _mountPointsTable->horizontalHeader()->resizeSection(2,9*ww);
407 _mountPointsTable->horizontalHeader()->resizeSection(3,7*ww);
408 _mountPointsTable->horizontalHeader()->resizeSection(4,7*ww);
409 _mountPointsTable->horizontalHeader()->resizeSection(5,5*ww);
410 _mountPointsTable->horizontalHeader()->resizeSection(6,5*ww);
411 _mountPointsTable->horizontalHeader()->setResizeMode(QHeaderView::Interactive);
412 _mountPointsTable->horizontalHeader()->setStretchLastSection(true);
413 _mountPointsTable->horizontalHeader()->setDefaultAlignment(Qt::AlignLeft);
414 _mountPointsTable->setHorizontalHeaderLabels(labels);
415 _mountPointsTable->setGridStyle(Qt::NoPen);
416 _mountPointsTable->setHorizontalScrollBarPolicy(Qt::ScrollBarAlwaysOff);
417 _mountPointsTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
418 _mountPointsTable->setSelectionBehavior(QAbstractItemView::SelectRows);
419 _mountPointsTable->hideColumn(0);
420 connect(_mountPointsTable, SIGNAL(itemSelectionChanged()),
421 SLOT(slotSelectionChanged()));
422 populateMountPointsTable();
423
424 _log = new QTextBrowser();
425 _log->setReadOnly(true);
426
427 // WhatsThis
428 // ---------
429 _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>"));
430 _proxyPortLineEdit->setWhatsThis(tr("<p>Enter your proxy server port number in case a proxy is operated in front of BNC.</p>"));
431 _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 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>"));
432 _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."));
433 _outPortLineEdit->setWhatsThis(tr("BNC can produce synchronized observations in binary format on your local host through an IP port. Specify a port number here to activate this function."));
434 _outUPortLineEdit->setWhatsThis(tr("BNC can produce unsynchronized observations in binary format on your local host through an IP port. Specify a port number here to activate this function."));
435 _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."));
436 _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."));
437 _corrTimeSpinBox->setWhatsThis(tr("Concerning output through IP port, BNC drops Broadcast Ephemeris Corrections received later than 'Wait for full epoch' seconds. A value of 2 to 5 seconds is recommended, depending on the latency of the incoming correction stream(s) and the delay acceptable to your real-time application."));
438 _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."));
439 _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."));
440 _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."));
441 _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>"));
442 _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>"));
443 _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>"));
444 _autoStartCheckBox->setWhatsThis(tr("<p>Tick 'Auto start' for auto-start of BNC at startup time in window mode with preassigned processing options.</p>"));
445 _rawOutFileLineEdit->setWhatsThis(tr("<p>Save all data coming in through various streams in the received order and format in one file.</p>"));
446
447 _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', '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>"));
448 _rnxIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Observation file.</p>"));
449 _ephIntrComboBox->setWhatsThis(tr("<p>Select the length of the RINEX Navigation file.</p>"));
450 _corrIntrComboBox->setWhatsThis(tr("<p>Select the length of the Broadcast Ephemeris Correction files.</p>"));
451 _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>"));
452 _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>"));
453 _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>"));
454 _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>"));
455 _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>"));
456 _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."));
457 _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>"));
458 _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>"));
459 _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 'RTIGS'.</p><p>In case you need to log the raw data as is, BNC allows users to by-pass its decoders and 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>"));
460 _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."));
461 _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)."));
462 _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."));
463 _ephV3CheckBox->setWhatsThis(tr("The default format for output of RINEX Navigation data containing Broadcast Ephemeris is RINEX Version 2.11. Select 'Version 3' if you want to output the ephemeris in RINEX Version 3 format."));
464 _rnxV3CheckBox->setWhatsThis(tr("The default format for RINEX Observation files is RINEX Version 2.11. Select 'Version 3' if you want to save the observations in RINEX Version 3 format."));
465 _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>"));
466 _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>"));
467 _serialMountPointLineEdit->setWhatsThis(tr("<p>Enter a 'Mountpoint' to forward the corresponding stream to a serial connected receiver.</p>"));
468 _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>"));
469 _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>"));
470 _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>"));
471 _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>"));
472 _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>"));
473 _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>"));
474 _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>"));
475 _serialFileNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where NMEA messages coming from your serial connected receiver are saved.</p>"));
476 _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>"));
477 _pppMountLineEdit->setWhatsThis(tr("<p>Specify a mountpoint if you want BNC to estimate coordinates for the affected receiver position through a PPP solution.</p><p>Note that PPP in BNC requires to also pull a stream carrying RTCM Version 3 satellite orbit and clock corrections to Broadcast Ephemeris referring to the satellites' Antenna Phase Centers (APC). Stream CLK11 on NTRIP broadcaster products.igs-ip.net is an example.</p><p>Pulling in addition a third stream carrying Broadcast Ephemeris messages in high repetition rate is suggested if such messages are comeing from the receiver in low repetition rate or don't come at all from there.</p>"));
478 _pppSPPComboBox->setWhatsThis(tr("<p>Choose between plain Single Point Positioning (SPP) and Precise Point Positioning (PPP).</p>"));
479 _pppUsePhaseCheckBox->setWhatsThis(tr("<p>By default BNC applies a PPP solution using an ionosphere free P3 linear combination of code observations.</p><p>Tick 'Use phase obs' for an ionosphere free L3 linear combination of phase observations.</p>"));
480 _pppEstTropoCheckBox->setWhatsThis(tr("<p>By default BNC does not introduce troposphere parameters when estimating coordinates.</p><p>Tick 'Estimate tropo' to introduce troposphere parameters when estimating coordinates.</p>"));
481 _pppGLONASSCheckBox->setWhatsThis(tr("<p>By default BNC does not use GLONASS observations in PPP mode.</p><p>Tick 'Use GLONASS' for a combined processing of both, GPS and GLONASS observations in PPP mode.</p>"));
482 _pppGalileoCheckBox->setWhatsThis(tr("<p>By default BNC does not use Galileo observations in PPP mode.</p><p>Tick 'Use Galileo' for a combined processing of both, GPS and Galileo observations in PPP mode.</p>"));
483 _pppPlotCoordinates->setWhatsThis(tr("<p>BNC will plot PPP results in the 'PPP Plot' tab as North (red), East (green) and Up (blue) displacements when this option is selected. Values will be either referred to an XYZ reference coordinate (if specified) or referred to the first estimated coordinate. The sliding PPP time series window will cover the period of the latest 5 minutes.</p><p>Note that a PPP time series makes only sense for a stationary operated receiver."));
484 _pppNMEALineEdit->setWhatsThis(tr("<p>Specify the full path to a file where PPP results are saved as NMEA messages.</p>"));
485 _pppNMEAPortLineEdit->setWhatsThis(tr("<p>Specify an IP port number to output PPP results as NMEA messages through an IP port.</p>"));
486 _pppSigCLineEdit->setWhatsThis(tr("<p>Enter a sigma for your code observations in meters.</p><p>The higher the sigma you enter, the less the contribution of code observations to a PPP solution based on a combination of code and phase data. 5.0 (default) is likely to be an appropriate choice.</p>"));
487 _pppQuickStartLineEdit->setWhatsThis(tr("<p>Enter the lenght of a startup period in seconds for which you want to fix the PPP solution to a known XYZ coordinate as introduced above and adjust a sigma 'XYZ Ini' according to the coordinate's precision. Fixing the coordinate is done in BNC through setting the 'XYZ White Noise' you define below temporarily to zero.</p><p>This so-called Quick-Start option allows the PPP solution to rapidly converge. It requires that the antenna remains unmoved on the know position throughout the startup period.</p><p>A value of 120 is likely to be an appropriate choice for 'Quick-Start'. Default is an empty option field, meaning that you don't want BNC to operate in Quick-Start mode.</p>"));
488 _pppSigPLineEdit->setWhatsThis(tr("<p>Enter a sigma for your phase observations in meters.</p><p>The higher the sigma you enter, the less the contribution of phase observations to a PPP solutions based on a combination of code and phase data. 0.02 (default) is likely to be an appropriate choice.</p>"));
489 _pppAverageLineEdit->setWhatsThis(tr("<p>Enter the length of a sliding time window in minutes. BNC will continuously output moving average positions computed from those individual positions obtained most recently throughout this period.</p><p>An empty option field (default) means that you don't want BNC to output moving average positions.</p>"));
490 _pppSigCrd0->setWhatsThis(tr("<p>Enter a sigma in meters for the initial XYZ coordinate componentes. A value of 100.0 (default) may be an appropriate choice. However, this value may be significantly smaller (i.e. 0.01) when starting for example from a station with known XZY position in Quick-Start mode."));
491 _pppSigCrdP->setWhatsThis(tr("<p>Enter a sigma in meters for the 'White Noise' of estimated XYZ coordinate components. A value of 100.0 (default) may be appropriate considering the potential movement of a rover position.</p>"));
492 _pppSigTrp0->setWhatsThis(tr("<p>Enter a sigma in meters for the a-priory model based tropospheric delay estimation. A value of 0.1 (default) may be an appropriate choice.</p>"));
493 _pppSigTrpP->setWhatsThis(tr("<p>Enter a sigma in meters per second to describe the variation of the tropospheric effect.</p><p>Supposing 1Hz observation data, a value of 1e-6 (default) would mean that the tropospheric effect may vary for 3600 * 1e-6 = 0.0036 meters per hour.</p>"));
494 _pppRefCrdXLineEdit->setWhatsThis(tr("<p>Enter reference coordinate X of the receiver's position.</p>"));
495 _pppRefCrdYLineEdit->setWhatsThis(tr("<p>Enter reference coordinate Y of the receiver's position.</p>"));
496 _pppRefCrdZLineEdit->setWhatsThis(tr("<p>Enter reference coordinate Z of the receiver's position.</p>"));
497 _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."));
498 _pppSync->setWhatsThis(tr(
499 "<p> Zero value (or empty field) means that BNC processes each epoch of data "
500 "immediately after its arrival using satellite clock corrections available at "
501 "that time. Non-zero value 'pppSync' (i.e. 5) means that the epochs of data "
502 "are buffered and the processing of each epoch is postponed till the satellite clock "
503 "corrections not older than 'pppSync' seconds are available.<p>"));
504
505 // Canvas with Editable Fields
506 // ---------------------------
507 _canvas = new QWidget;
508 setCentralWidget(_canvas);
509
510 _aogroup = new QTabWidget();
511 QWidget* pgroup = new QWidget();
512 QWidget* ggroup = new QWidget();
513 QWidget* sgroup = new QWidget();
514 QWidget* egroup = new QWidget();
515 QWidget* agroup = new QWidget();
516 QWidget* cgroup = new QWidget();
517 QWidget* ogroup = new QWidget();
518 QWidget* rgroup = new QWidget();
519 QWidget* sergroup = new QWidget();
520 QWidget* pppgroup = new QWidget();
521 QWidget* ppp2group = new QWidget();
522 QWidget* cmbgroup = new QWidget();
523 _aogroup->addTab(pgroup,tr("Proxy"));
524 _aogroup->addTab(ggroup,tr("General"));
525 _aogroup->addTab(ogroup,tr("RINEX Observations"));
526 _aogroup->addTab(egroup,tr("RINEX Ephemeris"));
527 _aogroup->addTab(cgroup,tr("Broadcast Corrections"));
528 _aogroup->addTab(sgroup,tr("Feed Engine"));
529 _aogroup->addTab(sergroup,tr("Serial Output"));
530 _aogroup->addTab(agroup,tr("Outages"));
531 _aogroup->addTab(rgroup,tr("Miscellaneous"));
532 _aogroup->addTab(pppgroup,tr("PPP (1)"));
533 _aogroup->addTab(ppp2group,tr("PPP (2)"));
534 _aogroup->addTab(cmbgroup,tr("Combination"));
535
536 // Log Tab
537 // -------
538 _loggroup = new QTabWidget();
539 _loggroup->addTab(_log,tr("Log"));
540 _loggroup->addTab(_bncFigure,tr("Throughput"));
541 _loggroup->addTab(_bncFigureLate,tr("Latency"));
542 _loggroup->addTab(_bncFigurePPP,tr("PPP Plot"));
543
544 // Proxy Tab
545 // ---------
546 QGridLayout* pLayout = new QGridLayout;
547 pLayout->setColumnMinimumWidth(0,13*ww);
548 _proxyPortLineEdit->setMaximumWidth(9*ww);
549
550 pLayout->addWidget(new QLabel("Proxy host"), 0, 0);
551 pLayout->addWidget(_proxyHostLineEdit, 0, 1, 1,10);
552 pLayout->addWidget(new QLabel("Proxy port"), 1, 0);
553 pLayout->addWidget(_proxyPortLineEdit, 1, 1);
554 pLayout->addWidget(new QLabel("Settings for proxy in protected networks, leave boxes blank if none."),2, 0, 1, 50, Qt::AlignLeft);
555 pLayout->addWidget(new QLabel(" "),3,0);
556 pLayout->addWidget(new QLabel(" "),4,0);
557 pLayout->addWidget(new QLabel(" "),5,0);
558 pgroup->setLayout(pLayout);
559
560 // General Tab
561 // -----------
562 QGridLayout* gLayout = new QGridLayout;
563 gLayout->setColumnMinimumWidth(0,14*ww);
564 _onTheFlyComboBox->setMaximumWidth(9*ww);
565
566 gLayout->addWidget(new QLabel("Logfile (full path)"), 0, 0);
567 gLayout->addWidget(_logFileLineEdit, 0, 1, 1,30); // 1
568 gLayout->addWidget(new QLabel("Append files"), 1, 0);
569 gLayout->addWidget(_rnxAppendCheckBox, 1, 1);
570 gLayout->addWidget(new QLabel("Reread configuration"), 2, 0);
571 gLayout->addWidget(_onTheFlyComboBox, 2, 1);
572 gLayout->addWidget(new QLabel("Auto start"), 3, 0);
573 gLayout->addWidget(_autoStartCheckBox, 3, 1);
574 gLayout->addWidget(new QLabel("Raw output file (full path)"), 4, 0);
575 gLayout->addWidget(_rawOutFileLineEdit, 4, 1, 1,30);
576 gLayout->addWidget(new QLabel("General settings for logfile, file handling, configuration on-the-fly, and auto-start."),5, 0, 1, 50, Qt::AlignLeft);
577 ggroup->setLayout(gLayout);
578
579 // RINEX Observations
580 // ------------------
581 QGridLayout* oLayout = new QGridLayout;
582 oLayout->setColumnMinimumWidth(0,14*ww);
583 _rnxIntrComboBox->setMaximumWidth(9*ww);
584 _rnxSamplSpinBox->setMaximumWidth(9*ww);
585
586 oLayout->addWidget(new QLabel("Directory"), 0, 0);
587 oLayout->addWidget(_rnxPathLineEdit, 0, 1,1,24);
588 oLayout->addWidget(new QLabel("Interval"), 1, 0);
589 oLayout->addWidget(_rnxIntrComboBox, 1, 1);
590 oLayout->addWidget(new QLabel(" Sampling"), 1, 2, Qt::AlignRight);
591 oLayout->addWidget(_rnxSamplSpinBox, 1, 3, Qt::AlignLeft);
592 oLayout->addWidget(new QLabel("Skeleton extension"), 2, 0);
593 oLayout->addWidget(_rnxSkelLineEdit, 2, 1,1,1, Qt::AlignLeft);
594 oLayout->addWidget(new QLabel("Script (full path)"), 3, 0);
595 oLayout->addWidget(_rnxScrpLineEdit, 3, 1,1,24);
596 oLayout->addWidget(new QLabel("Version 3"), 4, 0);
597 oLayout->addWidget(_rnxV3CheckBox, 4, 1);
598 oLayout->addWidget(new QLabel("Saving RINEX observation files."),5,0,1,50, Qt::AlignLeft);
599 ogroup->setLayout(oLayout);
600
601 // RINEX Ephemeris
602 // ---------------
603 QGridLayout* eLayout = new QGridLayout;
604 eLayout->setColumnMinimumWidth(0,14*ww);
605 _ephIntrComboBox->setMaximumWidth(9*ww);
606 _outEphPortLineEdit->setMaximumWidth(9*ww);
607
608 eLayout->addWidget(new QLabel("Directory"), 0, 0);
609 eLayout->addWidget(_ephPathLineEdit, 0, 1, 1,30);
610 eLayout->addWidget(new QLabel("Interval"), 1, 0);
611 eLayout->addWidget(_ephIntrComboBox, 1, 1);
612 eLayout->addWidget(new QLabel("Port"), 2, 0);
613 eLayout->addWidget(_outEphPortLineEdit, 2, 1);
614 eLayout->addWidget(new QLabel("Version 3"), 3, 0);
615 eLayout->addWidget(_ephV3CheckBox, 3, 1);
616 eLayout->addWidget(new QLabel("Saving RINEX ephemeris files and ephemeris output through IP port."),4,0,1,50,Qt::AlignLeft);
617 eLayout->addWidget(new QLabel(" "),5,0);
618 egroup->setLayout(eLayout);
619
620
621 // Broadcast Corrections
622 // ---------------------
623 QGridLayout* cLayout = new QGridLayout;
624 cLayout->setColumnMinimumWidth(0,14*ww);
625 _corrIntrComboBox->setMaximumWidth(9*ww);
626 _corrPortLineEdit->setMaximumWidth(9*ww);
627 _corrTimeSpinBox->setMaximumWidth(9*ww);
628
629 cLayout->addWidget(new QLabel("Directory"), 0, 0);
630 cLayout->addWidget(_corrPathLineEdit, 0, 1,1,20);
631 cLayout->addWidget(new QLabel("Interval"), 1, 0);
632 cLayout->addWidget(_corrIntrComboBox, 1, 1);
633 cLayout->addWidget(new QLabel("Port"), 2, 0);
634 cLayout->addWidget(_corrPortLineEdit, 2, 1);
635 cLayout->addWidget(new QLabel(" Wait for full epoch"), 2, 2, Qt::AlignRight);
636 cLayout->addWidget(_corrTimeSpinBox, 2, 3, Qt::AlignLeft);
637 cLayout->addWidget(new QLabel("Saving Broadcast Ephemeris correction files and correction output through IP port."),3,0,1,50);
638 cLayout->addWidget(new QLabel(" "),4,0);
639 cLayout->addWidget(new QLabel(" "),5,0);
640 cgroup->setLayout(cLayout);
641
642 // Feed Engine
643 // -----------
644 QGridLayout* sLayout = new QGridLayout;
645 sLayout->setColumnMinimumWidth(0,14*ww);
646 _outPortLineEdit->setMaximumWidth(9*ww);
647 _waitTimeSpinBox->setMaximumWidth(9*ww);
648 _binSamplSpinBox->setMaximumWidth(9*ww);
649 _outUPortLineEdit->setMaximumWidth(9*ww);
650
651 sLayout->addWidget(new QLabel("Port"), 0, 0);
652 sLayout->addWidget(_outPortLineEdit, 0, 1);
653 sLayout->addWidget(new QLabel("Wait for full epoch"), 0, 2, Qt::AlignRight);
654 sLayout->addWidget(_waitTimeSpinBox, 0, 3, Qt::AlignLeft);
655 sLayout->addWidget(new QLabel("Sampling"), 1, 0);
656 sLayout->addWidget(_binSamplSpinBox, 1, 1, Qt::AlignLeft);
657 sLayout->addWidget(new QLabel("File (full path)"), 2, 0);
658 sLayout->addWidget(_outFileLineEdit, 2, 1, 1, 20);
659 sLayout->addWidget(new QLabel("Port (unsynchronized)"), 3, 0);
660 sLayout->addWidget(_outUPortLineEdit, 3, 1);
661 sLayout->addWidget(new QLabel("Output decoded observations in a binary format to feed a real-time GNSS network engine."),4,0,1,50);
662 sLayout->addWidget(new QLabel(" "),5,0);
663 sgroup->setLayout(sLayout);
664
665 // Serial Output
666 // -------------
667 QGridLayout* serLayout = new QGridLayout;
668 serLayout->setColumnMinimumWidth(0,14*ww);
669 _serialBaudRateComboBox->setMaximumWidth(9*ww);
670 _serialFlowControlComboBox->setMaximumWidth(11*ww);
671 _serialDataBitsComboBox->setMaximumWidth(5*ww);
672 _serialParityComboBox->setMaximumWidth(9*ww);
673 _serialStopBitsComboBox->setMaximumWidth(5*ww);
674 _serialAutoNMEAComboBox->setMaximumWidth(9*ww);
675 _serialHeightNMEALineEdit->setMaximumWidth(8*ww);
676
677 serLayout->addWidget(new QLabel("Mountpoint"), 0,0, Qt::AlignLeft);
678 serLayout->addWidget(_serialMountPointLineEdit, 0,1,1,2);
679 serLayout->addWidget(new QLabel("Port name"), 1,0, Qt::AlignLeft);
680 serLayout->addWidget(_serialPortNameLineEdit, 1,1,1,2);
681 serLayout->addWidget(new QLabel("Baud rate"), 2,0, Qt::AlignLeft);
682 serLayout->addWidget(_serialBaudRateComboBox, 2,1);
683 serLayout->addWidget(new QLabel("Flow control"), 2,2, Qt::AlignRight);
684 serLayout->addWidget(_serialFlowControlComboBox, 2,3);
685 serLayout->addWidget(new QLabel("Data bits"), 3,0, Qt::AlignLeft);
686 serLayout->addWidget(_serialDataBitsComboBox, 3,1);
687 serLayout->addWidget(new QLabel("Parity"), 3,2, Qt::AlignRight);
688 serLayout->addWidget(_serialParityComboBox, 3,3);
689 serLayout->addWidget(new QLabel(" Stop bits"), 3,4, Qt::AlignRight);
690 serLayout->addWidget(_serialStopBitsComboBox, 3,5);
691 serLayout->addWidget(new QLabel("NMEA"), 4,0);
692 serLayout->addWidget(_serialAutoNMEAComboBox, 4,1);
693 serLayout->addWidget(new QLabel(" File (full path)"), 4,2, Qt::AlignRight);
694 serLayout->addWidget(_serialFileNMEALineEdit, 4,3,1,15);
695 serLayout->addWidget(new QLabel("Height"), 4,20, Qt::AlignRight);
696 serLayout->addWidget(_serialHeightNMEALineEdit, 4,21,1,11);
697 serLayout->addWidget(new QLabel("Port settings to feed a serial connected receiver."),5,0,1,30);
698
699 sergroup->setLayout(serLayout);
700
701 // Outages
702 // -------
703 QGridLayout* aLayout = new QGridLayout;
704 aLayout->setColumnMinimumWidth(0,14*ww);
705 _obsRateComboBox->setMaximumWidth(9*ww);
706 _adviseFailSpinBox->setMaximumWidth(9*ww);
707 _adviseRecoSpinBox->setMaximumWidth(9*ww);
708
709 aLayout->addWidget(new QLabel("Observation rate"), 0, 0);
710 aLayout->addWidget(_obsRateComboBox, 0, 1);
711 aLayout->addWidget(new QLabel("Failure threshold"), 1, 0);
712 aLayout->addWidget(_adviseFailSpinBox, 1, 1);
713 aLayout->addWidget(new QLabel("Recovery threshold"), 2, 0);
714 aLayout->addWidget(_adviseRecoSpinBox, 2, 1);
715 aLayout->addWidget(new QLabel("Script (full path)"), 3, 0);
716 aLayout->addWidget(_adviseScriptLineEdit, 3, 1,1,30);
717 aLayout->addWidget(new QLabel("Failure and recovery reports, advisory notes."),4,0,1,50,Qt::AlignLeft);
718 aLayout->addWidget(new QLabel(" "), 5, 0);
719 agroup->setLayout(aLayout);
720
721 // Miscellaneous
722 // -------------
723 QGridLayout* rLayout = new QGridLayout;
724 rLayout->setColumnMinimumWidth(0,14*ww);
725 _perfIntrComboBox->setMaximumWidth(9*ww);
726
727 rLayout->addWidget(new QLabel("Mountpoint"), 0, 0);
728 rLayout->addWidget(_miscMountLineEdit, 0, 1, 1,7);
729 rLayout->addWidget(new QLabel("Log latency"), 1, 0);
730 rLayout->addWidget(_perfIntrComboBox, 1, 1);
731 rLayout->addWidget(new QLabel("Scan RTCM"), 2, 0);
732 rLayout->addWidget(_scanRTCMCheckBox, 2, 1);
733 rLayout->addWidget(new QLabel("Log latencies or scan RTCM streams for numbers of message types and antenna information."),3, 0,1,30);
734 rLayout->addWidget(new QLabel(" "), 4, 0);
735 rLayout->addWidget(new QLabel(" "), 5, 0);
736 rgroup->setLayout(rLayout);
737
738 // PPP Client
739 // ----------
740 QGridLayout* pppLayout = new QGridLayout;
741 _pppSigCLineEdit->setMaximumWidth(6*ww);
742 _pppSigPLineEdit->setMaximumWidth(6*ww);
743 _pppSigCrd0->setMaximumWidth(6*ww);
744 _pppSigCrdP->setMaximumWidth(6*ww);
745 _pppSigTrp0->setMaximumWidth(6*ww);
746 _pppSigTrpP->setMaximumWidth(6*ww);
747 _pppAverageLineEdit->setMaximumWidth(6*ww);
748 _pppQuickStartLineEdit->setMaximumWidth(6*ww);
749 _pppRefCrdXLineEdit->setMaximumWidth(14*ww);
750 _pppRefCrdYLineEdit->setMaximumWidth(14*ww);
751 _pppRefCrdZLineEdit->setMaximumWidth(14*ww);
752 _pppSync->setMaximumWidth(6*ww);
753 _pppSPPComboBox->setMaximumWidth(8*ww);
754 _pppNMEAPortLineEdit->setMaximumWidth(6*ww);
755//pppLayout->setColumnMinimumWidth(0,12*ww);
756 pppLayout->addWidget(new QLabel("Mountpoint"), 0, 0);
757 pppLayout->addWidget(_pppMountLineEdit, 0, 1);
758 pppLayout->addWidget(_pppSPPComboBox, 0, 2);
759 pppLayout->addWidget(new QLabel(" X "), 0, 3, Qt::AlignRight);
760 pppLayout->addWidget(_pppRefCrdXLineEdit, 0, 4);
761 pppLayout->addWidget(new QLabel(" Y "), 0, 5, Qt::AlignRight);
762 pppLayout->addWidget(_pppRefCrdYLineEdit, 0, 6);
763 pppLayout->addWidget(new QLabel(" Z "), 0, 7, Qt::AlignRight);
764 pppLayout->addWidget(_pppRefCrdZLineEdit, 0, 8);
765 pppLayout->addWidget(new QLabel("Options"), 1, 0, 1, 5);
766 pppLayout->addWidget(_pppUsePhaseCheckBox, 1, 1, Qt::AlignRight);
767 pppLayout->addWidget(new QLabel("Use phase obs"), 1, 2);
768 pppLayout->addWidget(_pppEstTropoCheckBox, 1, 3, Qt::AlignRight);
769 pppLayout->addWidget(new QLabel("Estimate tropo"), 1, 4);
770 pppLayout->addWidget(_pppGLONASSCheckBox, 1, 5, Qt::AlignRight);
771 pppLayout->addWidget(new QLabel("Use GLONASS"), 1, 6);
772 pppLayout->addWidget(_pppGalileoCheckBox, 1, 7, Qt::AlignRight);
773 pppLayout->addWidget(new QLabel("Use Galileo"), 1, 8);
774 pppLayout->addWidget(new QLabel("Options cont'd"), 2, 0);
775 pppLayout->addWidget(_pppSigCLineEdit, 2, 1, Qt::AlignRight);
776 pppLayout->addWidget(new QLabel("Sigma Code"), 2, 2);
777 pppLayout->addWidget(_pppSigPLineEdit, 2, 3);
778 pppLayout->addWidget(new QLabel("Sigma Phase"), 2, 4);
779 pppLayout->addWidget(_pppQuickStartLineEdit, 2, 5, Qt::AlignRight);
780 pppLayout->addWidget(new QLabel("Quick-Start (sec) ") , 2, 6);
781 pppLayout->addWidget(_pppAverageLineEdit, 2, 7);
782 pppLayout->addWidget(new QLabel("Averaging (min)") , 2, 8);
783 pppLayout->addWidget(new QLabel("Parameter sigmas"), 3, 0);
784 pppLayout->addWidget(_pppSigCrd0, 3, 1, Qt::AlignRight);
785 pppLayout->addWidget(new QLabel("XYZ Init"), 3, 2);
786 pppLayout->addWidget(_pppSigCrdP, 3, 3);
787 pppLayout->addWidget(new QLabel("XYZ White Noise "), 3, 4);
788 pppLayout->addWidget(_pppSigTrp0, 3, 5, Qt::AlignRight);
789 pppLayout->addWidget(new QLabel("Tropo Init"), 3, 6);
790 pppLayout->addWidget(_pppSigTrpP, 3, 7);
791 pppLayout->addWidget(new QLabel("Tropo White Noise"), 3, 8);
792 pppLayout->addWidget(new QLabel("Output"), 4, 0);
793 pppLayout->addWidget(_pppNMEALineEdit, 4, 1, 1, 3);
794 pppLayout->addWidget(new QLabel("NMEA file"), 4, 4);
795 pppLayout->addWidget(_pppNMEAPortLineEdit, 4, 5);
796 pppLayout->addWidget(new QLabel("NMEA port"), 4, 6);
797 pppLayout->addWidget(_pppPlotCoordinates, 4, 7, Qt::AlignRight);
798 pppLayout->addWidget(new QLabel("PPP Plot"), 4, 8);
799
800 pppLayout->addWidget(new QLabel("Coordinates from Precise Point Positioning (PPP)."),5, 0,1,5);
801 pppLayout->addWidget(_pppSync, 5, 7);
802 pppLayout->addWidget(new QLabel("Sync Corr (sec)"), 5, 8);
803
804 pppgroup->setLayout(pppLayout);
805
806 // PPP Client (second panel)
807 // -------------------------
808 QGridLayout* ppp2Layout = new QGridLayout;
809
810 _pppAntennaLineEdit = new QLineEdit(settings.value("pppAntenna").toString());
811 _pppAntennaLineEdit->setMinimumWidth(20*ww);
812 _pppAntennaLineEdit->setMaximumWidth(20*ww);
813
814 _pppAntexLineEdit = new QLineEdit(settings.value("pppAntex").toString());
815 _pppAntexLineEdit->setMinimumWidth(20*ww);
816 _pppAntexLineEdit->setMaximumWidth(20*ww);
817
818 _pppIgnoreSatAntCheckBox = new QCheckBox();
819 _pppIgnoreSatAntCheckBox->setCheckState(Qt::CheckState(
820 settings.value("pppIgnoreSatAnt").toInt()));
821
822 ppp2Layout->addWidget(new QLabel("Antenna Name"), 0, 0);
823 ppp2Layout->addWidget(_pppAntennaLineEdit, 0, 1);
824 ppp2Layout->addWidget(new QLabel("ANTEX File"), 1, 0);
825 ppp2Layout->addWidget(_pppAntexLineEdit, 1, 1);
826 ppp2Layout->addWidget(new QLabel("Ignore Satellite Antenna Offsets"), 1, 2);
827 ppp2Layout->addWidget(_pppIgnoreSatAntCheckBox, 1, 3);
828
829 ppp2Layout->setRowStretch(2,1);
830 ppp2Layout->setColumnStretch(4,1);
831
832 ppp2Layout->addWidget(new QLabel("Options for PPP (continuation)"), 3, 0, 1, 4);
833
834 ppp2group->setLayout(ppp2Layout);
835
836 // Combination
837 // -----------
838 QGridLayout* cmbLayout = new QGridLayout;
839
840 _cmbTable = new QTableWidget(0,3);
841 _cmbTable->setHorizontalHeaderLabels(QString("Mountpoint, AC Name, Weight").split(","));
842 _cmbTable->setSelectionMode(QAbstractItemView::ExtendedSelection);
843 _cmbTable->setSelectionBehavior(QAbstractItemView::SelectRows);
844 populateCmbTable();
845 cmbLayout->addWidget(_cmbTable,0,0,6,3);
846 cmbLayout->setColumnStretch(0,1);
847 cmbLayout->setColumnStretch(1,1);
848 cmbLayout->setColumnStretch(2,1);
849
850 QPushButton* addCmbRowButton = new QPushButton("Add Row");
851 cmbLayout->addWidget(addCmbRowButton,0,3);
852 connect(addCmbRowButton, SIGNAL(clicked()), this, SLOT(slotAddCmbRow()));
853
854 QPushButton* delCmbRowButton = new QPushButton("Delete");
855 cmbLayout->addWidget(delCmbRowButton,1,3);
856 connect(delCmbRowButton, SIGNAL(clicked()), this, SLOT(slotDelCmbRow()));
857
858 cmbLayout->setColumnStretch(4,1);
859
860 cmbLayout->addWidget(new QLabel("Host"), 0, 5);
861 _cmbOutHostLineEdit = new QLineEdit(settings.value("cmbOutHost").toString());
862 cmbLayout->addWidget(_cmbOutHostLineEdit, 0, 6);
863
864 cmbLayout->addWidget(new QLabel("Port"), 0, 7);
865 _cmbOutPortLineEdit = new QLineEdit(settings.value("cmbOutPort").toString());
866 _cmbOutPortLineEdit->setMaximumWidth(9*ww);
867 cmbLayout->addWidget(_cmbOutPortLineEdit, 0, 8);
868
869 cmbLayout->addWidget(new QLabel("Mountpoint"), 1, 5);
870 _cmbMountpointLineEdit = new QLineEdit(settings.value("cmbMountpoint").toString());
871 _cmbMountpointLineEdit->setMaximumWidth(12*ww);
872 cmbLayout->addWidget(_cmbMountpointLineEdit, 1, 6);
873
874 cmbLayout->addWidget(new QLabel("Password"), 1, 7);
875 _cmbPasswordLineEdit = new QLineEdit(settings.value("cmbPassword").toString());
876 _cmbPasswordLineEdit->setEchoMode(QLineEdit::Password);
877 _cmbPasswordLineEdit->setMaximumWidth(9*ww);
878 cmbLayout->addWidget(_cmbPasswordLineEdit, 1, 8);
879
880 cmbLayout->addWidget(new QLabel("Output File"), 2, 5);
881 _cmbOutFileLineEdit = new QLineEdit(settings.value("cmbOutFile").toString());
882 cmbLayout->addWidget(_cmbOutFileLineEdit, 2, 6);
883
884 cmbLayout->addWidget(new QLabel("Output SP3"), 3, 5);
885 _cmbSP3FileLineEdit = new QLineEdit(settings.value("cmbSP3File").toString());
886 cmbLayout->addWidget(_cmbSP3FileLineEdit, 3, 6);
887
888 cmbgroup->setLayout(cmbLayout);
889
890 // Main Layout
891 // -----------
892 QGridLayout* mLayout = new QGridLayout;
893 _aogroup->setCurrentIndex(settings.value("startTab").toInt());
894 mLayout->addWidget(_aogroup, 0,0);
895 mLayout->addWidget(_mountPointsTable, 1,0);
896 _loggroup->setCurrentIndex(settings.value("statusTab").toInt());
897 mLayout->addWidget(_loggroup, 2,0);
898
899 _canvas->setLayout(mLayout);
900
901 // Enable/Disable all Widgets
902 // --------------------------
903 slotBncTextChanged();
904
905 // Auto start
906 // ----------
907 if ( Qt::CheckState(settings.value("autoStart").toInt()) == Qt::Checked) {
908 slotGetData();
909 }
910}
911
912// Destructor
913////////////////////////////////////////////////////////////////////////////
914bncWindow::~bncWindow() {
915 delete _caster;
916}
917
918//
919////////////////////////////////////////////////////////////////////////////
920void bncWindow::populateMountPointsTable() {
921
922 for (int iRow = _mountPointsTable->rowCount()-1; iRow >=0; iRow--) {
923 _mountPointsTable->removeRow(iRow);
924 }
925
926 bncSettings settings;
927
928 QListIterator<QString> it(settings.value("mountPoints").toStringList());
929 if (!it.hasNext()) {
930 _actGetData->setEnabled(false);
931 }
932 int iRow = 0;
933 while (it.hasNext()) {
934 QStringList hlp = it.next().split(" ");
935 if (hlp.size() < 5) continue;
936 _mountPointsTable->insertRow(iRow);
937
938 QUrl url(hlp[0]);
939
940 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
941 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
942 QString nmea(hlp[4]);
943 if (hlp[5] == "S") {
944 fullPath = hlp[0].replace(0,2,"");
945 }
946 QString ntripVersion = "1";
947 if (hlp.size() >= 6) {
948 ntripVersion = (hlp[5]);
949 }
950
951 QTableWidgetItem* it;
952 it = new QTableWidgetItem(url.userInfo());
953 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
954 _mountPointsTable->setItem(iRow, 0, it);
955
956 it = new QTableWidgetItem(fullPath);
957 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
958 _mountPointsTable->setItem(iRow, 1, it);
959
960 it = new QTableWidgetItem(format);
961 _mountPointsTable->setItem(iRow, 2, it);
962
963 if (nmea == "yes") {
964 it = new QTableWidgetItem(latitude);
965 _mountPointsTable->setItem(iRow, 3, it);
966 it = new QTableWidgetItem(longitude);
967 _mountPointsTable->setItem(iRow, 4, it);
968 } else {
969 it = new QTableWidgetItem(latitude);
970 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
971 _mountPointsTable->setItem(iRow, 3, it);
972 it = new QTableWidgetItem(longitude);
973 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
974 _mountPointsTable->setItem(iRow, 4, it);
975 }
976
977 it = new QTableWidgetItem(nmea);
978 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
979 _mountPointsTable->setItem(iRow, 5, it);
980
981 it = new QTableWidgetItem(ntripVersion);
982 //// it->setFlags(it->flags() & ~Qt::ItemIsEditable);
983 _mountPointsTable->setItem(iRow, 6, it);
984
985 bncTableItem* bncIt = new bncTableItem();
986 bncIt->setFlags(bncIt->flags() & ~Qt::ItemIsEditable);
987 _mountPointsTable->setItem(iRow, 7, bncIt);
988
989 iRow++;
990 }
991
992 _mountPointsTable->sortItems(1);
993}
994
995// Retrieve Table
996////////////////////////////////////////////////////////////////////////////
997void bncWindow::slotAddMountPoints() {
998
999 bncSettings settings;
1000 QString proxyHost = settings.value("proxyHost").toString();
1001 int proxyPort = settings.value("proxyPort").toInt();
1002 if (proxyHost != _proxyHostLineEdit->text() ||
1003 proxyPort != _proxyPortLineEdit->text().toInt()) {
1004 int iRet = QMessageBox::question(this, "Question", "Proxy options "
1005 "changed. Use the new ones?",
1006 QMessageBox::Yes, QMessageBox::No,
1007 QMessageBox::NoButton);
1008 if (iRet == QMessageBox::Yes) {
1009 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1010 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1011 settings.sync();
1012 }
1013 }
1014
1015 QMessageBox msgBox;
1016 msgBox.setIcon(QMessageBox::Question);
1017 msgBox.setWindowTitle("Add Stream");
1018 msgBox.setText("Add stream(s) coming from:");
1019
1020 QPushButton* buttonNtrip = msgBox.addButton(tr("Caster"), QMessageBox::ActionRole);
1021 QPushButton* buttonIP = msgBox.addButton(tr("TCP/IP port"), QMessageBox::ActionRole);
1022 QPushButton* buttonUDP = msgBox.addButton(tr("UDP port"), QMessageBox::ActionRole);
1023 QPushButton* buttonSerial = msgBox.addButton(tr("Serial port"), QMessageBox::ActionRole);
1024 QPushButton* buttonCancel = msgBox.addButton(tr("Cancel"), QMessageBox::ActionRole);
1025
1026 msgBox.exec();
1027
1028 if (msgBox.clickedButton() == buttonNtrip) {
1029 bncTableDlg* dlg = new bncTableDlg(this);
1030 dlg->move(this->pos().x()+50, this->pos().y()+50);
1031 connect(dlg, SIGNAL(newMountPoints(QStringList*)),
1032 this, SLOT(slotNewMountPoints(QStringList*)));
1033 dlg->exec();
1034 delete dlg;
1035 } else if (msgBox.clickedButton() == buttonIP) {
1036 bncIpPort* ipp = new bncIpPort(this);
1037 connect(ipp, SIGNAL(newMountPoints(QStringList*)),
1038 this, SLOT(slotNewMountPoints(QStringList*)));
1039 ipp->exec();
1040 delete ipp;
1041 } else if (msgBox.clickedButton() == buttonUDP) {
1042 bncUdpPort* udp = new bncUdpPort(this);
1043 connect(udp, SIGNAL(newMountPoints(QStringList*)),
1044 this, SLOT(slotNewMountPoints(QStringList*)));
1045 udp->exec();
1046 delete udp;
1047 } else if (msgBox.clickedButton() == buttonSerial) {
1048 bncSerialPort* sep = new bncSerialPort(this);
1049 connect(sep, SIGNAL(newMountPoints(QStringList*)),
1050 this, SLOT(slotNewMountPoints(QStringList*)));
1051 sep->exec();
1052 delete sep;
1053 } else if (msgBox.clickedButton() == buttonCancel) {
1054 // Cancel
1055 }
1056}
1057
1058// Delete Selected Mount Points
1059////////////////////////////////////////////////////////////////////////////
1060void bncWindow::slotDeleteMountPoints() {
1061
1062 int nRows = _mountPointsTable->rowCount();
1063 bool flg[nRows];
1064 for (int iRow = 0; iRow < nRows; iRow++) {
1065 if (_mountPointsTable->isItemSelected(_mountPointsTable->item(iRow,1))) {
1066 flg[iRow] = true;
1067 }
1068 else {
1069 flg[iRow] = false;
1070 }
1071 }
1072 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1073 if (flg[iRow]) {
1074 _mountPointsTable->removeRow(iRow);
1075 }
1076 }
1077 _actDeleteMountPoints->setEnabled(false);
1078
1079 if (_mountPointsTable->rowCount() == 0) {
1080 _actGetData->setEnabled(false);
1081 }
1082}
1083
1084// New Mount Points Selected
1085////////////////////////////////////////////////////////////////////////////
1086void bncWindow::slotNewMountPoints(QStringList* mountPoints) {
1087 int iRow = 0;
1088 QListIterator<QString> it(*mountPoints);
1089 while (it.hasNext()) {
1090 QStringList hlp = it.next().split(" ");
1091 QUrl url(hlp[0]);
1092 QString fullPath = url.host() + QString(":%1").arg(url.port()) + url.path();
1093 QString format(hlp[1]); QString latitude(hlp[2]); QString longitude(hlp[3]);
1094 QString nmea(hlp[4]);
1095 if (hlp[5] == "S") {
1096 fullPath = hlp[0].replace(0,2,"");
1097 }
1098 QString ntripVersion = "1";
1099 if (hlp.size() >= 6) {
1100 ntripVersion = (hlp[5]);
1101 }
1102
1103 _mountPointsTable->insertRow(iRow);
1104
1105 QTableWidgetItem* it;
1106 it = new QTableWidgetItem(url.userInfo());
1107 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1108 _mountPointsTable->setItem(iRow, 0, it);
1109
1110 it = new QTableWidgetItem(fullPath);
1111 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1112 _mountPointsTable->setItem(iRow, 1, it);
1113
1114 it = new QTableWidgetItem(format);
1115 _mountPointsTable->setItem(iRow, 2, it);
1116
1117 if (nmea == "yes") {
1118 it = new QTableWidgetItem(latitude);
1119 _mountPointsTable->setItem(iRow, 3, it);
1120 it = new QTableWidgetItem(longitude);
1121 _mountPointsTable->setItem(iRow, 4, it);
1122 } else {
1123 it = new QTableWidgetItem(latitude);
1124 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1125 _mountPointsTable->setItem(iRow, 3, it);
1126 it = new QTableWidgetItem(longitude);
1127 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1128 _mountPointsTable->setItem(iRow, 4, it);
1129 }
1130
1131 it = new QTableWidgetItem(nmea);
1132 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1133 _mountPointsTable->setItem(iRow, 5, it);
1134
1135 it = new QTableWidgetItem(ntripVersion);
1136 it->setFlags(it->flags() & ~Qt::ItemIsEditable);
1137 _mountPointsTable->setItem(iRow, 6, it);
1138
1139 bncTableItem* bncIt = new bncTableItem();
1140 _mountPointsTable->setItem(iRow, 7, bncIt);
1141
1142 iRow++;
1143 }
1144 _mountPointsTable->hideColumn(0);
1145 _mountPointsTable->sortItems(1);
1146 if (mountPoints->count() > 0 && !_actStop->isEnabled()) {
1147 _actGetData->setEnabled(true);
1148 }
1149 delete mountPoints;
1150}
1151
1152// Save Options
1153////////////////////////////////////////////////////////////////////////////
1154void bncWindow::slotSaveOptions() {
1155
1156 QStringList mountPoints;
1157 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1158
1159 if (_mountPointsTable->item(iRow, 6)->text() != "S") {
1160 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1161 "@" + _mountPointsTable->item(iRow, 1)->text() );
1162
1163 mountPoints.append(url.toString() + " " +
1164 _mountPointsTable->item(iRow, 2)->text()
1165 + " " + _mountPointsTable->item(iRow, 3)->text()
1166 + " " + _mountPointsTable->item(iRow, 4)->text()
1167 + " " + _mountPointsTable->item(iRow, 5)->text()
1168 + " " + _mountPointsTable->item(iRow, 6)->text());
1169 } else {
1170 mountPoints.append(
1171 "//" + _mountPointsTable->item(iRow, 1)->text()
1172 + " " + _mountPointsTable->item(iRow, 2)->text()
1173 + " " + _mountPointsTable->item(iRow, 3)->text()
1174 + " " + _mountPointsTable->item(iRow, 4)->text()
1175 + " " + _mountPointsTable->item(iRow, 5)->text()
1176 + " " + _mountPointsTable->item(iRow, 6)->text());
1177 }
1178 }
1179
1180 QStringList combineStreams;
1181 for (int iRow = 0; iRow < _cmbTable->rowCount(); iRow++) {
1182 QString hlp;
1183 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1184 hlp += _cmbTable->item(iRow, iCol)->text() + " ";
1185 }
1186 combineStreams << hlp;
1187 }
1188
1189 bncSettings settings;
1190
1191 settings.setValue("adviseFail", _adviseFailSpinBox->value());
1192 settings.setValue("adviseReco", _adviseRecoSpinBox->value());
1193 settings.setValue("adviseScript",_adviseScriptLineEdit->text());
1194 settings.setValue("autoStart", _autoStartCheckBox->checkState());
1195 settings.setValue("binSampl", _binSamplSpinBox->value());
1196 settings.setValue("corrIntr", _corrIntrComboBox->currentText());
1197 settings.setValue("corrPath", _corrPathLineEdit->text());
1198 settings.setValue("corrPort", _corrPortLineEdit->text());
1199 settings.setValue("corrTime", _corrTimeSpinBox->value());
1200 settings.setValue("ephIntr", _ephIntrComboBox->currentText());
1201 settings.setValue("ephPath", _ephPathLineEdit->text());
1202 settings.setValue("ephV3", _ephV3CheckBox->checkState());
1203 settings.setValue("logFile", _logFileLineEdit->text());
1204 settings.setValue("rawOutFile", _rawOutFileLineEdit->text());
1205 settings.setValue("miscMount", _miscMountLineEdit->text());
1206 settings.setValue("pppMount", _pppMountLineEdit->text());
1207 settings.setValue("pppSPP", _pppSPPComboBox->currentText());
1208 settings.setValue("nmeaFile", _pppNMEALineEdit->text());
1209 settings.setValue("nmeaPort", _pppNMEAPortLineEdit->text());
1210 settings.setValue("pppSigmaCode",_pppSigCLineEdit->text());
1211 settings.setValue("pppSigmaPhase",_pppSigPLineEdit->text());
1212 settings.setValue("pppSigCrd0",_pppSigCrd0->text());
1213 settings.setValue("pppSigCrdP",_pppSigCrdP->text());
1214 settings.setValue("pppSigTrp0",_pppSigTrp0->text());
1215 settings.setValue("pppSigTrpP",_pppSigTrpP->text());
1216 settings.setValue("pppAverage", _pppAverageLineEdit->text());
1217 settings.setValue("pppQuickStart", _pppQuickStartLineEdit->text());
1218 settings.setValue("pppRefCrdX", _pppRefCrdXLineEdit->text());
1219 settings.setValue("pppRefCrdY", _pppRefCrdYLineEdit->text());
1220 settings.setValue("pppRefCrdZ", _pppRefCrdZLineEdit->text());
1221 settings.setValue("pppSync", _pppSync->text());
1222 settings.setValue("pppUsePhase", _pppUsePhaseCheckBox->checkState());
1223 settings.setValue("pppPlotCoordinates", _pppPlotCoordinates->checkState());
1224 settings.setValue("pppEstTropo", _pppEstTropoCheckBox->checkState());
1225 settings.setValue("pppGLONASS", _pppGLONASSCheckBox->checkState());
1226 settings.setValue("pppGalileo", _pppGalileoCheckBox->checkState());
1227 settings.setValue("pppAntenna", _pppAntennaLineEdit->text());
1228 settings.setValue("pppAntex", _pppAntexLineEdit->text());
1229 settings.setValue("pppIgnoreSatAnt", _pppIgnoreSatAntCheckBox->checkState());
1230 settings.setValue("mountPoints", mountPoints);
1231 settings.setValue("obsRate", _obsRateComboBox->currentText());
1232 settings.setValue("onTheFlyInterval", _onTheFlyComboBox->currentText());
1233 settings.setValue("outEphPort", _outEphPortLineEdit->text());
1234 settings.setValue("outFile", _outFileLineEdit->text());
1235 settings.setValue("outPort", _outPortLineEdit->text());
1236 settings.setValue("outUPort", _outUPortLineEdit->text());
1237 settings.setValue("perfIntr", _perfIntrComboBox->currentText());
1238 settings.setValue("proxyHost", _proxyHostLineEdit->text());
1239 settings.setValue("proxyPort", _proxyPortLineEdit->text());
1240 settings.setValue("rnxAppend", _rnxAppendCheckBox->checkState());
1241 settings.setValue("rnxIntr", _rnxIntrComboBox->currentText());
1242 settings.setValue("rnxPath", _rnxPathLineEdit->text());
1243 settings.setValue("rnxSampl", _rnxSamplSpinBox->value());
1244 settings.setValue("rnxScript", _rnxScrpLineEdit->text());
1245 settings.setValue("rnxSkel", _rnxSkelLineEdit->text());
1246 settings.setValue("rnxV3", _rnxV3CheckBox->checkState());
1247 settings.setValue("scanRTCM", _scanRTCMCheckBox->checkState());
1248 settings.setValue("serialFileNMEA",_serialFileNMEALineEdit->text());
1249 settings.setValue("serialHeightNMEA",_serialHeightNMEALineEdit->text());
1250 settings.setValue("serialAutoNMEA", _serialAutoNMEAComboBox->currentText());
1251 settings.setValue("serialBaudRate", _serialBaudRateComboBox->currentText());
1252 settings.setValue("serialDataBits", _serialDataBitsComboBox->currentText());
1253 settings.setValue("serialMountPoint",_serialMountPointLineEdit->text());
1254 settings.setValue("serialParity", _serialParityComboBox->currentText());
1255 settings.setValue("serialPortName", _serialPortNameLineEdit->text());
1256 settings.setValue("serialStopBits", _serialStopBitsComboBox->currentText());
1257 settings.setValue("serialFlowControl",_serialFlowControlComboBox->currentText());
1258 settings.setValue("startTab", _aogroup->currentIndex());
1259 settings.setValue("statusTab", _loggroup->currentIndex());
1260 settings.setValue("waitTime", _waitTimeSpinBox->value());
1261 settings.setValue("combineStreams", combineStreams);
1262 settings.setValue("cmbOutHost", _cmbOutHostLineEdit->text());
1263 settings.setValue("cmbOutPort", _cmbOutPortLineEdit->text());
1264 settings.setValue("cmbMountpoint", _cmbMountpointLineEdit->text());
1265 settings.setValue("cmbPassword", _cmbPasswordLineEdit->text());
1266 settings.setValue("cmbOutFile", _cmbOutFileLineEdit->text());
1267 settings.setValue("cmbSP3File", _cmbSP3FileLineEdit->text());
1268
1269 if (_caster) {
1270 _caster->slotReadMountPoints();
1271 }
1272 settings.sync();
1273}
1274
1275// All get slots terminated
1276////////////////////////////////////////////////////////////////////////////
1277void bncWindow::slotGetThreadsFinished() {
1278 ((bncApp*)qApp)->slotMessage("All Get Threads Terminated", true);
1279 delete _caster; _caster = 0;
1280 _actGetData->setEnabled(true);
1281 _actStop->setEnabled(false);
1282}
1283
1284// Retrieve Data
1285////////////////////////////////////////////////////////////////////////////
1286void bncWindow::slotGetData() {
1287 slotSaveOptions();
1288
1289 _bncFigurePPP->reset();
1290
1291 _actDeleteMountPoints->setEnabled(false);
1292 _actGetData->setEnabled(false);
1293 _actStop->setEnabled(true);
1294
1295 _caster = new bncCaster(_outFileLineEdit->text(),
1296 _outPortLineEdit->text().toInt());
1297
1298 ((bncApp*)qApp)->setPort(_outEphPortLineEdit->text().toInt());
1299 ((bncApp*)qApp)->setPortCorr(_corrPortLineEdit->text().toInt());
1300
1301 connect(_caster, SIGNAL(getThreadsFinished()),
1302 this, SLOT(slotGetThreadsFinished()));
1303
1304 connect (_caster, SIGNAL(mountPointsRead(QList<bncGetThread*>)),
1305 this, SLOT(slotMountPointsRead(QList<bncGetThread*>)));
1306
1307 ((bncApp*)qApp)->slotMessage("========== Start BNC v" BNCVERSION " =========", true);
1308
1309 bncSettings settings;
1310
1311 QDir rnxdir(settings.value("rnxPath").toString());
1312 if (!rnxdir.exists()) ((bncApp*)qApp)->slotMessage("Cannot find RINEX Observations directory", true);
1313
1314 QString rnx_file = settings.value("rnxScript").toString();
1315 if ( !rnx_file.isEmpty() ) {
1316 QFile rnxfile(settings.value("rnxScript").toString());
1317 if (!rnxfile.exists()) ((bncApp*)qApp)->slotMessage("Cannot find RINEX Observations script", true);
1318 }
1319
1320 QDir ephdir(settings.value("ephPath").toString());
1321 if (!ephdir.exists()) ((bncApp*)qApp)->slotMessage("Cannot find RINEX Ephemeris directory", true);
1322
1323 QDir corrdir(settings.value("corrPath").toString());
1324 if (!corrdir.exists()) ((bncApp*)qApp)->slotMessage("Cannot find Broadcast Corrections directory", true);
1325
1326 QString advise_file = settings.value("adviseScript").toString();
1327 if ( !advise_file.isEmpty() ) {
1328 QFile advisefile(settings.value("adviseScript").toString());
1329 if (!advisefile.exists()) ((bncApp*)qApp)->slotMessage("Cannot find Outages script", true);
1330 }
1331
1332 _caster->slotReadMountPoints();
1333}
1334
1335// Retrieve Data
1336////////////////////////////////////////////////////////////////////////////
1337void bncWindow::slotStop() {
1338 int iRet = QMessageBox::question(this, "Stop", "Stop retrieving data?",
1339 QMessageBox::Yes, QMessageBox::No,
1340 QMessageBox::NoButton);
1341 if (iRet == QMessageBox::Yes) {
1342 delete _caster; _caster = 0;
1343 _actGetData->setEnabled(true);
1344 _actStop->setEnabled(false);
1345 }
1346}
1347
1348// Close Application gracefully
1349////////////////////////////////////////////////////////////////////////////
1350void bncWindow::closeEvent(QCloseEvent* event) {
1351
1352 int iRet = QMessageBox::question(this, "Close", "Save Options?",
1353 QMessageBox::Yes, QMessageBox::No,
1354 QMessageBox::Cancel);
1355
1356 if (iRet == QMessageBox::Cancel) {
1357 event->ignore();
1358 return;
1359 }
1360 else if (iRet == QMessageBox::Yes) {
1361 slotSaveOptions();
1362 }
1363
1364 QMainWindow::closeEvent(event);
1365}
1366
1367// User changed the selection of mountPoints
1368////////////////////////////////////////////////////////////////////////////
1369void bncWindow::slotSelectionChanged() {
1370 if (_mountPointsTable->selectedItems().isEmpty()) {
1371 _actDeleteMountPoints->setEnabled(false);
1372 }
1373 else {
1374 _actDeleteMountPoints->setEnabled(true);
1375 }
1376}
1377
1378// Display Program Messages
1379////////////////////////////////////////////////////////////////////////////
1380void bncWindow::slotWindowMessage(const QByteArray msg, bool showOnScreen) {
1381
1382#ifdef DEBUG_RTCM2_2021
1383 const int maxBufferSize = 1000;
1384#else
1385 const int maxBufferSize = 10000;
1386#endif
1387
1388 if (! showOnScreen ) {
1389 return;
1390 }
1391
1392 QString txt = _log->toPlainText() + "\n" +
1393 QDateTime::currentDateTime().toUTC().toString("yy-MM-dd hh:mm:ss ") + msg;
1394 _log->clear();
1395 _log->append(txt.right(maxBufferSize));
1396}
1397
1398// About Message
1399////////////////////////////////////////////////////////////////////////////
1400void bncWindow::slotAbout() {
1401 new bncAboutDlg(0);
1402}
1403
1404//Flowchart
1405////////////////////////////////////////////////////////////////////////////
1406void bncWindow::slotFlowchart() {
1407 new bncFlowchartDlg(0);
1408}
1409
1410// Help Window
1411////////////////////////////////////////////////////////////////////////////
1412void bncWindow::slotHelp() {
1413 QUrl url;
1414 url.setPath(":bnchelp.html");
1415 new bncHlpDlg(0, url);
1416}
1417
1418// Select Fonts
1419////////////////////////////////////////////////////////////////////////////
1420void bncWindow::slotFontSel() {
1421 bool ok;
1422 QFont newFont = QFontDialog::getFont(&ok, this->font(), this);
1423 if (ok) {
1424 bncSettings settings;
1425 settings.setValue("font", newFont.toString());
1426 QApplication::setFont(newFont);
1427 int ww = QFontMetrics(newFont).width('w');
1428 setMinimumSize(60*ww, 80*ww);
1429 resize(60*ww, 80*ww);
1430 }
1431}
1432
1433// Whats This Help
1434void bncWindow::slotWhatsThis() {
1435 QWhatsThis::enterWhatsThisMode();
1436}
1437
1438//
1439////////////////////////////////////////////////////////////////////////////
1440void bncWindow::slotMountPointsRead(QList<bncGetThread*> threads) {
1441 _bncFigure->updateMountPoints();
1442 _bncFigureLate->updateMountPoints();
1443
1444 populateMountPointsTable();
1445 bncSettings settings;
1446 _binSamplSpinBox->setValue(settings.value("binSampl").toInt());
1447 _waitTimeSpinBox->setValue(settings.value("waitTime").toInt());
1448 QListIterator<bncGetThread*> iTh(threads);
1449 while (iTh.hasNext()) {
1450 bncGetThread* thread = iTh.next();
1451 for (int iRow = 0; iRow < _mountPointsTable->rowCount(); iRow++) {
1452 QUrl url( "//" + _mountPointsTable->item(iRow, 0)->text() +
1453 "@" + _mountPointsTable->item(iRow, 1)->text() );
1454 if (url == thread->mountPoint() &&
1455 _mountPointsTable->item(iRow, 3)->text() == thread->latitude() &&
1456 _mountPointsTable->item(iRow, 4)->text() == thread->longitude() ) {
1457 ((bncTableItem*) _mountPointsTable->item(iRow, 7))->setGetThread(thread);
1458 disconnect(thread, SIGNAL(newBytes(QByteArray, double)),
1459 _bncFigure, SLOT(slotNewData(QByteArray, double)));
1460 connect(thread, SIGNAL(newBytes(QByteArray, double)),
1461 _bncFigure, SLOT(slotNewData(QByteArray, double)));
1462 disconnect(thread, SIGNAL(newLatency(QByteArray, double)),
1463 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
1464 connect(thread, SIGNAL(newLatency(QByteArray, double)),
1465 _bncFigureLate, SLOT(slotNewLatency(QByteArray, double)));
1466 if ( Qt::CheckState(settings.value("pppPlotCoordinates").toInt()) == Qt::Checked) {
1467 disconnect(thread,
1468 SIGNAL(newPosition(bncTime, double, double, double)),
1469 _bncFigurePPP,
1470 SLOT(slotNewPosition(bncTime, double, double, double)));
1471 connect(thread, SIGNAL(newPosition(bncTime, double, double, double)),
1472 _bncFigurePPP,
1473 SLOT(slotNewPosition(bncTime, double, double, double)));
1474 }
1475 break;
1476 }
1477 }
1478 }
1479}
1480
1481//
1482////////////////////////////////////////////////////////////////////////////
1483void bncWindow::CreateMenu() {
1484 // Create Menus
1485 // ------------
1486 _menuFile = menuBar()->addMenu(tr("&File"));
1487 _menuFile->addAction(_actFontSel);
1488 _menuFile->addSeparator();
1489 _menuFile->addAction(_actSaveOpt);
1490 _menuFile->addSeparator();
1491 _menuFile->addAction(_actQuit);
1492
1493 _menuHlp = menuBar()->addMenu(tr("&Help"));
1494 _menuHlp->addAction(_actHelp);
1495 _menuHlp->addAction(_actFlowchart);
1496 _menuHlp->addAction(_actAbout);
1497}
1498
1499// Toolbar
1500////////////////////////////////////////////////////////////////////////////
1501void bncWindow::AddToolbar() {
1502 // Tool (Command) Bar
1503 // ------------------
1504 QToolBar* toolBar = new QToolBar;
1505 addToolBar(Qt::BottomToolBarArea, toolBar);
1506 toolBar->setMovable(false);
1507 toolBar->addAction(_actAddMountPoints);
1508 toolBar->addAction(_actDeleteMountPoints);
1509 toolBar->addAction(_actGetData);
1510 toolBar->addAction(_actStop);
1511 toolBar->addWidget(new QLabel(" "));
1512 toolBar->addAction(_actwhatsthis);
1513}
1514
1515// About
1516////////////////////////////////////////////////////////////////////////////
1517bncAboutDlg::bncAboutDlg(QWidget* parent) :
1518 QDialog(parent) {
1519
1520 QTextBrowser* tb = new QTextBrowser;
1521 QUrl url; url.setPath(":bncabout.html");
1522 tb->setSource(url);
1523 tb->setReadOnly(true);
1524
1525 int ww = QFontMetrics(font()).width('w');
1526 QPushButton* _closeButton = new QPushButton("Close");
1527 _closeButton->setMaximumWidth(10*ww);
1528 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
1529
1530 QGridLayout* dlgLayout = new QGridLayout();
1531 QLabel* img = new QLabel();
1532 img->setPixmap(QPixmap(":ntrip-logo.png"));
1533 dlgLayout->addWidget(img, 0,0);
1534 dlgLayout->addWidget(new QLabel("BKG Ntrip Client (BNC) Version "BNCVERSION), 0,1);
1535 dlgLayout->addWidget(tb,1,0,1,2);
1536 dlgLayout->addWidget(_closeButton,2,1,Qt::AlignRight);
1537
1538 setLayout(dlgLayout);
1539 resize(60*ww, 60*ww);
1540 setWindowTitle("About BNC");
1541 show();
1542}
1543
1544//
1545////////////////////////////////////////////////////////////////////////////
1546bncAboutDlg::~bncAboutDlg() {
1547};
1548
1549// Flowchart
1550////////////////////////////////////////////////////////////////////////////
1551bncFlowchartDlg::bncFlowchartDlg(QWidget* parent) :
1552 QDialog(parent) {
1553
1554 int ww = QFontMetrics(font()).width('w');
1555 QPushButton* _closeButton = new QPushButton("Close");
1556 _closeButton->setMaximumWidth(10*ww);
1557 connect(_closeButton, SIGNAL(clicked()), this, SLOT(close()));
1558
1559 QGridLayout* dlgLayout = new QGridLayout();
1560 QLabel* img = new QLabel();
1561 img->setPixmap(QPixmap(":bncflowchart.png"));
1562 dlgLayout->addWidget(img, 0,0);
1563 dlgLayout->addWidget(_closeButton,1,0,Qt::AlignLeft);
1564
1565 setLayout(dlgLayout);
1566 setWindowTitle("Flow Chart");
1567 show();
1568}
1569
1570//
1571////////////////////////////////////////////////////////////////////////////
1572bncFlowchartDlg::~bncFlowchartDlg() {
1573};
1574
1575// Bnc Text
1576////////////////////////////////////////////////////////////////////////////
1577void bncWindow::slotBncTextChanged(){
1578
1579 QPalette palette_white(QColor(255, 255, 255));
1580 QPalette palette_gray(QColor(230, 230, 230));
1581 bncSettings settings;
1582
1583 // Proxy
1584 //------
1585 if (sender() == 0 || sender() == _proxyHostLineEdit) {
1586 if (!_proxyHostLineEdit->text().isEmpty()) {
1587 _proxyPortLineEdit->setStyleSheet("background-color: white");
1588 _proxyPortLineEdit->setEnabled(true);
1589 }
1590 else {
1591 _proxyPortLineEdit->setStyleSheet("background-color: lightGray");
1592 _proxyPortLineEdit->setEnabled(false);
1593 }
1594 }
1595
1596 // RINEX Observations
1597 // ------------------
1598 if (sender() == 0 || sender() == _rnxPathLineEdit) {
1599 if (!_rnxPathLineEdit->text().isEmpty()) {
1600 _rnxSamplSpinBox->setStyleSheet("background-color: white");
1601 _rnxSkelLineEdit->setStyleSheet("background-color: white");
1602 _rnxScrpLineEdit->setStyleSheet("background-color: white");
1603 _rnxV3CheckBox->setPalette(palette_white);
1604 _rnxIntrComboBox->setStyleSheet("background-color: white");
1605 _rnxSamplSpinBox->setEnabled(true);
1606 _rnxSkelLineEdit->setEnabled(true);
1607 _rnxScrpLineEdit->setEnabled(true);
1608 _rnxV3CheckBox->setEnabled(true);
1609 _rnxIntrComboBox->setEnabled(true);
1610 }
1611 else {
1612 _rnxSamplSpinBox->setStyleSheet("background-color: lightGray");
1613 _rnxSkelLineEdit->setStyleSheet("background-color: lightGray");
1614 _rnxScrpLineEdit->setStyleSheet("background-color: lightGray");
1615 _rnxV3CheckBox->setPalette(palette_gray);
1616 _rnxIntrComboBox->setStyleSheet("background-color: lightGray");
1617 _rnxSamplSpinBox->setEnabled(false);
1618 _rnxSkelLineEdit->setEnabled(false);
1619 _rnxScrpLineEdit->setEnabled(false);
1620 _rnxV3CheckBox->setEnabled(false);
1621 _rnxIntrComboBox->setEnabled(false);
1622 }
1623 }
1624
1625 // RINEX Ephemeris
1626 // ---------------
1627 if (sender() == 0 ||
1628 sender() == _ephPathLineEdit || sender() == _outEphPortLineEdit) {
1629 if (!_ephPathLineEdit->text().isEmpty() ||
1630 !_outEphPortLineEdit->text().isEmpty()) {
1631 _ephIntrComboBox->setStyleSheet("background-color: white");
1632 _ephV3CheckBox->setPalette(palette_white);
1633 _ephIntrComboBox->setEnabled(true);
1634 _ephV3CheckBox->setEnabled(true);
1635 }
1636 else {
1637 _ephIntrComboBox->setStyleSheet("background-color: lightGray");
1638 _ephV3CheckBox->setPalette(palette_gray);
1639 _ephIntrComboBox->setEnabled(false);
1640 _ephV3CheckBox->setEnabled(false);
1641 }
1642 }
1643
1644 // Broadcast Corrections
1645 // ---------------------
1646 if (sender() == 0 ||
1647 sender() == _corrPathLineEdit || sender() == _corrPortLineEdit) {
1648 if (!_corrPathLineEdit->text().isEmpty() ||
1649 !_corrPortLineEdit->text().isEmpty()) {
1650 _corrIntrComboBox->setStyleSheet("background-color: white");
1651 _corrIntrComboBox->setEnabled(true);
1652 }
1653 else {
1654 _corrIntrComboBox->setStyleSheet("background-color: lightGray");
1655 _corrIntrComboBox->setEnabled(false);
1656 }
1657 }
1658
1659 // Feed Engine
1660 // -----------
1661 if (sender() == 0 ||
1662 sender() == _outPortLineEdit || sender() == _outFileLineEdit) {
1663 if ( !_outPortLineEdit->text().isEmpty() ||
1664 !_outFileLineEdit->text().isEmpty()) {
1665 _waitTimeSpinBox->setStyleSheet("background-color: white");
1666 _binSamplSpinBox->setStyleSheet("background-color: white");
1667 _waitTimeSpinBox->setEnabled(true);
1668 _binSamplSpinBox->setEnabled(true);
1669 }
1670 else {
1671 _waitTimeSpinBox->setStyleSheet("background-color: lightGray");
1672 _binSamplSpinBox->setStyleSheet("background-color: lightGray");
1673 _waitTimeSpinBox->setEnabled(false);
1674 _binSamplSpinBox->setEnabled(false);
1675 }
1676 }
1677
1678 // Serial Output
1679 // -------------
1680 if (sender() == 0 || sender() == _serialMountPointLineEdit ||
1681 sender() == _serialAutoNMEAComboBox) {
1682 if (!_serialMountPointLineEdit->text().isEmpty()) {
1683 _serialPortNameLineEdit->setStyleSheet("background-color: white");
1684 _serialBaudRateComboBox->setStyleSheet("background-color: white");
1685 _serialParityComboBox->setStyleSheet("background-color: white");
1686 _serialDataBitsComboBox->setStyleSheet("background-color: white");
1687 _serialStopBitsComboBox->setStyleSheet("background-color: white");
1688 _serialFlowControlComboBox->setStyleSheet("background-color: white");
1689 _serialAutoNMEAComboBox->setStyleSheet("background-color: white");
1690 _serialPortNameLineEdit->setEnabled(true);
1691 _serialBaudRateComboBox->setEnabled(true);
1692 _serialParityComboBox->setEnabled(true);
1693 _serialDataBitsComboBox->setEnabled(true);
1694 _serialStopBitsComboBox->setEnabled(true);
1695 _serialFlowControlComboBox->setEnabled(true);
1696 _serialAutoNMEAComboBox->setEnabled(true);
1697 if (_serialAutoNMEAComboBox->currentText() != "Auto" ) {
1698 _serialHeightNMEALineEdit->setStyleSheet("background-color: white");
1699 _serialHeightNMEALineEdit->setEnabled(true);
1700 _serialFileNMEALineEdit->setStyleSheet("background-color: lightGray");
1701 _serialFileNMEALineEdit->setEnabled(false);
1702 }
1703 else {
1704 _serialHeightNMEALineEdit->setStyleSheet("background-color: lightGray");
1705 _serialHeightNMEALineEdit->setEnabled(false);
1706 _serialFileNMEALineEdit->setStyleSheet("background-color: white");
1707 _serialFileNMEALineEdit->setEnabled(true);
1708 }
1709 }
1710 else {
1711 _serialPortNameLineEdit->setStyleSheet("background-color: lightGray");
1712 _serialBaudRateComboBox->setStyleSheet("background-color: lightGray");
1713 _serialParityComboBox->setStyleSheet("background-color: lightGray");
1714 _serialDataBitsComboBox->setStyleSheet("background-color: lightGray");
1715 _serialStopBitsComboBox->setStyleSheet("background-color: lightGray");
1716 _serialFlowControlComboBox->setStyleSheet("background-color: lightGray");
1717 _serialAutoNMEAComboBox->setStyleSheet("background-color: lightGray");
1718 _serialFileNMEALineEdit->setStyleSheet("background-color: lightGray");
1719 _serialHeightNMEALineEdit->setStyleSheet("background-color: lightGray");
1720 _serialPortNameLineEdit->setEnabled(false);
1721 _serialBaudRateComboBox->setEnabled(false);
1722 _serialParityComboBox->setEnabled(false);
1723 _serialDataBitsComboBox->setEnabled(false);
1724 _serialStopBitsComboBox->setEnabled(false);
1725 _serialFlowControlComboBox->setEnabled(false);
1726 _serialAutoNMEAComboBox->setEnabled(false);
1727 _serialHeightNMEALineEdit->setEnabled(false);
1728 _serialFileNMEALineEdit->setEnabled(false);
1729 }
1730 }
1731
1732 // Outages
1733 // -------
1734 if (sender() == 0 || sender() == _obsRateComboBox) {
1735 if (!_obsRateComboBox->currentText().isEmpty()) {
1736 _adviseScriptLineEdit->setStyleSheet("background-color: white");
1737 _adviseFailSpinBox->setStyleSheet("background-color: white");
1738 _adviseRecoSpinBox->setStyleSheet("background-color: white");
1739 _adviseFailSpinBox->setEnabled(true);
1740 _adviseRecoSpinBox->setEnabled(true);
1741 _adviseScriptLineEdit->setEnabled(true);
1742 } else {
1743 _adviseScriptLineEdit->setStyleSheet("background-color: lightGray");
1744 _adviseFailSpinBox->setStyleSheet("background-color: lightGray");
1745 _adviseRecoSpinBox->setStyleSheet("background-color: lightGray");
1746 _adviseFailSpinBox->setEnabled(false);
1747 _adviseRecoSpinBox->setEnabled(false);
1748 _adviseScriptLineEdit->setEnabled(false);
1749 }
1750 }
1751
1752 // Miscellaneous
1753 // -------------
1754 if (sender() == 0 || sender() == _miscMountLineEdit) {
1755 if (!_miscMountLineEdit->text().isEmpty()) {
1756 _perfIntrComboBox->setStyleSheet("background-color: white");
1757 _scanRTCMCheckBox->setPalette(palette_white);
1758 _perfIntrComboBox->setEnabled(true);
1759 _scanRTCMCheckBox->setEnabled(true);
1760 } else {
1761 _perfIntrComboBox->setStyleSheet("background-color: lightGray");
1762 _scanRTCMCheckBox->setPalette(palette_gray);
1763 _perfIntrComboBox->setEnabled(false);
1764 _scanRTCMCheckBox->setEnabled(false);
1765 }
1766 }
1767
1768 // PPP Client
1769 // ----------
1770 if (sender() == 0
1771 || sender() == _pppMountLineEdit
1772 || sender() == _pppRefCrdXLineEdit
1773 || sender() == _pppRefCrdYLineEdit
1774 || sender() == _pppRefCrdZLineEdit
1775 || sender() == _pppSync
1776 || sender() == _pppSPPComboBox
1777 || sender() == _pppEstTropoCheckBox
1778 || sender() == _pppUsePhaseCheckBox ) {
1779 if (!_pppMountLineEdit->text().isEmpty()) {
1780 _pppSPPComboBox->setPalette(palette_white);
1781 _pppNMEALineEdit->setPalette(palette_white);
1782 _pppNMEAPortLineEdit->setPalette(palette_white);
1783 _pppRefCrdXLineEdit->setPalette(palette_white);
1784 _pppRefCrdYLineEdit->setPalette(palette_white);
1785 _pppRefCrdZLineEdit->setPalette(palette_white);
1786 _pppUsePhaseCheckBox->setPalette(palette_white);
1787 _pppPlotCoordinates->setPalette(palette_white);
1788 _pppEstTropoCheckBox->setPalette(palette_white);
1789 _pppGLONASSCheckBox->setPalette(palette_white);
1790 _pppGalileoCheckBox->setPalette(palette_white);
1791 _pppSPPComboBox->setEnabled(true);
1792 _pppNMEALineEdit->setEnabled(true);
1793 _pppNMEAPortLineEdit->setEnabled(true);
1794 _pppRefCrdXLineEdit->setEnabled(true);
1795 _pppRefCrdYLineEdit->setEnabled(true);
1796 _pppRefCrdZLineEdit->setEnabled(true);
1797 _pppUsePhaseCheckBox->setEnabled(true);
1798 _pppPlotCoordinates->setEnabled(true);
1799 _pppEstTropoCheckBox->setEnabled(true);
1800 _pppGLONASSCheckBox->setEnabled(true);
1801 _pppGalileoCheckBox->setEnabled(true);
1802 _pppRefCrdXLineEdit->setPalette(palette_white);
1803 _pppRefCrdXLineEdit->setEnabled(true);
1804 _pppRefCrdYLineEdit->setPalette(palette_white);
1805 _pppRefCrdYLineEdit->setEnabled(true);
1806 _pppRefCrdZLineEdit->setPalette(palette_white);
1807 _pppRefCrdZLineEdit->setEnabled(true);
1808 if (!_pppRefCrdXLineEdit->text().isEmpty() &&
1809 !_pppRefCrdYLineEdit->text().isEmpty() &&
1810 !_pppRefCrdZLineEdit->text().isEmpty()) {
1811 _pppAverageLineEdit->setPalette(palette_white);
1812 _pppAverageLineEdit->setEnabled(true);
1813 _pppQuickStartLineEdit->setPalette(palette_white);
1814 _pppQuickStartLineEdit->setEnabled(true);
1815 }
1816 else {
1817 _pppAverageLineEdit->setPalette(palette_gray);
1818 _pppAverageLineEdit->setEnabled(false);
1819 _pppQuickStartLineEdit->setPalette(palette_gray);
1820 _pppQuickStartLineEdit->setEnabled(false);
1821 }
1822 _pppSigCLineEdit->setPalette(palette_white);
1823 _pppSigCLineEdit->setEnabled(true);
1824 _pppSigCrd0->setPalette(palette_white);
1825 _pppSigCrd0->setEnabled(true);
1826 _pppSigCrdP->setPalette(palette_white);
1827 _pppSigCrdP->setEnabled(true);
1828 if (_pppEstTropoCheckBox->isChecked()
1829 && !_pppMountLineEdit->text().isEmpty()) {
1830 _pppSigTrp0->setPalette(palette_white);
1831 _pppSigTrp0->setEnabled(true);
1832 _pppSigTrpP->setPalette(palette_white);
1833 _pppSigTrpP->setEnabled(true);
1834 }
1835 else {
1836 _pppSigTrp0->setPalette(palette_gray);
1837 _pppSigTrp0->setEnabled(false);
1838 _pppSigTrpP->setPalette(palette_gray);
1839 _pppSigTrpP->setEnabled(false);
1840 }
1841 if (_pppUsePhaseCheckBox->isChecked()
1842 && !_pppMountLineEdit->text().isEmpty()) {
1843 _pppSigPLineEdit->setPalette(palette_white);
1844 _pppSigPLineEdit->setEnabled(true);
1845 }
1846 else {
1847 _pppSigPLineEdit->setPalette(palette_gray);
1848 _pppSigPLineEdit->setEnabled(false);
1849 }
1850 if (_pppSPPComboBox->currentText() == "PPP") {
1851 _pppSync->setPalette(palette_white);
1852 _pppSync->setEnabled(true);
1853 }
1854 else {
1855 _pppSync->setPalette(palette_gray);
1856 _pppSync->setEnabled(false);
1857 }
1858 } else {
1859 _pppSPPComboBox->setPalette(palette_gray);
1860 _pppNMEALineEdit->setPalette(palette_gray);
1861 _pppNMEAPortLineEdit->setPalette(palette_gray);
1862 _pppRefCrdXLineEdit->setPalette(palette_gray);
1863 _pppRefCrdYLineEdit->setPalette(palette_gray);
1864 _pppRefCrdZLineEdit->setPalette(palette_gray);
1865 _pppSync->setPalette(palette_gray);
1866 _pppUsePhaseCheckBox->setPalette(palette_gray);
1867 _pppPlotCoordinates->setPalette(palette_gray);
1868 _pppEstTropoCheckBox->setPalette(palette_gray);
1869 _pppGLONASSCheckBox->setPalette(palette_gray);
1870 _pppGalileoCheckBox->setPalette(palette_gray);
1871 _pppSigCLineEdit->setPalette(palette_gray);
1872 _pppSigPLineEdit->setPalette(palette_gray);
1873 _pppSigCrd0->setPalette(palette_gray);
1874 _pppSigCrdP->setPalette(palette_gray);
1875 _pppSigTrp0->setPalette(palette_gray);
1876 _pppSigTrpP->setPalette(palette_gray);
1877 _pppAverageLineEdit->setPalette(palette_gray);
1878 _pppQuickStartLineEdit->setPalette(palette_gray);
1879 _pppSPPComboBox->setEnabled(false);
1880 _pppNMEALineEdit->setEnabled(false);
1881 _pppNMEAPortLineEdit->setEnabled(false);
1882 _pppRefCrdXLineEdit->setEnabled(false);
1883 _pppRefCrdYLineEdit->setEnabled(false);
1884 _pppRefCrdZLineEdit->setEnabled(false);
1885 _pppSync->setEnabled(false);
1886 _pppUsePhaseCheckBox->setEnabled(false);
1887 _pppPlotCoordinates->setEnabled(false);
1888 _pppEstTropoCheckBox->setEnabled(false);
1889 _pppGLONASSCheckBox->setEnabled(false);
1890 _pppGalileoCheckBox->setEnabled(false);
1891 _pppSigCLineEdit->setEnabled(false);
1892 _pppSigPLineEdit->setEnabled(false);
1893 _pppSigCrd0->setEnabled(false);
1894 _pppSigCrdP->setEnabled(false);
1895 _pppSigTrp0->setEnabled(false);
1896 _pppSigTrpP->setEnabled(false);
1897 _pppAverageLineEdit->setEnabled(false);
1898 _pppQuickStartLineEdit->setEnabled(false);
1899 }
1900 }
1901}
1902
1903//
1904////////////////////////////////////////////////////////////////////////////
1905void bncWindow::slotAddCmbRow() {
1906 int iRow = _cmbTable->rowCount();
1907 _cmbTable->insertRow(iRow);
1908 for (int iCol = 0; iCol < _cmbTable->columnCount(); iCol++) {
1909 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(""));
1910 }
1911}
1912
1913//
1914////////////////////////////////////////////////////////////////////////////
1915void bncWindow::slotDelCmbRow() {
1916 int nRows = _cmbTable->rowCount();
1917 bool flg[nRows];
1918 for (int iRow = 0; iRow < nRows; iRow++) {
1919 if (_cmbTable->isItemSelected(_cmbTable->item(iRow,1))) {
1920 flg[iRow] = true;
1921 }
1922 else {
1923 flg[iRow] = false;
1924 }
1925 }
1926 for (int iRow = nRows-1; iRow >= 0; iRow--) {
1927 if (flg[iRow]) {
1928 _cmbTable->removeRow(iRow);
1929 }
1930 }
1931}
1932
1933//
1934////////////////////////////////////////////////////////////////////////////
1935void bncWindow::populateCmbTable() {
1936
1937 for (int iRow = _cmbTable->rowCount()-1; iRow >=0; iRow--) {
1938 _cmbTable->removeRow(iRow);
1939 }
1940
1941 bncSettings settings;
1942
1943 int iRow = -1;
1944 QListIterator<QString> it(settings.value("combineStreams").toStringList());
1945 while (it.hasNext()) {
1946 QStringList hlp = it.next().split(" ");
1947 if (hlp.size() > 0) {
1948 ++iRow;
1949 _cmbTable->insertRow(iRow);
1950 }
1951 for (int iCol = 0; iCol < hlp.size(); iCol++) {
1952 _cmbTable->setItem(iRow, iCol, new QTableWidgetItem(hlp[iCol]));
1953 }
1954 }
1955}
Note: See TracBrowser for help on using the repository browser.