From 3e127a059f598a30e9cfd71411783d71f40b315f Mon Sep 17 00:00:00 2001 From: "Joseph W. Joshua" Date: Fri, 30 May 2014 10:49:58 +0300 Subject: Create class to write settings to dive computer Adds a class to write settings to dive computer, and modifies the existing ones to integrate it. Signed-off-by: Joseph W. Joshua Signed-off-by: Thiago Macieira --- qt-ui/configuredivecomputer.cpp | 90 ++++++++++++++++++++++++++++++++++++++--- 1 file changed, 85 insertions(+), 5 deletions(-) (limited to 'qt-ui/configuredivecomputer.cpp') diff --git a/qt-ui/configuredivecomputer.cpp b/qt-ui/configuredivecomputer.cpp index d02ceffb7..fcd8fbc80 100644 --- a/qt-ui/configuredivecomputer.cpp +++ b/qt-ui/configuredivecomputer.cpp @@ -3,7 +3,8 @@ #include ConfigureDiveComputer::ConfigureDiveComputer(QObject *parent) : QObject(parent), - readThread(0) + readThread(0), + writeThread(0) { setState(INITIAL); } @@ -23,27 +24,55 @@ void ConfigureDiveComputer::readSettings(device_data_t *data) readThread->start(); } +void ConfigureDiveComputer::setDeviceName(device_data_t *data, QString newName) +{ + writeSettingToDevice(data, "Name", newName); +} + +void ConfigureDiveComputer::setDeviceDateAndTime(device_data_t *data, QDateTime dateAndTime) +{ + writeSettingToDevice(data, "DateAndTime", dateAndTime); +} + void ConfigureDiveComputer::setState(ConfigureDiveComputer::states newState) { currentState = newState; emit stateChanged(currentState); } +void ConfigureDiveComputer::writeSettingToDevice(device_data_t *data, QString settingName, QVariant settingValue) +{ + setState(READING); + + if (writeThread) + writeThread->deleteLater(); + + writeThread = new WriteSettingsThread(this, data, settingName, settingValue); + connect (writeThread, SIGNAL(error(QString)), this, SLOT(setError(QString))); + connect (writeThread, SIGNAL(finished()), this, SLOT(writeThreadFinished())); + + writeThread->start(); +} + void ConfigureDiveComputer::setError(QString err) { lastError = err; emit error(err); } -void ConfigureDiveComputer::readHWSettings(device_data_t *data) +void ConfigureDiveComputer::readThreadFinished() { - + setState(DONE); + emit deviceSettings(readThread->result); } -void ConfigureDiveComputer::readThreadFinished() +void ConfigureDiveComputer::writeThreadFinished() { setState(DONE); - emit deviceSettings(readThread->result); + if (writeThread->lastError.isEmpty()) { + //No error + emit message(tr("Setting successfully written to device")); + } } ReadSettingsThread::ReadSettingsThread(QObject *parent, device_data_t *data) @@ -72,3 +101,54 @@ void ReadSettingsThread::run() emit error(lastError); } } + +WriteSettingsThread::WriteSettingsThread(QObject *parent, device_data_t *data, QString settingName, QVariant settingValue) + : QThread(parent), data(data), m_settingName(settingName), m_settingValue(settingValue) +{ + +} + +void WriteSettingsThread::run() +{ + bool supported = false; + dc_status_t rc; + QString product = data->product; + QString vendor = data->vendor; + rc = dc_device_open(&data->device, data->context, data->descriptor, data->devname); + if (rc == DC_STATUS_SUCCESS) { + dc_status_t result; + if (product.trimmed() == "OSTC 3") { + if (m_settingName == "Name") { + supported = true; + result = hw_ostc3_device_customtext(data->device, m_settingValue.toByteArray().data()); + } + } + if (vendor.trimmed() == "Heinrichs Weikamp" && m_settingName == "DateAndTime") { + supported = true; + QDateTime timeToSet = m_settingValue.toDateTime(); + dc_datetime_t time; + time.year = timeToSet.date().year(); + time.month = timeToSet.date().month(); + time.day = timeToSet.date().day(); + time.hour = timeToSet.time().hour(); + time.minute = timeToSet.time().minute(); + time.second = timeToSet.time().second(); + result = hw_ostc_device_clock(data->device, &time); //Toto fix error here + } + if (result != DC_STATUS_SUCCESS) { + qDebug() << result; + lastError = tr("An error occurred while sending data to the dive computer."); + //Todo Update this message to change depending on actual result. + + emit error(lastError); + } + dc_device_close(data->device); + } else { + lastError = tr("Could not a establish connection to the dive computer."); + emit error(lastError); + } + if (!supported) { + lastError = tr("This feature is not yet available for the selected dive computer."); + emit error(lastError); + } +} -- cgit v1.2.3-70-g09d2