/************************************************************************ ** ** @file vstandardmeasurements.cpp ** @author Roman Telezhynskyi ** @date 8 3, 2014 ** ** @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) 2013 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 "vstandardmeasurements.h" #include #include "../core/vapplication.h" const QString VStandardMeasurements::TagDescription = QStringLiteral("description"); const QString VStandardMeasurements::TagId = QStringLiteral("id"); const QString VStandardMeasurements::TagSize = QStringLiteral("size"); const QString VStandardMeasurements::TagHeight = QStringLiteral("height"); const QString VStandardMeasurements::AttrSize_increase = QStringLiteral("size_increase"); const QString VStandardMeasurements::AttrHeight_increase = QStringLiteral("height_increase"); //--------------------------------------------------------------------------------------------------------------------- VStandardMeasurements::VStandardMeasurements(VContainer *data) :VAbstractMeasurements(data) { SCASSERT(data != nullptr) } //--------------------------------------------------------------------------------------------------------------------- VStandardMeasurements::~VStandardMeasurements() {} //--------------------------------------------------------------------------------------------------------------------- QString VStandardMeasurements::Description() { const QString desc = UniqueTagText(TagDescription, ""); if (desc.isEmpty()) { qWarning()<<"Empty description in standard table."<patternUnit()); qreal size_increase = GetParametrDouble(domElement, AttrSize_increase, "0.0"); size_increase = UnitConvertor(size_increase, MUnit(), qApp->patternUnit()); qreal height_increase = GetParametrDouble(domElement, AttrHeight_increase, "0.0"); height_increase = UnitConvertor(height_increase, MUnit(), qApp->patternUnit()); if (MUnit() == Unit::Inch) { qWarning()<<"Standard table can't use inch unit."; } data->AddVariable(tag, new VMeasurement(tag, value, size_increase, height_increase, qApp->GuiText(tag), qApp->Description(tag), tag)); } //--------------------------------------------------------------------------------------------------------------------- qreal VStandardMeasurements::TakeParametr(const QString &tag, qreal defValue) const { const qreal defVal = UnitConvertor(defValue, Unit::Cm, qApp->patternUnit()); const QDomNodeList nodeList = this->elementsByTagName(tag); if (nodeList.isEmpty()) { return defVal; } else { const QDomNode domNode = nodeList.at(0); if (domNode.isNull() == false && domNode.isElement()) { const QDomElement domElement = domNode.toElement(); if (domElement.isNull() == false) { qreal value = GetParametrDouble(domElement, AttrValue, QString("%1").arg(defVal)); value = UnitConvertor(value, MUnit(), qApp->patternUnit()); return value; } } } return defVal; } //--------------------------------------------------------------------------------------------------------------------- void VStandardMeasurements::SetSize() { const qreal value = TakeParametr(TagSize, 50); data->SetSize(value); data->SetSizeName(size_M); } //--------------------------------------------------------------------------------------------------------------------- void VStandardMeasurements::SetHeight() { const qreal value = TakeParametr(TagHeight, 176); data->SetHeight(value); data->SetHeightName(height_M); }