/************************************************************************ ** ** @file vstandardtablecell.cpp ** @author Roman Telezhynskyi ** @date November 15, 2013 ** ** @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) 2013-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 "vmeasurement.h" #include #include #include #include "../ifc/ifcdef.h" #include "vvariable.h" #include "vmeasurement_p.h" //--------------------------------------------------------------------------------------------------------------------- /** * @brief VMeasurement create measurement for multisize table * @param name measurement's name * @param base value in base size and height * @param ksize increment in sizes * @param kheight increment in heights * @param gui_text shor tooltip for user * @param description measurement full description * @param tagName measurement's tag name in file */ VMeasurement::VMeasurement(quint32 index, const QString &name, qreal baseSize, qreal baseHeight, const qreal &base, const qreal &ksize, const qreal &kheight, const QString &gui_text, const QString &description, const QString &tagName) :VVariable(name, description), d(new VMeasurementData(index, gui_text, tagName, baseSize, baseHeight, base, ksize, kheight)) { SetType(VarType::Measurement); VInternalVariable::SetValue(d->base); } //--------------------------------------------------------------------------------------------------------------------- /** * @brief VMeasurement create measurement for individual table * @param name measurement's name * @param base value in base size and height * @param gui_text shor tooltip for user * @param description measurement full description * @param tagName measurement's tag name in file */ VMeasurement::VMeasurement(VContainer *data, quint32 index, const QString &name, const qreal &base, const QString &formula, bool ok, const QString &gui_text, const QString &description, const QString &tagName) :VVariable(name, description), d(new VMeasurementData(data, index, formula, ok, gui_text, tagName, base)) { SetType(VarType::Measurement); VInternalVariable::SetValue(base); } //--------------------------------------------------------------------------------------------------------------------- VMeasurement::VMeasurement(const VMeasurement &m) :VVariable(m), d(m.d) {} //--------------------------------------------------------------------------------------------------------------------- VMeasurement &VMeasurement::operator=(const VMeasurement &m) { if ( &m == this ) { return *this; } VVariable::operator=(m); d = m.d; return *this; } #ifdef Q_COMPILER_RVALUE_REFS //--------------------------------------------------------------------------------------------------------------------- VMeasurement &VMeasurement::operator=(VMeasurement &&m) Q_DECL_NOTHROW { Swap(m); return *this; } #endif //--------------------------------------------------------------------------------------------------------------------- void VMeasurement::Swap(VMeasurement &m) Q_DECL_NOTHROW { VVariable::Swap(m); std::swap(d, m.d); } //--------------------------------------------------------------------------------------------------------------------- VMeasurement::~VMeasurement() {} //--------------------------------------------------------------------------------------------------------------------- QStringList VMeasurement::ListHeights(const QMap &heights, Unit patternUnit) { QStringList list; if (patternUnit == Unit::Inch) { qWarning()<<"Multisize table doesn't support inches."; return list; } QMap::const_iterator i = heights.constBegin(); while (i != heights.constEnd()) { if (i.value() && i.key() != GHeights::ALL) { list.append(QString::number(UnitConvertor(static_cast(i.key()), Unit::Cm, patternUnit))); } ++i; } if (list.isEmpty()) { list = VMeasurement::WholeListHeights(patternUnit); } return list; } //--------------------------------------------------------------------------------------------------------------------- QStringList VMeasurement::ListSizes(const QMap &sizes, Unit patternUnit) { QStringList list; if (patternUnit == Unit::Inch) { qWarning()<<"Multisize table doesn't support inches."; return list; } QMap::const_iterator i = sizes.constBegin(); while (i != sizes.constEnd()) { if (i.value() && i.key() != GSizes::ALL) { list.append(QString::number(UnitConvertor(static_cast(i.key()), Unit::Cm, patternUnit))); } ++i; } if (list.isEmpty()) { list = VMeasurement::WholeListSizes(patternUnit); } return list; } //--------------------------------------------------------------------------------------------------------------------- QStringList VMeasurement::WholeListHeights(Unit patternUnit) { QStringList list; if (patternUnit == Unit::Inch) { qWarning()<<"Multisize table doesn't support inches."; return list; } list.reserve((static_cast(GHeights::H200) - static_cast(GHeights::H50))/heightStep); for (int i = static_cast(GHeights::H50); i<= static_cast(GHeights::H200); i = i+heightStep) { list.append(QString::number(UnitConvertor(i, Unit::Cm, patternUnit))); } return list; } //--------------------------------------------------------------------------------------------------------------------- QStringList VMeasurement::WholeListSizes(Unit patternUnit) { QStringList list; if (patternUnit == Unit::Inch) { qWarning()<<"Multisize table doesn't support inches."; return list; } list.reserve((static_cast(GSizes::S72) - static_cast(GSizes::S22))/sizeStep); for (int i = static_cast(GSizes::S22); i<= static_cast(GSizes::S72); i = i+sizeStep) { list.append(QString::number(UnitConvertor(i, Unit::Cm, patternUnit))); } return list; } //--------------------------------------------------------------------------------------------------------------------- bool VMeasurement::IsGradationSizeValid(const QString &size) { if (not size.isEmpty()) { const QStringList sizes = VMeasurement::WholeListSizes(Unit::Cm); return sizes.contains(size); } else { return false; } } //--------------------------------------------------------------------------------------------------------------------- bool VMeasurement::IsGradationHeightValid(const QString &height) { if (not height.isEmpty()) { const QStringList heights = VMeasurement::WholeListHeights(Unit::Cm); return heights.contains(height); } else { return false; } } //--------------------------------------------------------------------------------------------------------------------- qreal VMeasurement::CalcValue() const { if (d->currentUnit == nullptr || qFuzzyIsNull(d->currentSize) || qFuzzyIsNull(d->currentHeight)) { return VInternalVariable::GetValue(); } if (*d->currentUnit == Unit::Inch) { qWarning("Gradation doesn't support inches"); return 0; } const qreal sizeIncrement = UnitConvertor(2.0, Unit::Cm, *d->currentUnit); const qreal heightIncrement = UnitConvertor(6.0, Unit::Cm, *d->currentUnit); // Formula for calculation gradation const qreal k_size = ( d->currentSize - d->baseSize ) / sizeIncrement; const qreal k_height = ( d->currentHeight - d->baseHeight ) / heightIncrement; return d->base + k_size * d->ksize + k_height * d->kheight; } //--------------------------------------------------------------------------------------------------------------------- /** * @brief GetGuiText measurement name for tooltip * @return measurement name */ QString VMeasurement::GetGuiText() const { return d->gui_text; } //--------------------------------------------------------------------------------------------------------------------- QString VMeasurement::TagName() const { return d->_tagName; } //--------------------------------------------------------------------------------------------------------------------- void VMeasurement::setTagName(const QString &tagName) { d->_tagName = tagName; } //--------------------------------------------------------------------------------------------------------------------- QString VMeasurement::GetFormula() const { return d->formula; } //--------------------------------------------------------------------------------------------------------------------- bool VMeasurement::IsCustom() const { return GetName().indexOf(CustomMSign) == 0; } //--------------------------------------------------------------------------------------------------------------------- int VMeasurement::Index() const { return static_cast(d->index); } //--------------------------------------------------------------------------------------------------------------------- bool VMeasurement::IsFormulaOk() const { return d->formulaOk; } //--------------------------------------------------------------------------------------------------------------------- bool VMeasurement::IsNotUsed() const { return qFuzzyIsNull(d->base) && qFuzzyIsNull(d->ksize) && qFuzzyIsNull(d->kheight); } //--------------------------------------------------------------------------------------------------------------------- qreal VMeasurement::GetValue() const { return CalcValue(); } //--------------------------------------------------------------------------------------------------------------------- qreal *VMeasurement::GetValue() { VInternalVariable::SetValue(CalcValue()); return VInternalVariable::GetValue(); } //--------------------------------------------------------------------------------------------------------------------- VContainer *VMeasurement::GetData() { return d->data.data(); } //--------------------------------------------------------------------------------------------------------------------- void VMeasurement::SetSize(qreal size) { d->currentSize = size; } //--------------------------------------------------------------------------------------------------------------------- void VMeasurement::SetHeight(qreal height) { d->currentHeight = height; } //--------------------------------------------------------------------------------------------------------------------- void VMeasurement::SetUnit(const Unit *unit) { d->currentUnit = unit; } //--------------------------------------------------------------------------------------------------------------------- /** * @brief GetBase return value in base size and height * @return value */ qreal VMeasurement::GetBase() const { return d->base; } //--------------------------------------------------------------------------------------------------------------------- void VMeasurement::SetBase(const qreal &value) { d->base = value; } //--------------------------------------------------------------------------------------------------------------------- /** * @brief GetKsize return increment in sizes * @return increment */ qreal VMeasurement::GetKsize() const { return d->ksize; } //--------------------------------------------------------------------------------------------------------------------- // cppcheck-suppress unusedFunction void VMeasurement::SetKsize(const qreal &value) { d->ksize = value; } //--------------------------------------------------------------------------------------------------------------------- /** * @brief GetKheight return increment in heights * @return increment */ qreal VMeasurement::GetKheight() const { return d->kheight; } //--------------------------------------------------------------------------------------------------------------------- // cppcheck-suppress unusedFunction void VMeasurement::SetKheight(const qreal &value) { d->kheight = value; }