/************************************************************************ ** ** @file vcurveangle.cpp ** @author Roman Telezhynskyi ** @date 1 6, 2015 ** ** @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) 2015 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 . ** *************************************************************************/ #include "vcurveangle.h" #include #include #include "../vmisc/def.h" #include "../ifc/ifcdef.h" #include "../vgeometry/vabstractcurve.h" #include "../vgeometry/vspline.h" #include "../vgeometry/vellipticalarc.h" #include "vcurvevariable.h" //--------------------------------------------------------------------------------------------------------------------- VCurveAngle::VCurveAngle() :VCurveVariable() { SetType(VarType::CurveAngle); } //--------------------------------------------------------------------------------------------------------------------- VCurveAngle::VCurveAngle(const quint32 &id, const quint32 &parentId) :VCurveVariable(id, parentId) { SetType(VarType::CurveAngle); } //--------------------------------------------------------------------------------------------------------------------- VCurveAngle::VCurveAngle(const quint32 &id, const quint32 &parentId, const VAbstractCurve *curve, CurveAngle angle) :VCurveVariable(id, parentId) { SetType(VarType::CurveAngle); SCASSERT(curve != nullptr) if (angle == CurveAngle::StartAngle) { SetValue(curve->GetStartAngle()); SetName(angle1_V + curve->name()); if (not curve->GetAlias().isEmpty()) { SetAlias(angle1_V + curve->GetAlias()); } } else { SetValue(curve->GetEndAngle()); SetName(angle2_V + curve->name()); if (not curve->GetAlias().isEmpty()) { SetAlias(angle2_V + curve->GetAlias()); } } } //--------------------------------------------------------------------------------------------------------------------- VCurveAngle::VCurveAngle(const quint32 &id, const quint32 &parentId, const VAbstractCurve *baseCurve, const VSpline &spl, CurveAngle angle, qint32 segment) :VCurveVariable(id, parentId) { SCASSERT(baseCurve != nullptr) SetType(VarType::CurveAngle); if (angle == CurveAngle::StartAngle) { SetValue(spl.GetStartAngle()); SetName(angle1_V + baseCurve->name() + QLatin1String("_") + seg_ + QString().setNum(segment)); if (not baseCurve->GetAlias().isEmpty()) { SetAlias(angle1_V + baseCurve->GetAlias() + QLatin1String("_") + seg_ + QString().setNum(segment)); } } else { SetValue(spl.GetEndAngle()); SetName(angle2_V + baseCurve->name() + QLatin1String("_") + seg_ + QString().setNum(segment)); if (not baseCurve->GetAlias().isEmpty()) { SetAlias(angle2_V + baseCurve->GetAlias() + QLatin1String("_") + seg_ + QString().setNum(segment)); } } } //--------------------------------------------------------------------------------------------------------------------- VEllipticalArcRotation::VEllipticalArcRotation() : VCurveAngle() { SetType(VarType::CurveAngle); } //--------------------------------------------------------------------------------------------------------------------- VEllipticalArcRotation::VEllipticalArcRotation(const quint32 &id, const quint32 &parentId, const VEllipticalArc *elArc) : VCurveAngle(id, parentId) { SetType(VarType::CurveAngle); SCASSERT(elArc != nullptr) SetValue(elArc->GetRotationAngle()); SetName(rotation_V + elArc->name()); if (not elArc->GetAlias().isEmpty()) { SetAlias(rotation_V + elArc->GetAlias()); } }