2015-05-12 14:42:19 +02:00
|
|
|
/************************************************************************
|
|
|
|
**
|
|
|
|
** @file mainwindowsnogui.cpp
|
|
|
|
** @author Roman Telezhynskyi <dismine(at)gmail.com>
|
|
|
|
** @date 12 5, 2015
|
|
|
|
**
|
|
|
|
** @brief
|
|
|
|
** @copyright
|
2017-10-05 11:20:01 +02:00
|
|
|
** This source code is part of the Valentina project, a pattern making
|
2015-05-12 14:42:19 +02:00
|
|
|
** program, whose allow create and modeling patterns of clothing.
|
|
|
|
** Copyright (C) 2015 Valentina project
|
|
|
|
** <https://bitbucket.org/dismine/valentina> All Rights Reserved.
|
|
|
|
**
|
|
|
|
** Valentina is free software: you can redistribute it and/or modify
|
|
|
|
** it under the terms of the GNU General Public License as published by
|
|
|
|
** the Free Software Foundation, either version 3 of the License, or
|
|
|
|
** (at your option) any later version.
|
|
|
|
**
|
|
|
|
** Valentina is distributed in the hope that it will be useful,
|
|
|
|
** but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
** MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
** GNU General Public License for more details.
|
|
|
|
**
|
|
|
|
** You should have received a copy of the GNU General Public License
|
|
|
|
** along with Valentina. If not, see <http://www.gnu.org/licenses/>.
|
|
|
|
**
|
|
|
|
*************************************************************************/
|
|
|
|
|
|
|
|
#include "mainwindowsnogui.h"
|
2015-06-15 15:10:55 +02:00
|
|
|
#include "core/vapplication.h"
|
2015-08-27 17:55:17 +02:00
|
|
|
#include "../vpatterndb/vcontainer.h"
|
|
|
|
#include "../vobj/vobjpaintdevice.h"
|
2015-09-07 21:47:02 +02:00
|
|
|
#include "../vdxf/vdxfpaintdevice.h"
|
2015-08-25 19:53:03 +02:00
|
|
|
#include "dialogs/dialoglayoutsettings.h"
|
2016-02-23 15:59:05 +01:00
|
|
|
#include "../vwidgets/vmaingraphicsscene.h"
|
2017-09-27 13:47:05 +02:00
|
|
|
#include "../vmisc/dialogs/dialogexporttocsv.h"
|
|
|
|
#include "../vmisc/qxtcsvmodel.h"
|
2018-08-06 18:38:23 +02:00
|
|
|
#include "../vformat/vmeasurements.h"
|
2015-08-27 18:03:43 +02:00
|
|
|
#include "../vlayout/vlayoutgenerator.h"
|
|
|
|
#include "dialogs/dialoglayoutprogress.h"
|
|
|
|
#include "dialogs/dialogsavelayout.h"
|
|
|
|
#include "../vlayout/vposter.h"
|
2017-02-23 10:37:19 +01:00
|
|
|
#include "../vpatterndb/floatItemData/vpiecelabeldata.h"
|
|
|
|
#include "../vpatterndb/floatItemData/vpatternlabeldata.h"
|
|
|
|
#include "../vpatterndb/floatItemData/vgrainlinedata.h"
|
2017-08-21 16:29:25 +02:00
|
|
|
#include "../vpatterndb/measurements.h"
|
2017-09-27 13:47:05 +02:00
|
|
|
#include "../vpatterndb/calculator.h"
|
2017-02-08 09:28:18 +01:00
|
|
|
#include "../vtools/tools/vabstracttool.h"
|
2017-07-01 13:41:46 +02:00
|
|
|
#include "../vtools/tools/vtoolseamallowance.h"
|
2018-08-06 18:38:23 +02:00
|
|
|
#include "../ifc/xml/vvstconverter.h"
|
|
|
|
#include "../ifc/xml/vvitconverter.h"
|
2015-05-12 14:42:19 +02:00
|
|
|
|
2015-05-14 14:27:04 +02:00
|
|
|
#include <QFileDialog>
|
|
|
|
#include <QFileInfo>
|
2015-05-12 14:42:19 +02:00
|
|
|
#include <QGraphicsScene>
|
2015-05-14 14:27:04 +02:00
|
|
|
#include <QMessageBox>
|
|
|
|
#include <QProcess>
|
2015-05-12 17:15:10 +02:00
|
|
|
#include <QToolButton>
|
2015-05-14 14:27:04 +02:00
|
|
|
#include <QtSvg>
|
|
|
|
#include <QPrintPreviewDialog>
|
|
|
|
#include <QPrintDialog>
|
2015-05-31 12:00:16 +02:00
|
|
|
#include <QPrinterInfo>
|
2019-01-20 11:19:42 +01:00
|
|
|
#include <QtConcurrent>
|
2019-01-20 15:50:16 +01:00
|
|
|
#include <functional>
|
2019-04-28 17:49:29 +02:00
|
|
|
#include <QPageSize>
|
2015-05-14 14:27:04 +02:00
|
|
|
|
2018-02-03 19:21:08 +01:00
|
|
|
#if defined(Q_OS_WIN32) && QT_VERSION >= QT_VERSION_CHECK(5, 7, 0)
|
|
|
|
#include <QWinTaskbarButton>
|
|
|
|
#include <QWinTaskbarProgress>
|
|
|
|
#endif
|
|
|
|
|
2018-08-06 18:38:23 +02:00
|
|
|
QT_WARNING_PUSH
|
|
|
|
QT_WARNING_DISABLE_CLANG("-Wmissing-prototypes")
|
|
|
|
QT_WARNING_DISABLE_INTEL(1418)
|
|
|
|
|
|
|
|
Q_LOGGING_CATEGORY(vMainNoGUIWindow, "v.mainnoguiwindow")
|
|
|
|
|
|
|
|
QT_WARNING_POP
|
|
|
|
|
2019-01-17 09:36:37 +01:00
|
|
|
#ifndef PDFTOPS
|
2015-05-14 14:27:04 +02:00
|
|
|
#ifdef Q_OS_WIN
|
2019-01-17 09:36:37 +01:00
|
|
|
# define PDFTOPS QStringLiteral("pdftops.exe")
|
2015-05-14 14:27:04 +02:00
|
|
|
#else
|
2019-01-17 09:36:37 +01:00
|
|
|
# define PDFTOPS QStringLiteral("pdftops")
|
|
|
|
#endif
|
2015-05-14 14:27:04 +02:00
|
|
|
#endif
|
2015-05-12 14:42:19 +02:00
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
namespace
|
|
|
|
{
|
2018-02-03 14:29:23 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-07-16 20:10:48 +02:00
|
|
|
bool CreateLayoutPath(const QString &path)
|
|
|
|
{
|
|
|
|
bool usedNotExistedDir = true;
|
|
|
|
QDir dir(path);
|
|
|
|
dir.setPath(path);
|
|
|
|
if (not dir.exists(path))
|
|
|
|
{
|
2018-04-13 08:14:55 +02:00
|
|
|
usedNotExistedDir = dir.mkpath(QChar('.'));
|
2017-07-16 20:10:48 +02:00
|
|
|
}
|
|
|
|
return usedNotExistedDir;
|
|
|
|
}
|
|
|
|
|
2018-02-03 14:29:23 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-07-16 20:10:48 +02:00
|
|
|
void RemoveLayoutPath(const QString &path, bool usedNotExistedDir)
|
|
|
|
{
|
|
|
|
if (usedNotExistedDir)
|
|
|
|
{
|
|
|
|
QDir dir(path);
|
2018-04-13 08:14:55 +02:00
|
|
|
dir.rmpath(QChar('.'));
|
2017-07-16 20:10:48 +02:00
|
|
|
}
|
|
|
|
}
|
2019-03-27 09:29:59 +01:00
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
Q_DECL_UNUSED void InsertGlobalContours(const QList<QGraphicsScene *> &scenes, const QList<QGraphicsItem *> &gcontours);
|
|
|
|
void InsertGlobalContours(const QList<QGraphicsScene *> &scenes, const QList<QGraphicsItem *> &gcontours)
|
|
|
|
{
|
|
|
|
if (scenes.size() != gcontours.size())
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
for(int i = 0; i < scenes.size(); ++i)
|
|
|
|
{
|
|
|
|
scenes.at(i)->addItem(gcontours.at(i));
|
|
|
|
}
|
|
|
|
}
|
2017-07-16 20:10:48 +02:00
|
|
|
}
|
|
|
|
|
2015-05-12 14:42:19 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
MainWindowsNoGUI::MainWindowsNoGUI(QWidget *parent)
|
2017-02-09 14:43:17 +01:00
|
|
|
: VAbstractMainWindow(parent),
|
|
|
|
listDetails(),
|
|
|
|
currentScene(nullptr),
|
|
|
|
tempSceneLayout(nullptr),
|
2018-09-18 15:38:16 +02:00
|
|
|
pattern(new VContainer(qApp->TrVars(), qApp->patternUnitP(), valentinaNamespace)),
|
2017-02-09 14:43:17 +01:00
|
|
|
doc(nullptr),
|
|
|
|
papers(),
|
|
|
|
shadows(),
|
|
|
|
scenes(),
|
|
|
|
details(),
|
2019-03-27 09:29:59 +01:00
|
|
|
gcontours(),
|
2017-07-16 20:10:48 +02:00
|
|
|
detailsOnLayout(),
|
2017-02-09 14:43:17 +01:00
|
|
|
undoAction(nullptr),
|
|
|
|
redoAction(nullptr),
|
|
|
|
actionDockWidgetToolOptions(nullptr),
|
|
|
|
actionDockWidgetGroups(nullptr),
|
|
|
|
isNoScaling(false),
|
2016-06-22 15:23:05 +02:00
|
|
|
isLayoutStale(true),
|
2018-11-24 18:34:59 +01:00
|
|
|
isNeedAutosave(false),
|
2016-09-30 18:33:10 +02:00
|
|
|
ignorePrinterFields(false),
|
2016-06-22 15:23:05 +02:00
|
|
|
margins(),
|
|
|
|
paperSize(),
|
2017-10-13 16:48:20 +02:00
|
|
|
m_dialogSaveLayout(),
|
2019-03-27 09:15:24 +01:00
|
|
|
m_mouseCoordinate(),
|
2018-02-03 19:21:08 +01:00
|
|
|
#if defined(Q_OS_WIN32) && QT_VERSION >= QT_VERSION_CHECK(5, 7, 0)
|
|
|
|
m_taskbarButton(new QWinTaskbarButton(this)),
|
|
|
|
m_taskbarProgress(nullptr),
|
|
|
|
#endif
|
2016-06-22 15:23:05 +02:00
|
|
|
isTiled(false),
|
|
|
|
isAutoCrop(false),
|
2016-08-22 18:43:22 +02:00
|
|
|
isUnitePages(false),
|
|
|
|
layoutPrinterName()
|
2015-05-12 14:42:19 +02:00
|
|
|
{
|
|
|
|
InitTempLayoutScene();
|
2018-02-03 19:21:08 +01:00
|
|
|
|
|
|
|
#if defined(Q_OS_WIN32) && QT_VERSION >= QT_VERSION_CHECK(5, 7, 0)
|
|
|
|
m_taskbarButton->setWindow(this->windowHandle());
|
|
|
|
m_taskbarProgress = m_taskbarButton->progress();
|
|
|
|
m_taskbarProgress->setMinimum(0);
|
|
|
|
#endif
|
2015-05-12 14:42:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
MainWindowsNoGUI::~MainWindowsNoGUI()
|
|
|
|
{
|
2019-03-27 09:15:24 +01:00
|
|
|
delete m_mouseCoordinate;
|
2015-05-12 14:42:19 +02:00
|
|
|
delete tempSceneLayout;
|
|
|
|
delete pattern;
|
|
|
|
}
|
|
|
|
|
2015-05-12 17:15:10 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::ToolLayoutSettings(bool checked)
|
|
|
|
{
|
2015-05-12 19:59:36 +02:00
|
|
|
QToolButton *tButton = qobject_cast< QToolButton * >(this->sender());
|
|
|
|
SCASSERT(tButton != nullptr)
|
|
|
|
|
2015-05-12 17:15:10 +02:00
|
|
|
if (checked)
|
|
|
|
{
|
2015-08-25 19:53:03 +02:00
|
|
|
VLayoutGenerator lGenerator;
|
|
|
|
|
2015-05-12 17:15:10 +02:00
|
|
|
DialogLayoutSettings layout(&lGenerator, this);
|
|
|
|
if (layout.exec() == QDialog::Rejected)
|
|
|
|
{
|
2015-05-12 19:59:36 +02:00
|
|
|
tButton->setChecked(false);
|
2015-05-12 17:15:10 +02:00
|
|
|
return;
|
|
|
|
}
|
2016-08-22 18:43:22 +02:00
|
|
|
layoutPrinterName = layout.SelectedPrinter();
|
2019-03-30 10:16:54 +01:00
|
|
|
GenerateLayout(lGenerator);
|
2015-08-25 19:53:03 +02:00
|
|
|
tButton->setChecked(false);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
tButton->setChecked(true);
|
|
|
|
}
|
|
|
|
}
|
2015-05-12 17:15:10 +02:00
|
|
|
|
2015-08-25 19:53:03 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2019-03-30 10:16:54 +01:00
|
|
|
bool MainWindowsNoGUI::GenerateLayout(VLayoutGenerator& lGenerator)
|
2015-08-25 19:53:03 +02:00
|
|
|
{
|
|
|
|
lGenerator.SetDetails(listDetails);
|
2019-03-29 18:52:37 +01:00
|
|
|
|
|
|
|
QElapsedTimer timer;
|
|
|
|
timer.start();
|
|
|
|
|
|
|
|
#if defined(Q_OS_WIN32) && QT_VERSION >= QT_VERSION_CHECK(5, 7, 0)
|
|
|
|
QTimer *progressTimer = nullptr;
|
|
|
|
#endif
|
|
|
|
|
2019-04-03 12:29:42 +02:00
|
|
|
QSharedPointer<DialogLayoutProgress> progress;
|
2015-12-09 12:31:33 +01:00
|
|
|
if (VApplication::IsGUIMode())
|
2015-08-25 19:53:03 +02:00
|
|
|
{
|
2018-02-03 19:21:08 +01:00
|
|
|
#if defined(Q_OS_WIN32) && QT_VERSION >= QT_VERSION_CHECK(5, 7, 0)
|
|
|
|
m_taskbarProgress->setVisible(true);
|
|
|
|
m_taskbarProgress->setValue(0);
|
2019-08-21 16:14:23 +02:00
|
|
|
m_taskbarProgress->setMaximum(lGenerator.GetNestingTime()*60);
|
2019-03-29 18:52:37 +01:00
|
|
|
progressTimer = new QTimer(this);
|
2019-08-21 16:14:23 +02:00
|
|
|
connect(progressTimer, &QTimer::timeout, this, [this, timer]()
|
2019-03-29 18:52:37 +01:00
|
|
|
{
|
2019-08-21 16:14:23 +02:00
|
|
|
m_taskbarProgress->setValue(static_cast<int>(timer.elapsed()/1000));
|
2019-03-29 18:52:37 +01:00
|
|
|
});
|
|
|
|
progressTimer->start(1000);
|
2018-02-03 19:21:08 +01:00
|
|
|
#endif
|
2019-04-03 12:29:42 +02:00
|
|
|
|
|
|
|
progress = QSharedPointer<DialogLayoutProgress>(
|
|
|
|
new DialogLayoutProgress(timer, lGenerator.GetNestingTimeMSecs(), this));
|
|
|
|
|
2019-03-30 10:17:54 +01:00
|
|
|
connect(progress.data(), &DialogLayoutProgress::Abort, &lGenerator, &VLayoutGenerator::Abort);
|
2019-04-02 14:29:33 +02:00
|
|
|
connect(progress.data(), &DialogLayoutProgress::Timeout, &lGenerator, &VLayoutGenerator::Timeout);
|
2019-04-03 12:29:42 +02:00
|
|
|
|
|
|
|
progress->Start();
|
2015-08-25 19:53:03 +02:00
|
|
|
}
|
2019-04-03 12:29:42 +02:00
|
|
|
else
|
|
|
|
{
|
|
|
|
// Because the progress bar dialog will not terminate nesting we must create separate timer for this
|
|
|
|
auto *progressTimer = new QTimer(this);
|
|
|
|
connect(progressTimer, &QTimer::timeout, this, [timer, &lGenerator, progressTimer]()
|
|
|
|
{
|
|
|
|
const int timeout = static_cast<int>(lGenerator.GetNestingTimeMSecs() - timer.elapsed());
|
2019-03-29 18:52:37 +01:00
|
|
|
|
2019-04-03 12:29:42 +02:00
|
|
|
if (timeout <= 1000)
|
|
|
|
{
|
|
|
|
lGenerator.Timeout();
|
|
|
|
progressTimer->stop();
|
|
|
|
progressTimer->deleteLater();
|
|
|
|
}
|
|
|
|
});
|
|
|
|
progressTimer->start(1000);
|
|
|
|
}
|
2019-03-29 18:52:37 +01:00
|
|
|
|
|
|
|
LayoutErrors nestingState = LayoutErrors::NoError;
|
|
|
|
|
2019-03-30 10:17:54 +01:00
|
|
|
auto IsTimeout = [&progress, &lGenerator, timer, &nestingState]()
|
2019-03-29 18:52:37 +01:00
|
|
|
{
|
2019-04-03 12:29:42 +02:00
|
|
|
if (timer.hasExpired(lGenerator.GetNestingTimeMSecs()))
|
2019-03-29 18:52:37 +01:00
|
|
|
{
|
2019-04-01 18:21:39 +02:00
|
|
|
if (nestingState != LayoutErrors::EmptyPaperError)
|
|
|
|
{
|
|
|
|
nestingState = LayoutErrors::Timeout;
|
|
|
|
}
|
2019-04-03 12:29:42 +02:00
|
|
|
|
|
|
|
if (VApplication::IsGUIMode())
|
|
|
|
{
|
|
|
|
progress->Finished();
|
|
|
|
}
|
2019-03-29 18:52:37 +01:00
|
|
|
return true;
|
|
|
|
}
|
|
|
|
return false;
|
|
|
|
};
|
|
|
|
|
|
|
|
bool rotationUsed = false;
|
|
|
|
int rotatate = 1;
|
2019-03-30 10:17:54 +01:00
|
|
|
lGenerator.SetShift(-1); // Trigger first shift calulation
|
|
|
|
lGenerator.SetRotate(false);
|
2019-03-29 18:52:37 +01:00
|
|
|
int papersCount = INT_MAX;
|
|
|
|
qreal efficiency = 0;
|
2019-06-18 14:14:52 +02:00
|
|
|
bool hasResult = false;
|
2019-03-29 18:52:37 +01:00
|
|
|
|
2019-03-30 10:17:54 +01:00
|
|
|
QCoreApplication::processEvents();
|
|
|
|
|
2019-03-29 18:52:37 +01:00
|
|
|
forever
|
2015-08-25 19:53:03 +02:00
|
|
|
{
|
2019-03-29 18:52:37 +01:00
|
|
|
if (IsTimeout())
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2019-06-18 14:14:52 +02:00
|
|
|
lGenerator.Generate(timer, lGenerator.GetNestingTimeMSecs(), nestingState);
|
2019-03-29 18:52:37 +01:00
|
|
|
|
|
|
|
if (IsTimeout())
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2019-03-30 10:17:54 +01:00
|
|
|
switch (lGenerator.State())
|
2019-03-29 18:52:37 +01:00
|
|
|
{
|
|
|
|
case LayoutErrors::NoError:
|
|
|
|
if (lGenerator.PapersCount() <= papersCount)
|
|
|
|
{
|
|
|
|
const qreal layoutEfficiency = lGenerator.LayoutEfficiency();
|
2019-03-30 10:17:54 +01:00
|
|
|
if (efficiency < layoutEfficiency)
|
2019-03-29 18:52:37 +01:00
|
|
|
{
|
|
|
|
efficiency = layoutEfficiency;
|
2019-04-03 12:29:42 +02:00
|
|
|
if (VApplication::IsGUIMode())
|
|
|
|
{
|
|
|
|
progress->Efficiency(efficiency);
|
|
|
|
}
|
2019-03-29 18:52:37 +01:00
|
|
|
|
|
|
|
CleanLayout();
|
|
|
|
papers = lGenerator.GetPapersItems();// Blank sheets
|
|
|
|
details = lGenerator.GetAllDetailsItems();// All details items
|
|
|
|
detailsOnLayout = lGenerator.GetAllDetails();// All details items
|
|
|
|
shadows = CreateShadows(papers);
|
2019-06-18 11:35:43 +02:00
|
|
|
isLayoutPortrait = lGenerator.IsPortrait();
|
2019-03-29 18:52:37 +01:00
|
|
|
scenes = CreateScenes(papers, shadows, details);
|
2019-07-27 06:22:22 +02:00
|
|
|
#if !defined(V_NO_ASSERT)
|
2019-03-29 18:52:37 +01:00
|
|
|
//Uncomment to debug, shows global contour
|
2019-07-27 06:22:22 +02:00
|
|
|
// gcontours = lGenerator.GetGlobalContours(); // uncomment for debugging
|
|
|
|
// InsertGlobalContours(scenes, gcontours); // uncomment for debugging
|
|
|
|
#endif
|
2019-04-28 17:32:09 +02:00
|
|
|
if (VApplication::IsGUIMode())
|
|
|
|
{
|
|
|
|
PrepareSceneList(PreviewQuatilty::Fast);
|
|
|
|
}
|
2019-03-29 18:52:37 +01:00
|
|
|
ignorePrinterFields = not lGenerator.IsUsePrinterFields();
|
|
|
|
margins = lGenerator.GetPrinterFields();
|
|
|
|
paperSize = QSizeF(lGenerator.GetPaperWidth(), lGenerator.GetPaperHeight());
|
|
|
|
isAutoCrop = lGenerator.GetAutoCrop();
|
|
|
|
isUnitePages = lGenerator.IsUnitePages();
|
|
|
|
isLayoutStale = false;
|
2019-07-20 21:03:43 +02:00
|
|
|
papersCount = lGenerator.PapersCount();
|
2019-06-18 14:14:52 +02:00
|
|
|
hasResult = true;
|
2019-03-29 18:52:37 +01:00
|
|
|
}
|
2019-07-20 21:56:48 +02:00
|
|
|
else
|
|
|
|
{
|
|
|
|
if (lGenerator.IsRotationNeeded())
|
|
|
|
{
|
|
|
|
lGenerator.SetRotate(true);
|
|
|
|
lGenerator.SetRotationNumber(++rotatate);
|
|
|
|
rotationUsed = true;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
if (lGenerator.IsRotationNeeded())
|
|
|
|
{
|
|
|
|
lGenerator.SetRotate(true);
|
|
|
|
lGenerator.SetRotationNumber(++rotatate);
|
|
|
|
rotationUsed = true;
|
|
|
|
}
|
2019-03-29 18:52:37 +01:00
|
|
|
}
|
|
|
|
lGenerator.SetShift(lGenerator.GetShift()/2.0);
|
|
|
|
break;
|
|
|
|
case LayoutErrors::EmptyPaperError:
|
2019-03-30 10:17:54 +01:00
|
|
|
if (lGenerator.IsRotationNeeded())
|
2019-03-29 18:52:37 +01:00
|
|
|
{
|
2019-03-30 10:17:54 +01:00
|
|
|
if (not rotationUsed)
|
|
|
|
{
|
|
|
|
lGenerator.SetRotate(true);
|
|
|
|
lGenerator.SetRotationNumber(++rotatate);
|
|
|
|
rotationUsed = true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
lGenerator.SetShift(lGenerator.GetShift()/2.0);
|
|
|
|
rotationUsed = false;
|
|
|
|
}
|
2019-03-29 18:52:37 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
lGenerator.SetShift(lGenerator.GetShift()/2.0);
|
|
|
|
}
|
|
|
|
break;
|
|
|
|
case LayoutErrors::Timeout:
|
|
|
|
case LayoutErrors::PrepareLayoutError:
|
|
|
|
case LayoutErrors::ProcessStoped:
|
2019-06-24 11:14:10 +02:00
|
|
|
case LayoutErrors::TerminatedByException:
|
2019-03-29 18:52:37 +01:00
|
|
|
default:
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2019-03-30 10:17:54 +01:00
|
|
|
nestingState = lGenerator.State();
|
|
|
|
|
2019-03-29 18:52:37 +01:00
|
|
|
if (nestingState == LayoutErrors::PrepareLayoutError || nestingState == LayoutErrors::ProcessStoped
|
2019-06-24 11:14:10 +02:00
|
|
|
|| nestingState == LayoutErrors::TerminatedByException
|
2019-03-29 18:52:37 +01:00
|
|
|
|| (nestingState == LayoutErrors::NoError && not qFuzzyIsNull(lGenerator.GetEfficiencyCoefficient())
|
|
|
|
&& efficiency >= lGenerator.GetEfficiencyCoefficient()))
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (IsTimeout())
|
|
|
|
{
|
|
|
|
break;
|
|
|
|
}
|
2015-08-25 19:53:03 +02:00
|
|
|
}
|
2015-05-12 17:15:10 +02:00
|
|
|
|
2019-04-03 12:29:42 +02:00
|
|
|
if (VApplication::IsGUIMode())
|
|
|
|
{
|
2019-04-28 17:32:09 +02:00
|
|
|
PrepareSceneList(PreviewQuatilty::Slow);
|
2019-04-03 12:29:42 +02:00
|
|
|
progress->Finished();
|
|
|
|
}
|
2019-03-30 10:17:54 +01:00
|
|
|
|
2018-02-03 19:21:08 +01:00
|
|
|
#if defined(Q_OS_WIN32) && QT_VERSION >= QT_VERSION_CHECK(5, 7, 0)
|
|
|
|
if (VApplication::IsGUIMode())
|
|
|
|
{
|
2019-03-29 18:52:37 +01:00
|
|
|
progressTimer->stop();
|
2018-02-03 19:21:08 +01:00
|
|
|
m_taskbarProgress->setVisible(false);
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
2019-03-29 18:52:37 +01:00
|
|
|
if (VApplication::IsGUIMode())
|
2015-08-25 19:53:03 +02:00
|
|
|
{
|
2019-03-29 18:52:37 +01:00
|
|
|
QApplication::alert(this);
|
|
|
|
}
|
2015-05-12 17:15:10 +02:00
|
|
|
|
2019-06-18 14:14:52 +02:00
|
|
|
if (hasResult && nestingState != LayoutErrors::ProcessStoped)
|
2019-03-29 18:52:37 +01:00
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
ShowLayoutError(nestingState);
|
|
|
|
if (not VApplication::IsGUIMode())
|
|
|
|
{
|
|
|
|
qApp->exit(V_EX_DATAERR);
|
|
|
|
}
|
|
|
|
return false;
|
2015-05-12 17:15:10 +02:00
|
|
|
}
|
2015-08-25 19:53:03 +02:00
|
|
|
}
|
2019-03-29 18:52:37 +01:00
|
|
|
|
2015-08-25 19:53:03 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2019-03-29 18:52:37 +01:00
|
|
|
void MainWindowsNoGUI::ShowLayoutError(const LayoutErrors &state)
|
2015-08-25 19:53:03 +02:00
|
|
|
{
|
|
|
|
switch (state)
|
2015-05-12 17:15:10 +02:00
|
|
|
{
|
2015-08-25 19:53:03 +02:00
|
|
|
case LayoutErrors::NoError:
|
|
|
|
return;
|
|
|
|
case LayoutErrors::PrepareLayoutError:
|
2015-10-01 16:59:01 +02:00
|
|
|
qCritical() << tr("Couldn't prepare data for creation layout");
|
2015-08-25 19:53:03 +02:00
|
|
|
break;
|
|
|
|
case LayoutErrors::EmptyPaperError:
|
2017-10-10 11:22:59 +02:00
|
|
|
qCritical() << tr("One or more pattern pieces are bigger than the paper format you selected. Please, "
|
|
|
|
"select a bigger paper format.");
|
2015-08-25 19:53:03 +02:00
|
|
|
break;
|
2019-03-29 18:52:37 +01:00
|
|
|
case LayoutErrors::Timeout:
|
|
|
|
qCritical() << tr("Timeout.");
|
|
|
|
break;
|
2019-06-24 11:14:10 +02:00
|
|
|
case LayoutErrors::TerminatedByException:
|
|
|
|
qCritical() << tr("Process has been stoped because of exception.");
|
|
|
|
break;
|
2016-12-21 20:35:07 +01:00
|
|
|
case LayoutErrors::ProcessStoped:
|
2015-08-25 19:53:03 +02:00
|
|
|
default:
|
|
|
|
break;
|
2015-05-12 17:15:10 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-09-27 13:47:05 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::ExportFMeasurementsToCSV()
|
|
|
|
{
|
|
|
|
QString fileName = CSVFilePath();
|
|
|
|
|
|
|
|
if (fileName.isEmpty())
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
DialogExportToCSV dialog(this);
|
|
|
|
dialog.SetWithHeader(qApp->Settings()->GetCSVWithHeader());
|
|
|
|
dialog.SetSelectedMib(qApp->Settings()->GetCSVCodec());
|
|
|
|
dialog.SetSeparator(qApp->Settings()->GetCSVSeparator());
|
|
|
|
|
|
|
|
if (dialog.exec() == QDialog::Accepted)
|
|
|
|
{
|
|
|
|
ExportFMeasurementsToCSVData(fileName, dialog.IsWithHeader(), dialog.GetSelectedMib(), dialog.GetSeparator());
|
|
|
|
|
|
|
|
qApp->Settings()->SetCSVSeparator(dialog.GetSeparator());
|
|
|
|
qApp->Settings()->SetCSVCodec(dialog.GetSelectedMib());
|
|
|
|
qApp->Settings()->SetCSVWithHeader(dialog.IsWithHeader());
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-14 14:27:04 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-10-13 16:48:20 +02:00
|
|
|
void MainWindowsNoGUI::ExportData(const QVector<VLayoutPiece> &listDetails)
|
2017-07-09 13:45:49 +02:00
|
|
|
{
|
2017-10-13 16:48:20 +02:00
|
|
|
const LayoutExportFormats format = m_dialogSaveLayout->Format();
|
2017-07-16 20:10:48 +02:00
|
|
|
|
|
|
|
if (format == LayoutExportFormats::DXF_AC1006_AAMA ||
|
|
|
|
format == LayoutExportFormats::DXF_AC1009_AAMA ||
|
|
|
|
format == LayoutExportFormats::DXF_AC1012_AAMA ||
|
|
|
|
format == LayoutExportFormats::DXF_AC1014_AAMA ||
|
|
|
|
format == LayoutExportFormats::DXF_AC1015_AAMA ||
|
|
|
|
format == LayoutExportFormats::DXF_AC1018_AAMA ||
|
|
|
|
format == LayoutExportFormats::DXF_AC1021_AAMA ||
|
|
|
|
format == LayoutExportFormats::DXF_AC1024_AAMA ||
|
|
|
|
format == LayoutExportFormats::DXF_AC1027_AAMA)
|
2017-07-09 13:45:49 +02:00
|
|
|
{
|
2017-10-13 16:48:20 +02:00
|
|
|
if (m_dialogSaveLayout->Mode() == Draw::Layout)
|
2017-07-16 20:10:48 +02:00
|
|
|
{
|
|
|
|
for (int i = 0; i < detailsOnLayout.size(); ++i)
|
|
|
|
{
|
2019-01-17 09:36:37 +01:00
|
|
|
const QString name = m_dialogSaveLayout->Path() + '/' + m_dialogSaveLayout->FileName() +
|
2019-04-10 15:32:35 +02:00
|
|
|
QString::number(i+1) + DialogSaveLayout::ExportFormatSuffix(m_dialogSaveLayout->Format());
|
2017-07-16 20:10:48 +02:00
|
|
|
|
|
|
|
QGraphicsRectItem *paper = qgraphicsitem_cast<QGraphicsRectItem *>(papers.at(i));
|
|
|
|
SCASSERT(paper != nullptr)
|
|
|
|
|
2017-10-13 16:48:20 +02:00
|
|
|
ExportApparelLayout(detailsOnLayout.at(i), name, paper->rect().size().toSize());
|
2017-07-16 20:10:48 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-10-13 16:48:20 +02:00
|
|
|
ExportDetailsAsApparelLayout(listDetails);
|
2017-07-16 20:10:48 +02:00
|
|
|
}
|
2017-07-09 13:45:49 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-10-13 16:48:20 +02:00
|
|
|
if (m_dialogSaveLayout->Mode() == Draw::Layout)
|
2017-07-09 13:45:49 +02:00
|
|
|
{
|
2017-10-13 16:48:20 +02:00
|
|
|
ExportFlatLayout(scenes, papers, shadows, details, ignorePrinterFields, margins);
|
2017-07-09 13:45:49 +02:00
|
|
|
}
|
2017-07-16 20:10:48 +02:00
|
|
|
else
|
2017-07-09 13:45:49 +02:00
|
|
|
{
|
2017-10-13 16:48:20 +02:00
|
|
|
ExportDetailsAsFlatLayout(listDetails);
|
2017-07-09 13:45:49 +02:00
|
|
|
}
|
2017-07-16 20:10:48 +02:00
|
|
|
}
|
|
|
|
}
|
2017-07-09 13:45:49 +02:00
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-10-13 16:48:20 +02:00
|
|
|
void MainWindowsNoGUI::ExportFlatLayout(const QList<QGraphicsScene *> &scenes,
|
2017-07-16 20:10:48 +02:00
|
|
|
const QList<QGraphicsItem *> &papers, const QList<QGraphicsItem *> &shadows,
|
|
|
|
const QList<QList<QGraphicsItem *> > &details, bool ignorePrinterFields,
|
|
|
|
const QMarginsF &margins)
|
|
|
|
{
|
2017-10-13 16:48:20 +02:00
|
|
|
const QString path = m_dialogSaveLayout->Path();
|
2017-07-16 20:10:48 +02:00
|
|
|
bool usedNotExistedDir = CreateLayoutPath(path);
|
|
|
|
if (not usedNotExistedDir)
|
|
|
|
{
|
|
|
|
qCritical() << tr("Can't create a path");
|
|
|
|
return;
|
|
|
|
}
|
2017-07-09 21:27:54 +02:00
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
qApp->ValentinaSettings()->SetPathLayout(path);
|
2017-10-13 16:48:20 +02:00
|
|
|
const LayoutExportFormats format = m_dialogSaveLayout->Format();
|
2017-07-09 21:27:54 +02:00
|
|
|
|
2017-10-13 16:48:20 +02:00
|
|
|
if (format == LayoutExportFormats::PDFTiled && m_dialogSaveLayout->Mode() == Draw::Layout)
|
2017-07-16 20:10:48 +02:00
|
|
|
{
|
2019-01-17 09:36:37 +01:00
|
|
|
const QString name = path + '/' + m_dialogSaveLayout->FileName() + QString::number(1)
|
2019-04-10 15:32:35 +02:00
|
|
|
+ DialogSaveLayout::ExportFormatSuffix(m_dialogSaveLayout->Format());
|
2017-07-16 20:10:48 +02:00
|
|
|
PdfTiledFile(name);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-10-13 16:48:20 +02:00
|
|
|
ExportScene(scenes, papers, shadows, details, ignorePrinterFields, margins);
|
2017-07-16 20:10:48 +02:00
|
|
|
}
|
2017-07-09 21:27:54 +02:00
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
RemoveLayoutPath(path, usedNotExistedDir);
|
|
|
|
}
|
2017-07-09 21:27:54 +02:00
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-10-13 16:48:20 +02:00
|
|
|
void MainWindowsNoGUI::ExportDetailsAsFlatLayout(const QVector<VLayoutPiece> &listDetails)
|
2017-07-16 20:10:48 +02:00
|
|
|
{
|
|
|
|
if (listDetails.isEmpty())
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
QScopedPointer<QGraphicsScene> scene(new QGraphicsScene());
|
2017-07-09 21:27:54 +02:00
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
QList<QGraphicsItem *> list;
|
2018-04-03 13:36:38 +02:00
|
|
|
for (auto piece : listDetails)
|
2017-07-16 20:10:48 +02:00
|
|
|
{
|
2018-02-04 17:23:07 +01:00
|
|
|
QGraphicsItem *item = piece.GetItem(m_dialogSaveLayout->IsTextAsPaths());
|
|
|
|
qreal diff = 0;
|
2018-02-04 09:08:18 +01:00
|
|
|
if (piece.IsForceFlipping())
|
|
|
|
{
|
2018-02-04 17:23:07 +01:00
|
|
|
const qreal x = item->boundingRect().x();
|
2018-02-04 09:08:18 +01:00
|
|
|
piece.Mirror();
|
2018-02-04 17:23:07 +01:00
|
|
|
item = piece.GetItem(m_dialogSaveLayout->IsTextAsPaths());
|
|
|
|
diff = item->boundingRect().x() - x;
|
2018-02-04 09:08:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
if (piece.IsForceFlipping())
|
|
|
|
{
|
2018-02-04 17:23:07 +01:00
|
|
|
item->setPos(piece.GetMx()-diff, piece.GetMy());
|
2018-02-04 09:08:18 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
item->setPos(piece.GetMx(), piece.GetMy());
|
|
|
|
}
|
|
|
|
list.append(item);
|
2017-07-16 20:10:48 +02:00
|
|
|
}
|
2017-07-09 13:45:49 +02:00
|
|
|
|
2018-04-03 13:36:38 +02:00
|
|
|
for (auto item : list)
|
2017-07-16 20:10:48 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
scene->addItem(item);
|
2017-07-16 20:10:48 +02:00
|
|
|
}
|
2017-07-09 13:45:49 +02:00
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
QList<QGraphicsItem *> papers;// Blank sheets
|
|
|
|
QRect rect = scene->itemsBoundingRect().toRect();
|
2017-07-09 13:45:49 +02:00
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
const int mx = rect.x();
|
|
|
|
const int my = rect.y();
|
2017-07-09 13:45:49 +02:00
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
QTransform matrix;
|
|
|
|
matrix = matrix.translate(-mx, -my);
|
|
|
|
|
2018-04-03 13:36:38 +02:00
|
|
|
for (auto item : list)
|
2017-07-16 20:10:48 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
item->setTransform(matrix);
|
2017-07-09 13:45:49 +02:00
|
|
|
}
|
2017-07-16 20:10:48 +02:00
|
|
|
|
|
|
|
rect = scene->itemsBoundingRect().toRect();
|
|
|
|
|
|
|
|
QGraphicsRectItem *paper = new QGraphicsRectItem(rect);
|
|
|
|
paper->setPen(QPen(Qt::black, 1));
|
|
|
|
paper->setBrush(QBrush(Qt::white));
|
|
|
|
papers.append(paper);
|
|
|
|
|
|
|
|
QList<QList<QGraphicsItem *> > details;// All details
|
|
|
|
details.append(list);
|
|
|
|
|
|
|
|
QList<QGraphicsItem *> shadows = CreateShadows(papers);
|
|
|
|
QList<QGraphicsScene *> scenes = CreateScenes(papers, shadows, details);
|
|
|
|
|
|
|
|
const bool ignorePrinterFields = false;
|
|
|
|
const qreal margin = ToPixel(1, Unit::Cm);
|
2017-10-13 16:48:20 +02:00
|
|
|
ExportFlatLayout(scenes, papers, shadows, details, ignorePrinterFields, QMarginsF(margin, margin, margin, margin));
|
2017-07-16 20:10:48 +02:00
|
|
|
|
|
|
|
qDeleteAll(scenes);//Scene will clear all other items
|
2017-07-09 13:45:49 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-10-13 16:48:20 +02:00
|
|
|
void MainWindowsNoGUI::ExportApparelLayout(const QVector<VLayoutPiece> &details, const QString &name,
|
|
|
|
const QSize &size) const
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2017-10-13 16:48:20 +02:00
|
|
|
const QString path = m_dialogSaveLayout->Path();
|
2017-07-16 20:10:48 +02:00
|
|
|
bool usedNotExistedDir = CreateLayoutPath(path);
|
|
|
|
if (not usedNotExistedDir)
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2017-07-16 20:10:48 +02:00
|
|
|
qCritical() << tr("Can't create a path");
|
|
|
|
return;
|
2015-10-11 11:06:14 +02:00
|
|
|
}
|
2017-07-16 20:10:48 +02:00
|
|
|
|
2015-07-24 14:06:53 +02:00
|
|
|
qApp->ValentinaSettings()->SetPathLayout(path);
|
2017-10-13 16:48:20 +02:00
|
|
|
const LayoutExportFormats format = m_dialogSaveLayout->Format();
|
2015-05-14 14:27:04 +02:00
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
switch (format)
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2017-07-16 20:10:48 +02:00
|
|
|
case LayoutExportFormats::DXF_AC1006_ASTM:
|
|
|
|
case LayoutExportFormats::DXF_AC1009_ASTM:
|
|
|
|
case LayoutExportFormats::DXF_AC1012_ASTM:
|
|
|
|
case LayoutExportFormats::DXF_AC1014_ASTM:
|
|
|
|
case LayoutExportFormats::DXF_AC1015_ASTM:
|
|
|
|
case LayoutExportFormats::DXF_AC1018_ASTM:
|
|
|
|
case LayoutExportFormats::DXF_AC1021_ASTM:
|
|
|
|
case LayoutExportFormats::DXF_AC1024_ASTM:
|
|
|
|
case LayoutExportFormats::DXF_AC1027_ASTM:
|
|
|
|
Q_UNREACHABLE(); // For now not supported
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1006_AAMA:
|
2017-10-13 16:48:20 +02:00
|
|
|
AAMADxfFile(name, DRW::AC1006, m_dialogSaveLayout->IsBinaryDXFFormat(), size, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1009_AAMA:
|
2017-10-13 16:48:20 +02:00
|
|
|
AAMADxfFile(name, DRW::AC1009, m_dialogSaveLayout->IsBinaryDXFFormat(), size, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1012_AAMA:
|
2017-10-13 16:48:20 +02:00
|
|
|
AAMADxfFile(name, DRW::AC1012, m_dialogSaveLayout->IsBinaryDXFFormat(), size, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1014_AAMA:
|
2017-10-13 16:48:20 +02:00
|
|
|
AAMADxfFile(name, DRW::AC1014, m_dialogSaveLayout->IsBinaryDXFFormat(), size, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1015_AAMA:
|
2017-10-13 16:48:20 +02:00
|
|
|
AAMADxfFile(name, DRW::AC1015, m_dialogSaveLayout->IsBinaryDXFFormat(), size, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1018_AAMA:
|
2017-10-13 16:48:20 +02:00
|
|
|
AAMADxfFile(name, DRW::AC1018, m_dialogSaveLayout->IsBinaryDXFFormat(), size, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1021_AAMA:
|
2017-10-13 16:48:20 +02:00
|
|
|
AAMADxfFile(name, DRW::AC1021, m_dialogSaveLayout->IsBinaryDXFFormat(), size, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1024_AAMA:
|
2017-10-13 16:48:20 +02:00
|
|
|
AAMADxfFile(name, DRW::AC1024, m_dialogSaveLayout->IsBinaryDXFFormat(), size, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1027_AAMA:
|
2017-10-13 16:48:20 +02:00
|
|
|
AAMADxfFile(name, DRW::AC1027, m_dialogSaveLayout->IsBinaryDXFFormat(), size, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
break;
|
|
|
|
default:
|
|
|
|
qDebug() << "Can't recognize file type." << Q_FUNC_INFO;
|
|
|
|
break;
|
2017-07-08 19:18:47 +02:00
|
|
|
}
|
2017-07-16 20:10:48 +02:00
|
|
|
|
|
|
|
RemoveLayoutPath(path, usedNotExistedDir);
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-10-13 16:48:20 +02:00
|
|
|
void MainWindowsNoGUI::ExportDetailsAsApparelLayout(QVector<VLayoutPiece> listDetails)
|
2017-07-16 20:10:48 +02:00
|
|
|
{
|
|
|
|
if (listDetails.isEmpty())
|
2017-07-08 19:18:47 +02:00
|
|
|
{
|
2017-07-16 20:10:48 +02:00
|
|
|
return;
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
QScopedPointer<QGraphicsScene> scene(new QGraphicsScene());
|
|
|
|
|
|
|
|
QList<QGraphicsItem *> list;
|
|
|
|
for (int i=0; i < listDetails.count(); ++i)
|
2017-07-08 19:18:47 +02:00
|
|
|
{
|
2018-02-04 09:08:18 +01:00
|
|
|
VLayoutPiece piece = listDetails.at(i);
|
2018-02-04 17:23:07 +01:00
|
|
|
QGraphicsItem *item = piece.GetItem(m_dialogSaveLayout->IsTextAsPaths());
|
|
|
|
qreal diff = 0;
|
2018-02-04 09:08:18 +01:00
|
|
|
if (piece.IsForceFlipping())
|
|
|
|
{
|
2018-02-04 17:23:07 +01:00
|
|
|
const qreal x = item->boundingRect().x();
|
2018-02-04 09:08:18 +01:00
|
|
|
piece.Mirror();
|
2018-02-04 17:23:07 +01:00
|
|
|
item = piece.GetItem(m_dialogSaveLayout->IsTextAsPaths());
|
|
|
|
diff = item->boundingRect().x() - x;
|
2018-02-04 09:08:18 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
QTransform moveMatrix = piece.GetMatrix();
|
|
|
|
if (piece.IsForceFlipping())
|
|
|
|
{
|
2018-02-04 17:23:07 +01:00
|
|
|
item->setPos(piece.GetMx()-diff, piece.GetMy());
|
|
|
|
moveMatrix = moveMatrix.translate(-piece.GetMx()+diff, piece.GetMy());
|
2018-02-04 09:08:18 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
item->setPos(piece.GetMx(), piece.GetMy());
|
|
|
|
moveMatrix = moveMatrix.translate(piece.GetMx(), piece.GetMy());
|
|
|
|
}
|
|
|
|
listDetails[i].SetMatrix(moveMatrix);
|
|
|
|
list.append(item);
|
2017-07-16 20:10:48 +02:00
|
|
|
}
|
|
|
|
|
2018-04-03 13:36:38 +02:00
|
|
|
for (auto item : list)
|
2017-07-16 20:10:48 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
scene->addItem(item);
|
2017-07-16 20:10:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
QRect rect = scene->itemsBoundingRect().toRect();
|
|
|
|
|
|
|
|
const int mx = rect.x();
|
|
|
|
const int my = rect.y();
|
|
|
|
|
|
|
|
QTransform matrix;
|
|
|
|
matrix = matrix.translate(-mx, -my);
|
|
|
|
|
2018-04-03 13:36:38 +02:00
|
|
|
for (auto item : list)
|
2017-07-16 20:10:48 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
item->setTransform(matrix);
|
2017-07-16 20:10:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
rect = scene->itemsBoundingRect().toRect();
|
|
|
|
|
|
|
|
for (int i=0; i < listDetails.count(); ++i)
|
|
|
|
{
|
2018-02-04 09:08:18 +01:00
|
|
|
QTransform moveMatrix = listDetails.at(i).GetMatrix();
|
2018-02-04 17:23:07 +01:00
|
|
|
if (listDetails.at(i).IsForceFlipping())
|
|
|
|
{
|
|
|
|
moveMatrix = moveMatrix.translate(mx, -my);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
moveMatrix = moveMatrix.translate(-mx, -my);
|
|
|
|
}
|
2017-07-16 20:10:48 +02:00
|
|
|
listDetails[i].SetMatrix(moveMatrix);
|
2017-07-08 19:18:47 +02:00
|
|
|
}
|
2017-07-16 20:10:48 +02:00
|
|
|
|
2019-01-17 09:36:37 +01:00
|
|
|
const QString name = m_dialogSaveLayout->Path() + '/' + m_dialogSaveLayout->FileName() +
|
2019-04-10 15:32:35 +02:00
|
|
|
QString::number(1) + DialogSaveLayout::ExportFormatSuffix(m_dialogSaveLayout->Format());
|
2017-07-16 20:10:48 +02:00
|
|
|
|
2017-10-13 16:48:20 +02:00
|
|
|
ExportApparelLayout(listDetails, name, rect.size());
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::PrintPages(QPrinter *printer)
|
|
|
|
{
|
2016-06-15 12:55:43 +02:00
|
|
|
// Here we try understand difference between printer's dpi and our.
|
|
|
|
// Get printer rect acording to our dpi.
|
|
|
|
const QRectF printerPageRect(0, 0, ToPixel(printer->pageRect(QPrinter::Millimeter).width(), Unit::Mm),
|
|
|
|
ToPixel(printer->pageRect(QPrinter::Millimeter).height(), Unit::Mm));
|
|
|
|
const double xscale = printer->pageRect().width() / printerPageRect.width();
|
|
|
|
const double yscale = printer->pageRect().height() / printerPageRect.height();
|
|
|
|
const double scale = qMin(xscale, yscale);
|
|
|
|
|
|
|
|
QPainter painter;
|
|
|
|
if (not painter.begin(printer))
|
|
|
|
{ // failed to open file
|
|
|
|
qWarning("failed to open file, is it writable?");
|
2015-05-14 14:27:04 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2019-01-17 09:36:37 +01:00
|
|
|
painter.setFont( QFont( QStringLiteral("Arial"), 8, QFont::Normal ) );
|
2016-06-15 12:55:43 +02:00
|
|
|
painter.setRenderHint(QPainter::Antialiasing, true);
|
2018-02-06 18:30:27 +01:00
|
|
|
painter.setPen(QPen(Qt::black, qApp->Settings()->WidthMainLine(), Qt::SolidLine, Qt::RoundCap, Qt::RoundJoin));
|
2016-06-15 12:55:43 +02:00
|
|
|
painter.setBrush ( QBrush ( Qt::NoBrush ) );
|
|
|
|
|
|
|
|
int count = 0;
|
|
|
|
QSharedPointer<QVector<PosterData>> poster;
|
|
|
|
QSharedPointer<VPoster> posterazor;
|
2015-05-14 14:27:04 +02:00
|
|
|
|
|
|
|
if (isTiled)
|
|
|
|
{
|
2017-10-13 16:48:20 +02:00
|
|
|
PageOrientation orientation;
|
|
|
|
if (not m_dialogSaveLayout.isNull())
|
|
|
|
{
|
|
|
|
orientation = m_dialogSaveLayout->GetTiledPageOrientation();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
orientation = qApp->ValentinaSettings()->GetTiledPDFOrientation();
|
|
|
|
}
|
|
|
|
|
2017-10-10 11:22:59 +02:00
|
|
|
// when isTiled, the landscape tiles have to be rotated, because the pages
|
|
|
|
// stay portrait in the pdf
|
2017-10-13 16:48:20 +02:00
|
|
|
if(orientation == PageOrientation::Landscape)
|
2017-10-10 11:22:59 +02:00
|
|
|
{
|
|
|
|
painter.rotate(-90);
|
|
|
|
painter.translate(-ToPixel(printer->pageRect(QPrinter::Millimeter).height(), Unit::Mm), 0);
|
|
|
|
}
|
|
|
|
|
2016-06-15 12:55:43 +02:00
|
|
|
poster = QSharedPointer<QVector<PosterData>>(new QVector<PosterData>());
|
|
|
|
posterazor = QSharedPointer<VPoster>(new VPoster(printer));
|
|
|
|
|
|
|
|
for (int i=0; i < scenes.size(); ++i)
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2016-06-15 12:55:43 +02:00
|
|
|
auto *paper = qgraphicsitem_cast<QGraphicsRectItem *>(papers.at(i));
|
|
|
|
if (paper)
|
|
|
|
{
|
2017-10-13 16:48:20 +02:00
|
|
|
*poster += posterazor->Calc(paper->rect().toRect(), i, orientation);
|
2016-06-15 12:55:43 +02:00
|
|
|
}
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
2016-06-15 12:55:43 +02:00
|
|
|
|
|
|
|
count = poster->size();
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2016-06-15 12:55:43 +02:00
|
|
|
count = scenes.size();
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
// Handle the fromPage(), toPage(), supportsMultipleCopies(), and numCopies() values from QPrinter.
|
|
|
|
int firstPage = printer->fromPage() - 1;
|
2016-06-15 12:55:43 +02:00
|
|
|
if (firstPage >= count)
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
if (firstPage == -1)
|
|
|
|
{
|
|
|
|
firstPage = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int lastPage = printer->toPage() - 1;
|
2016-06-15 12:55:43 +02:00
|
|
|
if (lastPage == -1 || lastPage >= count)
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2016-06-15 12:55:43 +02:00
|
|
|
lastPage = count - 1;
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
const int numPages = lastPage - firstPage + 1;
|
|
|
|
int copyCount = 1;
|
|
|
|
if (not printer->supportsMultipleCopies())
|
|
|
|
{
|
|
|
|
copyCount = printer->copyCount();
|
|
|
|
}
|
|
|
|
|
|
|
|
for (int i = 0; i < copyCount; ++i)
|
|
|
|
{
|
|
|
|
for (int j = 0; j < numPages; ++j)
|
|
|
|
{
|
|
|
|
if (i != 0 || j != 0)
|
|
|
|
{
|
|
|
|
if (not printer->newPage())
|
|
|
|
{
|
|
|
|
qWarning("failed in flushing page to disk, disk full?");
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
int index;
|
|
|
|
if (printer->pageOrder() == QPrinter::FirstPageFirst)
|
|
|
|
{
|
|
|
|
index = firstPage + j;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
index = lastPage - j;
|
|
|
|
}
|
2016-06-15 12:55:43 +02:00
|
|
|
|
|
|
|
int paperIndex = -1;
|
2016-11-01 09:42:32 +01:00
|
|
|
isTiled ? paperIndex = static_cast<int>(poster->at(index).index) : paperIndex = index;
|
2016-06-15 12:55:43 +02:00
|
|
|
|
|
|
|
auto *paper = qgraphicsitem_cast<QGraphicsRectItem *>(papers.at(paperIndex));
|
|
|
|
if (paper)
|
|
|
|
{
|
|
|
|
QVector<QGraphicsItem *> posterData;
|
|
|
|
if (isTiled)
|
|
|
|
{
|
|
|
|
// Draw borders
|
|
|
|
posterData = posterazor->Borders(paper, poster->at(index), scenes.size());
|
|
|
|
}
|
|
|
|
|
|
|
|
PreparePaper(paperIndex);
|
|
|
|
|
|
|
|
// Render
|
|
|
|
QRectF source;
|
|
|
|
isTiled ? source = poster->at(index).rect : source = paper->rect();
|
2016-10-23 11:11:00 +02:00
|
|
|
|
|
|
|
qreal x,y;
|
|
|
|
if(printer->fullPage())
|
|
|
|
{
|
2019-04-05 14:42:22 +02:00
|
|
|
QMarginsF printerMargins = printer->pageLayout().margins();
|
|
|
|
x = qFloor(ToPixel(printerMargins.left(),Unit::Mm));
|
|
|
|
y = qFloor(ToPixel(printerMargins.top(),Unit::Mm));
|
2016-10-23 11:11:00 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
x = 0; y = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
QRectF target(x * scale, y * scale, source.width() * scale, source.height() * scale);
|
2016-06-15 12:55:43 +02:00
|
|
|
|
|
|
|
scenes.at(paperIndex)->render(&painter, target, source, Qt::IgnoreAspectRatio);
|
|
|
|
|
|
|
|
if (isTiled)
|
|
|
|
{
|
|
|
|
// Remove borders
|
|
|
|
qDeleteAll(posterData);
|
|
|
|
}
|
|
|
|
|
|
|
|
// Restore
|
|
|
|
RestorePaper(paperIndex);
|
|
|
|
}
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
painter.end();
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::PrintPreviewOrigin()
|
|
|
|
{
|
|
|
|
if (not isPagesUniform())
|
|
|
|
{
|
2015-12-15 15:39:26 +01:00
|
|
|
qCritical()<<tr("For previewing multipage document all sheet should have the same size.");
|
2015-05-14 14:27:04 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
isTiled = false;
|
|
|
|
PrintPreview();
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::PrintPreviewTiled()
|
|
|
|
{
|
|
|
|
isTiled = true;
|
|
|
|
PrintPreview();
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::PrintOrigin()
|
|
|
|
{
|
|
|
|
if (not isPagesUniform())
|
|
|
|
{
|
2015-12-15 15:39:26 +01:00
|
|
|
qCritical()<<tr("For printing multipages document all sheet should have the same size.");
|
2015-05-14 14:27:04 +02:00
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
|
|
|
isTiled = false;
|
|
|
|
LayoutPrint();
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::PrintTiled()
|
|
|
|
{
|
2017-07-17 08:37:57 +02:00
|
|
|
isTiled = true;
|
2015-05-14 14:27:04 +02:00
|
|
|
LayoutPrint();
|
|
|
|
}
|
|
|
|
|
2015-05-12 14:42:19 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2019-01-20 11:19:42 +01:00
|
|
|
QVector<VLayoutPiece> MainWindowsNoGUI::PrepareDetailsForLayout(const QVector<DetailForLayout> &details)
|
2015-05-12 14:42:19 +02:00
|
|
|
{
|
2019-01-20 11:19:42 +01:00
|
|
|
if (details.isEmpty())
|
2015-05-12 14:42:19 +02:00
|
|
|
{
|
2019-01-20 11:19:42 +01:00
|
|
|
return QVector<VLayoutPiece>();
|
|
|
|
}
|
|
|
|
|
|
|
|
std::function<VLayoutPiece (const DetailForLayout &data)> PrepareDetail = [](const DetailForLayout &data)
|
|
|
|
{
|
|
|
|
VAbstractTool *tool = qobject_cast<VAbstractTool*>(VAbstractPattern::getTool(data.id));
|
|
|
|
SCASSERT(tool != nullptr)
|
2019-07-19 09:45:57 +02:00
|
|
|
return VLayoutPiece::Create(data.piece, data.id, tool->getData());
|
2019-01-20 11:19:42 +01:00
|
|
|
};
|
|
|
|
|
|
|
|
QProgressDialog progress(tr("Preparing details for layout"), QString(), 0, details.size());
|
|
|
|
progress.setWindowModality(Qt::ApplicationModal);
|
|
|
|
|
|
|
|
QFutureWatcher<VLayoutPiece> futureWatcher;
|
|
|
|
QObject::connect(&futureWatcher, &QFutureWatcher<VLayoutPiece>::finished, &progress, &QProgressDialog::reset);
|
|
|
|
QObject::connect(&futureWatcher, &QFutureWatcher<VLayoutPiece>::progressRangeChanged, &progress,
|
|
|
|
&QProgressDialog::setRange);
|
|
|
|
QObject::connect(&futureWatcher, &QFutureWatcher<VLayoutPiece>::progressValueChanged, &progress,
|
|
|
|
&QProgressDialog::setValue);
|
|
|
|
|
|
|
|
futureWatcher.setFuture(QtConcurrent::mapped(details, PrepareDetail));
|
|
|
|
|
|
|
|
if (qApp->IsGUIMode())
|
|
|
|
{
|
|
|
|
progress.exec();
|
|
|
|
}
|
|
|
|
|
|
|
|
futureWatcher.waitForFinished();
|
|
|
|
|
2019-01-20 12:18:50 +01:00
|
|
|
QVector<VLayoutPiece> layoutDetails;
|
|
|
|
layoutDetails.reserve(details.size());
|
2019-01-20 11:19:42 +01:00
|
|
|
const QFuture<VLayoutPiece> future = futureWatcher.future();
|
|
|
|
|
|
|
|
QFuture<VLayoutPiece>::const_iterator i;
|
|
|
|
for (i = future.constBegin(); i != future.constEnd(); ++i)
|
|
|
|
{
|
2019-01-20 12:18:50 +01:00
|
|
|
layoutDetails.append(*i);
|
2015-05-12 14:42:19 +02:00
|
|
|
}
|
|
|
|
|
2019-01-20 12:18:50 +01:00
|
|
|
return layoutDetails;
|
2015-05-12 14:42:19 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::InitTempLayoutScene()
|
|
|
|
{
|
2016-02-23 15:59:05 +01:00
|
|
|
tempSceneLayout = new VMainGraphicsScene();
|
2015-05-12 14:42:19 +02:00
|
|
|
tempSceneLayout->setBackgroundBrush( QBrush(QColor(Qt::gray), Qt::SolidPattern) );
|
|
|
|
}
|
2015-05-12 17:15:10 +02:00
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2019-04-28 17:32:09 +02:00
|
|
|
QIcon MainWindowsNoGUI::ScenePreview(int i, QSize iconSize, PreviewQuatilty quality) const
|
2015-05-12 17:15:10 +02:00
|
|
|
{
|
|
|
|
QImage image;
|
|
|
|
QGraphicsRectItem *paper = qgraphicsitem_cast<QGraphicsRectItem *>(papers.at(i));
|
|
|
|
if (paper)
|
|
|
|
{
|
2019-04-28 17:32:09 +02:00
|
|
|
if (quality == PreviewQuatilty::Fast)
|
2015-05-12 17:15:10 +02:00
|
|
|
{
|
2019-04-28 17:32:09 +02:00
|
|
|
image = QImage(iconSize, QImage::Format_RGB32);
|
2015-05-12 17:15:10 +02:00
|
|
|
image.fill(Qt::white);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-04-28 17:32:09 +02:00
|
|
|
const QRectF r = paper->rect();
|
|
|
|
// Create the image with the exact size of the shrunk scene
|
|
|
|
image = QImage(QSize(static_cast<qint32>(r.width()), static_cast<qint32>(r.height())),
|
|
|
|
QImage::Format_RGB32);
|
|
|
|
|
|
|
|
if (not image.isNull())
|
|
|
|
{
|
|
|
|
image.fill(Qt::white);
|
|
|
|
QPainter painter(&image);
|
|
|
|
painter.setFont( QFont( QStringLiteral("Arial"), 8, QFont::Normal ) );
|
|
|
|
painter.setRenderHint(QPainter::Antialiasing, true);
|
|
|
|
painter.setPen(QPen(Qt::black, qApp->Settings()->WidthMainLine(), Qt::SolidLine, Qt::RoundCap,
|
|
|
|
Qt::RoundJoin));
|
|
|
|
painter.setBrush ( QBrush ( Qt::NoBrush ) );
|
|
|
|
scenes.at(i)->render(&painter, r, r, Qt::IgnoreAspectRatio);
|
|
|
|
painter.end();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
qDebug()<<"Cannot create image. Size " << r.size() << "too big";
|
|
|
|
|
|
|
|
image = QImage(iconSize, QImage::Format_RGB32);
|
|
|
|
image.fill(Qt::white);
|
|
|
|
}
|
2015-05-12 17:15:10 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-04-28 17:32:09 +02:00
|
|
|
image = QImage(iconSize, QImage::Format_RGB32);
|
2015-05-12 17:15:10 +02:00
|
|
|
image.fill(Qt::white);
|
|
|
|
}
|
|
|
|
return QIcon(QBitmap::fromImage(image));
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-07-09 13:45:49 +02:00
|
|
|
QList<QGraphicsItem *> MainWindowsNoGUI::CreateShadows(const QList<QGraphicsItem *> &papers)
|
2015-05-12 17:15:10 +02:00
|
|
|
{
|
2017-07-09 13:45:49 +02:00
|
|
|
QList<QGraphicsItem *> shadows;
|
|
|
|
|
2018-04-03 13:36:38 +02:00
|
|
|
for (auto paper : papers)
|
2015-05-12 17:15:10 +02:00
|
|
|
{
|
|
|
|
qreal x1=0, y1=0, x2=0, y2=0;
|
2018-04-03 13:36:38 +02:00
|
|
|
if (QGraphicsRectItem *item = qgraphicsitem_cast<QGraphicsRectItem *>(paper))
|
2015-05-12 17:15:10 +02:00
|
|
|
{
|
|
|
|
item->rect().getCoords(&x1, &y1, &x2, &y2);
|
|
|
|
QGraphicsRectItem *shadowPaper = new QGraphicsRectItem(QRectF(x1+4, y1+4, x2+4, y2+4));
|
|
|
|
shadowPaper->setBrush(QBrush(Qt::black));
|
|
|
|
shadows.append(shadowPaper);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
shadows.append(nullptr);
|
|
|
|
}
|
|
|
|
}
|
2017-07-09 13:45:49 +02:00
|
|
|
|
|
|
|
return shadows;
|
2015-05-12 17:15:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-07-09 13:45:49 +02:00
|
|
|
QList<QGraphicsScene *> MainWindowsNoGUI::CreateScenes(const QList<QGraphicsItem *> &papers,
|
|
|
|
const QList<QGraphicsItem *> &shadows,
|
|
|
|
const QList<QList<QGraphicsItem *> > &details)
|
2015-05-12 17:15:10 +02:00
|
|
|
{
|
2017-07-09 13:45:49 +02:00
|
|
|
QList<QGraphicsScene *> scenes;
|
2019-07-21 11:28:28 +02:00
|
|
|
scenes.reserve(papers.size());
|
2015-05-12 17:15:10 +02:00
|
|
|
for (int i=0; i<papers.size(); ++i)
|
|
|
|
{
|
2019-07-21 11:27:58 +02:00
|
|
|
auto *scene = new VMainGraphicsScene();
|
|
|
|
scene->SetNonInteractive(true);
|
2015-05-12 17:15:10 +02:00
|
|
|
scene->setBackgroundBrush(QBrush(QColor(Qt::gray), Qt::SolidPattern));
|
|
|
|
scene->addItem(shadows.at(i));
|
|
|
|
scene->addItem(papers.at(i));
|
|
|
|
|
2018-04-03 13:36:38 +02:00
|
|
|
const QList<QGraphicsItem *> paperDetails = details.at(i);
|
|
|
|
for (auto &detail : paperDetails)
|
2015-05-12 17:15:10 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
scene->addItem(detail);
|
2015-05-12 17:15:10 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
scenes.append(scene);
|
|
|
|
}
|
2017-07-09 13:45:49 +02:00
|
|
|
|
|
|
|
return scenes;
|
2015-05-12 17:15:10 +02:00
|
|
|
}
|
2015-05-14 14:27:04 +02:00
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief SvgFile save layout to svg file.
|
|
|
|
* @param name name layout file.
|
|
|
|
*/
|
2019-01-03 18:33:15 +01:00
|
|
|
void MainWindowsNoGUI::SvgFile(const QString &name, QGraphicsRectItem *paper, QGraphicsScene *scene,
|
|
|
|
const QMarginsF &margins) const
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2019-01-03 18:33:15 +01:00
|
|
|
const QRectF r = paper->rect();
|
2017-07-09 13:45:49 +02:00
|
|
|
QSvgGenerator generator;
|
|
|
|
generator.setFileName(name);
|
2019-01-03 18:33:15 +01:00
|
|
|
generator.setSize(QSize(qFloor(r.width() + margins.left() + margins.right()),
|
|
|
|
qFloor(r.height() + margins.top() + margins.bottom())));
|
|
|
|
generator.setViewBox(QRectF(0, 0, r.width() + margins.left() + margins.right(),
|
|
|
|
r.height() + margins.top() + margins.bottom()));
|
2017-07-09 13:45:49 +02:00
|
|
|
generator.setTitle(tr("Pattern"));
|
2018-03-22 15:32:20 +01:00
|
|
|
generator.setDescription(doc->GetDescription().toHtmlEscaped());
|
2017-07-09 13:45:49 +02:00
|
|
|
generator.setResolution(static_cast<int>(PrintDPI));
|
|
|
|
QPainter painter;
|
|
|
|
painter.begin(&generator);
|
2019-01-03 18:33:15 +01:00
|
|
|
painter.translate(margins.left(), margins.top());
|
2017-07-09 13:45:49 +02:00
|
|
|
painter.setRenderHint(QPainter::Antialiasing, true);
|
2018-02-06 18:30:27 +01:00
|
|
|
painter.setPen(QPen(Qt::black, qApp->Settings()->WidthHairLine(), Qt::SolidLine, Qt::RoundCap, Qt::RoundJoin));
|
2017-07-09 13:45:49 +02:00
|
|
|
painter.setBrush ( QBrush ( Qt::NoBrush ) );
|
2019-01-03 18:33:15 +01:00
|
|
|
scene->render(&painter, r, r, Qt::IgnoreAspectRatio);
|
2017-07-09 13:45:49 +02:00
|
|
|
painter.end();
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief PngFile save layout to png file.
|
|
|
|
* @param name name layout file.
|
|
|
|
*/
|
2019-01-03 18:33:15 +01:00
|
|
|
void MainWindowsNoGUI::PngFile(const QString &name, QGraphicsRectItem *paper, QGraphicsScene *scene,
|
|
|
|
const QMarginsF &margins) const
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2017-07-09 13:45:49 +02:00
|
|
|
const QRectF r = paper->rect();
|
|
|
|
// Create the image with the exact size of the shrunk scene
|
2019-01-03 18:33:15 +01:00
|
|
|
QImage image(QSize(qFloor(r.width() + margins.left() + margins.right()),
|
|
|
|
qFloor(r.height() + margins.top() + margins.bottom())),
|
|
|
|
QImage::Format_ARGB32);
|
|
|
|
image.fill(Qt::white);
|
2017-07-09 13:45:49 +02:00
|
|
|
QPainter painter(&image);
|
2019-01-03 18:33:15 +01:00
|
|
|
painter.translate(margins.left(), margins.top());
|
2017-07-09 13:45:49 +02:00
|
|
|
painter.setRenderHint(QPainter::Antialiasing, true);
|
2018-02-06 18:30:27 +01:00
|
|
|
painter.setPen(QPen(Qt::black, qApp->Settings()->WidthMainLine(), Qt::SolidLine, Qt::RoundCap, Qt::RoundJoin));
|
2017-07-09 13:45:49 +02:00
|
|
|
painter.setBrush ( QBrush ( Qt::NoBrush ) );
|
|
|
|
scene->render(&painter, r, r, Qt::IgnoreAspectRatio);
|
|
|
|
image.save(name);
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief PdfFile save layout to pdf file.
|
|
|
|
* @param name name layout file.
|
|
|
|
*/
|
2017-07-09 13:45:49 +02:00
|
|
|
void MainWindowsNoGUI::PdfFile(const QString &name, QGraphicsRectItem *paper, QGraphicsScene *scene,
|
|
|
|
bool ignorePrinterFields, const QMarginsF &margins) const
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2017-07-09 13:45:49 +02:00
|
|
|
QPrinter printer;
|
2018-04-08 18:45:23 +02:00
|
|
|
printer.setCreator(QGuiApplication::applicationDisplayName()+QChar(QChar::Space)+
|
2017-07-09 13:45:49 +02:00
|
|
|
QCoreApplication::applicationVersion());
|
|
|
|
printer.setOutputFormat(QPrinter::PdfFormat);
|
|
|
|
printer.setOutputFileName(name);
|
|
|
|
printer.setDocName(FileName());
|
|
|
|
const QRectF r = paper->rect();
|
|
|
|
printer.setResolution(static_cast<int>(PrintDPI));
|
2017-07-09 21:27:54 +02:00
|
|
|
printer.setOrientation(QPrinter::Portrait);
|
2017-07-09 13:45:49 +02:00
|
|
|
printer.setFullPage(ignorePrinterFields);
|
2019-04-28 17:49:29 +02:00
|
|
|
if (not printer.setPageSize(QPageSize(QSizeF(FromPixel(r.width() + margins.left() + margins.right(), Unit::Mm),
|
|
|
|
FromPixel(r.height() + margins.top() + margins.bottom(), Unit::Mm)),
|
|
|
|
QPageSize::Millimeter)))
|
|
|
|
{
|
|
|
|
qWarning() << tr("Cannot set printer page size");
|
|
|
|
}
|
2017-07-09 21:27:54 +02:00
|
|
|
|
|
|
|
const qreal left = FromPixel(margins.left(), Unit::Mm);
|
|
|
|
const qreal top = FromPixel(margins.top(), Unit::Mm);
|
|
|
|
const qreal right = FromPixel(margins.right(), Unit::Mm);
|
|
|
|
const qreal bottom = FromPixel(margins.bottom(), Unit::Mm);
|
2019-04-05 14:42:22 +02:00
|
|
|
|
2019-04-05 14:51:16 +02:00
|
|
|
if (not printer.setPageMargins(QMarginsF(left, top, right, bottom), QPageLayout::Millimeter))
|
2017-07-09 21:27:54 +02:00
|
|
|
{
|
|
|
|
qWarning() << tr("Cannot set printer margins");
|
|
|
|
}
|
|
|
|
|
2017-07-09 13:45:49 +02:00
|
|
|
QPainter painter;
|
|
|
|
if (painter.begin( &printer ) == false)
|
|
|
|
{ // failed to open file
|
|
|
|
qCritical("%s", qUtf8Printable(tr("Can't open printer %1").arg(name)));
|
|
|
|
return;
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
2019-01-17 09:36:37 +01:00
|
|
|
painter.setFont( QFont( QStringLiteral("Arial"), 8, QFont::Normal ) );
|
2017-07-09 13:45:49 +02:00
|
|
|
painter.setRenderHint(QPainter::Antialiasing, true);
|
2018-02-06 18:30:27 +01:00
|
|
|
painter.setPen(QPen(Qt::black, qApp->Settings()->WidthMainLine(), Qt::SolidLine, Qt::RoundCap, Qt::RoundJoin));
|
2017-07-09 13:45:49 +02:00
|
|
|
painter.setBrush ( QBrush ( Qt::NoBrush ) );
|
|
|
|
scene->render(&painter, r, r, Qt::IgnoreAspectRatio);
|
|
|
|
painter.end();
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
|
2017-07-08 19:18:47 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::PdfTiledFile(const QString &name)
|
|
|
|
{
|
|
|
|
isTiled = true;
|
|
|
|
|
|
|
|
if (isLayoutStale)
|
|
|
|
{
|
|
|
|
if (ContinueIfLayoutStale() == QMessageBox::No)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
QPrinter printer;
|
|
|
|
SetPrinterSettings(&printer, PrintType::PrintPDF);
|
|
|
|
|
|
|
|
// Call IsPagesFit after setting a printer settings and check if pages is not bigger than printer's paper size
|
|
|
|
if (not isTiled && not IsPagesFit(printer.paperRect().size()))
|
|
|
|
{
|
|
|
|
qWarning()<<tr("Pages will be cropped because they do not fit printer paper size.");
|
|
|
|
}
|
|
|
|
|
|
|
|
printer.setOutputFileName(name);
|
|
|
|
printer.setResolution(static_cast<int>(PrintDPI));
|
2017-10-13 16:48:20 +02:00
|
|
|
PrintPages(&printer);
|
2017-07-08 19:18:47 +02:00
|
|
|
}
|
|
|
|
|
2015-05-14 14:27:04 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief EpsFile save layout to eps file.
|
|
|
|
* @param name name layout file.
|
|
|
|
*/
|
2017-07-09 13:45:49 +02:00
|
|
|
void MainWindowsNoGUI::EpsFile(const QString &name, QGraphicsRectItem *paper, QGraphicsScene *scene,
|
|
|
|
bool ignorePrinterFields, const QMarginsF &margins) const
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
|
|
|
QTemporaryFile tmp;
|
|
|
|
if (tmp.open())
|
|
|
|
{
|
2017-07-09 13:45:49 +02:00
|
|
|
PdfFile(tmp.fileName(), paper, scene, ignorePrinterFields, margins);
|
2019-01-17 09:36:37 +01:00
|
|
|
QStringList params = QStringList() << QStringLiteral("-eps") << tmp.fileName() << name;
|
2015-05-14 14:27:04 +02:00
|
|
|
PdfToPs(params);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief PsFile save layout to ps file.
|
|
|
|
* @param name name layout file.
|
|
|
|
*/
|
2017-07-09 13:45:49 +02:00
|
|
|
void MainWindowsNoGUI::PsFile(const QString &name, QGraphicsRectItem *paper, QGraphicsScene *scene, bool
|
|
|
|
ignorePrinterFields, const QMarginsF &margins) const
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
|
|
|
QTemporaryFile tmp;
|
|
|
|
if (tmp.open())
|
|
|
|
{
|
2017-07-09 13:45:49 +02:00
|
|
|
PdfFile(tmp.fileName(), paper, scene, ignorePrinterFields, margins);
|
2015-05-14 14:27:04 +02:00
|
|
|
QStringList params = QStringList() << tmp.fileName() << name;
|
|
|
|
PdfToPs(params);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief PdfToPs use external tool "pdftops" for converting pdf too eps or ps format.
|
|
|
|
* @param params string with parameter for tool. Parameters have format: "-eps input_file out_file". Use -eps when
|
|
|
|
* need create eps file.
|
|
|
|
*/
|
|
|
|
void MainWindowsNoGUI::PdfToPs(const QStringList ¶ms) const
|
|
|
|
{
|
|
|
|
#ifndef QT_NO_CURSOR
|
2017-07-09 08:02:26 +02:00
|
|
|
QGuiApplication::setOverrideCursor(Qt::WaitCursor);
|
2015-05-14 14:27:04 +02:00
|
|
|
#endif
|
|
|
|
QProcess proc;
|
2016-12-10 17:47:33 +01:00
|
|
|
#if defined(Q_OS_MAC)
|
|
|
|
// Fix issue #594. Broken export on Mac.
|
|
|
|
proc.setWorkingDirectory(qApp->applicationDirPath());
|
|
|
|
proc.start(QLatin1String("./") + PDFTOPS, params);
|
|
|
|
#else
|
2015-05-14 14:27:04 +02:00
|
|
|
proc.start(PDFTOPS, params);
|
2016-12-10 17:47:33 +01:00
|
|
|
#endif
|
2016-12-03 09:40:23 +01:00
|
|
|
if (proc.waitForStarted(15000))
|
|
|
|
{
|
|
|
|
proc.waitForFinished(15000);
|
|
|
|
}
|
2015-05-14 14:27:04 +02:00
|
|
|
#ifndef QT_NO_CURSOR
|
2017-07-09 08:02:26 +02:00
|
|
|
QGuiApplication::restoreOverrideCursor();
|
2015-05-14 14:27:04 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
QFile f(params.last());
|
|
|
|
if (f.exists() == false)
|
|
|
|
{
|
2018-03-14 14:39:15 +01:00
|
|
|
const QString msg = tr("Creating file '%1' failed! %2").arg(params.last(), proc.errorString());
|
2015-05-14 14:27:04 +02:00
|
|
|
QMessageBox msgBox(QMessageBox::Critical, tr("Critical error!"), msg, QMessageBox::Ok | QMessageBox::Default);
|
|
|
|
msgBox.exec();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-07-09 13:45:49 +02:00
|
|
|
void MainWindowsNoGUI::ObjFile(const QString &name, QGraphicsRectItem *paper, QGraphicsScene *scene) const
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2017-07-09 13:45:49 +02:00
|
|
|
VObjPaintDevice generator;
|
|
|
|
generator.setFileName(name);
|
|
|
|
generator.setSize(paper->rect().size().toSize());
|
|
|
|
generator.setResolution(static_cast<int>(PrintDPI));
|
|
|
|
QPainter painter;
|
|
|
|
painter.begin(&generator);
|
|
|
|
scene->render(&painter, paper->rect(), paper->rect(), Qt::IgnoreAspectRatio);
|
|
|
|
painter.end();
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
|
2015-09-07 21:47:02 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2016-08-06 20:42:40 +02:00
|
|
|
QT_WARNING_PUSH
|
|
|
|
QT_WARNING_DISABLE_GCC("-Wswitch-default")
|
2016-03-27 18:00:08 +02:00
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
void MainWindowsNoGUI::FlatDxfFile(const QString &name, int version, bool binary, QGraphicsRectItem *paper,
|
2017-07-09 21:27:54 +02:00
|
|
|
QGraphicsScene *scene, const QList<QList<QGraphicsItem *> > &details) const
|
2015-09-07 21:47:02 +02:00
|
|
|
{
|
2017-07-09 21:27:54 +02:00
|
|
|
PrepareTextForDXF(endStringPlaceholder, details);
|
2017-07-09 13:45:49 +02:00
|
|
|
VDxfPaintDevice generator;
|
|
|
|
generator.setFileName(name);
|
|
|
|
generator.setSize(paper->rect().size().toSize());
|
|
|
|
generator.setResolution(PrintDPI);
|
|
|
|
generator.SetVersion(static_cast<DRW::Version>(version));
|
|
|
|
generator.SetBinaryFormat(binary);
|
2017-08-10 15:50:10 +02:00
|
|
|
generator.setInsunits(VarInsunits::Millimeters);// Decided to always use mm. See issue #745
|
2016-03-27 18:00:08 +02:00
|
|
|
|
2017-07-09 13:45:49 +02:00
|
|
|
QPainter painter;
|
|
|
|
if (painter.begin(&generator))
|
|
|
|
{
|
|
|
|
scene->render(&painter, paper->rect(), paper->rect(), Qt::IgnoreAspectRatio);
|
|
|
|
painter.end();
|
2015-09-07 21:47:02 +02:00
|
|
|
}
|
2017-07-09 21:27:54 +02:00
|
|
|
RestoreTextAfterDXF(endStringPlaceholder, details);
|
2015-09-07 21:47:02 +02:00
|
|
|
}
|
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::AAMADxfFile(const QString &name, int version, bool binary, const QSize &size,
|
|
|
|
const QVector<VLayoutPiece> &details) const
|
|
|
|
{
|
|
|
|
VDxfPaintDevice generator;
|
|
|
|
generator.setFileName(name);
|
|
|
|
generator.setSize(size);
|
|
|
|
generator.setResolution(PrintDPI);
|
|
|
|
generator.SetVersion(static_cast<DRW::Version>(version));
|
|
|
|
generator.SetBinaryFormat(binary);
|
2017-08-10 15:50:10 +02:00
|
|
|
generator.setInsunits(VarInsunits::Millimeters);// Decided to always use mm. See issue #745
|
2017-07-16 20:10:48 +02:00
|
|
|
generator.ExportToAAMA(details);
|
|
|
|
}
|
|
|
|
|
2016-08-06 20:42:40 +02:00
|
|
|
QT_WARNING_POP
|
2016-03-27 18:00:08 +02:00
|
|
|
|
2015-05-14 14:27:04 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2016-06-15 12:55:43 +02:00
|
|
|
void MainWindowsNoGUI::PreparePaper(int index) const
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2016-06-15 12:55:43 +02:00
|
|
|
auto *paper = qgraphicsitem_cast<QGraphicsRectItem *>(papers.at(index));
|
|
|
|
if (paper)
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2016-06-15 12:55:43 +02:00
|
|
|
QBrush brush(Qt::white);
|
|
|
|
scenes.at(index)->setBackgroundBrush(brush);
|
|
|
|
shadows.at(index)->setVisible(false);
|
|
|
|
paper->setPen(QPen(Qt::white, 0.1, Qt::NoPen));// border
|
|
|
|
}
|
2016-06-02 20:28:44 +02:00
|
|
|
|
2016-06-15 12:55:43 +02:00
|
|
|
}
|
2015-05-14 14:27:04 +02:00
|
|
|
|
2016-06-15 12:55:43 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::RestorePaper(int index) const
|
|
|
|
{
|
|
|
|
auto *paper = qgraphicsitem_cast<QGraphicsRectItem *>(papers.at(index));
|
|
|
|
if (paper)
|
|
|
|
{
|
|
|
|
// Restore
|
2017-10-11 10:34:22 +02:00
|
|
|
paper->setPen(QPen(Qt::black, 1));
|
2016-06-15 12:55:43 +02:00
|
|
|
QBrush brush(Qt::gray);
|
|
|
|
scenes.at(index)->setBackgroundBrush(brush);
|
|
|
|
shadows.at(index)->setVisible(true);
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2017-06-29 17:56:52 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief PrepareTextForDXF prepare QGraphicsSimpleTextItem items for export to flat dxf.
|
|
|
|
*
|
|
|
|
* Because QPaintEngine::drawTextItem doesn't pass whole string per time we mark end of each string by adding special
|
|
|
|
* placholder. This method append it.
|
|
|
|
*
|
|
|
|
* @param placeholder placeholder that will be appended to each QGraphicsSimpleTextItem item's text string.
|
|
|
|
*/
|
2017-07-09 21:27:54 +02:00
|
|
|
void MainWindowsNoGUI::PrepareTextForDXF(const QString &placeholder,
|
|
|
|
const QList<QList<QGraphicsItem *> > &details) const
|
2017-06-29 17:56:52 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
for (auto &paperItems : details)
|
2017-06-29 17:56:52 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
for (auto item : paperItems)
|
2017-06-29 17:56:52 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
QList<QGraphicsItem *> pieceChildren = item->childItems();
|
|
|
|
for (auto child : pieceChildren)
|
2017-06-29 17:56:52 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
if (child->type() == QGraphicsSimpleTextItem::Type)
|
2017-06-29 17:56:52 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
if(QGraphicsSimpleTextItem *textItem = qgraphicsitem_cast<QGraphicsSimpleTextItem *>(child))
|
2017-06-29 17:56:52 +02:00
|
|
|
{
|
|
|
|
textItem->setText(textItem->text() + placeholder);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
/**
|
|
|
|
* @brief MainWindowsNoGUI::RestoreTextAfterDXF restore QGraphicsSimpleTextItem items after export to flat dxf.
|
|
|
|
*
|
|
|
|
* Because QPaintEngine::drawTextItem doesn't pass whole string per time we mark end of each string by adding special
|
|
|
|
* placholder. This method remove it.
|
|
|
|
*
|
|
|
|
* @param placeholder placeholder that will be removed from each QGraphicsSimpleTextItem item's text string.
|
|
|
|
*/
|
2017-07-09 21:27:54 +02:00
|
|
|
void MainWindowsNoGUI::RestoreTextAfterDXF(const QString &placeholder,
|
|
|
|
const QList<QList<QGraphicsItem *> > &details) const
|
2017-06-29 17:56:52 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
for (auto &paperItems : details)
|
2017-06-29 17:56:52 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
for (auto item : paperItems)
|
2017-06-29 17:56:52 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
QList<QGraphicsItem *> pieceChildren = item->childItems();
|
|
|
|
for (auto child : pieceChildren)
|
2017-06-29 17:56:52 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
if (child->type() == QGraphicsSimpleTextItem::Type)
|
2017-06-29 17:56:52 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
if(QGraphicsSimpleTextItem *textItem = qgraphicsitem_cast<QGraphicsSimpleTextItem *>(child))
|
2017-06-29 17:56:52 +02:00
|
|
|
{
|
|
|
|
QString text = textItem->text();
|
2018-03-14 15:01:24 +01:00
|
|
|
text.replace(placeholder, QString());
|
2017-06-29 17:56:52 +02:00
|
|
|
textItem->setText(text);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-14 14:27:04 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::PrintPreview()
|
|
|
|
{
|
|
|
|
if (isLayoutStale)
|
|
|
|
{
|
|
|
|
if (ContinueIfLayoutStale() == QMessageBox::No)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-08-22 18:43:22 +02:00
|
|
|
QPrinterInfo info = QPrinterInfo::printerInfo(layoutPrinterName);
|
|
|
|
if(info.isNull() || info.printerName().isEmpty())
|
|
|
|
{
|
|
|
|
info = QPrinterInfo::defaultPrinter();
|
|
|
|
}
|
|
|
|
QSharedPointer<QPrinter> printer = PreparePrinter(info);
|
2015-11-09 12:33:36 +01:00
|
|
|
if (printer.isNull())
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2015-11-09 12:33:36 +01:00
|
|
|
qCritical("%s\n\n%s", qUtf8Printable(tr("Print error")),
|
|
|
|
qUtf8Printable(tr("Cannot proceed because there are no available printers in your system.")));
|
|
|
|
return;
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
|
2016-06-02 12:25:34 +02:00
|
|
|
SetPrinterSettings(printer.data(), PrintType::PrintPreview);
|
2016-06-02 15:51:37 +02:00
|
|
|
printer->setResolution(static_cast<int>(PrintDPI));
|
2015-05-14 14:27:04 +02:00
|
|
|
// display print preview dialog
|
2016-06-15 12:55:43 +02:00
|
|
|
QPrintPreviewDialog preview(printer.data());
|
2015-05-14 14:27:04 +02:00
|
|
|
connect(&preview, &QPrintPreviewDialog::paintRequested, this, &MainWindowsNoGUI::PrintPages);
|
|
|
|
preview.exec();
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::LayoutPrint()
|
|
|
|
{
|
|
|
|
if (isLayoutStale)
|
|
|
|
{
|
|
|
|
if (ContinueIfLayoutStale() == QMessageBox::No)
|
|
|
|
{
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
// display print dialog and if accepted print
|
2016-08-22 18:43:22 +02:00
|
|
|
QPrinterInfo info = QPrinterInfo::printerInfo(layoutPrinterName);
|
|
|
|
if(info.isNull() || info.printerName().isEmpty())
|
|
|
|
{
|
|
|
|
info = QPrinterInfo::defaultPrinter();
|
|
|
|
}
|
|
|
|
QSharedPointer<QPrinter> printer = PreparePrinter(info, QPrinter::HighResolution);
|
2016-06-01 20:55:27 +02:00
|
|
|
if (printer.isNull())
|
|
|
|
{
|
|
|
|
qCritical("%s\n\n%s", qUtf8Printable(tr("Print error")),
|
|
|
|
qUtf8Printable(tr("Cannot proceed because there are no available printers in your system.")));
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
|
2016-06-02 12:25:34 +02:00
|
|
|
SetPrinterSettings(printer.data(), PrintType::PrintNative);
|
2016-06-01 20:55:27 +02:00
|
|
|
QPrintDialog dialog(printer.data(), this );
|
2015-05-14 14:27:04 +02:00
|
|
|
// If only user couldn't change page margins we could use method setMinMax();
|
|
|
|
dialog.setOption(QPrintDialog::PrintCurrentPage, false);
|
|
|
|
if ( dialog.exec() == QDialog::Accepted )
|
|
|
|
{
|
2016-06-01 20:55:27 +02:00
|
|
|
printer->setResolution(static_cast<int>(PrintDPI));
|
|
|
|
PrintPages(printer.data());
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2016-06-02 12:25:34 +02:00
|
|
|
void MainWindowsNoGUI::SetPrinterSettings(QPrinter *printer, const PrintType &printType)
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
|
|
|
SCASSERT(printer != nullptr)
|
2018-04-22 17:39:56 +02:00
|
|
|
printer->setCreator(QGuiApplication::applicationDisplayName()+QChar(QChar::Space)+
|
|
|
|
QCoreApplication::applicationVersion());
|
2015-05-14 14:27:04 +02:00
|
|
|
|
2019-06-18 11:35:43 +02:00
|
|
|
printer->setOrientation(isLayoutPortrait ? QPrinter::Portrait : QPrinter::Landscape);
|
2017-10-11 10:34:22 +02:00
|
|
|
|
2016-06-15 12:55:43 +02:00
|
|
|
if (not isTiled)
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2016-06-22 15:23:05 +02:00
|
|
|
QSizeF size = QSizeF(FromPixel(paperSize.width(), Unit::Mm), FromPixel(paperSize.height(), Unit::Mm));
|
|
|
|
if (isAutoCrop || isUnitePages)
|
|
|
|
{
|
|
|
|
auto *paper = qgraphicsitem_cast<QGraphicsRectItem *>(papers.at(0));
|
|
|
|
if (paper)
|
|
|
|
{
|
2019-06-18 11:35:43 +02:00
|
|
|
if (isLayoutPortrait)
|
|
|
|
{
|
|
|
|
size = QSizeF(FromPixel(paperSize.width(), Unit::Mm),
|
|
|
|
FromPixel(paper->rect().height() + margins.top() + margins.bottom(), Unit::Mm));
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
size = QSizeF(FromPixel(paper->rect().width() + margins.left() + margins.right(), Unit::Mm),
|
|
|
|
FromPixel(paperSize.height(), Unit::Mm));
|
|
|
|
}
|
2016-06-22 15:23:05 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2019-06-18 11:35:43 +02:00
|
|
|
if (not isLayoutPortrait)
|
|
|
|
{
|
|
|
|
size.transpose(); // QPrinter reverse this for landscape orientation
|
|
|
|
}
|
|
|
|
|
2019-04-28 17:49:29 +02:00
|
|
|
const QPageSize::PageSizeId pSZ = FindPageSizeId(size);
|
|
|
|
if (pSZ == QPageSize::Custom)
|
2015-11-09 13:29:37 +01:00
|
|
|
{
|
2019-04-28 17:49:29 +02:00
|
|
|
if (not printer->setPageSize(QPageSize(size, QPageSize::Millimeter)))
|
|
|
|
{
|
|
|
|
qWarning() << tr("Cannot set custom printer page size");
|
|
|
|
}
|
2015-11-09 13:29:37 +01:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2019-04-28 17:49:29 +02:00
|
|
|
if (not printer->setPageSize(QPageSize(pSZ)))
|
|
|
|
{
|
|
|
|
qWarning() << tr("Cannot set printer page size");
|
|
|
|
}
|
2015-11-09 13:29:37 +01:00
|
|
|
}
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
2019-02-13 15:41:31 +01:00
|
|
|
else
|
|
|
|
{
|
|
|
|
if (not m_dialogSaveLayout.isNull())
|
|
|
|
{
|
|
|
|
VAbstractLayoutDialog::PaperSizeTemplate tiledFormat = m_dialogSaveLayout->GetTiledPageFormat();
|
2019-04-28 17:49:29 +02:00
|
|
|
if (not printer->setPageSize(QPageSize(m_dialogSaveLayout->GetTemplateSize(tiledFormat, Unit::Mm),
|
|
|
|
QPageSize::Millimeter)))
|
|
|
|
{
|
|
|
|
qWarning() << tr("Cannot set printer page size");
|
|
|
|
}
|
2019-02-13 15:41:31 +01:00
|
|
|
}
|
|
|
|
}
|
2015-05-14 14:27:04 +02:00
|
|
|
|
2016-09-30 18:33:10 +02:00
|
|
|
printer->setFullPage(ignorePrinterFields);
|
|
|
|
|
2017-10-10 11:22:59 +02:00
|
|
|
qreal left, top, right, bottom;
|
|
|
|
|
|
|
|
if (not isTiled)
|
|
|
|
{
|
|
|
|
QMarginsF pageMargin = QMarginsF(UnitConvertor(margins, Unit::Px, Unit::Mm));
|
|
|
|
left = pageMargin.left();
|
|
|
|
top = pageMargin.top();
|
|
|
|
right = pageMargin.right();
|
|
|
|
bottom = pageMargin.bottom();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2017-10-13 16:48:20 +02:00
|
|
|
QMarginsF pageMargin;
|
|
|
|
PageOrientation orientation;
|
|
|
|
if (not m_dialogSaveLayout.isNull())
|
|
|
|
{
|
|
|
|
pageMargin = m_dialogSaveLayout->GetTiledMargins();
|
|
|
|
orientation = m_dialogSaveLayout->GetTiledPageOrientation();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
VSettings *settings = qApp->ValentinaSettings();
|
|
|
|
pageMargin = QMarginsF(settings->GetTiledPDFMargins(Unit::Mm));
|
|
|
|
orientation = settings->GetTiledPDFOrientation();
|
|
|
|
}
|
|
|
|
|
|
|
|
if(orientation == PageOrientation::Landscape)
|
2017-10-10 11:22:59 +02:00
|
|
|
{
|
|
|
|
// because when painting we have a -90rotation in landscape modus,
|
|
|
|
// see function PrintPages.
|
|
|
|
left = pageMargin.bottom();
|
|
|
|
top = pageMargin.left();
|
|
|
|
right = pageMargin.top();
|
|
|
|
bottom = pageMargin.right();
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
left = pageMargin.left();
|
|
|
|
top = pageMargin.top();
|
|
|
|
right = pageMargin.right();
|
|
|
|
bottom = pageMargin.bottom();
|
|
|
|
}
|
|
|
|
}
|
2016-10-06 18:28:58 +02:00
|
|
|
|
2019-04-05 14:42:22 +02:00
|
|
|
const bool success = printer->setPageMargins(QMarginsF(left, top, right, bottom), QPageLayout::Millimeter);
|
2016-10-06 18:28:58 +02:00
|
|
|
if (not success)
|
|
|
|
{
|
|
|
|
qWarning() << tr("Cannot set printer margins");
|
|
|
|
}
|
2015-11-09 12:33:36 +01:00
|
|
|
|
2016-06-02 12:25:34 +02:00
|
|
|
switch(printType)
|
2015-11-09 12:58:45 +01:00
|
|
|
{
|
2016-06-02 12:25:34 +02:00
|
|
|
case PrintType::PrintPDF:
|
|
|
|
{
|
|
|
|
const QString outputFileName = QDir::homePath() + QDir::separator() + FileName();
|
|
|
|
#ifdef Q_OS_WIN
|
|
|
|
printer->setOutputFileName(outputFileName);
|
|
|
|
#else
|
2019-01-17 09:36:37 +01:00
|
|
|
printer->setOutputFileName(outputFileName + QStringLiteral(".pdf"));
|
2016-06-02 12:25:34 +02:00
|
|
|
#endif
|
|
|
|
|
|
|
|
#ifdef Q_OS_MAC
|
|
|
|
printer->setOutputFormat(QPrinter::NativeFormat);
|
|
|
|
#else
|
|
|
|
printer->setOutputFormat(QPrinter::PdfFormat);
|
|
|
|
#endif
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
case PrintType::PrintNative:
|
2018-03-14 15:01:24 +01:00
|
|
|
printer->setOutputFileName(QString());//Disable printing to file if was enabled.
|
2016-06-02 12:25:34 +02:00
|
|
|
printer->setOutputFormat(QPrinter::NativeFormat);
|
|
|
|
break;
|
|
|
|
case PrintType::PrintPreview: /*do nothing*/
|
|
|
|
default:
|
|
|
|
break;
|
2015-11-09 12:58:45 +01:00
|
|
|
}
|
2016-06-02 12:25:34 +02:00
|
|
|
|
2015-05-14 14:27:04 +02:00
|
|
|
printer->setDocName(FileName());
|
2015-11-04 16:22:49 +01:00
|
|
|
|
|
|
|
IsLayoutGrayscale() ? printer->setColorMode(QPrinter::GrayScale) : printer->setColorMode(QPrinter::Color);
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
bool MainWindowsNoGUI::IsLayoutGrayscale() const
|
|
|
|
{
|
2016-06-15 12:55:43 +02:00
|
|
|
const QRect target = QRect(0, 0, 100, 100);//Small image less memory need
|
2015-11-04 16:22:49 +01:00
|
|
|
|
2016-06-15 12:55:43 +02:00
|
|
|
for (int i=0; i < scenes.size(); ++i)
|
2015-11-04 16:22:49 +01:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
if (auto *paper = qgraphicsitem_cast<QGraphicsRectItem *>(papers.at(i)))
|
2015-11-04 16:22:49 +01:00
|
|
|
{
|
2016-06-15 12:55:43 +02:00
|
|
|
// Hide shadow and paper border
|
|
|
|
PreparePaper(i);
|
|
|
|
|
|
|
|
// Render png
|
|
|
|
QImage image(target.size(), QImage::Format_RGB32);
|
|
|
|
image.fill(Qt::white);
|
|
|
|
QPainter painter(&image);
|
2018-02-06 18:30:27 +01:00
|
|
|
painter.setPen(QPen(Qt::black, qApp->Settings()->WidthMainLine(), Qt::SolidLine, Qt::RoundCap,
|
|
|
|
Qt::RoundJoin));
|
2016-06-15 12:55:43 +02:00
|
|
|
painter.setBrush ( QBrush ( Qt::NoBrush ) );
|
|
|
|
scenes.at(i)->render(&painter, target, paper->rect(), Qt::KeepAspectRatio);
|
|
|
|
painter.end();
|
|
|
|
|
|
|
|
// Restore
|
|
|
|
RestorePaper(i);
|
|
|
|
|
|
|
|
if (not image.isGrayscale())
|
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
2015-11-04 16:22:49 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return true;
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|
|
|
|
|
2015-11-09 13:29:37 +01:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2019-04-28 17:49:29 +02:00
|
|
|
QPageSize::PageSizeId MainWindowsNoGUI::FindPageSizeId(const QSizeF &size) const
|
2015-11-09 13:29:37 +01:00
|
|
|
{
|
2017-10-10 11:22:59 +02:00
|
|
|
if (size == QSizeF(841, 1189) || size == QSizeF(1189, 841))
|
2015-11-09 13:29:37 +01:00
|
|
|
{
|
2019-04-28 17:49:29 +02:00
|
|
|
return QPageSize::A0;
|
2015-11-09 13:29:37 +01:00
|
|
|
}
|
|
|
|
|
2017-10-10 11:22:59 +02:00
|
|
|
if (size == QSizeF(594, 841) || size == QSizeF(841, 594))
|
2015-11-09 13:29:37 +01:00
|
|
|
{
|
2019-04-28 17:49:29 +02:00
|
|
|
return QPageSize::A1;
|
2015-11-09 13:29:37 +01:00
|
|
|
}
|
|
|
|
|
2017-10-10 11:22:59 +02:00
|
|
|
if (size == QSizeF(420, 594) || size == QSizeF(594, 420))
|
2015-11-09 13:29:37 +01:00
|
|
|
{
|
2019-04-28 17:49:29 +02:00
|
|
|
return QPageSize::A2;
|
2015-11-09 13:29:37 +01:00
|
|
|
}
|
|
|
|
|
2017-10-10 11:22:59 +02:00
|
|
|
if (size == QSizeF(297, 420) || size == QSizeF(420, 297))
|
2015-11-09 13:29:37 +01:00
|
|
|
{
|
2019-04-28 17:49:29 +02:00
|
|
|
return QPageSize::A3;
|
2015-11-09 13:29:37 +01:00
|
|
|
}
|
|
|
|
|
2017-10-10 11:22:59 +02:00
|
|
|
if (size == QSizeF(210, 297) || size == QSizeF(297, 210))
|
2015-11-09 13:29:37 +01:00
|
|
|
{
|
2019-04-28 17:49:29 +02:00
|
|
|
return QPageSize::A4;
|
2015-11-09 13:29:37 +01:00
|
|
|
}
|
|
|
|
|
2017-10-10 11:22:59 +02:00
|
|
|
if (size == QSizeF(215.9, 355.6) || size == QSizeF(355.6, 215.9))
|
2015-11-09 13:29:37 +01:00
|
|
|
{
|
2019-04-28 17:49:29 +02:00
|
|
|
return QPageSize::Legal;
|
2015-11-09 13:29:37 +01:00
|
|
|
}
|
|
|
|
|
2017-10-10 11:22:59 +02:00
|
|
|
if (size == QSizeF(215.9, 279.4) || size == QSizeF(279.4, 215.9))
|
2015-11-09 13:29:37 +01:00
|
|
|
{
|
2019-04-28 17:49:29 +02:00
|
|
|
return QPageSize::Letter;
|
2015-11-09 13:29:37 +01:00
|
|
|
}
|
|
|
|
|
2019-04-28 17:49:29 +02:00
|
|
|
return QPageSize::Custom;
|
2015-11-09 13:29:37 +01:00
|
|
|
}
|
|
|
|
|
2015-05-14 14:27:04 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
bool MainWindowsNoGUI::isPagesUniform() const
|
|
|
|
{
|
|
|
|
if (papers.size() < 2)
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2016-06-15 12:55:43 +02:00
|
|
|
auto *paper = qgraphicsitem_cast<QGraphicsRectItem *>(papers.at(0));
|
2015-05-14 14:27:04 +02:00
|
|
|
SCASSERT(paper != nullptr)
|
2018-04-03 13:36:38 +02:00
|
|
|
for (auto paperItem : papers)
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
2018-04-03 13:36:38 +02:00
|
|
|
auto *p = qgraphicsitem_cast<QGraphicsRectItem *>(paperItem);
|
2015-05-14 14:27:04 +02:00
|
|
|
SCASSERT(p != nullptr)
|
2015-11-04 16:22:49 +01:00
|
|
|
if (paper->rect() != p->rect())
|
2015-05-14 14:27:04 +02:00
|
|
|
{
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
2016-06-02 15:51:37 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
bool MainWindowsNoGUI::IsPagesFit(const QSizeF &printPaper) const
|
|
|
|
{
|
|
|
|
// On previous stage already was checked if pages have uniform size
|
|
|
|
// Enough will be to check only one page
|
|
|
|
QGraphicsRectItem *p = qgraphicsitem_cast<QGraphicsRectItem *>(papers.at(0));
|
2016-12-20 19:57:20 +01:00
|
|
|
SCASSERT(p != nullptr)
|
2016-06-02 15:51:37 +02:00
|
|
|
const QSizeF pSize = p->rect().size();
|
|
|
|
if (pSize.height() <= printPaper.height() && pSize.width() <= printPaper.width())
|
|
|
|
{
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
return false;
|
|
|
|
}
|
|
|
|
|
2017-07-16 20:10:48 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-10-13 16:48:20 +02:00
|
|
|
void MainWindowsNoGUI::ExportScene(const QList<QGraphicsScene *> &scenes,
|
2017-07-16 20:10:48 +02:00
|
|
|
const QList<QGraphicsItem *> &papers, const QList<QGraphicsItem *> &shadows,
|
|
|
|
const QList<QList<QGraphicsItem *> > &details, bool ignorePrinterFields,
|
|
|
|
const QMarginsF &margins) const
|
|
|
|
{
|
|
|
|
for (int i=0; i < scenes.size(); ++i)
|
|
|
|
{
|
|
|
|
QGraphicsRectItem *paper = qgraphicsitem_cast<QGraphicsRectItem *>(papers.at(i));
|
|
|
|
if (paper)
|
|
|
|
{
|
2019-01-17 09:36:37 +01:00
|
|
|
const QString name = m_dialogSaveLayout->Path() + '/' + m_dialogSaveLayout->FileName() +
|
2019-04-10 15:32:35 +02:00
|
|
|
QString::number(i+1) + DialogSaveLayout::ExportFormatSuffix(m_dialogSaveLayout->Format());
|
2017-07-16 20:10:48 +02:00
|
|
|
QBrush *brush = new QBrush();
|
|
|
|
brush->setColor( QColor( Qt::white ) );
|
|
|
|
QGraphicsScene *scene = scenes.at(i);
|
|
|
|
scene->setBackgroundBrush( *brush );
|
|
|
|
shadows[i]->setVisible(false);
|
|
|
|
paper->setPen(QPen(QBrush(Qt::white, Qt::NoBrush), 0.1, Qt::NoPen));
|
|
|
|
|
2017-10-13 16:48:20 +02:00
|
|
|
switch (m_dialogSaveLayout->Format())
|
2017-07-16 20:10:48 +02:00
|
|
|
{
|
|
|
|
case LayoutExportFormats::SVG:
|
|
|
|
paper->setVisible(false);
|
2019-01-03 18:33:15 +01:00
|
|
|
SvgFile(name, paper, scene, margins);
|
2017-07-16 20:10:48 +02:00
|
|
|
paper->setVisible(true);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::PDF:
|
|
|
|
PdfFile(name, paper, scene, ignorePrinterFields, margins);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::PNG:
|
2019-01-03 18:33:15 +01:00
|
|
|
PngFile(name, paper, scene, margins);
|
2017-07-16 20:10:48 +02:00
|
|
|
break;
|
|
|
|
case LayoutExportFormats::OBJ:
|
|
|
|
paper->setVisible(false);
|
|
|
|
ObjFile(name, paper, scene);
|
|
|
|
paper->setVisible(true);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::PS:
|
|
|
|
PsFile(name, paper, scene, ignorePrinterFields, margins);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::EPS:
|
|
|
|
EpsFile(name, paper, scene, ignorePrinterFields, margins);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1006_Flat:
|
|
|
|
paper->setVisible(false);
|
2017-10-13 16:48:20 +02:00
|
|
|
FlatDxfFile(name, DRW::AC1006, m_dialogSaveLayout->IsBinaryDXFFormat(), paper, scene, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
paper->setVisible(true);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1009_Flat:
|
|
|
|
paper->setVisible(false);
|
2017-10-13 16:48:20 +02:00
|
|
|
FlatDxfFile(name, DRW::AC1009, m_dialogSaveLayout->IsBinaryDXFFormat(), paper, scene, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
paper->setVisible(true);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1012_Flat:
|
|
|
|
paper->setVisible(false);
|
2017-10-13 16:48:20 +02:00
|
|
|
FlatDxfFile(name, DRW::AC1012, m_dialogSaveLayout->IsBinaryDXFFormat(), paper, scene, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
paper->setVisible(true);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1014_Flat:
|
|
|
|
paper->setVisible(false);
|
2017-10-13 16:48:20 +02:00
|
|
|
FlatDxfFile(name, DRW::AC1014, m_dialogSaveLayout->IsBinaryDXFFormat(), paper, scene, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
paper->setVisible(true);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1015_Flat:
|
|
|
|
paper->setVisible(false);
|
2017-10-13 16:48:20 +02:00
|
|
|
FlatDxfFile(name, DRW::AC1015, m_dialogSaveLayout->IsBinaryDXFFormat(), paper, scene, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
paper->setVisible(true);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1018_Flat:
|
|
|
|
paper->setVisible(false);
|
2017-10-13 16:48:20 +02:00
|
|
|
FlatDxfFile(name, DRW::AC1018, m_dialogSaveLayout->IsBinaryDXFFormat(), paper, scene, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
paper->setVisible(true);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1021_Flat:
|
|
|
|
paper->setVisible(false);
|
2017-10-13 16:48:20 +02:00
|
|
|
FlatDxfFile(name, DRW::AC1021, m_dialogSaveLayout->IsBinaryDXFFormat(), paper, scene, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
paper->setVisible(true);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1024_Flat:
|
|
|
|
paper->setVisible(false);
|
2017-10-13 16:48:20 +02:00
|
|
|
FlatDxfFile(name, DRW::AC1024, m_dialogSaveLayout->IsBinaryDXFFormat(), paper, scene, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
paper->setVisible(true);
|
|
|
|
break;
|
|
|
|
case LayoutExportFormats::DXF_AC1027_Flat:
|
|
|
|
paper->setVisible(false);
|
2017-10-13 16:48:20 +02:00
|
|
|
FlatDxfFile(name, DRW::AC1027, m_dialogSaveLayout->IsBinaryDXFFormat(), paper, scene, details);
|
2017-07-16 20:10:48 +02:00
|
|
|
paper->setVisible(true);
|
|
|
|
break;
|
|
|
|
default:
|
|
|
|
qDebug() << "Can't recognize file type." << Q_FUNC_INFO;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
paper->setPen(QPen(Qt::black, 1));
|
|
|
|
brush->setColor( QColor( Qt::gray ) );
|
|
|
|
brush->setStyle( Qt::SolidPattern );
|
|
|
|
scenes[i]->setBackgroundBrush( *brush );
|
|
|
|
shadows[i]->setVisible(true);
|
|
|
|
delete brush;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-14 14:27:04 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
QString MainWindowsNoGUI::FileName() const
|
|
|
|
{
|
|
|
|
QString fileName;
|
2018-06-19 08:18:38 +02:00
|
|
|
qApp->GetPatternPath().isEmpty() ? fileName = tr("unnamed") : fileName = qApp->GetPatternPath();
|
2015-05-14 14:27:04 +02:00
|
|
|
return QFileInfo(fileName).baseName();
|
|
|
|
}
|
|
|
|
|
2017-08-21 16:29:25 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::SetSizeHeightForIndividualM() const
|
|
|
|
{
|
|
|
|
const QHash<QString, QSharedPointer<VInternalVariable> > * vars = pattern->DataVariables();
|
|
|
|
|
|
|
|
if (vars->contains(size_M))
|
|
|
|
{
|
2018-09-18 15:38:16 +02:00
|
|
|
pattern->SetSize(*vars->value(size_M)->GetValue());
|
2017-08-21 16:29:25 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2018-09-18 15:38:16 +02:00
|
|
|
pattern->SetSize(0);
|
2017-08-21 16:29:25 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
if (vars->contains(height_M))
|
|
|
|
{
|
2018-09-18 15:38:16 +02:00
|
|
|
pattern->SetHeight(*vars->value(height_M)->GetValue());
|
2017-08-21 16:29:25 +02:00
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
2018-09-18 15:38:16 +02:00
|
|
|
pattern->SetHeight(0);
|
2017-08-21 16:29:25 +02:00
|
|
|
}
|
2017-08-23 19:54:20 +02:00
|
|
|
|
|
|
|
doc->SetPatternWasChanged(true);
|
|
|
|
emit doc->UpdatePatternLabel();
|
2017-08-21 16:29:25 +02:00
|
|
|
}
|
|
|
|
|
2017-09-27 13:47:05 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
2017-09-28 15:05:04 +02:00
|
|
|
bool MainWindowsNoGUI::ExportFMeasurementsToCSVData(const QString &fileName, bool withHeader, int mib,
|
2017-09-27 13:47:05 +02:00
|
|
|
const QChar &separator) const
|
|
|
|
{
|
|
|
|
QxtCsvModel csv;
|
|
|
|
|
|
|
|
csv.insertColumn(0);
|
|
|
|
csv.insertColumn(1);
|
2017-10-03 09:40:08 +02:00
|
|
|
csv.insertColumn(2);
|
2017-09-27 13:47:05 +02:00
|
|
|
|
|
|
|
if (withHeader)
|
|
|
|
{
|
|
|
|
csv.setHeaderText(0, tr("Name"));
|
|
|
|
csv.setHeaderText(1, tr("Value"));
|
2017-10-03 09:40:08 +02:00
|
|
|
csv.setHeaderText(2, tr("Description"));
|
2017-09-27 13:47:05 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
const QVector<VFinalMeasurement> measurements = doc->GetFinalMeasurements();
|
|
|
|
const VContainer completeData = doc->GetCompleteData();
|
|
|
|
|
|
|
|
for (int i=0; i < measurements.size(); ++i)
|
|
|
|
{
|
|
|
|
const VFinalMeasurement &m = measurements.at(i);
|
|
|
|
|
|
|
|
csv.insertRow(i);
|
|
|
|
csv.setText(i, 0, m.name); // name
|
|
|
|
|
|
|
|
if (not m.formula.isEmpty())
|
|
|
|
{
|
|
|
|
try
|
|
|
|
{
|
|
|
|
QScopedPointer<Calculator> cal(new Calculator());
|
2018-01-24 21:08:53 +01:00
|
|
|
const qreal result = cal->EvalFormula(completeData.DataVariables(), m.formula);
|
2017-09-27 14:23:40 +02:00
|
|
|
|
|
|
|
csv.setText(i, 1, qApp->LocaleToString(result)); // value
|
2017-09-27 13:47:05 +02:00
|
|
|
|
|
|
|
if (qIsInf(result) || qIsNaN(result))
|
|
|
|
{
|
2017-09-27 14:23:40 +02:00
|
|
|
qCritical("%s\n\n%s", qUtf8Printable(tr("Export final measurements error.")),
|
|
|
|
qUtf8Printable(tr("Value in line %1 is infinite or NaN. Please, check your calculations.")
|
|
|
|
.arg(i+1)));
|
|
|
|
if (not VApplication::IsGUIMode())
|
|
|
|
{
|
|
|
|
qApp->exit(V_EX_DATAERR);
|
|
|
|
}
|
2017-09-28 15:05:04 +02:00
|
|
|
return false;
|
2017-09-27 13:47:05 +02:00
|
|
|
}
|
|
|
|
}
|
2017-09-27 14:23:40 +02:00
|
|
|
catch (qmu::QmuParserError &e)
|
2017-09-27 13:47:05 +02:00
|
|
|
{
|
2017-09-27 14:23:40 +02:00
|
|
|
qCritical("%s\n\n%s", qUtf8Printable(tr("Export final measurements error.")),
|
|
|
|
qUtf8Printable(tr("Parser error at line %1: %2.").arg(i+1).arg(e.GetMsg())));
|
|
|
|
if (not VApplication::IsGUIMode())
|
|
|
|
{
|
|
|
|
qApp->exit(V_EX_DATAERR);
|
|
|
|
}
|
2017-09-28 15:05:04 +02:00
|
|
|
return false;
|
2017-09-27 13:47:05 +02:00
|
|
|
}
|
|
|
|
}
|
2017-10-03 09:40:08 +02:00
|
|
|
|
|
|
|
csv.setText(i, 2, m.description); // description
|
2017-09-27 13:47:05 +02:00
|
|
|
}
|
|
|
|
|
2017-09-28 15:05:04 +02:00
|
|
|
QString error;
|
|
|
|
const bool success = csv.toCSV(fileName, error, withHeader, separator, QTextCodec::codecForMib(mib));
|
|
|
|
|
|
|
|
if (not success)
|
|
|
|
{
|
|
|
|
qCritical("%s\n\n%s", qUtf8Printable(tr("Export final measurements error.")),
|
|
|
|
qUtf8Printable(tr("File error %1.").arg(error)));
|
|
|
|
if (not VApplication::IsGUIMode())
|
|
|
|
{
|
|
|
|
qApp->exit(V_EX_CANTCREAT);
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return success;
|
2017-09-27 13:47:05 +02:00
|
|
|
}
|
|
|
|
|
2018-08-06 18:38:23 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
QSharedPointer<VMeasurements> MainWindowsNoGUI::OpenMeasurementFile(const QString &path) const
|
|
|
|
{
|
|
|
|
QSharedPointer<VMeasurements> m;
|
|
|
|
if (path.isEmpty())
|
|
|
|
{
|
|
|
|
return m;
|
|
|
|
}
|
|
|
|
|
|
|
|
try
|
|
|
|
{
|
|
|
|
m = QSharedPointer<VMeasurements>(new VMeasurements(pattern));
|
|
|
|
m->setXMLContent(path);
|
|
|
|
|
|
|
|
if (m->Type() == MeasurementsType::Unknown)
|
|
|
|
{
|
|
|
|
VException e(tr("Measurement file has unknown format."));
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
|
|
|
|
if (m->Type() == MeasurementsType::Multisize)
|
|
|
|
{
|
|
|
|
VVSTConverter converter(path);
|
|
|
|
m->setXMLContent(converter.Convert());// Read again after conversion
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
VVITConverter converter(path);
|
|
|
|
m->setXMLContent(converter.Convert());// Read again after conversion
|
|
|
|
}
|
|
|
|
|
|
|
|
if (not m->IsDefinedKnownNamesValid())
|
|
|
|
{
|
|
|
|
VException e(tr("Measurement file contains invalid known measurement(s)."));
|
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
|
|
|
|
CheckRequiredMeasurements(m.data());
|
|
|
|
|
|
|
|
if (m->Type() == MeasurementsType::Multisize)
|
|
|
|
{
|
|
|
|
if (m->MUnit() == Unit::Inch)
|
|
|
|
{
|
|
|
|
qCCritical(vMainNoGUIWindow, "%s\n\n%s", qUtf8Printable(tr("Wrong units.")),
|
|
|
|
qUtf8Printable(tr("Application doesn't support multisize table with inches.")));
|
|
|
|
m->clear();
|
|
|
|
if (not VApplication::IsGUIMode())
|
|
|
|
{
|
|
|
|
qApp->exit(V_EX_DATAERR);
|
|
|
|
}
|
|
|
|
return m;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
catch (VException &e)
|
|
|
|
{
|
|
|
|
qCCritical(vMainNoGUIWindow, "%s\n\n%s\n\n%s", qUtf8Printable(tr("File error.")),
|
|
|
|
qUtf8Printable(e.ErrorMessage()), qUtf8Printable(e.DetailedInformation()));
|
|
|
|
m->clear();
|
|
|
|
if (not VApplication::IsGUIMode())
|
|
|
|
{
|
|
|
|
qApp->exit(V_EX_NOINPUT);
|
|
|
|
}
|
|
|
|
return m;
|
|
|
|
}
|
|
|
|
return m;
|
|
|
|
}
|
|
|
|
|
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
void MainWindowsNoGUI::CheckRequiredMeasurements(const VMeasurements *m) const
|
|
|
|
{
|
|
|
|
const QSet<QString> match = doc->ListMeasurements().toSet().subtract(m->ListAll().toSet());
|
|
|
|
if (not match.isEmpty())
|
|
|
|
{
|
|
|
|
QList<QString> list = match.toList();
|
|
|
|
for (int i = 0; i < list.size(); ++i)
|
|
|
|
{
|
|
|
|
list[i] = qApp->TrVars()->MToUser(list.at(i));
|
|
|
|
}
|
|
|
|
|
|
|
|
VException e(tr("Measurement file doesn't include all required measurements."));
|
2019-01-17 09:36:37 +01:00
|
|
|
e.AddMoreInformation(tr("Please, additionally provide: %1").arg(QStringList(list).join(QStringLiteral(", "))));
|
2018-08-06 18:38:23 +02:00
|
|
|
throw e;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2015-05-14 14:27:04 +02:00
|
|
|
//---------------------------------------------------------------------------------------------------------------------
|
|
|
|
int MainWindowsNoGUI::ContinueIfLayoutStale()
|
|
|
|
{
|
|
|
|
QMessageBox msgBox(this);
|
|
|
|
msgBox.setIcon(QMessageBox::Question);
|
|
|
|
msgBox.setWindowTitle(tr("The layout is stale."));
|
|
|
|
msgBox.setText(tr("The layout was not updated since last pattern modification. Do you want to continue?"));
|
|
|
|
msgBox.setStandardButtons(QMessageBox::Yes|QMessageBox::No);
|
|
|
|
msgBox.setDefaultButton(QMessageBox::No);
|
|
|
|
QSpacerItem* horizontalSpacer = new QSpacerItem(500, 0, QSizePolicy::Minimum, QSizePolicy::Expanding);
|
|
|
|
QGridLayout* layout = static_cast<QGridLayout*>(msgBox.layout());
|
2016-12-20 19:57:20 +01:00
|
|
|
SCASSERT(layout != nullptr)
|
2015-05-14 14:27:04 +02:00
|
|
|
layout->addItem(horizontalSpacer, layout->rowCount(), 0, 1, layout->columnCount());
|
2017-04-19 13:06:48 +02:00
|
|
|
return msgBox.exec();
|
2015-05-14 14:27:04 +02:00
|
|
|
}
|