From 547b6bcdb3841622012751cc25ad52d4231f2828 Mon Sep 17 00:00:00 2001 From: Roman Telezhynskyi Date: Wed, 23 Dec 2020 18:57:25 +0200 Subject: [PATCH] VLayoutExporter, add support for the RLD format. --- src/app/valentina/mainwindow.cpp | 13 +++++++++++-- src/app/valentina/mainwindowsnogui.cpp | 21 +-------------------- src/app/valentina/mainwindowsnogui.h | 1 - src/libs/vlayout/vlayoutexporter.cpp | 22 ++++++++++++++++++++++ src/libs/vlayout/vlayoutexporter.h | 1 + 5 files changed, 35 insertions(+), 23 deletions(-) diff --git a/src/app/valentina/mainwindow.cpp b/src/app/valentina/mainwindow.cpp index 2ab8a1719..d92d193c1 100644 --- a/src/app/valentina/mainwindow.cpp +++ b/src/app/valentina/mainwindow.cpp @@ -66,6 +66,7 @@ #include "../vformat/vpatternrecipe.h" #include "watermarkwindow.h" #include "../vmisc/backport/qoverload.h" +#include "../vlayout/vlayoutexporter.h" #if QT_VERSION < QT_VERSION_CHECK(5, 12, 0) #include "../vmisc/backport/qscopeguard.h" @@ -3346,7 +3347,11 @@ void MainWindow::on_actionCreateManualLayout_triggered() return; } - RLDFile(rldFile.fileName(), listDetails); + VLayoutExporter exporter; + exporter.SetFileName(rldFile.fileName()); +// exporter.SetXScale(m_dialogSaveLayout->GetXScale()); +// exporter.SetYScale(m_dialogSaveLayout->GetYScale()); + exporter.ExportToRLD(listDetails); QStringList arguments {"-r", rldFile.fileName()}; if (isNoScaling) @@ -3424,7 +3429,11 @@ void MainWindow::on_actionUpdateManualLayout_triggered() return; } - RLDFile(rldFile.fileName(), listDetails); + VLayoutExporter exporter; + exporter.SetFileName(rldFile.fileName()); +// exporter.SetXScale(m_dialogSaveLayout->GetXScale()); +// exporter.SetYScale(m_dialogSaveLayout->GetYScale()); + exporter.ExportToRLD(listDetails); QStringList arguments {filePath, "-r", rldFile.fileName()}; if (isNoScaling) diff --git a/src/app/valentina/mainwindowsnogui.cpp b/src/app/valentina/mainwindowsnogui.cpp index a96cb9c57..30e3c599b 100644 --- a/src/app/valentina/mainwindowsnogui.cpp +++ b/src/app/valentina/mainwindowsnogui.cpp @@ -753,7 +753,7 @@ void MainWindowsNoGUI::ExportApparelLayout(const QVector &details, exporter.ExportToAAMADXF(details); break; case LayoutExportFormats::RLD: - RLDFile(name, details, m_dialogSaveLayout->GetXScale(), m_dialogSaveLayout->GetYScale()); + exporter.ExportToRLD(details); break; default: qDebug() << "Can't recognize file type." << Q_FUNC_INFO; @@ -1096,25 +1096,6 @@ void MainWindowsNoGUI::PdfTiledFile(const QString &name) m_layoutSettings->PdfTiledFile(name); } -//--------------------------------------------------------------------------------------------------------------------- -void MainWindowsNoGUI::RLDFile(const QString &name, QVector details, qreal xScale, qreal yScale) const -{ - for(auto detail : details) - { - detail.Scale(xScale, yScale); - } - - VRawLayoutData layoutDate; - layoutDate.pieces = details; - - VRawLayout generator; - if (not generator.WriteFile(name, layoutDate)) - { - const QString errorMsg = tr("Export raw layout data failed. %1.").arg(generator.ErrorString()); - qApp->IsPedantic() ? throw VException(errorMsg) : qCritical() << errorMsg; - } -} - //--------------------------------------------------------------------------------------------------------------------- void MainWindowsNoGUI::ExportScene(const QList &scenes, const QList &papers, const QList &shadows, diff --git a/src/app/valentina/mainwindowsnogui.h b/src/app/valentina/mainwindowsnogui.h index eaeb8bee5..247d1f5e4 100644 --- a/src/app/valentina/mainwindowsnogui.h +++ b/src/app/valentina/mainwindowsnogui.h @@ -142,7 +142,6 @@ protected: void CheckRequiredMeasurements(const VMeasurements *m) const; - void RLDFile(const QString &name, QVector details, qreal xScale=1, qreal yScale=1) const; private: Q_DISABLE_COPY(MainWindowsNoGUI) diff --git a/src/libs/vlayout/vlayoutexporter.cpp b/src/libs/vlayout/vlayoutexporter.cpp index c085dc5bb..ac967ffb0 100644 --- a/src/libs/vlayout/vlayoutexporter.cpp +++ b/src/libs/vlayout/vlayoutexporter.cpp @@ -44,6 +44,9 @@ #include "../vmisc/def.h" #include "../vobj/vobjpaintdevice.h" #include "../vdxf/vdxfpaintdevice.h" +#include "vrawlayout.h" +#include "../vmisc/vabstractvalapplication.h" +#include "../ifc/exception/vexception.h" namespace { @@ -304,6 +307,25 @@ void VLayoutExporter::ExportToASTMDXF(const QVector &details) cons generator.ExportToASTM(details); } +//--------------------------------------------------------------------------------------------------------------------- +void VLayoutExporter::ExportToRLD(const QVector &details) const +{ + for(auto detail : details) + { + detail.Scale(m_xScale, m_yScale); + } + + VRawLayoutData layoutData; + layoutData.pieces = details; + + VRawLayout generator; + if (not generator.WriteFile(m_fileName, layoutData)) + { + const QString errorMsg = tr("Export raw layout data failed. %1.").arg(generator.ErrorString()); + qApp->IsPedantic() ? throw VException(errorMsg) : qCritical() << errorMsg; + } +} + //--------------------------------------------------------------------------------------------------------------------- auto VLayoutExporter::SupportPDFConversion() -> bool { diff --git a/src/libs/vlayout/vlayoutexporter.h b/src/libs/vlayout/vlayoutexporter.h index 182e216dd..a44ab7d70 100644 --- a/src/libs/vlayout/vlayoutexporter.h +++ b/src/libs/vlayout/vlayoutexporter.h @@ -86,6 +86,7 @@ public: void ExportToFlatDXF(QGraphicsScene *scene, const QList > &details) const; void ExportToAAMADXF(const QVector &details) const; void ExportToASTMDXF(const QVector &details) const; + void ExportToRLD(const QVector &details) const; static auto SupportPDFConversion() -> bool;