mirror of
				https://github.com/subsurface/subsurface.git
				synced 2025-02-19 22:16:15 +00:00 
			
		
		
		
	Polish up on classes
This patch polishes up on all classes added for dive computer configuration to give a clean workflow. The classes can now write and read data from the OSTC 3. Signed-off-by: Joseph W. Joshua <joejoshw@gmail.com> Signed-off-by: Thiago Macieira <thiago@macieira.org>
This commit is contained in:
		
							parent
							
								
									4fc16b1674
								
							
						
					
					
						commit
						20eb62a98a
					
				
					 7 changed files with 150 additions and 60 deletions
				
			
		| 
						 | 
					@ -4,31 +4,42 @@
 | 
				
			||||||
ConfigureDiveComputer::ConfigureDiveComputer(QObject *parent) :
 | 
					ConfigureDiveComputer::ConfigureDiveComputer(QObject *parent) :
 | 
				
			||||||
	QObject(parent),
 | 
						QObject(parent),
 | 
				
			||||||
	readThread(0),
 | 
						readThread(0),
 | 
				
			||||||
	writeThread(0),
 | 
						writeThread(0)
 | 
				
			||||||
	m_deviceDetails(0)
 | 
					 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	setState(INITIAL);
 | 
						setState(INITIAL);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void ConfigureDiveComputer::readSettings(DeviceDetails *deviceDetails, device_data_t *data)
 | 
					void ConfigureDiveComputer::readSettings(device_data_t *data)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	setState(READING);
 | 
						setState(READING);
 | 
				
			||||||
	m_deviceDetails = deviceDetails;
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
	if (readThread)
 | 
						if (readThread)
 | 
				
			||||||
		readThread->deleteLater();
 | 
							readThread->deleteLater();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	readThread = new ReadSettingsThread(this, deviceDetails, data);
 | 
						readThread = new ReadSettingsThread(this, data);
 | 
				
			||||||
	connect (readThread, SIGNAL(finished()),
 | 
						connect (readThread, SIGNAL(finished()),
 | 
				
			||||||
		 this, SLOT(readThreadFinished()), Qt::QueuedConnection);
 | 
							 this, SLOT(readThreadFinished()), Qt::QueuedConnection);
 | 
				
			||||||
	connect (readThread, SIGNAL(error(QString)), this, SLOT(setError(QString)));
 | 
						connect (readThread, SIGNAL(error(QString)), this, SLOT(setError(QString)));
 | 
				
			||||||
 | 
						connect (readThread, SIGNAL(devicedetails(DeviceDetails*)), this,
 | 
				
			||||||
 | 
							 SIGNAL(deviceDetailsChanged(DeviceDetails*)));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	readThread->start();
 | 
						readThread->start();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void ConfigureDiveComputer::saveDeviceDetails()
 | 
					void ConfigureDiveComputer::saveDeviceDetails(DeviceDetails *details, device_data_t *data)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
						setState(WRITING);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						if (writeThread)
 | 
				
			||||||
 | 
							writeThread->deleteLater();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						writeThread = new WriteSettingsThread(this, data);
 | 
				
			||||||
 | 
						connect (writeThread, SIGNAL(finished()),
 | 
				
			||||||
 | 
							 this, SLOT(writeThreadFinished()), Qt::QueuedConnection);
 | 
				
			||||||
 | 
						connect (writeThread, SIGNAL(error(QString)), this, SLOT(setError(QString)));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
						writeThread->setDeviceDetails(details);
 | 
				
			||||||
 | 
						writeThread->start();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void ConfigureDiveComputer::setState(ConfigureDiveComputer::states newState)
 | 
					void ConfigureDiveComputer::setState(ConfigureDiveComputer::states newState)
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -13,7 +13,7 @@ class ConfigureDiveComputer : public QObject
 | 
				
			||||||
	Q_OBJECT
 | 
						Q_OBJECT
 | 
				
			||||||
