aboutsummaryrefslogtreecommitdiffstats
path: root/qt-ui/configuredivecomputerdialog.cpp
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tomaz.canabrava@intel.com>2015-09-03 14:20:19 -0300
committerGravatar Dirk Hohndel <dirk@hohndel.org>2015-10-30 10:36:49 -0700
commite49d6213ad129284a45d53c3fcdc03249e84efe2 (patch)
tree2946a666ab38af3375e7bb2b8c5dd887d4a7f9a1 /qt-ui/configuredivecomputerdialog.cpp
parent588abd019fb2ed3f607682f2b6c7fe86a7a5bb90 (diff)
downloadsubsurface-e49d6213ad129284a45d53c3fcdc03249e84efe2.tar.gz
Move qt-ui to desktop-widgets
Since we have now destkop and mobile versions, 'qt-ui' was a very poor name choice for a folder that contains only destkop-enabled widgets. Also, move the graphicsview-common.h/cpp to subsurface-core because it doesn't depend on qgraphicsview, it merely implements all the colors that we use throughout Subsurface, and we will use colors on both desktop and mobile versions Same thing applies for metrics.h/cpp Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
Diffstat (limited to 'qt-ui/configuredivecomputerdialog.cpp')
-rw-r--r--qt-ui/configuredivecomputerdialog.cpp1257
1 files changed, 0 insertions, 1257 deletions
diff --git a/qt-ui/configuredivecomputerdialog.cpp b/qt-ui/configuredivecomputerdialog.cpp
deleted file mode 100644
index ddb9450de..000000000
--- a/qt-ui/configuredivecomputerdialog.cpp
+++ /dev/null
@@ -1,1257 +0,0 @@
-#include "configuredivecomputerdialog.h"
-
-#include "helpers.h"
-#include "mainwindow.h"
-#include "display.h"
-
-#include <QFileDialog>
-#include <QMessageBox>
-#include <QSettings>
-#include <QNetworkReply>
-#include <QProgressDialog>
-
-struct product {
- const char *product;
- dc_descriptor_t *descriptor;
- struct product *next;
-};
-
-struct vendor {
- const char *vendor;
- struct product *productlist;
- struct vendor *next;
-};
-
-struct mydescriptor {
- const char *vendor;
- const char *product;
- dc_family_t type;
- unsigned int model;
-};
-
-GasSpinBoxItemDelegate::GasSpinBoxItemDelegate(QObject *parent, column_type type) : QStyledItemDelegate(parent), type(type)
-{
-}
-GasSpinBoxItemDelegate::~GasSpinBoxItemDelegate()
-{
-}
-
-QWidget *GasSpinBoxItemDelegate::createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const
-{
- // Create the spinbox and give it it's settings
- QSpinBox *sb = new QSpinBox(parent);
- if (type == PERCENT) {
- sb->setMinimum(0);
- sb->setMaximum(100);
- sb->setSuffix("%");
- } else if (type == DEPTH) {
- sb->setMinimum(0);
- sb->setMaximum(255);
- sb->setSuffix(" m");
- } else if (type == SETPOINT) {
- sb->setMinimum(0);
- sb->setMaximum(255);
- sb->setSuffix(" cbar");
- }
- return sb;
-}
-
-void GasSpinBoxItemDelegate::setEditorData(QWidget *editor, const QModelIndex &index) const
-{
- if (QSpinBox *sb = qobject_cast<QSpinBox *>(editor))
- sb->setValue(index.data(Qt::EditRole).toInt());
- else
- QStyledItemDelegate::setEditorData(editor, index);
-}
-
-
-void GasSpinBoxItemDelegate::setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const
-{
- if (QSpinBox *sb = qobject_cast<QSpinBox *>(editor))
- model->setData(index, sb->value(), Qt::EditRole);
- else
- QStyledItemDelegate::setModelData(editor, model, index);
-}
-
-GasTypeComboBoxItemDelegate::GasTypeComboBoxItemDelegate(QObject *parent, computer_type type) : QStyledItemDelegate(parent), type(type)
-{
-}
-GasTypeComboBoxItemDelegate::~GasTypeComboBoxItemDelegate()
-{
-}
-
-QWidget *GasTypeComboBoxItemDelegate::createEditor(QWidget *parent, const QStyleOptionViewItem &option, const QModelIndex &index) const
-{
- // Create the combobox and populate it
- QComboBox *cb = new QComboBox(parent);
- cb->addItem(QString("Disabled"));
- if (type == OSTC3) {
- cb->addItem(QString("First"));
- cb->addItem(QString("Travel"));
- cb->addItem(QString("Deco"));
- } else if (type == OSTC) {
- cb->addItem(QString("Active"));
- cb->addItem(QString("First"));
- }
- return cb;
-}
-
-void GasTypeComboBoxItemDelegate::setEditorData(QWidget *editor, const QModelIndex &index) const
-{
- if (QComboBox *cb = qobject_cast<QComboBox *>(editor))
- cb->setCurrentIndex(index.data(Qt::EditRole).toInt());
- else
- QStyledItemDelegate::setEditorData(editor, index);
-}
-
-
-void GasTypeComboBoxItemDelegate::setModelData(QWidget *editor, QAbstractItemModel *model, const QModelIndex &index) const
-{
- if (QComboBox *cb = qobject_cast<QComboBox *>(editor))
- model->setData(index, cb->currentIndex(), Qt::EditRole);
- else
- QStyledItemDelegate::setModelData(editor, model, index);
-}
-
-ConfigureDiveComputerDialog::ConfigureDiveComputerDialog(QWidget *parent) : QDialog(parent),
- config(0),
-#ifdef BT_SUPPORT
- deviceDetails(0),
- btDeviceSelectionDialog(0)
-#else
- deviceDetails(0)
-#endif
-{
- ui.setupUi(this);
-
- deviceDetails = new DeviceDetails(this);
- config = new ConfigureDiveComputer();
- connect(config, SIGNAL(progress(int)), ui.progressBar, SLOT(setValue(int)));
- connect(config, SIGNAL(error(QString)), this, SLOT(configError(QString)));
- connect(config, SIGNAL(message(QString)), this, SLOT(configMessage(QString)));
- connect(config, SIGNAL(deviceDetailsChanged(DeviceDetails *)),
- this, SLOT(deviceDetailsReceived(DeviceDetails *)));
- connect(ui.retrieveDetails, SIGNAL(clicked()), this, SLOT(readSettings()));
- connect(ui.resetButton, SIGNAL(clicked()), this, SLOT(resetSettings()));
- ui.chooseLogFile->setEnabled(ui.logToFile->isChecked());
- connect(ui.chooseLogFile, SIGNAL(clicked()), this, SLOT(pickLogFile()));
- connect(ui.logToFile, SIGNAL(stateChanged(int)), this, SLOT(checkLogFile(int)));
- connect(ui.connectButton, SIGNAL(clicked()), this, SLOT(dc_open()));
- connect(ui.disconnectButton, SIGNAL(clicked()), this, SLOT(dc_close()));
-#ifdef BT_SUPPORT
- connect(ui.bluetoothMode, SIGNAL(clicked(bool)), this, SLOT(selectRemoteBluetoothDevice()));
-#else
- ui.bluetoothMode->setVisible(false);
-#endif
-
- memset(&device_data, 0, sizeof(device_data));
- fill_computer_list();
- if (default_dive_computer_device)
- ui.device->setEditText(default_dive_computer_device);
-
- ui.DiveComputerList->setCurrentRow(0);
- on_DiveComputerList_currentRowChanged(0);
-
- ui.ostc3GasTable->setItemDelegateForColumn(1, new GasSpinBoxItemDelegate(this, GasSpinBoxItemDelegate::PERCENT));
- ui.ostc3GasTable->setItemDelegateForColumn(2, new GasSpinBoxItemDelegate(this, GasSpinBoxItemDelegate::PERCENT));
- ui.ostc3GasTable->setItemDelegateForColumn(3, new GasTypeComboBoxItemDelegate(this, GasTypeComboBoxItemDelegate::OSTC3));
- ui.ostc3GasTable->setItemDelegateForColumn(4, new GasSpinBoxItemDelegate(this, GasSpinBoxItemDelegate::DEPTH));
- ui.ostc3DilTable->setItemDelegateForColumn(3, new GasTypeComboBoxItemDelegate(this, GasTypeComboBoxItemDelegate::OSTC3));
- ui.ostc3DilTable->setItemDelegateForColumn(4, new GasSpinBoxItemDelegate(this, GasSpinBoxItemDelegate::DEPTH));
- ui.ostc3SetPointTable->setItemDelegateForColumn(1, new GasSpinBoxItemDelegate(this, GasSpinBoxItemDelegate::SETPOINT));
- ui.ostc3SetPointTable->setItemDelegateForColumn(2, new GasSpinBoxItemDelegate(this, GasSpinBoxItemDelegate::DEPTH));
- ui.ostcGasTable->setItemDelegateForColumn(1, new GasSpinBoxItemDelegate(this, GasSpinBoxItemDelegate::PERCENT));
- ui.ostcGasTable->setItemDelegateForColumn(2, new GasSpinBoxItemDelegate(this, GasSpinBoxItemDelegate::PERCENT));
- ui.ostcGasTable->setItemDelegateForColumn(3, new GasTypeComboBoxItemDelegate(this, GasTypeComboBoxItemDelegate::OSTC));
- ui.ostcGasTable->setItemDelegateForColumn(4, new GasSpinBoxItemDelegate(this, GasSpinBoxItemDelegate::DEPTH));
- ui.ostcDilTable->setItemDelegateForColumn(3, new GasTypeComboBoxItemDelegate(this, GasTypeComboBoxItemDelegate::OSTC));
- ui.ostcDilTable->setItemDelegateForColumn(4, new GasSpinBoxItemDelegate(this, GasSpinBoxItemDelegate::DEPTH));
- ui.ostcSetPointTable->setItemDelegateForColumn(1, new GasSpinBoxItemDelegate(this, GasSpinBoxItemDelegate::SETPOINT));
- ui.ostcSetPointTable->setItemDelegateForColumn(2, new GasSpinBoxItemDelegate(this, GasSpinBoxItemDelegate::DEPTH));
-
- QSettings settings;
- settings.beginGroup("ConfigureDiveComputerDialog");
- settings.beginGroup("ostc3GasTable");
- for (int i = 0; i < ui.ostc3GasTable->columnCount(); i++) {
- QVariant width = settings.value(QString("colwidth%1").arg(i));
- if (width.isValid())
- ui.ostc3GasTable->setColumnWidth(i, width.toInt());
- }
- settings.endGroup();
- settings.beginGroup("ostc3DilTable");
- for (int i = 0; i < ui.ostc3DilTable->columnCount(); i++) {
- QVariant width = settings.value(QString("colwidth%1").arg(i));
- if (width.isValid())
- ui.ostc3DilTable->setColumnWidth(i, width.toInt());
- }
- settings.endGroup();
- settings.beginGroup("ostc3SetPointTable");
- for (int i = 0; i < ui.ostc3SetPointTable->columnCount(); i++) {
- QVariant width = settings.value(QString("colwidth%1").arg(i));
- if (width.isValid())
- ui.ostc3SetPointTable->setColumnWidth(i, width.toInt());
- }
- settings.endGroup();
-
- settings.beginGroup("ostcGasTable");
- for (int i = 0; i < ui.ostcGasTable->columnCount(); i++) {
- QVariant width = settings.value(QString("colwidth%1").arg(i));
- if (width.isValid())
- ui.ostcGasTable->setColumnWidth(i, width.toInt());
- }
- settings.endGroup();
- settings.beginGroup("ostcDilTable");
- for (int i = 0; i < ui.ostcDilTable->columnCount(); i++) {
- QVariant width = settings.value(QString("colwidth%1").arg(i));
- if (width.isValid())
- ui.ostcDilTable->setColumnWidth(i, width.toInt());
- }
- settings.endGroup();
- settings.beginGroup("ostcSetPointTable");
- for (int i = 0; i < ui.ostcSetPointTable->columnCount(); i++) {
- QVariant width = settings.value(QString("colwidth%1").arg(i));
- if (width.isValid())
- ui.ostcSetPointTable->setColumnWidth(i, width.toInt());
- }
- settings.endGroup();
- settings.endGroup();
-}
-
-OstcFirmwareCheck::OstcFirmwareCheck(QString product) : parent(0)
-{
- QUrl url;
- memset(&devData, 1, sizeof(devData));
- if (product == "OSTC 3") {
- url = QUrl("http://www.heinrichsweikamp.net/autofirmware/ostc3_changelog.txt");
- latestFirmwareHexFile = QString("http://www.heinrichsweikamp.net/autofirmware/ostc3_firmware.hex");
- } else if (product == "OSTC Sport") {
- url = QUrl("http://www.heinrichsweikamp.net/autofirmware/ostc_sport_changelog.txt");
- latestFirmwareHexFile = QString("http://www.heinrichsweikamp.net/autofirmware/ostc_sport_firmware.hex");
- } else { // not one of the known dive computers
- return;
- }
- connect(&manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(parseOstcFwVersion(QNetworkReply *)));
- QNetworkRequest download(url);
- manager.get(download);
-}
-
-void OstcFirmwareCheck::parseOstcFwVersion(QNetworkReply *reply)
-{
- QString parse = reply->readAll();
- int firstOpenBracket = parse.indexOf('[');
- int firstCloseBracket = parse.indexOf(']');
- latestFirmwareAvailable = parse.mid(firstOpenBracket + 1, firstCloseBracket - firstOpenBracket - 1);
- disconnect(&manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(parseOstcFwVersion(QNetworkReply *)));
-}
-
-void OstcFirmwareCheck::checkLatest(QWidget *_parent, device_data_t *data)
-{
- devData = *data;
- parent = _parent;
- // If we didn't find a current firmware version stop this hole thing here.
- if (latestFirmwareAvailable.isEmpty())
- return;
-
- // for now libdivecomputer gives us the firmware on device undecoded as integer
- // for the OSTC that means highbyte.lowbyte is the version number
- int firmwareOnDevice = devData.libdc_firmware;
- QString firmwareOnDeviceString = QString("%1.%2").arg(firmwareOnDevice / 256).arg(firmwareOnDevice % 256);
-
- // Convert the latestFirmwareAvailable to a integear we can compare with
- QStringList fwParts = latestFirmwareAvailable.split(".");
- int latestFirmwareAvailableNumber = fwParts[0].toInt() * 256 + fwParts[1].toInt();
- if (latestFirmwareAvailableNumber > firmwareOnDevice) {
- QMessageBox response(parent);
- QString message = tr("You should update the firmware on your dive computer: you have version %1 but the latest stable version is %2")
- .arg(firmwareOnDeviceString)
- .arg(latestFirmwareAvailable);
- if (strcmp(data->product, "OSTC Sport") == 0)
- message += tr("\n\nPlease start Bluetooth on your OSTC Sport and do the same preparations as for a logbook download before continuing with the update");
- response.addButton(tr("Not now"), QMessageBox::RejectRole);
- response.addButton(tr("Update firmware"), QMessageBox::AcceptRole);
- response.setText(message);
- response.setWindowTitle(tr("Firmware upgrade notice"));
- response.setIcon(QMessageBox::Question);
- response.setWindowModality(Qt::WindowModal);
- int ret = response.exec();
- if (ret == QMessageBox::Accepted)
- upgradeFirmware();
- }
-}
-
-void OstcFirmwareCheck::upgradeFirmware()
-{
- // start download of latestFirmwareHexFile
- QString saveFileName = latestFirmwareHexFile;
- saveFileName.replace("http://www.heinrichsweikamp.net/autofirmware/", "");
- saveFileName.replace("firmware", latestFirmwareAvailable);
- QString filename = existing_filename ?: prefs.default_filename;
- QFileInfo fi(filename);
- filename = fi.absolutePath().append(QDir::separator()).append(saveFileName);
- storeFirmware = QFileDialog::getSaveFileName(parent, tr("Save the downloaded firmware as"),
- filename, tr("HEX files (*.hex)"));
- if (storeFirmware.isEmpty())
- return;
-
- connect(&manager, SIGNAL(finished(QNetworkReply *)), this, SLOT(saveOstcFirmware(QNetworkReply *)));
- QNetworkRequest download(latestFirmwareHexFile);
- manager.get(download);
-}
-
-void OstcFirmwareCheck::saveOstcFirmware(QNetworkReply *reply)
-{
- // firmware is downloaded
- // call config->startFirmwareUpdate() with that file and the device data
-
- QByteArray firmwareData = reply->readAll();
- QFile file(storeFirmware);
- file.open(QIODevice::WriteOnly);
- file.write(firmwareData);
- file.close();
- QProgressDialog *dialog = new QProgressDialog("Updating firmware", "", 0, 100);
- dialog->setCancelButton(0);
- dialog->setAutoClose(true);
- ConfigureDiveComputer *config = new ConfigureDiveComputer();
- connect(config, SIGNAL(message(QString)), dialog, SLOT(setLabelText(QString)));
- connect(config, SIGNAL(error(QString)), dialog, SLOT(setLabelText(QString)));
- connect(config, SIGNAL(progress(int)), dialog, SLOT(setValue(int)));
- connect(dialog, SIGNAL(finished(int)), config, SLOT(dc_close()));
- config->dc_open(&devData);
- config->startFirmwareUpdate(storeFirmware, &devData);
-}
-
-ConfigureDiveComputerDialog::~ConfigureDiveComputerDialog()
-{
- delete config;
-}
-
-void ConfigureDiveComputerDialog::closeEvent(QCloseEvent *event)
-{
- dc_close();
-
- QSettings settings;
- settings.beginGroup("ConfigureDiveComputerDialog");
- settings.beginGroup("ostc3GasTable");
- for (int i = 0; i < ui.ostc3GasTable->columnCount(); i++)
- settings.setValue(QString("colwidth%1").arg(i), ui.ostc3GasTable->columnWidth(i));
- settings.endGroup();
- settings.beginGroup("ostc3DilTable");
- for (int i = 0; i < ui.ostc3DilTable->columnCount(); i++)
- settings.setValue(QString("colwidth%1").arg(i), ui.ostc3DilTable->columnWidth(i));
- settings.endGroup();
- settings.beginGroup("ostc3SetPointTable");
- for (int i = 0; i < ui.ostc3SetPointTable->columnCount(); i++)
- settings.setValue(QString("colwidth%1").arg(i), ui.ostc3SetPointTable->columnWidth(i));
- settings.endGroup();
-
- settings.beginGroup("ostcGasTable");
- for (int i = 0; i < ui.ostcGasTable->columnCount(); i++)
- settings.setValue(QString("colwidth%1").arg(i), ui.ostcGasTable->columnWidth(i));
- settings.endGroup();
- settings.beginGroup("ostcDilTable");
- for (int i = 0; i < ui.ostcDilTable->columnCount(); i++)
- settings.setValue(QString("colwidth%1").arg(i), ui.ostcDilTable->columnWidth(i));
- settings.endGroup();
- settings.beginGroup("ostcSetPointTable");
- for (int i = 0; i < ui.ostcSetPointTable->columnCount(); i++)
- settings.setValue(QString("colwidth%1").arg(i), ui.ostcSetPointTable->columnWidth(i));
- settings.endGroup();
- settings.endGroup();
-}
-
-
-static void fillDeviceList(const char *name, void *data)
-{
- QComboBox *comboBox = (QComboBox *)data;
- comboBox->addItem(name);
-}
-
-void ConfigureDiveComputerDialog::fill_device_list(int dc_type)
-{
- int deviceIndex;
- ui.device->clear();
- deviceIndex = enumerate_devices(fillDeviceList, ui.device, dc_type);
- if (deviceIndex >= 0)
- ui.device->setCurrentIndex(deviceIndex);
-}
-
-void ConfigureDiveComputerDialog::fill_computer_list()
-{
- dc_iterator_t *iterator = NULL;
- dc_descriptor_t *descriptor = NULL;
-
- struct mydescriptor *mydescriptor;
-
- dc_descriptor_iterator(&iterator);
- while (dc_iterator_next(iterator, &descriptor) == DC_STATUS_SUCCESS) {
- const char *vendor = dc_descriptor_get_vendor(descriptor);
- const char *product = dc_descriptor_get_product(descriptor);
-
- if (!vendorList.contains(vendor))
- vendorList.append(vendor);
-
- if (!productList[vendor].contains(product))
- productList[vendor].push_back(product);
-
- descriptorLookup[QString(vendor) + QString(product)] = descriptor;
- }
- dc_iterator_free(iterator);
-
- mydescriptor = (struct mydescriptor *)malloc(sizeof(struct mydescriptor));
- mydescriptor->vendor = "Uemis";
- mydescriptor->product = "Zurich";
- mydescriptor->type = DC_FAMILY_NULL;
- mydescriptor->model = 0;
-
- if (!vendorList.contains("Uemis"))
- vendorList.append("Uemis");
-
- if (!productList["Uemis"].contains("Zurich"))
- productList["Uemis"].push_back("Zurich");
-
- descriptorLookup["UemisZurich"] = (dc_descriptor_t *)mydescriptor;
-
- qSort(vendorList);
-}
-
-void ConfigureDiveComputerDialog::populateDeviceDetails()
-{
- switch (ui.dcStackedWidget->currentIndex()) {
- case 0:
- populateDeviceDetailsOSTC3();
- break;
- case 1:
- populateDeviceDetailsSuuntoVyper();
- break;
- case 2:
- populateDeviceDetailsOSTC();
- break;
- }
-}
-
-#define GET_INT_FROM(_field, _default) ((_field) != NULL) ? (_field)->data(Qt::EditRole).toInt() : (_default)
-
-void ConfigureDiveComputerDialog::populateDeviceDetailsOSTC3()
-{
- deviceDetails->customText = ui.customTextLlineEdit->text();
- deviceDetails->diveMode = ui.diveModeComboBox->currentIndex();
- deviceDetails->saturation = ui.saturationSpinBox->value();
- deviceDetails->desaturation = ui.desaturationSpinBox->value();
- deviceDetails->lastDeco = ui.lastDecoSpinBox->value();
- deviceDetails->brightness = ui.brightnessComboBox->currentIndex();
- deviceDetails->units = ui.unitsComboBox->currentIndex();
- deviceDetails->samplingRate = ui.samplingRateComboBox->currentIndex();
- deviceDetails->salinity = ui.salinitySpinBox->value();
- deviceDetails->diveModeColor = ui.diveModeColour->currentIndex();
- deviceDetails->language = ui.languageComboBox->currentIndex();
- deviceDetails->dateFormat = ui.dateFormatComboBox->currentIndex();
- deviceDetails->compassGain = ui.compassGainComboBox->currentIndex();
- deviceDetails->syncTime = ui.dateTimeSyncCheckBox->isChecked();
- deviceDetails->safetyStop = ui.safetyStopCheckBox->isChecked();
- deviceDetails->gfHigh = ui.gfHighSpinBox->value();
- deviceDetails->gfLow = ui.gfLowSpinBox->value();
- deviceDetails->pressureSensorOffset = ui.pressureSensorOffsetSpinBox->value();
- deviceDetails->ppO2Min = ui.ppO2MinSpinBox->value();
- deviceDetails->ppO2Max = ui.ppO2MaxSpinBox->value();
- deviceDetails->futureTTS = ui.futureTTSSpinBox->value();
- deviceDetails->ccrMode = ui.ccrModeComboBox->currentIndex();
- deviceDetails->decoType = ui.decoTypeComboBox->currentIndex();
- deviceDetails->aGFSelectable = ui.aGFSelectableCheckBox->isChecked();
- deviceDetails->aGFHigh = ui.aGFHighSpinBox->value();
- deviceDetails->aGFLow = ui.aGFLowSpinBox->value();
- deviceDetails->calibrationGas = ui.calibrationGasSpinBox->value();
- deviceDetails->flipScreen = ui.flipScreenCheckBox->isChecked();
- deviceDetails->setPointFallback = ui.setPointFallbackCheckBox->isChecked();
- deviceDetails->leftButtonSensitivity = ui.leftButtonSensitivity->value();
- deviceDetails->rightButtonSensitivity = ui.rightButtonSensitivity->value();
- deviceDetails->bottomGasConsumption = ui.bottomGasConsumption->value();
- deviceDetails->decoGasConsumption = ui.decoGasConsumption->value();
- deviceDetails->modWarning = ui.modWarning->isChecked();
- deviceDetails->dynamicAscendRate = ui.dynamicAscendRate->isChecked();
- deviceDetails->graphicalSpeedIndicator = ui.graphicalSpeedIndicator->isChecked();
- deviceDetails->alwaysShowppO2 = ui.alwaysShowppO2->isChecked();
-
- //set gas values
- gas gas1;
- gas gas2;
- gas gas3;
- gas gas4;
- gas gas5;
-
- gas1.oxygen = GET_INT_FROM(ui.ostc3GasTable->item(0, 1), 21);
- gas1.helium = GET_INT_FROM(ui.ostc3GasTable->item(0, 2), 0);
- gas1.type = GET_INT_FROM(ui.ostc3GasTable->item(0, 3), 0);
- gas1.depth = GET_INT_FROM(ui.ostc3GasTable->item(0, 4), 0);
-
- gas2.oxygen = GET_INT_FROM(ui.ostc3GasTable->item(1, 1), 21);
- gas2.helium = GET_INT_FROM(ui.ostc3GasTable->item(1, 2), 0);
- gas2.type = GET_INT_FROM(ui.ostc3GasTable->item(1, 3), 0);
- gas2.depth = GET_INT_FROM(ui.ostc3GasTable->item(1, 4), 0);
-
- gas3.oxygen = GET_INT_FROM(ui.ostc3GasTable->item(2, 1), 21);
- gas3.helium = GET_INT_FROM(ui.ostc3GasTable->item(2, 2), 0);
- gas3.type = GET_INT_FROM(ui.ostc3GasTable->item(2, 3), 0);
- gas3.depth = GET_INT_FROM(ui.ostc3GasTable->item(2, 4), 0);
-
- gas4.oxygen = GET_INT_FROM(ui.ostc3GasTable->item(3, 1), 21);
- gas4.helium = GET_INT_FROM(ui.ostc3GasTable->item(3, 2), 0);
- gas4.type = GET_INT_FROM(ui.ostc3GasTable->item(3, 3), 0);
- gas4.depth = GET_INT_FROM(ui.ostc3GasTable->item(3, 4), 0);
-
- gas5.oxygen = GET_INT_FROM(ui.ostc3GasTable->item(4, 1), 21);
- gas5.helium = GET_INT_FROM(ui.ostc3GasTable->item(4, 2), 0);
- gas5.type = GET_INT_FROM(ui.ostc3GasTable->item(4, 3), 0);
- gas5.depth = GET_INT_FROM(ui.ostc3GasTable->item(4, 4), 0);
-
- deviceDetails->gas1 = gas1;
- deviceDetails->gas2 = gas2;
- deviceDetails->gas3 = gas3;
- deviceDetails->gas4 = gas4;
- deviceDetails->gas5 = gas5;
-
- //set dil values
- gas dil1;
- gas dil2;
- gas dil3;
- gas dil4;
- gas dil5;
-
- dil1.oxygen = GET_INT_FROM(ui.ostc3DilTable->item(0, 1), 21);
- dil1.helium = GET_INT_FROM(ui.ostc3DilTable->item(0, 2), 0);
- dil1.type = GET_INT_FROM(ui.ostc3DilTable->item(0, 3), 0);
- dil1.depth = GET_INT_FROM(ui.ostc3DilTable->item(0, 4), 0);
-
- dil2.oxygen = GET_INT_FROM(ui.ostc3DilTable->item(1, 1), 21);
- dil2.helium = GET_INT_FROM(ui.ostc3DilTable->item(1, 2), 0);
- dil2.type = GET_INT_FROM(ui.ostc3DilTable->item(1, 3), 0);
- dil2.depth = GET_INT_FROM(ui.ostc3DilTable->item(1, 4), 0);
-
- dil3.oxygen = GET_INT_FROM(ui.ostc3DilTable->item(2, 1), 21);
- dil3.helium = GET_INT_FROM(ui.ostc3DilTable->item(2, 2), 0);
- dil3.type = GET_INT_FROM(ui.ostc3DilTable->item(2, 3), 0);
- dil3.depth = GET_INT_FROM(ui.ostc3DilTable->item(2, 4), 0);
-
- dil4.oxygen = GET_INT_FROM(ui.ostc3DilTable->item(3, 1), 21);
- dil4.helium = GET_INT_FROM(ui.ostc3DilTable->item(3, 2), 0);
- dil4.type = GET_INT_FROM(ui.ostc3DilTable->item(3, 3), 0);
- dil4.depth = GET_INT_FROM(ui.ostc3DilTable->item(3, 4), 0);
-
- dil5.oxygen = GET_INT_FROM(ui.ostc3DilTable->item(4, 1), 21);
- dil5.helium = GET_INT_FROM(ui.ostc3DilTable->item(4, 2), 0);
- dil5.type = GET_INT_FROM(ui.ostc3DilTable->item(4, 3), 0);
- dil5.depth = GET_INT_FROM(ui.ostc3DilTable->item(4, 4), 0);
-
- deviceDetails->dil1 = dil1;
- deviceDetails->dil2 = dil2;
- deviceDetails->dil3 = dil3;
- deviceDetails->dil4 = dil4;
- deviceDetails->dil5 = dil5;
-
- //set set point details
- setpoint sp1;
- setpoint sp2;
- setpoint sp3;
- setpoint sp4;
- setpoint sp5;
-
- sp1.sp = GET_INT_FROM(ui.ostc3SetPointTable->item(0, 1), 70);
- sp1.depth = GET_INT_FROM(ui.ostc3SetPointTable->item(0, 2), 0);
-
- sp2.sp = GET_INT_FROM(ui.ostc3SetPointTable->item(1, 1), 90);
- sp2.depth = GET_INT_FROM(ui.ostc3SetPointTable->item(1, 2), 20);
-
- sp3.sp = GET_INT_FROM(ui.ostc3SetPointTable->item(2, 1), 100);
- sp3.depth = GET_INT_FROM(ui.ostc3SetPointTable->item(2, 2), 33);
-
- sp4.sp = GET_INT_FROM(ui.ostc3SetPointTable->item(3, 1), 120);
- sp4.depth = GET_INT_FROM(ui.ostc3SetPointTable->item(3, 2), 50);
-
- sp5.sp = GET_INT_FROM(ui.ostc3SetPointTable->item(4, 1), 140);
- sp5.depth = GET_INT_FROM(ui.ostc3SetPointTable->item(4, 2), 70);
-
- deviceDetails->sp1 = sp1;
- deviceDetails->sp2 = sp2;
- deviceDetails->sp3 = sp3;
- deviceDetails->sp4 = sp4;
- deviceDetails->sp5 = sp5;
-}
-
-void ConfigureDiveComputerDialog::populateDeviceDetailsOSTC()
-{
- deviceDetails->customText = ui.customTextLlineEdit_3->text();
- deviceDetails->saturation = ui.saturationSpinBox_3->value();
- deviceDetails->desaturation = ui.desaturationSpinBox_3->value();
- deviceDetails->lastDeco = ui.lastDecoSpinBox_3->value();
- deviceDetails->samplingRate = ui.samplingRateSpinBox_3->value();
- deviceDetails->salinity = ui.salinityDoubleSpinBox_3->value() * 100;
- deviceDetails->dateFormat = ui.dateFormatComboBox_3->currentIndex();
- deviceDetails->syncTime = ui.dateTimeSyncCheckBox_3->isChecked();
- deviceDetails->safetyStop = ui.safetyStopCheckBox_3->isChecked();
- deviceDetails->gfHigh = ui.gfHighSpinBox_3->value();
- deviceDetails->gfLow = ui.gfLowSpinBox_3->value();
- deviceDetails->ppO2Min = ui.ppO2MinSpinBox_3->value();
- deviceDetails->ppO2Max = ui.ppO2MaxSpinBox_3->value();
- deviceDetails->futureTTS = ui.futureTTSSpinBox_3->value();
- deviceDetails->decoType = ui.decoTypeComboBox_3->currentIndex();
- deviceDetails->aGFSelectable = ui.aGFSelectableCheckBox_3->isChecked();
- deviceDetails->aGFHigh = ui.aGFHighSpinBox_3->value();
- deviceDetails->aGFLow = ui.aGFLowSpinBox_3->value();
- deviceDetails->bottomGasConsumption = ui.bottomGasConsumption_3->value();
- deviceDetails->decoGasConsumption = ui.decoGasConsumption_3->value();
- deviceDetails->graphicalSpeedIndicator = ui.graphicalSpeedIndicator_3->isChecked();
-
- //set gas values
- gas gas1;
- gas gas2;
- gas gas3;
- gas gas4;
- gas gas5;
-
- gas1.oxygen = GET_INT_FROM(ui.ostcGasTable->item(0, 1), 21);
- gas1.helium = GET_INT_FROM(ui.ostcGasTable->item(0, 2), 0);
- gas1.type = GET_INT_FROM(ui.ostcGasTable->item(0, 3), 0);
- gas1.depth = GET_INT_FROM(ui.ostcGasTable->item(0, 4), 0);
-
- gas2.oxygen = GET_INT_FROM(ui.ostcGasTable->item(1, 1), 21);
- gas2.helium = GET_INT_FROM(ui.ostcGasTable->item(1, 2), 0);
- gas2.type = GET_INT_FROM(ui.ostcGasTable->item(1, 3), 0);
- gas2.depth = GET_INT_FROM(ui.ostcGasTable->item(1, 4), 0);
-
- gas3.oxygen = GET_INT_FROM(ui.ostcGasTable->item(2, 1), 21);
- gas3.helium = GET_INT_FROM(ui.ostcGasTable->item(2, 2), 0);
- gas3.type = GET_INT_FROM(ui.ostcGasTable->item(2, 3), 0);
- gas3.depth = GET_INT_FROM(ui.ostcGasTable->item(2, 4), 0);
-
- gas4.oxygen = GET_INT_FROM(ui.ostcGasTable->item(3, 1), 21);
- gas4.helium = GET_INT_FROM(ui.ostcGasTable->item(3, 2), 0);
- gas4.type = GET_INT_FROM(ui.ostcGasTable->item(3, 3), 0);
- gas4.depth = GET_INT_FROM(ui.ostcGasTable->item(3, 4), 0);
-
- gas5.oxygen = GET_INT_FROM(ui.ostcGasTable->item(4, 1), 21);
- gas5.helium = GET_INT_FROM(ui.ostcGasTable->item(4, 2), 0);
- gas5.type = GET_INT_FROM(ui.ostcGasTable->item(4, 3), 0);
- gas5.depth = GET_INT_FROM(ui.ostcGasTable->item(4, 4), 0);
-
- deviceDetails->gas1 = gas1;
- deviceDetails->gas2 = gas2;
- deviceDetails->gas3 = gas3;
- deviceDetails->gas4 = gas4;
- deviceDetails->gas5 = gas5;
-
- //set dil values
- gas dil1;
- gas dil2;
- gas dil3;
- gas dil4;
- gas dil5;
-
- dil1.oxygen = GET_INT_FROM(ui.ostcDilTable->item(0, 1), 21);
- dil1.helium = GET_INT_FROM(ui.ostcDilTable->item(0, 2), 0);
- dil1.type = GET_INT_FROM(ui.ostcDilTable->item(0, 3), 0);
- dil1.depth = GET_INT_FROM(ui.ostcDilTable->item(0, 4), 0);
-
- dil2.oxygen = GET_INT_FROM(ui.ostcDilTable->item(1, 1), 21);
- dil2.helium = GET_INT_FROM(ui.ostcDilTable->item(1, 2), 0);
- dil2.type = GET_INT_FROM(ui.ostcDilTable->item(1, 3), 0);
- dil2.depth = GET_INT_FROM(ui.ostcDilTable->item(1, 4), 0);
-
- dil3.oxygen = GET_INT_FROM(ui.ostcDilTable->item(2, 1), 21);
- dil3.helium = GET_INT_FROM(ui.ostcDilTable->item(2, 2), 0);
- dil3.type = GET_INT_FROM(ui.ostcDilTable->item(2, 3), 0);
- dil3.depth = GET_INT_FROM(ui.ostcDilTable->item(2, 4), 0);
-
- dil4.oxygen = GET_INT_FROM(ui.ostcDilTable->item(3, 1), 21);
- dil4.helium = GET_INT_FROM(ui.ostcDilTable->item(3, 2), 0);
- dil4.type = GET_INT_FROM(ui.ostcDilTable->item(3, 3), 0);
- dil4.depth = GET_INT_FROM(ui.ostcDilTable->item(3, 4), 0);
-
- dil5.oxygen = GET_INT_FROM(ui.ostcDilTable->item(4, 1), 21);
- dil5.helium = GET_INT_FROM(ui.ostcDilTable->item(4, 2), 0);
- dil5.type = GET_INT_FROM(ui.ostcDilTable->item(4, 3), 0);
- dil5.depth = GET_INT_FROM(ui.ostcDilTable->item(4, 4), 0);
-
- deviceDetails->dil1 = dil1;
- deviceDetails->dil2 = dil2;
- deviceDetails->dil3 = dil3;
- deviceDetails->dil4 = dil4;
- deviceDetails->dil5 = dil5;
-
- //set set point details
- setpoint sp1;
- setpoint sp2;
- setpoint sp3;
- setpoint sp4;
- setpoint sp5;
-
- sp1.sp = GET_INT_FROM(ui.ostcSetPointTable->item(0, 1), 70);
- sp1.depth = GET_INT_FROM(ui.ostcSetPointTable->item(0, 2), 0);
-
- sp2.sp = GET_INT_FROM(ui.ostcSetPointTable->item(1, 1), 90);
- sp2.depth = GET_INT_FROM(ui.ostcSetPointTable->item(1, 2), 20);
-
- sp3.sp = GET_INT_FROM(ui.ostcSetPointTable->item(2, 1), 100);
- sp3.depth = GET_INT_FROM(ui.ostcSetPointTable->item(2, 2), 33);
-
- sp4.sp = GET_INT_FROM(ui.ostcSetPointTable->item(3, 1), 120);
- sp4.depth = GET_INT_FROM(ui.ostcSetPointTable->item(3, 2), 50);
-
- sp5.sp = GET_INT_FROM(ui.ostcSetPointTable->item(4, 1), 140);
- sp5.depth = GET_INT_FROM(ui.ostcSetPointTable->item(4, 2), 70);
-
- deviceDetails->sp1 = sp1;
- deviceDetails->sp2 = sp2;
- deviceDetails->sp3 = sp3;
- deviceDetails->sp4 = sp4;
- deviceDetails->sp5 = sp5;
-}
-
-void ConfigureDiveComputerDialog::populateDeviceDetailsSuuntoVyper()
-{
- deviceDetails->customText = ui.customTextLlineEdit_1->text();
- deviceDetails->samplingRate = ui.samplingRateComboBox_1->currentIndex() == 3 ? 60 : (ui.samplingRateComboBox_1->currentIndex() + 1) * 10;
- deviceDetails->altitude = ui.altitudeRangeComboBox->currentIndex();
- deviceDetails->personalSafety = ui.personalSafetyComboBox->currentIndex();
- deviceDetails->timeFormat = ui.timeFormatComboBox->currentIndex();
- deviceDetails->units = ui.unitsComboBox_1->currentIndex();
- deviceDetails->diveMode = ui.diveModeComboBox_1->currentIndex();
- deviceDetails->lightEnabled = ui.lightCheckBox->isChecked();
- deviceDetails->light = ui.lightSpinBox->value();
- deviceDetails->alarmDepthEnabled = ui.alarmDepthCheckBox->isChecked();
- deviceDetails->alarmDepth = units_to_depth(ui.alarmDepthDoubleSpinBox->value());
- deviceDetails->alarmTimeEnabled = ui.alarmTimeCheckBox->isChecked();
- deviceDetails->alarmTime = ui.alarmTimeSpinBox->value();
-}
-
-void ConfigureDiveComputerDialog::readSettings()
-{
- ui.progressBar->setValue(0);
- ui.progressBar->setFormat("%p%");
- ui.progressBar->setTextVisible(true);
- // Fw update is no longer a option, needs to be done on a untouched device
- ui.updateFirmwareButton->setEnabled(false);
-
- config->readSettings(&device_data);
-}
-
-void ConfigureDiveComputerDialog::resetSettings()
-{
- ui.progressBar->setValue(0);
- ui.progressBar->setFormat("%p%");
- ui.progressBar->setTextVisible(true);
-
- config->resetSettings(&device_data);
-}
-
-void ConfigureDiveComputerDialog::configMessage(QString msg)
-{
- ui.progressBar->setFormat(msg);
-}
-
-void ConfigureDiveComputerDialog::configError(QString err)
-{
- ui.progressBar->setFormat("Error: " + err);
-}
-
-void ConfigureDiveComputerDialog::getDeviceData()
-{
- device_data.devname = strdup(ui.device->currentText().toUtf8().data());
- device_data.vendor = strdup(selected_vendor.toUtf8().data());
- device_data.product = strdup(selected_product.toUtf8().data());
-
- device_data.descriptor = descriptorLookup[selected_vendor + selected_product];
- device_data.deviceid = device_data.diveid = 0;
-
- set_default_dive_computer_device(device_data.devname);
-}
-
-void ConfigureDiveComputerDialog::on_cancel_clicked()
-{
- this->close();
-}
-
-void ConfigureDiveComputerDialog::on_saveSettingsPushButton_clicked()
-{
- ui.progressBar->setValue(0);
- ui.progressBar->setFormat("%p%");
- ui.progressBar->setTextVisible(true);
-
- populateDeviceDetails();
- config->saveDeviceDetails(deviceDetails, &device_data);
-}
-
-void ConfigureDiveComputerDialog::deviceDetailsReceived(DeviceDetails *newDeviceDetails)
-{
- deviceDetails = newDeviceDetails;
- reloadValues();
-}
-
-void ConfigureDiveComputerDialog::reloadValues()
-{
- // Enable the buttons to do operations on this data
- ui.saveSettingsPushButton->setEnabled(true);
- ui.backupButton->setEnabled(true);
-
- switch (ui.dcStackedWidget->currentIndex()) {
- case 0:
- reloadValuesOSTC3();
- break;
- case 1:
- reloadValuesSuuntoVyper();
- break;
- case 2:
- reloadValuesOSTC();
- break;
- }
-}
-
-void ConfigureDiveComputerDialog::reloadValuesOSTC3()
-{
- ui.serialNoLineEdit->setText(deviceDetails->serialNo);
- ui.firmwareVersionLineEdit->setText(deviceDetails->firmwareVersion);
- ui.customTextLlineEdit->setText(deviceDetails->customText);
- ui.modelLineEdit->setText(deviceDetails->model);
- ui.diveModeComboBox->setCurrentIndex(deviceDetails->diveMode);
- ui.saturationSpinBox->setValue(deviceDetails->saturation);
- ui.desaturationSpinBox->setValue(deviceDetails->desaturation);
- ui.lastDecoSpinBox->setValue(deviceDetails->lastDeco);
- ui.brightnessComboBox->setCurrentIndex(deviceDetails->brightness);
- ui.unitsComboBox->setCurrentIndex(deviceDetails->units);
- ui.samplingRateComboBox->setCurrentIndex(deviceDetails->samplingRate);
- ui.salinitySpinBox->setValue(deviceDetails->salinity);
- ui.diveModeColour->setCurrentIndex(deviceDetails->diveModeColor);
- ui.languageComboBox->setCurrentIndex(deviceDetails->language);
- ui.dateFormatComboBox->setCurrentIndex(deviceDetails->dateFormat);
- ui.compassGainComboBox->setCurrentIndex(deviceDetails->compassGain);
- ui.safetyStopCheckBox->setChecked(deviceDetails->safetyStop);
- ui.gfHighSpinBox->setValue(deviceDetails->gfHigh);
- ui.gfLowSpinBox->setValue(deviceDetails->gfLow);
- ui.pressureSensorOffsetSpinBox->setValue(deviceDetails->pressureSensorOffset);
- ui.ppO2MinSpinBox->setValue(deviceDetails->ppO2Min);
- ui.ppO2MaxSpinBox->setValue(deviceDetails->ppO2Max);
- ui.futureTTSSpinBox->setValue(deviceDetails->futureTTS);
- ui.ccrModeComboBox->setCurrentIndex(deviceDetails->ccrMode);
- ui.decoTypeComboBox->setCurrentIndex(deviceDetails->decoType);
- ui.aGFSelectableCheckBox->setChecked(deviceDetails->aGFSelectable);
- ui.aGFHighSpinBox->setValue(deviceDetails->aGFHigh);
- ui.aGFLowSpinBox->setValue(deviceDetails->aGFLow);
- ui.calibrationGasSpinBox->setValue(deviceDetails->calibrationGas);
- ui.flipScreenCheckBox->setChecked(deviceDetails->flipScreen);
- ui.setPointFallbackCheckBox->setChecked(deviceDetails->setPointFallback);
- ui.leftButtonSensitivity->setValue(deviceDetails->leftButtonSensitivity);
- ui.rightButtonSensitivity->setValue(deviceDetails->rightButtonSensitivity);
- ui.bottomGasConsumption->setValue(deviceDetails->bottomGasConsumption);
- ui.decoGasConsumption->setValue(deviceDetails->decoGasConsumption);
- ui.modWarning->setChecked(deviceDetails->modWarning);
- ui.dynamicAscendRate->setChecked(deviceDetails->dynamicAscendRate);
- ui.graphicalSpeedIndicator->setChecked(deviceDetails->graphicalSpeedIndicator);
- ui.alwaysShowppO2->setChecked(deviceDetails->alwaysShowppO2);
-
- //load gas 1 values
- ui.ostc3GasTable->setItem(0, 1, new QTableWidgetItem(QString::number(deviceDetails->gas1.oxygen)));
- ui.ostc3GasTable->setItem(0, 2, new QTableWidgetItem(QString::number(deviceDetails->gas1.helium)));
- ui.ostc3GasTable->setItem(0, 3, new QTableWidgetItem(QString::number(deviceDetails->gas1.type)));
- ui.ostc3GasTable->setItem(0, 4, new QTableWidgetItem(QString::number(deviceDetails->gas1.depth)));
-
- //load gas 2 values
- ui.ostc3GasTable->setItem(1, 1, new QTableWidgetItem(QString::number(deviceDetails->gas2.oxygen)));
- ui.ostc3GasTable->setItem(1, 2, new QTableWidgetItem(QString::number(deviceDetails->gas2.helium)));
- ui.ostc3GasTable->setItem(1, 3, new QTableWidgetItem(QString::number(deviceDetails->gas2.type)));
- ui.ostc3GasTable->setItem(1, 4, new QTableWidgetItem(QString::number(deviceDetails->gas2.depth)));
-
- //load gas 3 values
- ui.ostc3GasTable->setItem(2, 1, new QTableWidgetItem(QString::number(deviceDetails->gas3.oxygen)));
- ui.ostc3GasTable->setItem(2, 2, new QTableWidgetItem(QString::number(deviceDetails->gas3.helium)));
- ui.ostc3GasTable->setItem(2, 3, new QTableWidgetItem(QString::number(deviceDetails->gas3.type)));
- ui.ostc3GasTable->setItem(2, 4, new QTableWidgetItem(QString::number(deviceDetails->gas3.depth)));
-
- //load gas 4 values
- ui.ostc3GasTable->setItem(3, 1, new QTableWidgetItem(QString::number(deviceDetails->gas4.oxygen)));
- ui.ostc3GasTable->setItem(3, 2, new QTableWidgetItem(QString::number(deviceDetails->gas4.helium)));
- ui.ostc3GasTable->setItem(3, 3, new QTableWidgetItem(QString::number(deviceDetails->gas4.type)));
- ui.ostc3GasTable->setItem(3, 4, new QTableWidgetItem(QString::number(deviceDetails->gas4.depth)));
-
- //load gas 5 values
- ui.ostc3GasTable->setItem(4, 1, new QTableWidgetItem(QString::number(deviceDetails->gas5.oxygen)));
- ui.ostc3GasTable->setItem(4, 2, new QTableWidgetItem(QString::number(deviceDetails->gas5.helium)));
- ui.ostc3GasTable->setItem(4, 3, new QTableWidgetItem(QString::number(deviceDetails->gas5.type)));
- ui.ostc3GasTable->setItem(4, 4, new QTableWidgetItem(QString::number(deviceDetails->gas5.depth)));
-
- //load dil 1 values
- ui.ostc3DilTable->setItem(0, 1, new QTableWidgetItem(QString::number(deviceDetails->dil1.oxygen)));
- ui.ostc3DilTable->setItem(0, 2, new QTableWidgetItem(QString::number(deviceDetails->dil1.helium)));
- ui.ostc3DilTable->setItem(0, 3, new QTableWidgetItem(QString::number(deviceDetails->dil1.type)));
- ui.ostc3DilTable->setItem(0, 4, new QTableWidgetItem(QString::number(deviceDetails->dil1.depth)));
-
- //load dil 2 values
- ui.ostc3DilTable->setItem(1, 1, new QTableWidgetItem(QString::number(deviceDetails->dil2.oxygen)));
- ui.ostc3DilTable->setItem(1, 2, new QTableWidgetItem(QString::number(deviceDetails->dil2.helium)));
- ui.ostc3DilTable->setItem(1, 3, new QTableWidgetItem(QString::number(deviceDetails->dil2.type)));
- ui.ostc3DilTable->setItem(1, 4, new QTableWidgetItem(QString::number(deviceDetails->dil2.depth)));
-
- //load dil 3 values
- ui.ostc3DilTable->setItem(2, 1, new QTableWidgetItem(QString::number(deviceDetails->dil3.oxygen)));
- ui.ostc3DilTable->setItem(2, 2, new QTableWidgetItem(QString::number(deviceDetails->dil3.helium)));
- ui.ostc3DilTable->setItem(2, 3, new QTableWidgetItem(QString::number(deviceDetails->dil3.type)));
- ui.ostc3DilTable->setItem(2, 4, new QTableWidgetItem(QString::number(deviceDetails->dil3.depth)));
-
- //load dil 4 values
- ui.ostc3DilTable->setItem(3, 1, new QTableWidgetItem(QString::number(deviceDetails->dil4.oxygen)));
- ui.ostc3DilTable->setItem(3, 2, new QTableWidgetItem(QString::number(deviceDetails->dil4.helium)));
- ui.ostc3DilTable->setItem(3, 3, new QTableWidgetItem(QString::number(deviceDetails->dil4.type)));
- ui.ostc3DilTable->setItem(3, 4, new QTableWidgetItem(QString::number(deviceDetails->dil4.depth)));
-
- //load dil 5 values
- ui.ostc3DilTable->setItem(4, 1, new QTableWidgetItem(QString::number(deviceDetails->dil5.oxygen)));
- ui.ostc3DilTable->setItem(4, 2, new QTableWidgetItem(QString::number(deviceDetails->dil5.helium)));
- ui.ostc3DilTable->setItem(4, 3, new QTableWidgetItem(QString::number(deviceDetails->dil5.type)));
- ui.ostc3DilTable->setItem(4, 4, new QTableWidgetItem(QString::number(deviceDetails->dil5.depth)));
-
- //load set point 1 values
- ui.ostc3SetPointTable->setItem(0, 1, new QTableWidgetItem(QString::number(deviceDetails->sp1.sp)));
- ui.ostc3SetPointTable->setItem(0, 2, new QTableWidgetItem(QString::number(deviceDetails->sp1.depth)));
-
- //load set point 2 values
- ui.ostc3SetPointTable->setItem(1, 1, new QTableWidgetItem(QString::number(deviceDetails->sp2.sp)));
- ui.ostc3SetPointTable->setItem(1, 2, new QTableWidgetItem(QString::number(deviceDetails->sp2.depth)));
-
- //load set point 3 values
- ui.ostc3SetPointTable->setItem(2, 1, new QTableWidgetItem(QString::number(deviceDetails->sp3.sp)));
- ui.ostc3SetPointTable->setItem(2, 2, new QTableWidgetItem(QString::number(deviceDetails->sp3.depth)));
-
- //load set point 4 values
- ui.ostc3SetPointTable->setItem(3, 1, new QTableWidgetItem(QString::number(deviceDetails->sp4.sp)));
- ui.ostc3SetPointTable->setItem(3, 2, new QTableWidgetItem(QString::number(deviceDetails->sp4.depth)));
-
- //load set point 5 values
- ui.ostc3SetPointTable->setItem(4, 1, new QTableWidgetItem(QString::number(deviceDetails->sp5.sp)));
- ui.ostc3SetPointTable->setItem(4, 2, new QTableWidgetItem(QString::number(deviceDetails->sp5.depth)));
-}
-
-void ConfigureDiveComputerDialog::reloadValuesOSTC()
-{
- /*
-# Not in OSTC
-setBrightness
-setCalibrationGas
-setCompassGain
-setDiveMode - Bult into setDecoType
-setDiveModeColor - Lots of different colors
-setFlipScreen
-setLanguage
-setPressureSensorOffset
-setUnits
-setSetPointFallback
-setCcrMode
-# Not in OSTC3
-setNumberOfDives
-*/
- ui.serialNoLineEdit_3->setText(deviceDetails->serialNo);
- ui.firmwareVersionLineEdit_3->setText(deviceDetails->firmwareVersion);
- ui.customTextLlineEdit_3->setText(deviceDetails->customText);
- ui.saturationSpinBox_3->setValue(deviceDetails->saturation);
- ui.desaturationSpinBox_3->setValue(deviceDetails->desaturation);
- ui.lastDecoSpinBox_3->setValue(deviceDetails->lastDeco);
- ui.samplingRateSpinBox_3->setValue(deviceDetails->samplingRate);
- ui.salinityDoubleSpinBox_3->setValue((double)deviceDetails->salinity / 100.0);
- ui.dateFormatComboBox_3->setCurrentIndex(deviceDetails->dateFormat);
- ui.safetyStopCheckBox_3->setChecked(deviceDetails->safetyStop);
- ui.gfHighSpinBox_3->setValue(deviceDetails->gfHigh);
- ui.gfLowSpinBox_3->setValue(deviceDetails->gfLow);
- ui.ppO2MinSpinBox_3->setValue(deviceDetails->ppO2Min);
- ui.ppO2MaxSpinBox_3->setValue(deviceDetails->ppO2Max);
- ui.futureTTSSpinBox_3->setValue(deviceDetails->futureTTS);
- ui.decoTypeComboBox_3->setCurrentIndex(deviceDetails->decoType);
- ui.aGFSelectableCheckBox_3->setChecked(deviceDetails->aGFSelectable);
- ui.aGFHighSpinBox_3->setValue(deviceDetails->aGFHigh);
- ui.aGFLowSpinBox_3->setValue(deviceDetails->aGFLow);
- ui.numberOfDivesSpinBox_3->setValue(deviceDetails->numberOfDives);
- ui.bottomGasConsumption_3->setValue(deviceDetails->bottomGasConsumption);
- ui.decoGasConsumption_3->setValue(deviceDetails->decoGasConsumption);
- ui.graphicalSpeedIndicator_3->setChecked(deviceDetails->graphicalSpeedIndicator);
-
- //load gas 1 values
- ui.ostcGasTable->setItem(0, 1, new QTableWidgetItem(QString::number(deviceDetails->gas1.oxygen)));
- ui.ostcGasTable->setItem(0, 2, new QTableWidgetItem(QString::number(deviceDetails->gas1.helium)));
- ui.ostcGasTable->setItem(0, 3, new QTableWidgetItem(QString::number(deviceDetails->gas1.type)));
- ui.ostcGasTable->setItem(0, 4, new QTableWidgetItem(QString::number(deviceDetails->gas1.depth)));
-
- //load gas 2 values
- ui.ostcGasTable->setItem(1, 1, new QTableWidgetItem(QString::number(deviceDetails->gas2.oxygen)));
- ui.ostcGasTable->setItem(1, 2, new QTableWidgetItem(QString::number(deviceDetails->gas2.helium)));
- ui.ostcGasTable->setItem(1, 3, new QTableWidgetItem(QString::number(deviceDetails->gas2.type)));
- ui.ostcGasTable->setItem(1, 4, new QTableWidgetItem(QString::number(deviceDetails->gas2.depth)));
-
- //load gas 3 values
- ui.ostcGasTable->setItem(2, 1, new QTableWidgetItem(QString::number(deviceDetails->gas3.oxygen)));
- ui.ostcGasTable->setItem(2, 2, new QTableWidgetItem(QString::number(deviceDetails->gas3.helium)));
- ui.ostcGasTable->setItem(2, 3, new QTableWidgetItem(QString::number(deviceDetails->gas3.type)));
- ui.ostcGasTable->setItem(2, 4, new QTableWidgetItem(QString::number(deviceDetails->gas3.depth)));
-
- //load gas 4 values
- ui.ostcGasTable->setItem(3, 1, new QTableWidgetItem(QString::number(deviceDetails->gas4.oxygen)));
- ui.ostcGasTable->setItem(3, 2, new QTableWidgetItem(QString::number(deviceDetails->gas4.helium)));
- ui.ostcGasTable->setItem(3, 3, new QTableWidgetItem(QString::number(deviceDetails->gas4.type)));
- ui.ostcGasTable->setItem(3, 4, new QTableWidgetItem(QString::number(deviceDetails->gas4.depth)));
-
- //load gas 5 values
- ui.ostcGasTable->setItem(4, 1, new QTableWidgetItem(QString::number(deviceDetails->gas5.oxygen)));
- ui.ostcGasTable->setItem(4, 2, new QTableWidgetItem(QString::number(deviceDetails->gas5.helium)));
- ui.ostcGasTable->setItem(4, 3, new QTableWidgetItem(QString::number(deviceDetails->gas5.type)));
- ui.ostcGasTable->setItem(4, 4, new QTableWidgetItem(QString::number(deviceDetails->gas5.depth)));
-
- //load dil 1 values
- ui.ostcDilTable->setItem(0, 1, new QTableWidgetItem(QString::number(deviceDetails->dil1.oxygen)));
- ui.ostcDilTable->setItem(0, 2, new QTableWidgetItem(QString::number(deviceDetails->dil1.helium)));
- ui.ostcDilTable->setItem(0, 3, new QTableWidgetItem(QString::number(deviceDetails->dil1.type)));
- ui.ostcDilTable->setItem(0, 4, new QTableWidgetItem(QString::number(deviceDetails->dil1.depth)));
-
- //load dil 2 values
- ui.ostcDilTable->setItem(1, 1, new QTableWidgetItem(QString::number(deviceDetails->dil2.oxygen)));
- ui.ostcDilTable->setItem(1, 2, new QTableWidgetItem(QString::number(deviceDetails->dil2.helium)));
- ui.ostcDilTable->setItem(1, 3, new QTableWidgetItem(QString::number(deviceDetails->dil2.type)));
- ui.ostcDilTable->setItem(1, 4, new QTableWidgetItem(QString::number(deviceDetails->dil2.depth)));
-
- //load dil 3 values
- ui.ostcDilTable->setItem(2, 1, new QTableWidgetItem(QString::number(deviceDetails->dil3.oxygen)));
- ui.ostcDilTable->setItem(2, 2, new QTableWidgetItem(QString::number(deviceDetails->dil3.helium)));
- ui.ostcDilTable->setItem(2, 3, new QTableWidgetItem(QString::number(deviceDetails->dil3.type)));
- ui.ostcDilTable->setItem(2, 4, new QTableWidgetItem(QString::number(deviceDetails->dil3.depth)));
-
- //load dil 4 values
- ui.ostcDilTable->setItem(3, 1, new QTableWidgetItem(QString::number(deviceDetails->dil4.oxygen)));
- ui.ostcDilTable->setItem(3, 2, new QTableWidgetItem(QString::number(deviceDetails->dil4.helium)));
- ui.ostcDilTable->setItem(3, 3, new QTableWidgetItem(QString::number(deviceDetails->dil4.type)));
- ui.ostcDilTable->setItem(3, 4, new QTableWidgetItem(QString::number(deviceDetails->dil4.depth)));
-
- //load dil 5 values
- ui.ostcDilTable->setItem(4, 1, new QTableWidgetItem(QString::number(deviceDetails->dil5.oxygen)));
- ui.ostcDilTable->setItem(4, 2, new QTableWidgetItem(QString::number(deviceDetails->dil5.helium)));
- ui.ostcDilTable->setItem(4, 3, new QTableWidgetItem(QString::number(deviceDetails->dil5.type)));
- ui.ostcDilTable->setItem(4, 4, new QTableWidgetItem(QString::number(deviceDetails->dil5.depth)));
-
- //load set point 1 values
- ui.ostcSetPointTable->setItem(0, 1, new QTableWidgetItem(QString::number(deviceDetails->sp1.sp)));
- ui.ostcSetPointTable->setItem(0, 2, new QTableWidgetItem(QString::number(deviceDetails->sp1.depth)));
-
- //load set point 2 values
- ui.ostcSetPointTable->setItem(1, 1, new QTableWidgetItem(QString::number(deviceDetails->sp2.sp)));
- ui.ostcSetPointTable->setItem(1, 2, new QTableWidgetItem(QString::number(deviceDetails->sp2.depth)));
-
- //load set point 3 values
- ui.ostcSetPointTable->setItem(2, 1, new QTableWidgetItem(QString::number(deviceDetails->sp3.sp)));
- ui.ostcSetPointTable->setItem(2, 2, new QTableWidgetItem(QString::number(deviceDetails->sp3.depth)));
-
- //load set point 4 values
- ui.ostcSetPointTable->setItem(3, 1, new QTableWidgetItem(QString::number(deviceDetails->sp4.sp)));
- ui.ostcSetPointTable->setItem(3, 2, new QTableWidgetItem(QString::number(deviceDetails->sp4.depth)));
-
- //load set point 5 values
- ui.ostcSetPointTable->setItem(4, 1, new QTableWidgetItem(QString::number(deviceDetails->sp5.sp)));
- ui.ostcSetPointTable->setItem(4, 2, new QTableWidgetItem(QString::number(deviceDetails->sp5.depth)));
-}
-
-void ConfigureDiveComputerDialog::reloadValuesSuuntoVyper()
-{
- const char *depth_unit;
- ui.maxDepthDoubleSpinBox->setValue(get_depth_units(deviceDetails->maxDepth, NULL, &depth_unit));
- ui.maxDepthDoubleSpinBox->setSuffix(depth_unit);
- ui.totalTimeSpinBox->setValue(deviceDetails->totalTime);
- ui.numberOfDivesSpinBox->setValue(deviceDetails->numberOfDives);
- ui.modelLineEdit_1->setText(deviceDetails->model);
- ui.firmwareVersionLineEdit_1->setText(deviceDetails->firmwareVersion);
- ui.serialNoLineEdit_1->setText(deviceDetails->serialNo);
- ui.customTextLlineEdit_1->setText(deviceDetails->customText);
- ui.samplingRateComboBox_1->setCurrentIndex(deviceDetails->samplingRate == 60 ? 3 : (deviceDetails->samplingRate / 10) - 1);
- ui.altitudeRangeComboBox->setCurrentIndex(deviceDetails->altitude);
- ui.personalSafetyComboBox->setCurrentIndex(deviceDetails->personalSafety);
- ui.timeFormatComboBox->setCurrentIndex(deviceDetails->timeFormat);
- ui.unitsComboBox_1->setCurrentIndex(deviceDetails->units);
- ui.diveModeComboBox_1->setCurrentIndex(deviceDetails->diveMode);
- ui.lightCheckBox->setChecked(deviceDetails->lightEnabled);
- ui.lightSpinBox->setValue(deviceDetails->light);
- ui.alarmDepthCheckBox->setChecked(deviceDetails->alarmDepthEnabled);
- ui.alarmDepthDoubleSpinBox->setValue(get_depth_units(deviceDetails->alarmDepth, NULL, &depth_unit));
- ui.alarmDepthDoubleSpinBox->setSuffix(depth_unit);
- ui.alarmTimeCheckBox->setChecked(deviceDetails->alarmTimeEnabled);
- ui.alarmTimeSpinBox->setValue(deviceDetails->alarmTime);
-}
-
-void ConfigureDiveComputerDialog::on_backupButton_clicked()
-{
- QString filename = existing_filename ?: prefs.default_filename;
- QFileInfo fi(filename);
- filename = fi.absolutePath().append(QDir::separator()).append("Backup.xml");
- QString backupPath = QFileDialog::getSaveFileName(this, tr("Backup dive computer settings"),
- filename, tr("Backup files (*.xml)"));
- if (!backupPath.isEmpty()) {
- populateDeviceDetails();
- if (!config->saveXMLBackup(backupPath, deviceDetails, &device_data)) {
- QMessageBox::critical(this, tr("XML backup error"),
- tr("An error occurred while saving the backup file.\n%1")
- .arg(config->lastError));
- } else {
- QMessageBox::information(this, tr("Backup succeeded"),
- tr("Your settings have been saved to: %1")
- .arg(backupPath));
- }
- }
-}
-
-void ConfigureDiveComputerDialog::on_restoreBackupButton_clicked()
-{
- QString filename = existing_filename ?: prefs.default_filename;
- QFileInfo fi(filename);
- filename = fi.absolutePath().append(QDir::separator()).append("Backup.xml");
- QString restorePath = QFileDialog::getOpenFileName(this, tr("Restore dive computer settings"),
- filename, tr("Backup files (*.xml)"));
- if (!restorePath.isEmpty()) {
- // Fw update is no longer a option, needs to be done on a untouched device
- ui.updateFirmwareButton->setEnabled(false);
- if (!config->restoreXMLBackup(restorePath, deviceDetails)) {
- QMessageBox::critical(this, tr("XML restore error"),
- tr("An error occurred while restoring the backup file.\n%1")
- .arg(config->lastError));
- } else {
- reloadValues();
- QMessageBox::information(this, tr("Restore succeeded"),
- tr("Your settings have been restored successfully."));
- }
- }
-}
-
-void ConfigureDiveComputerDialog::on_updateFirmwareButton_clicked()
-{
- QString filename = existing_filename ?: prefs.default_filename;
- QFileInfo fi(filename);
- filename = fi.absolutePath();
- QString firmwarePath = QFileDialog::getOpenFileName(this, tr("Select firmware file"),
- filename, tr("All files (*.*)"));
- if (!firmwarePath.isEmpty()) {
- ui.progressBar->setValue(0);
- ui.progressBar->setFormat("%p%");
- ui.progressBar->setTextVisible(true);
-
- config->startFirmwareUpdate(firmwarePath, &device_data);
- }
-}
-
-
-void ConfigureDiveComputerDialog::on_DiveComputerList_currentRowChanged(int currentRow)
-{
- switch (currentRow) {
- case 0:
- selected_vendor = "Heinrichs Weikamp";
- selected_product = "OSTC 3";
- fw_upgrade_possible = true;
- break;
- case 1:
- selected_vendor = "Suunto";
- selected_product = "Vyper";
- fw_upgrade_possible = false;
- break;
- case 2:
- selected_vendor = "Heinrichs Weikamp";
- selected_product = "OSTC 2N";
- fw_upgrade_possible = true;
- break;
- default:
- /* Not Supported */
- return;
- }
-
- int dcType = DC_TYPE_SERIAL;
-
-
- if (selected_vendor == QString("Uemis"))
- dcType = DC_TYPE_UEMIS;
- fill_device_list(dcType);
-}
-
-void ConfigureDiveComputerDialog::checkLogFile(int state)
-{
- ui.chooseLogFile->setEnabled(state == Qt::Checked);
- device_data.libdc_log = (state == Qt::Checked);
- if (state == Qt::Checked && logFile.isEmpty()) {
- pickLogFile();
- }
-}
-
-void ConfigureDiveComputerDialog::pickLogFile()
-{
- QString filename = existing_filename ?: prefs.default_filename;
- QFileInfo fi(filename);
- filename = fi.absolutePath().append(QDir::separator()).append("subsurface.log");
- logFile = QFileDialog::getSaveFileName(this, tr("Choose file for divecomputer download logfile"),
- filename, tr("Log files (*.log)"));
- if (!logFile.isEmpty()) {
- free(logfile_name);
- logfile_name = strdup(logFile.toUtf8().data());
- }
-}
-
-#ifdef BT_SUPPORT
-void ConfigureDiveComputerDialog::selectRemoteBluetoothDevice()
-{
- if (!btDeviceSelectionDialog) {
- btDeviceSelectionDialog = new BtDeviceSelectionDialog(this);
- connect(btDeviceSelectionDialog, SIGNAL(finished(int)),
- this, SLOT(bluetoothSelectionDialogIsFinished(int)));
- }
-
- btDeviceSelectionDialog->show();
-}
-
-void ConfigureDiveComputerDialog::bluetoothSelectionDialogIsFinished(int result)
-{
- if (result == QDialog::Accepted) {
- ui.device->setCurrentText(btDeviceSelectionDialog->getSelectedDeviceAddress());
- device_data.bluetooth_mode = true;
-
- ui.progressBar->setFormat("Connecting to device...");
- dc_open();
- }
-}
-#endif
-
-void ConfigureDiveComputerDialog::dc_open()
-{
- getDeviceData();
-
- QString err = config->dc_open(&device_data);
-
- if (err != "")
- return ui.progressBar->setFormat(err);
-
- ui.retrieveDetails->setEnabled(true);
- ui.resetButton->setEnabled(true);
- ui.updateFirmwareButton->setEnabled(true);
- ui.disconnectButton->setEnabled(true);
- ui.restoreBackupButton->setEnabled(true);
- ui.connectButton->setEnabled(false);
- ui.bluetoothMode->setEnabled(false);
- ui.DiveComputerList->setEnabled(false);
- ui.logToFile->setEnabled(false);
- if (fw_upgrade_possible)
- ui.updateFirmwareButton->setEnabled(true);
- ui.progressBar->setFormat("Connected to device");
-}
-
-void ConfigureDiveComputerDialog::dc_close()
-{
- config->dc_close(&device_data);
-
- ui.retrieveDetails->setEnabled(false);
- ui.resetButton->setEnabled(false);
- ui.updateFirmwareButton->setEnabled(false);
- ui.disconnectButton->setEnabled(false);
- ui.connectButton->setEnabled(true);
- ui.bluetoothMode->setEnabled(true);
- ui.backupButton->setEnabled(false);
- ui.saveSettingsPushButton->setEnabled(false);
- ui.restoreBackupButton->setEnabled(false);
- ui.DiveComputerList->setEnabled(true);
- ui.logToFile->setEnabled(true);
- ui.updateFirmwareButton->setEnabled(false);
- ui.progressBar->setFormat("Disonnected from device");
- ui.progressBar->setValue(0);
-}