From 2282035a4d07548cb1677b16c5df97c7f98ea498 Mon Sep 17 00:00:00 2001 From: "Robert C. Helling" Date: Sun, 28 Sep 2014 23:47:41 +0200 Subject: Add export for depths of images taken This adds an option to the export dialog to write an ascii file containing filenames of image files a tab and the depth at the time of the image taken. [Dirk Hohndel: whitespace cleanup] Signed-off-by: Robert C. Helling Signed-off-by: Dirk Hohndel --- qt-ui/divelogexportdialog.cpp | 42 +++++++++++++ qt-ui/divelogexportdialog.h | 1 + qt-ui/divelogexportdialog.ui | 142 ++++++++++++++++++++++-------------------- 3 files changed, 119 insertions(+), 66 deletions(-) diff --git a/qt-ui/divelogexportdialog.cpp b/qt-ui/divelogexportdialog.cpp index 67803eeee..3f9373a4f 100644 --- a/qt-ui/divelogexportdialog.cpp +++ b/qt-ui/divelogexportdialog.cpp @@ -74,6 +74,8 @@ void DiveLogExportDialog::showExplanation() ui->description->setText(tr("HTML export of the dive locations, visualized on a world map.")); } else if (ui->exportSubsurfaceXML->isChecked()) { ui->description->setText(tr("Subsurface native XML format.")); + } else if (ui->exportImageDepths->isChecked()) { + ui->description->setText(tr("Write depths of images to file.")); } } @@ -257,6 +259,10 @@ void DiveLogExportDialog::on_buttonBox_accepted() QByteArray bt = QFile::encodeName(filename); save_dives_logic(bt.data(), ui->exportSelected->isChecked()); } + } else if (ui->exportImageDepths->isChecked()) { + filename = QFileDialog::getSaveFileName(this, tr("Save image depths"), lastDir); + if (!filename.isNull() && !filename.isEmpty()) + export_depths(filename.toUtf8().data(), ui->exportSelected->isChecked()); } break; case 1: @@ -278,3 +284,39 @@ void DiveLogExportDialog::on_buttonBox_accepted() export_dives_xslt(filename.toUtf8(), ui->exportSelected->isChecked(), stylesheet.toUtf8()); } } + +void DiveLogExportDialog::export_depths(const char *filename, const bool selected_only) +{ + FILE *f; + struct dive *dive; + depth_t depth; + int i; + const char **unit; + + struct membuffer buf = { 0 }; + + for_each_dive (i, dive) { + if (selected_only && !dive->selected) + continue; + + FOR_EACH_PICTURE (dive) { + int n = dive->dc.samples; + struct sample *s = dive->dc.sample; + depth.mm = 0; + while (--n >= 0 && s->time.seconds <= picture->offset.seconds) { + depth.mm = s->depth.mm; + s++; + } + put_format(&buf, "%s\t%.1f%s\n", picture->filename, get_depth_units(depth.mm, NULL, unit), *unit); + } + } + + f = subsurface_fopen(filename, "w+"); + if (!f) { + report_error(tr("Can't open file %s").toUtf8().data(), filename); + } else { + flush_buffer(&buf, f); /*check for writing errors? */ + fclose(f); + } + free_buffer(&buf); +} diff --git a/qt-ui/divelogexportdialog.h b/qt-ui/divelogexportdialog.h index 8472f8075..0a603ced6 100644 --- a/qt-ui/divelogexportdialog.h +++ b/qt-ui/divelogexportdialog.h @@ -33,6 +33,7 @@ private: void exportHTMLsettings(const QString &filename); void exportHTMLstatistics(const QString &filename); void copy_and_overwrite(const QString &fileName, const QString &newName); + void export_depths(const char *filename, const bool selected_only); }; #endif // DIVELOGEXPORTDIALOG_H diff --git a/qt-ui/divelogexportdialog.ui b/qt-ui/divelogexportdialog.ui index 9510b5f6d..b54d2eac6 100644 --- a/qt-ui/divelogexportdialog.ui +++ b/qt-ui/divelogexportdialog.ui @@ -29,6 +29,76 @@ General export + + + + + 0 + 0 + + + + + 0 + 100 + + + + + 16777215 + 100 + + + + + + + true + + + + + + + Qt::Vertical + + + + 20 + 40 + + + + + + + + Selection + + + + + + true + + + Selected dives + + + true + + + + + + + All dives + + + + + + @@ -103,79 +173,19 @@ - - - - - - - Selection - - - - - - true - - - Selected dives - - - true - - - - + - All dives + Image depths + + exportGroup + - - - - - 0 - 0 - - - - - 0 - 100 - - - - - 16777215 - 100 - - - - - - - true - - - - - - - Qt::Vertical - - - - 20 - 40 - - - - @@ -420,7 +430,7 @@ - + -- cgit v1.2.3-70-g09d2