summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Anton Lundin <glance@acc.umu.se>2017-04-27 20:35:02 +0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2017-05-04 10:50:15 -0700
commit527763f306a34879d0a216f89da1befa9cbf8980 (patch)
treeafb50afb5a8b04f30204aa6bfcb7f294f73c895a
parent4cbf64bf99c7b47a9368f9f03399164b397c2ec8 (diff)
downloadsubsurface-527763f306a34879d0a216f89da1befa9cbf8980.tar.gz
Start to read/write and present some OSTC4 settings
This is mostly copy-paste from the ostc3 case, but there are some minor differences. Some minor things have different meaning, and there's a slightly different command set, but I couldn't figure out a sane way of joining them. Signed-off-by: Anton Lundin <glance@acc.umu.se>
-rw-r--r--core/configuredivecomputerthreads.cpp440
-rw-r--r--desktop-widgets/configuredivecomputerdialog.cpp270
2 files changed, 708 insertions, 2 deletions
diff --git a/core/configuredivecomputerthreads.cpp b/core/configuredivecomputerthreads.cpp
index cbd16611b..76890bbf7 100644
--- a/core/configuredivecomputerthreads.cpp
+++ b/core/configuredivecomputerthreads.cpp
@@ -363,23 +363,459 @@ static dc_status_t write_suunto_vyper_settings(dc_device_t *device, DeviceDetail
static dc_status_t read_ostc4_settings(dc_device_t *device, DeviceDetails *m_deviceDetails, dc_event_callback_t progress_cb, void *userdata)
{
+ // This code is really similar to the OSTC3 code, but there are minor
+ // differences in what the data means, and how to communicate with the
+ // device. If anyone can find a good way to harmonize the two, be my guest.
dc_status_t rc = DC_STATUS_SUCCESS;
dc_event_progress_t progress;
progress.current = 0;
- progress.maximum = 1;
+ progress.maximum = 19;
unsigned char hardware[1];
EMIT_PROGRESS();
+ //Read gas mixes
+ gas gas1;
+ gas gas2;
+ gas gas3;
+ gas gas4;
+ gas gas5;
+ unsigned char gasData[4] = { 0, 0, 0, 0 };
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_GAS1, gasData, sizeof(gasData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ gas1.oxygen = gasData[0];
+ gas1.helium = gasData[1];
+ gas1.type = gasData[2];
+ gas1.depth = gasData[3];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_GAS2, gasData, sizeof(gasData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ gas2.oxygen = gasData[0];
+ gas2.helium = gasData[1];
+ gas2.type = gasData[2];
+ gas2.depth = gasData[3];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_GAS3, gasData, sizeof(gasData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ gas3.oxygen = gasData[0];
+ gas3.helium = gasData[1];
+ gas3.type = gasData[2];
+ gas3.depth = gasData[3];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_GAS4, gasData, sizeof(gasData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ gas4.oxygen = gasData[0];
+ gas4.helium = gasData[1];
+ gas4.type = gasData[2];
+ gas4.depth = gasData[3];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_GAS5, gasData, sizeof(gasData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ gas5.oxygen = gasData[0];
+ gas5.helium = gasData[1];
+ gas5.type = gasData[2];
+ gas5.depth = gasData[3];
+ EMIT_PROGRESS();
+
+ m_deviceDetails->gas1 = gas1;
+ m_deviceDetails->gas2 = gas2;
+ m_deviceDetails->gas3 = gas3;
+ m_deviceDetails->gas4 = gas4;
+ m_deviceDetails->gas5 = gas5;
+ EMIT_PROGRESS();
+
+ //Read Dil Values
+ gas dil1;
+ gas dil2;
+ gas dil3;
+ gas dil4;
+ gas dil5;
+ unsigned char dilData[4] = { 0, 0, 0, 0 };
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_DIL1, dilData, sizeof(dilData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ dil1.oxygen = dilData[0];
+ dil1.helium = dilData[1];
+ dil1.type = dilData[2];
+ dil1.depth = dilData[3];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_DIL2, dilData, sizeof(dilData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ dil2.oxygen = dilData[0];
+ dil2.helium = dilData[1];
+ dil2.type = dilData[2];
+ dil2.depth = dilData[3];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_DIL3, dilData, sizeof(dilData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ dil3.oxygen = dilData[0];
+ dil3.helium = dilData[1];
+ dil3.type = dilData[2];
+ dil3.depth = dilData[3];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_DIL4, dilData, sizeof(dilData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ dil4.oxygen = dilData[0];
+ dil4.helium = dilData[1];
+ dil4.type = dilData[2];
+ dil4.depth = dilData[3];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_DIL5, dilData, sizeof(dilData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ dil5.oxygen = dilData[0];
+ dil5.helium = dilData[1];
+ dil5.type = dilData[2];
+ dil5.depth = dilData[3];
+ EMIT_PROGRESS();
+
+ m_deviceDetails->dil1 = dil1;
+ m_deviceDetails->dil2 = dil2;
+ m_deviceDetails->dil3 = dil3;
+ m_deviceDetails->dil4 = dil4;
+ m_deviceDetails->dil5 = dil5;
+
+ //Read setpoint Values
+ setpoint sp1;
+ setpoint sp2;
+ setpoint sp3;
+ setpoint sp4;
+ setpoint sp5;
+ unsigned char spData[4] = { 0, 0, 0, 0};
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_SP1, spData, sizeof(spData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ sp1.sp = spData[0];
+ sp1.depth = spData[1];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_SP2, spData, sizeof(spData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ sp2.sp = spData[0];
+ sp2.depth = spData[1];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_SP3, spData, sizeof(spData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ sp3.sp = spData[0];
+ sp3.depth = spData[1];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_SP4, spData, sizeof(spData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ sp4.sp = spData[0];
+ sp4.depth = spData[1];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_SP5, spData, sizeof(spData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ sp5.sp = spData[0];
+ sp5.depth = spData[1];
+ EMIT_PROGRESS();
+
+ m_deviceDetails->sp1 = sp1;
+ m_deviceDetails->sp2 = sp2;
+ m_deviceDetails->sp3 = sp3;
+ m_deviceDetails->sp4 = sp4;
+ m_deviceDetails->sp5 = sp5;
+
+ //Read other settings
+ unsigned char uData[4] = { 0 };
+
+#define READ_SETTING(_OSTC4_SETTING, _DEVICE_DETAIL) \
+ do { \
+ rc = hw_ostc3_device_config_read(device, _OSTC4_SETTING, uData, sizeof(uData)); \
+ if (rc != DC_STATUS_SUCCESS) \
+ return rc; \
+ m_deviceDetails->_DEVICE_DETAIL = uData[0]; \
+ EMIT_PROGRESS(); \
+ } while (0)
+
+#undef READ_SETTING
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_PRESSURE_SENSOR_OFFSET, uData, sizeof(uData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ // OSTC3 stores the pressureSensorOffset in two-complement
+ m_deviceDetails->pressureSensorOffset = (signed char)uData[0];
+ EMIT_PROGRESS();
+
+ rc = hw_ostc3_device_config_read(device, OSTC3_TEMP_SENSOR_OFFSET, uData, sizeof(uData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ // OSTC3 stores the tempSensorOffset in two-complement
+ m_deviceDetails->tempSensorOffset = (signed char)uData[0];
+ EMIT_PROGRESS();
+
+ //read firmware settings
+ unsigned char fData[64] = { 0 };
+ rc = hw_ostc3_device_version(device, fData, sizeof(fData));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ int serial = fData[0] + (fData[1] << 8);
+ m_deviceDetails->serialNo = QString::number(serial);
+ unsigned char X, Y, Z, beta;
+ unsigned int firmwareOnDevice = (fData[3] << 8) + fData[2];
+ X = (firmwareOnDevice & 0xF800) >> 11;
+ Y = (firmwareOnDevice & 0x07C0) >> 6;
+ Z = (firmwareOnDevice & 0x003E) >> 1;
+ beta = firmwareOnDevice & 0x0001;
+ m_deviceDetails->firmwareVersion = QString("%1.%2.%3%4").arg(X).arg(Y).arg(Z).arg(beta?" beta":"");
+ QByteArray ar((char *)fData + 4, 60);
+ m_deviceDetails->customText = ar.trimmed();
+ EMIT_PROGRESS();
+
return rc;
}
static dc_status_t write_ostc4_settings(dc_device_t *device, DeviceDetails *m_deviceDetails, dc_event_callback_t progress_cb, void *userdata)
{
+ // This code is really similar to the OSTC3 code, but there are minor
+ // differences in what the data means, and how to communicate with the
+ // device. If anyone can find a good way to harmonize the two, be my guest.
dc_status_t rc = DC_STATUS_SUCCESS;
dc_event_progress_t progress;
progress.current = 0;
- progress.maximum = 1;
+ progress.maximum = 18;
+
+ //write gas values
+ unsigned char gas1Data[4] = {
+ m_deviceDetails->gas1.oxygen,
+ m_deviceDetails->gas1.helium,
+ m_deviceDetails->gas1.type,
+ m_deviceDetails->gas1.depth
+ };
+
+ unsigned char gas2Data[4] = {
+ m_deviceDetails->gas2.oxygen,
+ m_deviceDetails->gas2.helium,
+ m_deviceDetails->gas2.type,
+ m_deviceDetails->gas2.depth
+ };
+
+ unsigned char gas3Data[4] = {
+ m_deviceDetails->gas3.oxygen,
+ m_deviceDetails->gas3.helium,
+ m_deviceDetails->gas3.type,
+ m_deviceDetails->gas3.depth
+ };
+
+ unsigned char gas4Data[4] = {
+ m_deviceDetails->gas4.oxygen,
+ m_deviceDetails->gas4.helium,
+ m_deviceDetails->gas4.type,
+ m_deviceDetails->gas4.depth
+ };
+
+ unsigned char gas5Data[4] = {
+ m_deviceDetails->gas5.oxygen,
+ m_deviceDetails->gas5.helium,
+ m_deviceDetails->gas5.type,
+ m_deviceDetails->gas5.depth
+ };
+ //gas 1
+ rc = hw_ostc3_device_config_write(device, OSTC3_GAS1, gas1Data, sizeof(gas1Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+ //gas 2
+ rc = hw_ostc3_device_config_write(device, OSTC3_GAS2, gas2Data, sizeof(gas2Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+ //gas 3
+ rc = hw_ostc3_device_config_write(device, OSTC3_GAS3, gas3Data, sizeof(gas3Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+ //gas 4
+ rc = hw_ostc3_device_config_write(device, OSTC3_GAS4, gas4Data, sizeof(gas4Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+ //gas 5
+ rc = hw_ostc3_device_config_write(device, OSTC3_GAS5, gas5Data, sizeof(gas5Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+
+ //write setpoint values
+ unsigned char sp1Data[4] = {
+ m_deviceDetails->sp1.sp,
+ m_deviceDetails->sp1.depth
+ };
+
+ unsigned char sp2Data[4] = {
+ m_deviceDetails->sp2.sp,
+ m_deviceDetails->sp2.depth
+ };
+
+ unsigned char sp3Data[4] = {
+ m_deviceDetails->sp3.sp,
+ m_deviceDetails->sp3.depth
+ };
+
+ unsigned char sp4Data[4] = {
+ m_deviceDetails->sp4.sp,
+ m_deviceDetails->sp4.depth
+ };
+
+ unsigned char sp5Data[4] = {
+ m_deviceDetails->sp5.sp,
+ m_deviceDetails->sp5.depth
+ };
+
+ //sp 1
+ rc = hw_ostc3_device_config_write(device, OSTC3_SP1, sp1Data, sizeof(sp1Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+ //sp 2
+ rc = hw_ostc3_device_config_write(device, OSTC3_SP2, sp2Data, sizeof(sp2Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+ //sp 3
+ rc = hw_ostc3_device_config_write(device, OSTC3_SP3, sp3Data, sizeof(sp3Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+ //sp 4
+ rc = hw_ostc3_device_config_write(device, OSTC3_SP4, sp4Data, sizeof(sp4Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+ //sp 5
+ rc = hw_ostc3_device_config_write(device, OSTC3_SP5, sp5Data, sizeof(sp5Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+
+ //write dil values
+ unsigned char dil1Data[4] = {
+ m_deviceDetails->dil1.oxygen,
+ m_deviceDetails->dil1.helium,
+ m_deviceDetails->dil1.type,
+ m_deviceDetails->dil1.depth
+ };
+
+ unsigned char dil2Data[4] = {
+ m_deviceDetails->dil2.oxygen,
+ m_deviceDetails->dil2.helium,
+ m_deviceDetails->dil2.type,
+ m_deviceDetails->dil2.depth
+ };
+
+ unsigned char dil3Data[4] = {
+ m_deviceDetails->dil3.oxygen,
+ m_deviceDetails->dil3.helium,
+ m_deviceDetails->dil3.type,
+ m_deviceDetails->dil3.depth
+ };
+
+ unsigned char dil4Data[4] = {
+ m_deviceDetails->dil4.oxygen,
+ m_deviceDetails->dil4.helium,
+ m_deviceDetails->dil4.type,
+ m_deviceDetails->dil4.depth
+ };
+
+ unsigned char dil5Data[4] = {
+ m_deviceDetails->dil5.oxygen,
+ m_deviceDetails->dil5.helium,
+ m_deviceDetails->dil5.type,
+ m_deviceDetails->dil5.depth
+ };
+ //dil 1
+ rc = hw_ostc3_device_config_write(device, OSTC3_DIL1, dil1Data, sizeof(gas1Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+ //dil 2
+ rc = hw_ostc3_device_config_write(device, OSTC3_DIL2, dil2Data, sizeof(dil2Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+ //dil 3
+ rc = hw_ostc3_device_config_write(device, OSTC3_DIL3, dil3Data, sizeof(dil3Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+ //dil 4
+ rc = hw_ostc3_device_config_write(device, OSTC3_DIL4, dil4Data, sizeof(dil4Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+ //dil 5
+ rc = hw_ostc3_device_config_write(device, OSTC3_DIL5, dil5Data, sizeof(dil5Data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+
+ //write general settings
+ //custom text
+ rc = hw_ostc3_device_customtext(device, m_deviceDetails->customText.toUtf8().data());
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+
+ unsigned char data[4] = { 0 };
+#define WRITE_SETTING(_OSTC4_SETTING, _DEVICE_DETAIL) \
+ do { \
+ data[0] = m_deviceDetails->_DEVICE_DETAIL; \
+ rc = hw_ostc3_device_config_write(device, _OSTC4_SETTING, data, sizeof(data)); \
+ if (rc != DC_STATUS_SUCCESS) \
+ return rc; \
+ EMIT_PROGRESS(); \
+ } while (0)
+
+#undef WRITE_SETTING
+
+ // OSTC3 stores the pressureSensorOffset in two-complement
+ data[0] = (unsigned char)m_deviceDetails->pressureSensorOffset;
+ rc = hw_ostc3_device_config_write(device, OSTC3_PRESSURE_SENSOR_OFFSET, data, sizeof(data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+
+ // OSTC3 stores the tempSensorOffset in two-complement
+ data[0] = (unsigned char)m_deviceDetails->tempSensorOffset;
+ rc = hw_ostc3_device_config_write(device, OSTC3_TEMP_SENSOR_OFFSET, data, sizeof(data));
+ if (rc != DC_STATUS_SUCCESS)
+ return rc;
+ EMIT_PROGRESS();
+
+
+ //sync date and time
+ if (m_deviceDetails->syncTime) {
+ dc_datetime_t now;
+ dc_datetime_localtime(&now, dc_datetime_now());
+
+ rc = hw_ostc3_device_clock(device, &now);
+ }
EMIT_PROGRESS();
diff --git a/desktop-widgets/configuredivecomputerdialog.cpp b/desktop-widgets/configuredivecomputerdialog.cpp
index 57f4451e7..551bc1f91 100644
--- a/desktop-widgets/configuredivecomputerdialog.cpp
+++ b/desktop-widgets/configuredivecomputerdialog.cpp
@@ -790,6 +790,152 @@ void ConfigureDiveComputerDialog::populateDeviceDetailsSuuntoVyper()
void ConfigureDiveComputerDialog::populateDeviceDetailsOSTC4()
{
+ deviceDetails->customText = ui.customTextLlineEdit_4->text();
+ deviceDetails->diveMode = ui.diveModeComboBox_4->currentIndex();
+ deviceDetails->saturation = ui.saturationSpinBox_4->value();
+ deviceDetails->desaturation = ui.desaturationSpinBox_4->value();
+ deviceDetails->lastDeco = ui.lastDecoSpinBox_4->value();
+ deviceDetails->brightness = ui.brightnessComboBox_4->currentIndex();
+ deviceDetails->units = ui.unitsComboBox_4->currentIndex();
+ deviceDetails->samplingRate = ui.samplingRateComboBox_4->currentIndex();
+ deviceDetails->salinity = ui.salinitySpinBox_4->value();
+ deviceDetails->diveModeColor = ui.diveModeColour_4->currentIndex();
+ deviceDetails->language = ui.languageComboBox_4->currentIndex();
+ deviceDetails->dateFormat = ui.dateFormatComboBox_4->currentIndex();
+ deviceDetails->compassGain = ui.compassGainComboBox_4->currentIndex();
+ deviceDetails->syncTime = ui.dateTimeSyncCheckBox_4->isChecked();
+ deviceDetails->safetyStop = ui.safetyStopCheckBox_4->isChecked();
+ deviceDetails->gfHigh = ui.gfHighSpinBox_4->value();
+ deviceDetails->gfLow = ui.gfLowSpinBox_4->value();
+ deviceDetails->pressureSensorOffset = ui.pressureSensorOffsetSpinBox_4->value();
+ deviceDetails->ppO2Min = ui.ppO2MinSpinBox_4->value();
+ deviceDetails->ppO2Max = ui.ppO2MaxSpinBox_4->value();
+ deviceDetails->futureTTS = ui.futureTTSSpinBox_4->value();
+ deviceDetails->ccrMode = ui.ccrModeComboBox_4->currentIndex();
+ deviceDetails->decoType = ui.decoTypeComboBox_4->currentIndex();
+ deviceDetails->aGFSelectable = ui.aGFSelectableCheckBox_4->isChecked();
+ deviceDetails->aGFHigh = ui.aGFHighSpinBox_4->value();
+ deviceDetails->aGFLow = ui.aGFLowSpinBox_4->value();
+ deviceDetails->calibrationGas = ui.calibrationGasSpinBox_4->value();
+ deviceDetails->flipScreen = ui.flipScreenCheckBox_4->isChecked();
+ deviceDetails->setPointFallback = ui.setPointFallbackCheckBox_4->isChecked();
+ deviceDetails->leftButtonSensitivity = ui.leftButtonSensitivity_4->value();
+ deviceDetails->rightButtonSensitivity = ui.rightButtonSensitivity_4->value();
+ deviceDetails->bottomGasConsumption = ui.bottomGasConsumption_4->value();
+ deviceDetails->decoGasConsumption = ui.decoGasConsumption_4->value();
+ deviceDetails->modWarning = ui.modWarning_4->isChecked();
+ deviceDetails->dynamicAscendRate = ui.dynamicAscendRate_4->isChecked();
+ deviceDetails->graphicalSpeedIndicator = ui.graphicalSpeedIndicator_4->isChecked();
+ deviceDetails->alwaysShowppO2 = ui.alwaysShowppO2_4->isChecked();
+ deviceDetails->tempSensorOffset = lrint(ui.tempSensorOffsetDoubleSpinBox_4->value() * 10);
+ deviceDetails->safetyStopLength = ui.safetyStopLengthSpinBox_4->value();
+ deviceDetails->safetyStopStartDepth = lrint(ui.safetyStopStartDepthDoubleSpinBox_4->value() * 10);
+ deviceDetails->safetyStopEndDepth = lrint(ui.safetyStopEndDepthDoubleSpinBox_4->value() * 10);
+ deviceDetails->safetyStopResetDepth = lrint(ui.safetyStopResetDepthDoubleSpinBox_4->value() * 10);
+
+ //set gas values
+ gas gas1;
+ gas gas2;
+ gas gas3;
+ gas gas4;
+ gas gas5;
+
+ gas1.oxygen = GET_INT_FROM(ui.ostc4GasTable->item(0, 1), 21);
+ gas1.helium = GET_INT_FROM(ui.ostc4GasTable->item(0, 2), 0);
+ gas1.type = GET_INT_FROM(ui.ostc4GasTable->item(0, 3), 0);
+ gas1.depth = GET_INT_FROM(ui.ostc4GasTable->item(0, 4), 0);
+
+ gas2.oxygen = GET_INT_FROM(ui.ostc4GasTable->item(1, 1), 21);
+ gas2.helium = GET_INT_FROM(ui.ostc4GasTable->item(1, 2), 0);
+ gas2.type = GET_INT_FROM(ui.ostc4GasTable->item(1, 3), 0);
+ gas2.depth = GET_INT_FROM(ui.ostc4GasTable->item(1, 4), 0);
+
+ gas3.oxygen = GET_INT_FROM(ui.ostc4GasTable->item(2, 1), 21);
+ gas3.helium = GET_INT_FROM(ui.ostc4GasTable->item(2, 2), 0);
+ gas3.type = GET_INT_FROM(ui.ostc4GasTable->item(2, 3), 0);
+ gas3.depth = GET_INT_FROM(ui.ostc4GasTable->item(2, 4), 0);
+
+ gas4.oxygen = GET_INT_FROM(ui.ostc4GasTable->item(3, 1), 21);
+ gas4.helium = GET_INT_FROM(ui.ostc4GasTable->item(3, 2), 0);
+ gas4.type = GET_INT_FROM(ui.ostc4GasTable->item(3, 3), 0);
+ gas4.depth = GET_INT_FROM(ui.ostc4GasTable->item(3, 4), 0);
+
+ gas5.oxygen = GET_INT_FROM(ui.ostc4GasTable->item(4, 1), 21);
+ gas5.helium = GET_INT_FROM(ui.ostc4GasTable->item(4, 2), 0);
+ gas5.type = GET_INT_FROM(ui.ostc4GasTable->item(4, 3), 0);
+ gas5.depth = GET_INT_FROM(ui.ostc4GasTable->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.ostc4DilTable->item(0, 1), 21);
+ dil1.helium = GET_INT_FROM(ui.ostc4DilTable->item(0, 2), 0);
+ dil1.type = GET_INT_FROM(ui.ostc4DilTable->item(0, 3), 0);
+ dil1.depth = GET_INT_FROM(ui.ostc4DilTable->item(0, 4), 0);
+
+ dil2.oxygen = GET_INT_FROM(ui.ostc4DilTable->item(1, 1), 21);
+ dil2.helium = GET_INT_FROM(ui.ostc4DilTable->item(1, 2), 0);
+ dil2.type = GET_INT_FROM(ui.ostc4DilTable->item(1, 3), 0);
+ dil2.depth = GET_INT_FROM(ui.ostc4DilTable->item(1, 4), 0);
+
+ dil3.oxygen = GET_INT_FROM(ui.ostc4DilTable->item(2, 1), 21);
+ dil3.helium = GET_INT_FROM(ui.ostc4DilTable->item(2, 2), 0);
+ dil3.type = GET_INT_FROM(ui.ostc4DilTable->item(2, 4), 0);
+ dil3.depth = GET_INT_FROM(ui.ostc4DilTable->item(2, 4), 0);
+
+ dil4.oxygen = GET_INT_FROM(ui.ostc4DilTable->item(3, 1), 21);
+ dil4.helium = GET_INT_FROM(ui.ostc4DilTable->item(3, 2), 0);
+ dil4.type = GET_INT_FROM(ui.ostc4DilTable->item(3, 3), 0);
+ dil4.depth = GET_INT_FROM(ui.ostc4DilTable->item(3, 4), 0);
+
+ dil5.oxygen = GET_INT_FROM(ui.ostc4DilTable->item(4, 1), 21);
+ dil5.helium = GET_INT_FROM(ui.ostc4DilTable->item(4, 2), 0);
+ dil5.type = GET_INT_FROM(ui.ostc4DilTable->item(4, 3), 0);
+ dil5.depth = GET_INT_FROM(ui.ostc4DilTable->item(4, 4), 0);
+
+ deviceDetails->dil1 = dil1;
+ deviceDetails->dil2 = dil2;
+ deviceDetails->dil3 = dil3;
+ deviceDetails->dil4 = dil4;
+ deviceDetails->dil5 = dil5;
+
+ //set setpoint details
+ setpoint sp1;
+ setpoint sp2;
+ setpoint sp3;
+ setpoint sp4;
+ setpoint sp5;
+
+ sp1.sp = GET_INT_FROM(ui.ostc4SetPointTable->item(0, 1), 70);
+ sp1.depth = GET_INT_FROM(ui.ostc4SetPointTable->item(0, 2), 0);
+
+ sp2.sp = GET_INT_FROM(ui.ostc4SetPointTable->item(1, 1), 90);
+ sp2.depth = GET_INT_FROM(ui.ostc4SetPointTable->item(1, 2), 20);
+
+ sp3.sp = GET_INT_FROM(ui.ostc4SetPointTable->item(2, 1), 100);
+ sp3.depth = GET_INT_FROM(ui.ostc4SetPointTable->item(2, 2), 44);
+
+ sp4.sp = GET_INT_FROM(ui.ostc4SetPointTable->item(3, 1), 120);
+ sp4.depth = GET_INT_FROM(ui.ostc4SetPointTable->item(3, 2), 50);
+
+ sp5.sp = GET_INT_FROM(ui.ostc4SetPointTable->item(4, 1), 140);
+ sp5.depth = GET_INT_FROM(ui.ostc4SetPointTable->item(4, 2), 70);
+
+ deviceDetails->sp1 = sp1;
+ deviceDetails->sp2 = sp2;
+ deviceDetails->sp3 = sp3;
+ deviceDetails->sp4 = sp4;
+ deviceDetails->sp5 = sp5;
}
void ConfigureDiveComputerDialog::readSettings()
@@ -1161,6 +1307,130 @@ void ConfigureDiveComputerDialog::reloadValuesSuuntoVyper()
void ConfigureDiveComputerDialog::reloadValuesOSTC4()
{
+ ui.serialNoLineEdit_4->setText(deviceDetails->serialNo);
+ ui.firmwareVersionLineEdit_4->setText(deviceDetails->firmwareVersion);
+ ui.customTextLlineEdit_4->setText(deviceDetails->customText);
+ ui.modelLineEdit_4->setText(deviceDetails->model);
+ ui.diveModeComboBox_4->setCurrentIndex(deviceDetails->diveMode);
+ ui.saturationSpinBox_4->setValue(deviceDetails->saturation);
+ ui.desaturationSpinBox_4->setValue(deviceDetails->desaturation);
+ ui.lastDecoSpinBox_4->setValue(deviceDetails->lastDeco);
+ ui.brightnessComboBox_4->setCurrentIndex(deviceDetails->brightness);
+ ui.unitsComboBox_4->setCurrentIndex(deviceDetails->units);
+ ui.samplingRateComboBox_4->setCurrentIndex(deviceDetails->samplingRate);
+ ui.salinitySpinBox_4->setValue(deviceDetails->salinity);
+ ui.diveModeColour_4->setCurrentIndex(deviceDetails->diveModeColor);
+ ui.languageComboBox_4->setCurrentIndex(deviceDetails->language);
+ ui.dateFormatComboBox_4->setCurrentIndex(deviceDetails->dateFormat);
+ ui.compassGainComboBox_4->setCurrentIndex(deviceDetails->compassGain);
+ ui.safetyStopCheckBox_4->setChecked(deviceDetails->safetyStop);
+ ui.gfHighSpinBox_4->setValue(deviceDetails->gfHigh);
+ ui.gfLowSpinBox_4->setValue(deviceDetails->gfLow);
+ ui.pressureSensorOffsetSpinBox_4->setValue(deviceDetails->pressureSensorOffset);
+ ui.ppO2MinSpinBox_4->setValue(deviceDetails->ppO2Min);
+ ui.ppO2MaxSpinBox_4->setValue(deviceDetails->ppO2Max);
+ ui.futureTTSSpinBox_4->setValue(deviceDetails->futureTTS);
+ ui.ccrModeComboBox_4->setCurrentIndex(deviceDetails->ccrMode);
+ ui.decoTypeComboBox_4->setCurrentIndex(deviceDetails->decoType);
+ ui.aGFSelectableCheckBox_4->setChecked(deviceDetails->aGFSelectable);
+ ui.aGFHighSpinBox_4->setValue(deviceDetails->aGFHigh);
+ ui.aGFLowSpinBox_4->setValue(deviceDetails->aGFLow);
+ ui.calibrationGasSpinBox_4->setValue(deviceDetails->calibrationGas);
+ ui.flipScreenCheckBox_4->setChecked(deviceDetails->flipScreen);
+ ui.setPointFallbackCheckBox_4->setChecked(deviceDetails->setPointFallback);
+ ui.leftButtonSensitivity_4->setValue(deviceDetails->leftButtonSensitivity);
+ ui.rightButtonSensitivity_4->setValue(deviceDetails->rightButtonSensitivity);
+ ui.bottomGasConsumption_4->setValue(deviceDetails->bottomGasConsumption);
+ ui.decoGasConsumption_4->setValue(deviceDetails->decoGasConsumption);
+ ui.modWarning_4->setChecked(deviceDetails->modWarning);
+ ui.dynamicAscendRate_4->setChecked(deviceDetails->dynamicAscendRate);
+ ui.graphicalSpeedIndicator_4->setChecked(deviceDetails->graphicalSpeedIndicator);
+ ui.alwaysShowppO2_4->setChecked(deviceDetails->alwaysShowppO2);
+ ui.tempSensorOffsetDoubleSpinBox_4->setValue((double)deviceDetails->tempSensorOffset / 10.0);
+ ui.safetyStopLengthSpinBox_4->setValue(deviceDetails->safetyStopLength);
+ ui.safetyStopStartDepthDoubleSpinBox_4->setValue(deviceDetails->safetyStopStartDepth / 10.0);
+ ui.safetyStopEndDepthDoubleSpinBox_4->setValue(deviceDetails->safetyStopEndDepth / 10.0);
+ ui.safetyStopResetDepthDoubleSpinBox_4->setValue(deviceDetails->safetyStopResetDepth / 10.0);
+
+ //load gas 1 values
+ ui.ostc4GasTable->setItem(0, 1, new QTableWidgetItem(QString::number(deviceDetails->gas1.oxygen)));
+ ui.ostc4GasTable->setItem(0, 2, new QTableWidgetItem(QString::number(deviceDetails->gas1.helium)));
+ ui.ostc4GasTable->setItem(0, 3, new QTableWidgetItem(QString::number(deviceDetails->gas1.type)));
+ ui.ostc4GasTable->setItem(0, 4, new QTableWidgetItem(QString::number(deviceDetails->gas1.depth)));
+
+ //load gas 2 values
+ ui.ostc4GasTable->setItem(1, 1, new QTableWidgetItem(QString::number(deviceDetails->gas2.oxygen)));
+ ui.ostc4GasTable->setItem(1, 2, new QTableWidgetItem(QString::number(deviceDetails->gas2.helium)));
+ ui.ostc4GasTable->setItem(1, 3, new QTableWidgetItem(QString::number(deviceDetails->gas2.type)));
+ ui.ostc4GasTable->setItem(1, 4, new QTableWidgetItem(QString::number(deviceDetails->gas2.depth)));
+
+ //load gas 3 values
+ ui.ostc4GasTable->setItem(2, 1, new QTableWidgetItem(QString::number(deviceDetails->gas3.oxygen)));
+ ui.ostc4GasTable->setItem(2, 2, new QTableWidgetItem(QString::number(deviceDetails->gas3.helium)));
+ ui.ostc4GasTable->setItem(2, 3, new QTableWidgetItem(QString::number(deviceDetails->gas3.type)));
+ ui.ostc4GasTable->setItem(2, 4, new QTableWidgetItem(QString::number(deviceDetails->gas3.depth)));
+
+ //load gas 4 values
+ ui.ostc4GasTable->setItem(3, 1, new QTableWidgetItem(QString::number(deviceDetails->gas4.oxygen)));
+ ui.ostc4GasTable->setItem(3, 2, new QTableWidgetItem(QString::number(deviceDetails->gas4.helium)));
+ ui.ostc4GasTable->setItem(3, 3, new QTableWidgetItem(QString::number(deviceDetails->gas4.type)));
+ ui.ostc4GasTable->setItem(3, 4, new QTableWidgetItem(QString::number(deviceDetails->gas4.depth)));
+
+ //load gas 5 values
+ ui.ostc4GasTable->setItem(4, 1, new QTableWidgetItem(QString::number(deviceDetails->gas5.oxygen)));
+ ui.ostc4GasTable->setItem(4, 2, new QTableWidgetItem(QString::number(deviceDetails->gas5.helium)));
+ ui.ostc4GasTable->setItem(4, 3, new QTableWidgetItem(QString::number(deviceDetails->gas5.type)));
+ ui.ostc4GasTable->setItem(4, 4, new QTableWidgetItem(QString::number(deviceDetails->gas5.depth)));
+
+ //load dil 1 values
+ ui.ostc4DilTable->setItem(0, 1, new QTableWidgetItem(QString::number(deviceDetails->dil1.oxygen)));
+ ui.ostc4DilTable->setItem(0, 2, new QTableWidgetItem(QString::number(deviceDetails->dil1.helium)));
+ ui.ostc4DilTable->setItem(0, 3, new QTableWidgetItem(QString::number(deviceDetails->dil1.type)));
+ ui.ostc4DilTable->setItem(0, 4, new QTableWidgetItem(QString::number(deviceDetails->dil1.depth)));
+
+ //load dil 2 values
+ ui.ostc4DilTable->setItem(1, 1, new QTableWidgetItem(QString::number(deviceDetails->dil2.oxygen)));
+ ui.ostc4DilTable->setItem(1, 2, new QTableWidgetItem(QString::number(deviceDetails->dil2.helium)));
+ ui.ostc4DilTable->setItem(1, 3, new QTableWidgetItem(QString::number(deviceDetails->dil2.type)));
+ ui.ostc4DilTable->setItem(1, 4, new QTableWidgetItem(QString::number(deviceDetails->dil2.depth)));
+
+ //load dil 3 values
+ ui.ostc4DilTable->setItem(2, 1, new QTableWidgetItem(QString::number(deviceDetails->dil3.oxygen)));
+ ui.ostc4DilTable->setItem(2, 2, new QTableWidgetItem(QString::number(deviceDetails->dil3.helium)));
+ ui.ostc4DilTable->setItem(2, 3, new QTableWidgetItem(QString::number(deviceDetails->dil3.type)));
+ ui.ostc4DilTable->setItem(2, 4, new QTableWidgetItem(QString::number(deviceDetails->dil3.depth)));
+
+ //load dil 4 values
+ ui.ostc4DilTable->setItem(3, 1, new QTableWidgetItem(QString::number(deviceDetails->dil4.oxygen)));
+ ui.ostc4DilTable->setItem(3, 2, new QTableWidgetItem(QString::number(deviceDetails->dil4.helium)));
+ ui.ostc4DilTable->setItem(3, 3, new QTableWidgetItem(QString::number(deviceDetails->dil4.type)));
+ ui.ostc4DilTable->setItem(3, 4, new QTableWidgetItem(QString::number(deviceDetails->dil4.depth)));
+
+ //load dil 5 values
+ ui.ostc4DilTable->setItem(4, 1, new QTableWidgetItem(QString::number(deviceDetails->dil5.oxygen)));
+ ui.ostc4DilTable->setItem(4, 2, new QTableWidgetItem(QString::number(deviceDetails->dil5.helium)));
+ ui.ostc4DilTable->setItem(4, 3, new QTableWidgetItem(QString::number(deviceDetails->dil5.type)));
+ ui.ostc4DilTable->setItem(4, 4, new QTableWidgetItem(QString::number(deviceDetails->dil5.depth)));
+
+ //load setpoint 1 values
+ ui.ostc4SetPointTable->setItem(0, 1, new QTableWidgetItem(QString::number(deviceDetails->sp1.sp)));
+ ui.ostc4SetPointTable->setItem(0, 2, new QTableWidgetItem(QString::number(deviceDetails->sp1.depth)));
+
+ //load setpoint 2 values
+ ui.ostc4SetPointTable->setItem(1, 1, new QTableWidgetItem(QString::number(deviceDetails->sp2.sp)));
+ ui.ostc4SetPointTable->setItem(1, 2, new QTableWidgetItem(QString::number(deviceDetails->sp2.depth)));
+
+ //load setpoint 4 values
+ ui.ostc4SetPointTable->setItem(2, 1, new QTableWidgetItem(QString::number(deviceDetails->sp3.sp)));
+ ui.ostc4SetPointTable->setItem(2, 2, new QTableWidgetItem(QString::number(deviceDetails->sp3.depth)));
+
+ //load setpoint 4 values
+ ui.ostc4SetPointTable->setItem(3, 1, new QTableWidgetItem(QString::number(deviceDetails->sp4.sp)));
+ ui.ostc4SetPointTable->setItem(3, 2, new QTableWidgetItem(QString::number(deviceDetails->sp4.depth)));
+
+ //load setpoint 5 values
+ ui.ostc4SetPointTable->setItem(4, 1, new QTableWidgetItem(QString::number(deviceDetails->sp5.sp)));
+ ui.ostc4SetPointTable->setItem(4, 2, new QTableWidgetItem(QString::number(deviceDetails->sp5.depth)));
}
void ConfigureDiveComputerDialog::on_backupButton_clicked()