/************************************************************************ ** ** @file ** @author Roman Telezhynskyi ** @date 3 11, 2016 ** ** @brief ** @copyright ** This source code is part of the Valentina project, a pattern making ** program, whose allow create and modeling patterns of clothing. ** Copyright (C) 2016 Valentina project ** 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 . ** *************************************************************************/ #ifndef VPIECE_H #define VPIECE_H #include #include #include "../vlayout/vabstractpiece.h" class VPieceData; class VPieceNode; class VPiecePath; class VPatternLabelData; class VPieceLabelData; class VGrainlineData; class VContainer; class QPainterPath; class VPointF; class VPassmark; class VPiece : public VAbstractPiece { Q_DECLARE_TR_FUNCTIONS(VPiece) // NOLINT public: VPiece(); VPiece(const VPiece &piece); virtual ~VPiece(); VPiece &operator=(const VPiece &piece); #ifdef Q_COMPILER_RVALUE_REFS VPiece(VPiece &&piece) Q_DECL_NOTHROW; VPiece &operator=(VPiece &&piece) Q_DECL_NOTHROW; #endif VPiecePath GetPath() const; VPiecePath &GetPath(); void SetPath(const VPiecePath &path); QVector MainPathPoints(const VContainer *data) const; QVector UniteMainPathPoints(const VContainer *data) const; QVector MainPathNodePoints(const VContainer *data, bool showExcluded = false) const; QVector SeamAllowancePoints(const VContainer *data) const; QVector CuttingPathPoints(const VContainer *data) const; QVector PassmarksLines(const VContainer *data) const; QVector Passmarks(const VContainer *data) const; QVector CurvesPainterPath(const VContainer *data) const; QPainterPath MainPathPath(const VContainer *data) const; static QPainterPath MainPathPath(const QVector &points); QPainterPath SeamAllowancePath(const VContainer *data) const; template QPainterPath SeamAllowancePath(const QVector &points) const; QPainterPath PassmarksPath(const VContainer *data) const; QPainterPath PlaceLabelPath(const VContainer *data) const; bool IsSeamAllowanceValid(const VContainer *data) const; bool IsInLayout() const; void SetInLayout(bool inLayout); bool IsUnited() const; void SetUnited(bool united); auto GetShortName() const -> QString; void SetShortName(const QString &value); QString GetFormulaSAWidth() const; void SetFormulaSAWidth(const QString &formula, qreal value); QVector GetInternalPaths() const; QVector &GetInternalPaths(); void SetInternalPaths(const QVector &iPaths); QVector GetCustomSARecords() const; QVector &GetCustomSARecords(); void SetCustomSARecords(const QVector &records); QVector GetPins() const; QVector &GetPins(); void SetPins(const QVector &pins); QVector GetPlaceLabels() const; QVector &GetPlaceLabels(); void SetPlaceLabels(const QVector &labels); QList Dependencies() const; QVector MissingNodes(const VPiece &det) const; QVector MissingCSAPath(const VPiece &det) const; QVector MissingInternalPaths(const VPiece &det) const; QVector MissingPins(const VPiece &det) const; QVector MissingPlaceLabels(const VPiece &det) const; void SetPieceLabelData(const VPieceLabelData &data); VPieceLabelData& GetPieceLabelData(); const VPieceLabelData& GetPieceLabelData() const; void SetPatternLabelData(const VPatternLabelData &info); VPatternLabelData& GetPatternLabelData(); const VPatternLabelData& GetPatternLabelData() const; void SetGrainlineGeometry(const VGrainlineData &data); VGrainlineData& GetGrainlineGeometry(); const VGrainlineData& GetGrainlineGeometry() const; QVector GetUnitedPath(const VContainer *data) const; QVector SeamAllowancePointsWithRotation(const VContainer *data, vsizetype makeFirst) const; void SetGradationLabel(const QString &label); auto GetGradationLabel() const -> QString; static void DumpPiece(const VPiece &piece, const VContainer *data, const QString &templateName=QString()); void TestInternalPaths(const VContainer *data) const; static auto ShortNameRegExp() -> QString; auto ExternalArea(const VContainer *data) const -> qreal; auto SeamLineArea(const VContainer *data) const -> qreal; private: QSharedDataPointer d; QVector GetValidRecords() const; QVector FilterRecords(QVector records) const; QVector GetNodeSAPoints(const QVector &path, vsizetype index, const VContainer *data) const; bool GetPassmarkSAPoint(const QVector &path, vsizetype index, const VContainer *data, VSAPoint &point) const; bool GetPassmarkPreviousSAPoints(const QVector &path, vsizetype index, const VSAPoint &passmarkSAPoint, const VContainer *data, VSAPoint &point, vsizetype passmarkIndex) const; bool GetPassmarkNextSAPoints(const QVector &path, vsizetype index, const VSAPoint &passmarkSAPoint, const VContainer *data, VSAPoint &point, vsizetype passmarkIndex) const; bool IsPassmarkVisible(const QVector &path, vsizetype passmarkIndex) const; VPassmark CreatePassmark(const QVector &path, vsizetype previousIndex, vsizetype passmarkIndex, vsizetype nextIndex, const VContainer *data) const; static int IsCSAStart(const QVector &records, quint32 id); QJsonObject MainPathToJson() const; QJsonObject DBToJson(const VContainer *data) const; qreal GlobalPassmarkLength(const VContainer *data) const; void TestInternalPathCuttingPathIntersection(const VContainer *data) const; void TestInternalPathsIntersections(const VContainer *data) const; auto Area(const QVector &shape, const VContainer *data) const -> qreal; }; Q_DECLARE_TYPEINFO(VPiece, Q_MOVABLE_TYPE); // NOLINT //--------------------------------------------------------------------------------------------------------------------- template inline QPainterPath VPiece::SeamAllowancePath(const QVector &points) const { QPainterPath ekv; // seam allowence if (IsSeamAllowance() && not IsSeamAllowanceBuiltIn()) { if (not points.isEmpty()) { ekv.moveTo(points.at(0)); for (qint32 i = 1; i < points.count(); ++i) { ekv.lineTo(points.at(i)); } #if !defined(V_NO_ASSERT) // uncomment for debug // QFont font; // font.setPixelSize(1); // for (qint32 i = 0; i < points.count(); ++i) // { // ekv.addEllipse(points.at(i).x()-accuracyPointOnLine, points.at(i).y()-accuracyPointOnLine, // accuracyPointOnLine*2., accuracyPointOnLine*2.); // ekv.addText(points.at(i).x()-accuracyPointOnLine, points.at(i).y()-accuracyPointOnLine, font, // QString::number(i+1)); // } #endif ekv.setFillRule(Qt::WindingFill); } } return ekv; } #endif // VPIECE_H