2024-01-19 17:07:41 +01:00
|
|
|
#include "dialogdevices.h"
|
|
|
|
#include "ui_dialogdevices.h"
|
|
|
|
#include "helpers.h"
|
2024-08-06 14:16:57 +02:00
|
|
|
#include <QFileDialog>
|
|
|
|
#include <QMessageBox>
|
|
|
|
#include <QFile>
|
|
|
|
#include <QTextStream>
|
|
|
|
#include <QVector>
|
|
|
|
#include <QPushButton> // Include QPushButton header for button creation
|
2024-01-19 17:07:41 +01:00
|
|
|
|
|
|
|
DialogDevices::DialogDevices(QWidget *parent) :
|
|
|
|
QDialog(parent),
|
|
|
|
ui(new Ui::DialogDevices)
|
|
|
|
{
|
|
|
|
ui->setupUi(this);
|
|
|
|
}
|
|
|
|
|
|
|
|
DialogDevices::~DialogDevices()
|
|
|
|
{
|
|
|
|
delete ui;
|
|
|
|
}
|
|
|
|
|
|
|
|
//***************** Initialization ******************
|
|
|
|
|
2024-08-06 15:06:06 +02:00
|
|
|
|
|
|
|
//***************** Processing ******************
|
|
|
|
|
|
|
|
void DialogDevices::accept()
|
|
|
|
{
|
|
|
|
// qInfo("Accepted!");
|
|
|
|
|
|
|
|
if (validateAndSave())
|
|
|
|
QDialog::accept();
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
void DialogDevices::applyCalibrationDataToDevice(int dev_nr, const QVector<unsigned short>& data)
|
|
|
|
{
|
|
|
|
// Implementation for applying the calibration data to the specific device
|
|
|
|
// For example, updating device settings or performing calculations
|
|
|
|
qDebug() << "Calibration data loaded for Device" << dev_nr << ":" << data;
|
|
|
|
|
|
|
|
// Example: Set the calibration data in your application logic
|
|
|
|
// deviceSettings->setValue("Device%1/CalibrationData", data); // if storing in settings
|
|
|
|
}
|
|
|
|
|
|
|
|
// Load calibration factors from a file and store them
|
|
|
|
void DialogDevices::selectCalibrationFile(int dev_nr)
|
|
|
|
{
|
|
|
|
QString filename = QFileDialog::getOpenFileName(this, "Select Calibration File", "", "Text Files (*.txt);;All Files (*)");
|
|
|
|
|
|
|
|
if (filename.isEmpty()) {
|
|
|
|
return; // User canceled the dialog
|
|
|
|
}
|
|
|
|
|
|
|
|
QVector<unsigned short> calibrationFactors(320, 8192); // Initialize with default value 8192
|
|
|
|
QFile file(filename);
|
|
|
|
|
|
|
|
if (!file.open(QIODevice::ReadOnly | QIODevice::Text)) {
|
|
|
|
QMessageBox::critical(this, "Error", "Could not open calibration file: " + filename);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
QTextStream in(&file);
|
|
|
|
int index = 0;
|
|
|
|
while (!in.atEnd() && index < 320) {
|
|
|
|
QString line = in.readLine().trimmed();
|
|
|
|
bool ok;
|
|
|
|
int value = line.toInt(&ok);
|
|
|
|
|
|
|
|
// Validate value and ensure it is within the range of an unsigned short
|
|
|
|
if (ok && value >= 0 && value <= 65535) {
|
|
|
|
calibrationFactors[index] = value;
|
|
|
|
} else {
|
|
|
|
qWarning() << "Invalid calibration factor in file:" << line << "at index" << index;
|
|
|
|
calibrationFactors[index] = 8192; // Use default if invalid
|
|
|
|
}
|
|
|
|
index++;
|
|
|
|
}
|
|
|
|
|
|
|
|
file.close();
|
|
|
|
|
|
|
|
// Store calibration factors for the device
|
|
|
|
if (dev_nr < deviceCalibrationData.size()) {
|
|
|
|
deviceCalibrationData[dev_nr] = calibrationFactors;
|
|
|
|
} else {
|
|
|
|
deviceCalibrationData.append(calibrationFactors);
|
|
|
|
}
|
|
|
|
|
2024-08-06 17:09:44 +02:00
|
|
|
|
|
|
|
// Save the calibration file path to QSettings
|
|
|
|
top(deviceSettings);
|
|
|
|
QString group_label = QString("Device%1").arg(dev_nr);
|
|
|
|
deviceSettings->beginGroup(group_label);
|
|
|
|
deviceSettings->setValue("CalibFile", filename); // Save the file path
|
|
|
|
deviceSettings->endGroup();
|
|
|
|
|
|
|
|
|
2024-08-06 15:06:06 +02:00
|
|
|
// Update the table display to show the file path (optional)
|
|
|
|
QTableWidgetItem* calibFileItem = new QTableWidgetItem(filename);
|
|
|
|
ui->tableDevices->setItem(dev_nr, 10, calibFileItem);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Retrieve all calibration factors for each device
|
|
|
|
QVector<QVector<unsigned short>> DialogDevices::getAllCalibrationFactors() const
|
|
|
|
{
|
|
|
|
return deviceCalibrationData;
|
|
|
|
}
|
|
|
|
|
2024-01-19 17:07:41 +01:00
|
|
|
void DialogDevices::showEvent(QShowEvent * event)
|
|
|
|
{
|
|
|
|
if (!event->spontaneous())
|
|
|
|
{
|
|
|
|
|
|
|
|
if (deviceSettings != NULL)
|
|
|
|
{
|
|
|
|
top(deviceSettings);
|
|
|
|
deviceSettings->beginGroup("Global");
|
|
|
|
|
|
|
|
ui->spinNrDevices->setValue(deviceSettings->value("NrDevices", int(1)).toInt());
|
|
|
|
|
2024-08-06 14:16:57 +02:00
|
|
|
ui->tableDevices->setColumnCount(12);
|
2024-01-19 17:07:41 +01:00
|
|
|
QStringList h_header;
|
|
|
|
h_header.append("IP Address");
|
|
|
|
h_header.append("Hardware ver.");
|
|
|
|
h_header.append("Layer");
|
|
|
|
h_header.append("Position");
|
|
|
|
h_header.append("Sensors");
|
|
|
|
h_header.append("Master");
|
|
|
|
h_header.append("Master dly");
|
|
|
|
h_header.append("Slave dly");
|
2024-07-19 14:39:26 +02:00
|
|
|
h_header.append("Threshold");
|
2024-08-06 14:16:57 +02:00
|
|
|
h_header.append("ClusterSize");
|
|
|
|
h_header.append("CalibFile"); // Column for showing file path
|
|
|
|
h_header.append("Select Calib File"); // New column for the button
|
|
|
|
|
|
|
|
|
2024-01-19 17:07:41 +01:00
|
|
|
ui->tableDevices->setHorizontalHeaderLabels(h_header);
|
|
|
|
|
|
|
|
importSettings();
|
|
|
|
}
|
|
|
|
initialized = 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
QDialog::showEvent(event);
|
|
|
|
}
|
|
|
|
|
|
|
|
void DialogDevices::importSettings()
|
|
|
|
{
|
|
|
|
int nr_devices = ui->spinNrDevices->value();
|
|
|
|
ui->tableDevices->setRowCount(nr_devices);
|
|
|
|
|
2024-08-06 15:06:06 +02:00
|
|
|
// Ensure the device calibration data vector is initialized properly
|
|
|
|
deviceCalibrationData.resize(nr_devices);
|
|
|
|
|
2024-01-19 17:07:41 +01:00
|
|
|
for (int dev_nr = 0; dev_nr < nr_devices; dev_nr++)
|
|
|
|
{
|
2024-08-06 15:06:06 +02:00
|
|
|
if (dev_nr >= last_nr_devices) // Update only new rows!
|
2024-01-19 17:07:41 +01:00
|
|
|
{
|
|
|
|
top(deviceSettings);
|
|
|
|
QString group_label = QString("Device%1").arg(dev_nr);
|
|
|
|
deviceSettings->beginGroup(group_label);
|
|
|
|
|
|
|
|
QTableWidgetItem* newItem;
|
2024-08-06 15:06:06 +02:00
|
|
|
newItem = new QTableWidgetItem(deviceSettings->value("IP", "0.0.0.0").toString());
|
|
|
|
ui->tableDevices->setItem(dev_nr, 0, newItem);
|
|
|
|
newItem = new QTableWidgetItem(deviceSettings->value("HardwareVer", "1").toString());
|
|
|
|
ui->tableDevices->setItem(dev_nr, 1, newItem);
|
|
|
|
newItem = new QTableWidgetItem(deviceSettings->value("Plane", "0").toString());
|
|
|
|
ui->tableDevices->setItem(dev_nr, 2, newItem);
|
|
|
|
newItem = new QTableWidgetItem(deviceSettings->value("Position", "0").toString());
|
|
|
|
ui->tableDevices->setItem(dev_nr, 3, newItem);
|
|
|
|
newItem = new QTableWidgetItem(deviceSettings->value("Sensors", "2").toString());
|
|
|
|
ui->tableDevices->setItem(dev_nr, 4, newItem);
|
|
|
|
newItem = new QTableWidgetItem(deviceSettings->value("Master", "0").toString());
|
|
|
|
ui->tableDevices->setItem(dev_nr, 5, newItem);
|
|
|
|
newItem = new QTableWidgetItem(deviceSettings->value("MasterDelay", "22").toString());
|
|
|
|
ui->tableDevices->setItem(dev_nr, 6, newItem);
|
|
|
|
newItem = new QTableWidgetItem(deviceSettings->value("SlaveDelay", "1").toString());
|
|
|
|
ui->tableDevices->setItem(dev_nr, 7, newItem);
|
|
|
|
newItem = new QTableWidgetItem(deviceSettings->value("ClusThresh", "10").toString());
|
|
|
|
ui->tableDevices->setItem(dev_nr, 8, newItem);
|
|
|
|
newItem = new QTableWidgetItem(deviceSettings->value("ClusSize", "4").toString());
|
|
|
|
ui->tableDevices->setItem(dev_nr, 9, newItem);
|
2024-08-06 14:16:57 +02:00
|
|
|
|
|
|
|
// Add a button for selecting calibration files
|
|
|
|
QPushButton* calibButton = new QPushButton("Select File");
|
2024-08-06 15:06:06 +02:00
|
|
|
ui->tableDevices->setCellWidget(dev_nr, 11, calibButton);
|
2024-08-06 14:16:57 +02:00
|
|
|
|
2024-08-06 15:06:06 +02:00
|
|
|
// Connect the button to the slot
|
2024-08-06 14:16:57 +02:00
|
|
|
connect(calibButton, &QPushButton::clicked, this, [this, dev_nr]() { selectCalibrationFile(dev_nr); });
|
2024-01-19 17:07:41 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
last_nr_devices = nr_devices;
|
|
|
|
}
|
|
|
|
|
|
|
|
int DialogDevices::validateAndSave()
|
|
|
|
{
|
|
|
|
if (deviceSettings == NULL)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
int nr_devices = ui->spinNrDevices->value();
|
|
|
|
int data_ok = 1;
|
|
|
|
|
|
|
|
//check each table row
|
|
|
|
for (int dev_nr = 0; dev_nr < nr_devices; dev_nr++)
|
|
|
|
{
|
|
|
|
//first the IP
|
|
|
|
QString user_data = ui->tableDevices->item(dev_nr,0)->text();
|
|
|
|
QString generated = ip2num(user_data);
|
|
|
|
//if the strings are identical, save the value and return 1
|
|
|
|
if (generated.compare(user_data) != 0)
|
|
|
|
data_ok = 0;
|
|
|
|
ui->tableDevices->item(dev_nr,0)->setText(generated);
|
|
|
|
|
|
|
|
//hardware version
|
|
|
|
user_data = ui->tableDevices->item(dev_nr,1)->text();
|
|
|
|
int num_hw = user_data.toInt();
|
|
|
|
if (num_hw < 1)
|
|
|
|
num_hw = 1;
|
|
|
|
if (num_hw > 2)
|
|
|
|
num_hw = 2;
|
|
|
|
generated = QString("%1").arg(num_hw);
|
|
|
|
//if the strings are identical, save the value and return 1
|
|
|
|
if (generated.compare(user_data) != 0)
|
|
|
|
data_ok = 0;
|
|
|
|
ui->tableDevices->item(dev_nr,1)->setText(generated);
|
|
|
|
|
|
|
|
//now the plane
|
|
|
|
user_data = ui->tableDevices->item(dev_nr,2)->text();
|
|
|
|
int num_value = user_data.toInt();
|
|
|
|
if (num_value < 0)
|
|
|
|
num_value = 0;
|
|
|
|
generated = QString("%1").arg(num_value);
|
|
|
|
//if the strings are identical, save the value and return 1
|
|
|
|
if (generated.compare(user_data) != 0)
|
|
|
|
data_ok = 0;
|
|
|
|
ui->tableDevices->item(dev_nr,2)->setText(generated);
|
|
|
|
|
|
|
|
//now physical position
|
|
|
|
user_data = ui->tableDevices->item(dev_nr,3)->text();
|
|
|
|
num_value = user_data.toInt();
|
|
|
|
if (num_value < 0)
|
|
|
|
num_value = 0;
|
|
|
|
generated = QString("%1").arg(num_value);
|
|
|
|
//if the strings are identical, save the value and return 1
|
|
|
|
if (generated.compare(user_data) != 0)
|
|
|
|
data_ok = 0;
|
|
|
|
ui->tableDevices->item(dev_nr,3)->setText(generated);
|
|
|
|
|
|
|
|
//now number of sensors
|
|
|
|
user_data = ui->tableDevices->item(dev_nr,4)->text();
|
|
|
|
num_value = user_data.toInt();
|
|
|
|
int max_sensors = (num_hw == 1) ? 2 : 5;
|
|
|
|
if (num_value < 1)
|
|
|
|
num_value = 1;
|
|
|
|
if (num_value > max_sensors)
|
|
|
|
num_value = max_sensors;
|
|
|
|
generated = QString("%1").arg(num_value);
|
|
|
|
//if the strings are identical, save the value and return 1
|
|
|
|
if (generated.compare(user_data) != 0)
|
|
|
|
data_ok = 0;
|
|
|
|
ui->tableDevices->item(dev_nr,4)->setText(generated);
|
|
|
|
|
|
|
|
//now master selector
|
|
|
|
user_data = ui->tableDevices->item(dev_nr,5)->text();
|
|
|
|
num_value = user_data.toInt();
|
|
|
|
if (num_value < 0)
|
|
|
|
num_value = 0;
|
|
|
|
if (num_value > 1)
|
|
|
|
num_value = 1;
|
|
|
|
generated = QString("%1").arg(num_value);
|
|
|
|
//if the strings are identical, save the value and return 1
|
|
|
|
if (generated.compare(user_data) != 0)
|
|
|
|
data_ok = 0;
|
|
|
|
ui->tableDevices->item(dev_nr,5)->setText(generated);
|
|
|
|
|
|
|
|
//now master delay
|
|
|
|
user_data = ui->tableDevices->item(dev_nr,6)->text();
|
|
|
|
num_value = user_data.toInt();
|
|
|
|
if (num_value < 1)
|
|
|
|
num_value = 1;
|
|
|
|
if (num_value > 255)
|
|
|
|
num_value = 255;
|
|
|
|
generated = QString("%1").arg(num_value);
|
|
|
|
//if the strings are identical, save the value and return 1
|
|
|
|
if (generated.compare(user_data) != 0)
|
|
|
|
data_ok = 0;
|
|
|
|
ui->tableDevices->item(dev_nr,6)->setText(generated);
|
|
|
|
|
|
|
|
//now slave delay
|
|
|
|
user_data = ui->tableDevices->item(dev_nr,7)->text();
|
|
|
|
num_value = user_data.toInt();
|
|
|
|
if (num_value < 1)
|
|
|
|
num_value = 1;
|
|
|
|
if (num_value > 255)
|
|
|
|
num_value = 255;
|
|
|
|
generated = QString("%1").arg(num_value);
|
|
|
|
//if the strings are identical, save the value and return 1
|
|
|
|
if (generated.compare(user_data) != 0)
|
|
|
|
data_ok = 0;
|
|
|
|
ui->tableDevices->item(dev_nr,7)->setText(generated);
|
2024-07-19 14:39:26 +02:00
|
|
|
|
|
|
|
//now cluster threshold
|
|
|
|
user_data = ui->tableDevices->item(dev_nr,8)->text();
|
|
|
|
num_value = user_data.toInt();
|
|
|
|
if (num_value < 1)
|
|
|
|
num_value = 1;
|
|
|
|
if (num_value > 255)
|
|
|
|
num_value = 255;
|
|
|
|
generated = QString("%1").arg(num_value);
|
|
|
|
//if the strings are identical, save the value and return 1
|
|
|
|
if (generated.compare(user_data) != 0)
|
|
|
|
data_ok = 0;
|
|
|
|
ui->tableDevices->item(dev_nr,8)->setText(generated);
|
|
|
|
|
2024-08-06 14:16:57 +02:00
|
|
|
//now cluster size
|
|
|
|
user_data = ui->tableDevices->item(dev_nr,9)->text();
|
|
|
|
num_value = user_data.toInt();
|
|
|
|
if (num_value < 1)
|
|
|
|
num_value = 1;
|
|
|
|
if (num_value > 255)
|
|
|
|
num_value = 255;
|
|
|
|
generated = QString("%1").arg(num_value);
|
|
|
|
//if the strings are identical, save the value and return 1
|
|
|
|
if (generated.compare(user_data) != 0)
|
|
|
|
data_ok = 0;
|
|
|
|
ui->tableDevices->item(dev_nr,9)->setText(generated);
|
|
|
|
|
2024-08-06 17:09:44 +02:00
|
|
|
|
|
|
|
// Calibration file path
|
|
|
|
user_data = ui->tableDevices->item(dev_nr, 10)->text();
|
|
|
|
if (user_data.isEmpty())
|
|
|
|
data_ok = 0;
|
|
|
|
|
|
|
|
// Save the calibration file path
|
|
|
|
top(deviceSettings);
|
|
|
|
QString group_label = QString("Device%1").arg(dev_nr);
|
|
|
|
deviceSettings->beginGroup(group_label);
|
|
|
|
deviceSettings->setValue("CalibFile", user_data); // Save the file path
|
|
|
|
deviceSettings->endGroup();
|
|
|
|
|
2024-01-19 17:07:41 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
//now store the data
|
|
|
|
if (!data_ok)
|
|
|
|
return 0;
|
|
|
|
|
|
|
|
top(deviceSettings);
|
|
|
|
deviceSettings->beginGroup("Global");
|
|
|
|
deviceSettings->setValue("NrDevices", nr_devices);
|
|
|
|
|
|
|
|
for (int dev_nr = 0; dev_nr < nr_devices; dev_nr++)
|
|
|
|
{
|
|
|
|
top(deviceSettings);
|
|
|
|
QString group_label = QString("Device%1").arg(dev_nr);
|
|
|
|
deviceSettings->beginGroup(group_label);
|
|
|
|
|
|
|
|
deviceSettings->setValue("IP", ui->tableDevices->item(dev_nr,0)->text());
|
|
|
|
deviceSettings->setValue("HardwareVer", ui->tableDevices->item(dev_nr,1)->text());
|
|
|
|
deviceSettings->setValue("Plane", ui->tableDevices->item(dev_nr,2)->text());
|
|
|
|
deviceSettings->setValue("Position", ui->tableDevices->item(dev_nr,3)->text());
|
|
|
|
deviceSettings->setValue("Sensors", ui->tableDevices->item(dev_nr,4)->text());
|
|
|
|
deviceSettings->setValue("Master", ui->tableDevices->item(dev_nr,5)->text());
|
|
|
|
deviceSettings->setValue("MasterDelay", ui->tableDevices->item(dev_nr,6)->text());
|
|
|
|
deviceSettings->setValue("SlaveDelay", ui->tableDevices->item(dev_nr,7)->text());
|
2024-07-19 14:39:26 +02:00
|
|
|
deviceSettings->setValue("Threshold", ui->tableDevices->item(dev_nr,8)->text());
|
2024-08-06 14:41:14 +02:00
|
|
|
deviceSettings->setValue("ClusterSize", ui->tableDevices->item(dev_nr,9)->text());
|
2024-08-06 14:16:57 +02:00
|
|
|
deviceSettings->setValue("CalibFile", ui->tableDevices->item(dev_nr, 10)->text());
|
|
|
|
}
|
2024-01-19 17:07:41 +01:00
|
|
|
|
|
|
|
return 1;
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
void DialogDevices::on_spinNrDevices_valueChanged(int arg1)
|
|
|
|
{
|
|
|
|
if (initialized)
|
|
|
|
importSettings();
|
|
|
|
}
|
2024-08-06 14:16:57 +02:00
|
|
|
|