/************************************************************************ ** ** @file vcurveangle.cpp ** @author Roman Telezhynskyi ** @date 1 6, 2015 ** ** @brief ** @copyright ** This source code is part of the Valentine 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 "../vgeometry/vabstractcurve.h" #include "../vgeometry/vspline.h" //--------------------------------------------------------------------------------------------------------------------- VCurveAngle::VCurveAngle() :VCurveVariable() { 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()); } else { SetValue(curve->GetEndAngle()); SetName(angle2_V + curve->name()); } } //--------------------------------------------------------------------------------------------------------------------- VCurveAngle::VCurveAngle(const quint32 &id, const quint32 &parentId, const QString &baseCurveName, const VSpline &spl, CurveAngle angle, qint32 segment) :VCurveVariable(id, parentId) { SetType(VarType::CurveAngle); if (angle == CurveAngle::StartAngle) { SetValue(spl.GetStartAngle()); SetName(angle1_V + baseCurveName + QLatin1String("_") + seg_ + QString().setNum(segment)); } else { SetValue(spl.GetEndAngle()); SetName(angle2_V + baseCurveName + QLatin1String("_") + seg_ + QString().setNum(segment)); } } //--------------------------------------------------------------------------------------------------------------------- VCurveAngle::VCurveAngle(const VCurveAngle &var) :VCurveVariable(var) {} //--------------------------------------------------------------------------------------------------------------------- VCurveAngle &VCurveAngle::operator=(const VCurveAngle &var) { if ( &var == this ) { return *this; } VCurveVariable::operator=(var); return *this; } //--------------------------------------------------------------------------------------------------------------------- VCurveAngle::~VCurveAngle() {}