public:
 | 
					public:
 | 
				
			||||||
	explicit ConfigureDiveComputer(QObject *parent = 0);
 | 
						explicit ConfigureDiveComputer(QObject *parent = 0);
 | 
				
			||||||
	void readSettings(DeviceDetails *deviceDetails, device_data_t *data);
 | 
						void readSettings(device_data_t *data);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	enum states {
 | 
						enum states {
 | 
				
			||||||
			INITIAL,
 | 
								INITIAL,
 | 
				
			||||||
| 
						 | 
					@ -27,9 +27,8 @@ public:
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	QString lastError;
 | 
						QString lastError;
 | 
				
			||||||
	states currentState;
 | 
						states currentState;
 | 
				
			||||||
	DeviceDetails *m_deviceDetails;
 | 
					 | 
				
			||||||
	device_data_t *m_data;
 | 
						device_data_t *m_data;
 | 
				
			||||||
	void saveDeviceDetails();
 | 
						void saveDeviceDetails(DeviceDetails *details, device_data_t *data);
 | 
				
			||||||
	void fetchDeviceDetails();
 | 
						void fetchDeviceDetails();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
signals:
 | 
					signals:
 | 
				
			||||||
| 
						 | 
					@ -38,6 +37,7 @@ signals:
 | 
				
			||||||
	void readFinished();
 | 
						void readFinished();
 | 
				
			||||||
	void writeFinished();
 | 
						void writeFinished();
 | 
				
			||||||
	void stateChanged(states newState);
 | 
						void stateChanged(states newState);
 | 
				
			||||||
 | 
						void deviceDetailsChanged(DeviceDetails *newDetails);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
private:
 | 
					private:
 | 
				
			||||||
	ReadSettingsThread *readThread;
 | 
						ReadSettingsThread *readThread;
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -8,6 +8,7 @@
 | 
				
			||||||
#include "../divelist.h"
 | 
					#include "../divelist.h"
 | 
				
			||||||
#include "configuredivecomputer.h"
 | 
					#include "configuredivecomputer.h"
 | 
				
			||||||
#include <QInputDialog>
 | 
					#include <QInputDialog>
 | 
				
			||||||
 | 
					#include <QDebug>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
struct product {
 | 
					struct product {
 | 
				
			||||||
	const char *product;
 | 
						const char *product;
 | 
				
			||||||
| 
						 | 
					@ -43,6 +44,8 @@ ConfigureDiveComputerDialog::ConfigureDiveComputerDialog(QWidget *parent) :
 | 
				
			||||||
	connect (config, SIGNAL(error(QString)), this, SLOT(configError(QString)));
 | 
						connect (config, SIGNAL(error(QString)), this, SLOT(configError(QString)));
 | 
				
			||||||
	connect (config, SIGNAL(message(QString)), this, SLOT(configMessage(QString)));
 | 
						connect (config, SIGNAL(message(QString)), this, SLOT(configMessage(QString)));
 | 
				
			||||||
	connect (config, SIGNAL(readFinished()), this, SLOT(deviceReadFinished()));
 | 
						connect (config, SIGNAL(readFinished()), this, SLOT(deviceReadFinished()));
 | 
				
			||||||
 | 
						connect (config, SIGNAL(deviceDetailsChanged(DeviceDetails*)),
 | 
				
			||||||
 | 
							 this, SLOT(deviceDetailsReceived(DeviceDetails*)));
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	fill_computer_list();
 | 
						fill_computer_list();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					@ -159,7 +162,7 @@ void ConfigureDiveComputerDialog::readSettings()
 | 
				
			||||||
	ui->errorLabel->clear();
 | 
						ui->errorLabel->clear();
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	getDeviceData();
 | 
						getDeviceData();
 | 
				
			||||||
	config->readSettings(deviceDetails, &device_data);
 | 
						config->readSettings(&device_data);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void ConfigureDiveComputerDialog::configMessage(QString msg)
 | 
					void ConfigureDiveComputerDialog::configMessage(QString msg)
 | 
				
			||||||
| 
						 | 
					@ -183,8 +186,6 @@ void ConfigureDiveComputerDialog::getDeviceData()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	set_default_dive_computer(device_data.vendor, device_data.product);
 | 
						set_default_dive_computer(device_data.vendor, device_data.product);
 | 
				
			||||||
	set_default_dive_computer_device(device_data.devname);
 | 
						set_default_dive_computer_device(device_data.devname);
 | 
				
			||||||
 | 
					 | 
				
			||||||
	//deviceDetails->setData(&device_data);
 | 
					 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void ConfigureDiveComputerDialog::on_cancel_clicked()
 | 
					void ConfigureDiveComputerDialog::on_cancel_clicked()
 | 
				
			||||||
| 
						 | 
					@ -194,11 +195,32 @@ void ConfigureDiveComputerDialog::on_cancel_clicked()
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void ConfigureDiveComputerDialog::deviceReadFinished()
 | 
					void ConfigureDiveComputerDialog::deviceReadFinished()
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	ui->brightnessComboBox->setCurrentIndex(config->m_deviceDetails->brightness());
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void ConfigureDiveComputerDialog::on_saveSettingsPushButton_clicked()
 | 
					void ConfigureDiveComputerDialog::on_saveSettingsPushButton_clicked()
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	config->saveDeviceDetails();
 | 
						deviceDetails->setBrightness(ui->brightnessComboBox->currentIndex());
 | 
				
			||||||
 | 
						deviceDetails->setLanguage(ui->languageComboBox->currentIndex());
 | 
				
			||||||
 | 
						deviceDetails->setDateFormat(ui->dateFormatComboBox->currentIndex());
 | 
				
			||||||
 | 
						deviceDetails->setCustomText(ui->customTextLlineEdit->text());
 | 
				
			||||||
 | 
						getDeviceData();
 | 
				
			||||||
 | 
						config->saveDeviceDetails(deviceDetails, &device_data);
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void ConfigureDiveComputerDialog::deviceDetailsReceived(DeviceDetails *newDeviceDetails)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						deviceDetails = newDeviceDetails;
 | 
				
			||||||
 | 
						reloadValues();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void ConfigureDiveComputerDialog::reloadValues()
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						ui->serialNoLineEdit->setText(deviceDetails->serialNo());
 | 
				
			||||||
 | 
						ui->firmwareVersionLineEdit->setText(deviceDetails->firmwareVersion());
 | 
				
			||||||
 | 
						ui->customTextLlineEdit->setText(deviceDetails->customText());
 | 
				
			||||||
 | 
						ui->brightnessComboBox->setCurrentIndex(deviceDetails->brightness());
 | 
				
			||||||
 | 
						ui->languageComboBox->setCurrentIndex(deviceDetails->language());
 | 
				
			||||||
 | 
						ui->dateFormatComboBox->setCurrentIndex(deviceDetails->dateFormat());
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -29,6 +29,8 @@ private slots:
 | 
				
			||||||
	void on_cancel_clicked();
 | 
						void on_cancel_clicked();
 | 
				
			||||||
	void deviceReadFinished();
 | 
						void deviceReadFinished();
 | 
				
			||||||
	void on_saveSettingsPushButton_clicked();
 | 
						void on_saveSettingsPushButton_clicked();
 | 
				
			||||||
 | 
						void deviceDetailsReceived(DeviceDetails *newDeviceDetails);
 | 
				
			||||||
 | 
						void reloadValues();
 | 
				
			||||||
private:
 | 
					private:
 | 
				
			||||||
	Ui::ConfigureDiveComputerDialog *ui;
 | 
						Ui::ConfigureDiveComputerDialog *ui;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -7,7 +7,7 @@
 | 
				
			||||||
    <x>0</x>
 | 
					    <x>0</x>
 | 
				
			||||||
    <y>0</y>
 | 
					    <y>0</y>
 | 
				
			||||||
    <width>343</width>
 | 
					    <width>343</width>
 | 
				
			||||||
    <height>365</height>
 | 
					    <height>390</height>
 | 
				
			||||||
   </rect>
 | 
					   </rect>
 | 
				
			||||||
  </property>
 | 
					  </property>
 | 
				
			||||||
  <property name="windowTitle">
 | 
					  <property name="windowTitle">
 | 
				
			||||||
| 
						 | 
					@ -93,12 +93,8 @@
 | 
				
			||||||
   </item>
 | 
					   </item>
 | 
				
			||||||
   <item>
 | 
					   <item>
 | 
				
			||||||
    <layout class="QGridLayout" name="gridLayout_2">
 | 
					    <layout class="QGridLayout" name="gridLayout_2">
 | 
				
			||||||
     <item row="3" column="0">
 | 
					     <item row="2" column="1">
 | 
				
			||||||
      <widget class="QLabel" name="label_4">
 | 
					      <widget class="QLineEdit" name="customTextLlineEdit"/>
 | 
				
			||||||
       <property name="text">
 | 
					 | 
				
			||||||
        <string>Brightness:</string>
 | 
					 | 
				
			||||||
       </property>
 | 
					 | 
				
			||||||
      </widget>
 | 
					 | 
				
			||||||
     </item>
 | 
					     </item>
 | 
				
			||||||
     <item row="3" column="1">
 | 
					     <item row="3" column="1">
 | 
				
			||||||
      <widget class="QComboBox" name="brightnessComboBox">
 | 
					      <widget class="QComboBox" name="brightnessComboBox">
 | 
				
			||||||
| 
						 | 
					@ -119,10 +115,10 @@
 | 
				
			||||||
       </item>
 | 
					       </item>
 | 
				
			||||||
      </widget>
 | 
					      </widget>
 | 
				
			||||||
     </item>
 | 
					     </item>
 | 
				
			||||||
     <item row="0" column="1">
 | 
					     <item row="1" column="0">
 | 
				
			||||||
      <widget class="QLineEdit" name="serialNoLineEdit">
 | 
					      <widget class="QLabel" name="label_8">
 | 
				
			||||||
       <property name="readOnly">
 | 
					       <property name="text">
 | 
				
			||||||
        <bool>true</bool>
 | 
					        <string>Firmware Version:</string>
 | 
				
			||||||
       </property>
 | 
					       </property>
 | 
				
			||||||
      </widget>
 | 
					      </widget>
 | 
				
			||||||
     </item>
 | 
					     </item>
 | 
				
			||||||
| 
						 | 
					@ -150,20 +146,17 @@
 | 
				
			||||||
       </item>
 | 
					       </item>
 | 
				
			||||||
      </widget>
 | 
					      </widget>
 | 
				
			||||||
     </item>
 | 
					     </item>
 | 
				
			||||||
     <item row="2" column="1">
 | 
					     <item row="3" column="0">
 | 
				
			||||||
      <widget class="QLineEdit" name="customTextLlineEdit"/>
 | 
					      <widget class="QLabel" name="label_4">
 | 
				
			||||||
     </item>
 | 
					 | 
				
			||||||
     <item row="4" column="0">
 | 
					 | 
				
			||||||
      <widget class="QLabel" name="label_6">
 | 
					 | 
				
			||||||
       <property name="text">
 | 
					       <property name="text">
 | 
				
			||||||
        <string>Language:</string>
 | 
					        <string>Brightness:</string>
 | 
				
			||||||
       </property>
 | 
					       </property>
 | 
				
			||||||
      </widget>
 | 
					      </widget>
 | 
				
			||||||
     </item>
 | 
					     </item>
 | 
				
			||||||
     <item row="0" column="0">
 | 
					     <item row="0" column="1">
 | 
				
			||||||
      <widget class="QLabel" name="label_7">
 | 
					      <widget class="QLineEdit" name="serialNoLineEdit">
 | 
				
			||||||
       <property name="text">
 | 
					       <property name="readOnly">
 | 
				
			||||||
        <string>Serial No.</string>
 | 
					        <bool>true</bool>
 | 
				
			||||||
       </property>
 | 
					       </property>
 | 
				
			||||||
      </widget>
 | 
					      </widget>
 | 
				
			||||||
     </item>
 | 
					     </item>
 | 
				
			||||||
| 
						 | 
					@ -174,10 +167,17 @@
 | 
				
			||||||
       </property>
 | 
					       </property>
 | 
				
			||||||
      </widget>
 | 
					      </widget>
 | 
				
			||||||
     </item>
 | 
					     </item>
 | 
				
			||||||
     <item row="1" column="0">
 | 
					     <item row="0" column="0">
 | 
				
			||||||
      <widget class="QLabel" name="label_8">
 | 
					      <widget class="QLabel" name="label_7">
 | 
				
			||||||
       <property name="text">
 | 
					       <property name="text">
 | 
				
			||||||
        <string>Firmware Version:</string>
 | 
					        <string>Serial No.</string>
 | 
				
			||||||
 | 
					       </property>
 | 
				
			||||||
 | 
					      </widget>
 | 
				
			||||||
 | 
					     </item>
 | 
				
			||||||
 | 
					     <item row="4" column="0">
 | 
				
			||||||
 | 
					      <widget class="QLabel" name="label_6">
 | 
				
			||||||
 | 
					       <property name="text">
 | 
				
			||||||
 | 
					        <string>Language:</string>
 | 
				
			||||||
       </property>
 | 
					       </property>
 | 
				
			||||||
      </widget>
 | 
					      </widget>
 | 
				
			||||||
     </item>
 | 
					     </item>
 | 
				
			||||||
| 
						 | 
					@ -188,6 +188,32 @@
 | 
				
			||||||
       </property>
 | 
					       </property>
 | 
				
			||||||
      </widget>
 | 
					      </widget>
 | 
				
			||||||
     </item>
 | 
					     </item>
 | 
				
			||||||
 | 
					     <item row="5" column="0">
 | 
				
			||||||
 | 
					      <widget class="QLabel" name="label_9">
 | 
				
			||||||
 | 
					       <property name="text">
 | 
				
			||||||
 | 
					        <string>Date Format:</string>
 | 
				
			||||||
 | 
					       </property>
 | 
				
			||||||
 | 
					      </widget>
 | 
				
			||||||
 | 
					     </item>
 | 
				
			||||||
 | 
					     <item row="5" column="1">
 | 
				
			||||||
 | 
					      <widget class="QComboBox" name="dateFormatComboBox">
 | 
				
			||||||
 | 
					       <item>
 | 
				
			||||||
 | 
					        <property name="text">
 | 
				
			||||||
 | 
					         <string>MMDDYY</string>
 | 
				
			||||||
 | 
					        </property>
 | 
				
			||||||
 | 
					       </item>
 | 
				
			||||||
 | 
					       <item>
 | 
				
			||||||
 | 
					        <property name="text">
 | 
				
			||||||
 | 
					         <string>DDMMYY</string>
 | 
				
			||||||
 | 
					        </property>
 | 
				
			||||||
 | 
					       </item>
 | 
				
			||||||
 | 
					       <item>
 | 
				
			||||||
 | 
					        <property name="text">
 | 
				
			||||||
 | 
					         <string>YYMMDD</string>
 | 
				
			||||||
 | 
					        </property>
 | 
				
			||||||
 | 
					       </item>
 | 
				
			||||||
 | 
					      </widget>
 | 
				
			||||||
 | 
					     </item>
 | 
				
			||||||
    </layout>
 | 
					    </layout>
 | 
				
			||||||
   </item>
 | 
					   </item>
 | 
				
			||||||
   <item>
 | 
					   <item>
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -2,8 +2,8 @@
 | 
				
			||||||
#include "libdivecomputer/hw.h"
 | 
					#include "libdivecomputer/hw.h"
 | 
				
			||||||
#include <QDebug>
 | 
					#include <QDebug>
 | 
				
			||||||
 | 
					
 | 
				
			||||||
ReadSettingsThread::ReadSettingsThread(QObject *parent, DeviceDetails *deviceDetails, device_data_t *data)
 | 
					ReadSettingsThread::ReadSettingsThread(QObject *parent, device_data_t *data)
 | 
				
			||||||
	: QThread(parent), m_deviceDetails(deviceDetails), m_data(data)
 | 
						: QThread(parent), m_data(data)
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					@ -14,6 +14,7 @@ void ReadSettingsThread::run()
 | 
				
			||||||
	dc_status_t rc;
 | 
						dc_status_t rc;
 | 
				
			||||||
	rc = rc = dc_device_open(&m_data->device, m_data->context, m_data->descriptor, m_data->devname);
 | 
						rc = rc = dc_device_open(&m_data->device, m_data->context, m_data->descriptor, m_data->devname);
 | 
				
			||||||
	if (rc == DC_STATUS_SUCCESS) {
 | 
						if (rc == DC_STATUS_SUCCESS) {
 | 
				
			||||||
 | 
							DeviceDetails *m_deviceDetails = new DeviceDetails(0);
 | 
				
			||||||
		switch (dc_device_get_type(m_data->device)) {
 | 
							switch (dc_device_get_type(m_data->device)) {
 | 
				
			||||||
		case DC_FAMILY_HW_OSTC3:
 | 
							case DC_FAMILY_HW_OSTC3:
 | 
				
			||||||
			supported = true;
 | 
								supported = true;
 | 
				
			||||||
| 
						 | 
					@ -25,7 +26,8 @@ void ReadSettingsThread::run()
 | 
				
			||||||
			m_deviceDetails->setLanguage(0);
 | 
								m_deviceDetails->setLanguage(0);
 | 
				
			||||||
			m_deviceDetails->setLastDeco(0);
 | 
								m_deviceDetails->setLastDeco(0);
 | 
				
			||||||
			m_deviceDetails->setSerialNo("");
 | 
								m_deviceDetails->setSerialNo("");
 | 
				
			||||||
			unsigned char uData[1];
 | 
								//Read general settings
 | 
				
			||||||
 | 
								unsigned char uData[1] = {0};
 | 
				
			||||||
			rc = hw_ostc3_device_config_read(m_data->device, 0x2D, uData, sizeof(uData));
 | 
								rc = hw_ostc3_device_config_read(m_data->device, 0x2D, uData, sizeof(uData));
 | 
				
			||||||
			if (rc == DC_STATUS_SUCCESS)
 | 
								if (rc == DC_STATUS_SUCCESS)
 | 
				
			||||||
				m_deviceDetails->setBrightness(uData[0]);
 | 
									m_deviceDetails->setBrightness(uData[0]);
 | 
				
			||||||
| 
						 | 
					@ -35,6 +37,20 @@ void ReadSettingsThread::run()
 | 
				
			||||||
			rc = hw_ostc3_device_config_read(m_data->device, 0x33, uData, sizeof(uData));
 | 
								rc = hw_ostc3_device_config_read(m_data->device, 0x33, uData, sizeof(uData));
 | 
				
			||||||
			if (rc == DC_STATUS_SUCCESS)
 | 
								if (rc == DC_STATUS_SUCCESS)
 | 
				
			||||||
				m_deviceDetails->setDateFormat(uData[0]);
 | 
									m_deviceDetails->setDateFormat(uData[0]);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								//read firmware settings
 | 
				
			||||||
 | 
								unsigned char fData[64] = {0};
 | 
				
			||||||
 | 
								rc = hw_ostc3_device_version (m_data->device, fData, sizeof (fData));
 | 
				
			||||||
 | 
								if (rc == DC_STATUS_SUCCESS) {
 | 
				
			||||||
 | 
									int serial = fData[0] + (fData[1] << 8);
 | 
				
			||||||
 | 
									m_deviceDetails->setSerialNo(QString::number(serial));
 | 
				
			||||||
 | 
									int fw = (fData[2] << 8) + fData[3];
 | 
				
			||||||
 | 
									m_deviceDetails->setFirmwareVersion(QString::number(fw));
 | 
				
			||||||
 | 
									QByteArray ar((char *)fData + 4, 60);
 | 
				
			||||||
 | 
									m_deviceDetails->setCustomText(ar.trimmed());
 | 
				
			||||||
 | 
								}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
								emit devicedetails(m_deviceDetails);
 | 
				
			||||||
			break;
 | 
								break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
| 
						 | 
					@ -51,31 +67,46 @@ void ReadSettingsThread::run()
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
WriteSettingsThread::WriteSettingsThread(QObject *parent, DeviceDetails *deviceDetails, QString settingName, QVariant settingValue)
 | 
					WriteSettingsThread::WriteSettingsThread(QObject *parent, device_data_t *data)
 | 
				
			||||||
	: QThread(parent), m_deviceDetails(deviceDetails), m_settingName(settingName), m_settingValue(settingValue)
 | 
						: QThread(parent), m_data(data) {
 | 
				
			||||||
{
 | 
					 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void WriteSettingsThread::setDeviceDetails(DeviceDetails *details)
 | 
				
			||||||
 | 
					{
 | 
				
			||||||
 | 
						m_deviceDetails = details;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void WriteSettingsThread::run()
 | 
					void WriteSettingsThread::run()
 | 
				
			||||||
{
 | 
					{
 | 
				
			||||||
	bool supported = false;
 | 
						bool supported = false;
 | 
				
			||||||
	dc_status_t rc;
 | 
						dc_status_t rc;
 | 
				
			||||||
 | 
						rc = rc = dc_device_open(&m_data->device, m_data->context, m_data->descriptor, m_data->devname);
 | 
				
			||||||
 | 
						if (rc == DC_STATUS_SUCCESS) {
 | 
				
			||||||
 | 
							switch (dc_device_get_type(m_data->device)) {
 | 
				
			||||||
 | 
							case DC_FAMILY_HW_OSTC3:
 | 
				
			||||||
 | 
								supported = true;
 | 
				
			||||||
 | 
								//write general settings
 | 
				
			||||||
 | 
								hw_ostc3_device_customtext(m_data->device, m_deviceDetails->customText().toUtf8().data());
 | 
				
			||||||
 | 
								unsigned char data[1] = {0};
 | 
				
			||||||
 | 
								data[0] = m_deviceDetails->brightness();
 | 
				
			||||||
 | 
								hw_ostc3_device_config_write(m_data->device, 0x2D, data, sizeof(data));
 | 
				
			||||||
 | 
								data[0] = m_deviceDetails->language();
 | 
				
			||||||
 | 
								hw_ostc3_device_config_write(m_data->device, 0x32, data, sizeof(data));
 | 
				
			||||||
 | 
								data[0] = m_deviceDetails->dateFormat();
 | 
				
			||||||
 | 
								hw_ostc3_device_config_write(m_data->device, 0x33, data, sizeof(data));
 | 
				
			||||||
 | 
								break;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
	switch (dc_device_get_type(data->device)) {
 | 
					 | 
				
			||||||
	case DC_FAMILY_HW_OSTC3:
 | 
					 | 
				
			||||||
		rc = dc_device_open(&data->device, data->context, data->descriptor, data->devname);
 | 
					 | 
				
			||||||
		if (rc == DC_STATUS_SUCCESS) {
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
		} else {
 | 
					 | 
				
			||||||
			lastError = tr("Could not a establish connection to the dive computer.");
 | 
					 | 
				
			||||||
			emit error(lastError);
 | 
					 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
		break;
 | 
							dc_device_close(m_data->device);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
		if (!supported) {
 | 
							if (!supported) {
 | 
				
			||||||
			lastError = tr("This feature is not yet available for the selected dive computer.");
 | 
								lastError = tr("This feature is not yet available for the selected dive computer.");
 | 
				
			||||||
			emit error(lastError);
 | 
								emit error(lastError);
 | 
				
			||||||
		}
 | 
							}
 | 
				
			||||||
	}
 | 
						}
 | 
				
			||||||
 | 
						else {
 | 
				
			||||||
 | 
							lastError = tr("Could not a establish connection to the dive computer.");
 | 
				
			||||||
 | 
							emit error(lastError);
 | 
				
			||||||
 | 
						}
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
| 
						 | 
					@ -11,31 +11,29 @@
 | 
				
			||||||
class ReadSettingsThread : public QThread {
 | 
					class ReadSettingsThread : public QThread {
 | 
				
			||||||
	Q_OBJECT
 | 
						Q_OBJECT
 | 
				
			||||||
public:
 | 
					public:
 | 
				
			||||||
	ReadSettingsThread(QObject *parent, DeviceDetails *deviceDetails, device_data_t *data);
 | 
						ReadSettingsThread(QObject *parent, device_data_t *data);
 | 
				
			||||||
	virtual void run();
 | 
						virtual void run();
 | 
				
			||||||
	QString result;
 | 
						QString result;
 | 
				
			||||||
	QString lastError;
 | 
						QString lastError;
 | 
				
			||||||
signals:
 | 
					signals:
 | 
				
			||||||
	void error(QString err);
 | 
						void error(QString err);
 | 
				
			||||||
 | 
						void devicedetails(DeviceDetails *newDeviceDetails);
 | 
				
			||||||
private:
 | 
					private:
 | 
				
			||||||
	DeviceDetails *m_deviceDetails;
 | 
					 | 
				
			||||||
	device_data_t *m_data;
 | 
						device_data_t *m_data;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class WriteSettingsThread : public QThread {
 | 
					class WriteSettingsThread : public QThread {
 | 
				
			||||||
	Q_OBJECT
 | 
						Q_OBJECT
 | 
				
			||||||
public:
 | 
					public:
 | 
				
			||||||
	WriteSettingsThread(QObject *parent, DeviceDetails *deviceDetails, QString settingName, QVariant settingValue);
 | 
						WriteSettingsThread(QObject *parent, device_data_t *data);
 | 
				
			||||||
 | 
						void setDeviceDetails(DeviceDetails *details);
 | 
				
			||||||
	virtual void run();
 | 
						virtual void run();
 | 
				
			||||||
	QString result;
 | 
						QString result;
 | 
				
			||||||
	QString lastError;
 | 
						QString lastError;
 | 
				
			||||||
signals:
 | 
					signals:
 | 
				
			||||||
	void error(QString err);
 | 
						void error(QString err);
 | 
				
			||||||
private:
 | 
					private:
 | 
				
			||||||
	device_data_t *data;
 | 
						device_data_t *m_data;
 | 
				
			||||||
	QString m_settingName;
 | 
					 | 
				
			||||||
	QVariant m_settingValue;
 | 
					 | 
				
			||||||
 | 
					 | 
				
			||||||
	DeviceDetails *m_deviceDetails;
 | 
						DeviceDetails *m_deviceDetails;
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
| 
						 | 
					
 | 
				
			||||||
		Loading…
	
	Add table
		Add a link
		
	
		Reference in a new issue