valentina/src/libs/vpatterndb/variables/vmeasurement.cpp

414 lines
14 KiB
C++
Raw Normal View History

/************************************************************************
**
** @file vstandardtablecell.cpp
** @author Roman Telezhynskyi <dismine(at)gmail.com>
** @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
** <https://gitlab.com/smart-pattern/valentina> 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 <http://www.gnu.org/licenses/>.
**
*************************************************************************/
#include "vmeasurement.h"
2013-07-17 13:38:11 +02:00
#include <QMap>
#include <QMessageLogger>
#include <QtDebug>
#include "../ifc/ifcdef.h"
2023-10-19 16:35:29 +02:00
#include "../ifc/xml/vpatternimage.h"
#include "vmeasurement_p.h"
2023-07-15 09:58:28 +02:00
#include "vvariable.h"
2023-10-18 14:23:55 +02:00
#if QT_VERSION < QT_VERSION_CHECK(6, 4, 0)
#include "../vmisc/compatibility.h"
#endif
using namespace Qt::Literals::StringLiterals;
2022-02-05 14:00:22 +01:00
//---------------------------------------------------------------------------------------------------------------------
VMeasurement::VMeasurement(quint32 index, const QString &name)
2023-07-15 09:58:28 +02:00
: VVariable(name),
d(new VMeasurementData(index, MeasurementType::Separator))
2022-02-05 14:00:22 +01:00
{
SetType(VarType::MeasurementSeparator);
VInternalVariable::SetValue(0);
}
//---------------------------------------------------------------------------------------------------------------------
/**
* @brief VMeasurement create measurement for multisize table
* @param name measurement's name
2020-10-03 17:52:31 +02:00
* @param base measurement's base value
*/
2020-10-03 17:52:31 +02:00
VMeasurement::VMeasurement(quint32 index, const QString &name, qreal baseA, qreal baseB, qreal baseC, qreal base)
2023-07-15 09:58:28 +02:00
: VVariable(name),
d(new VMeasurementData(index, baseA, baseB, baseC, base))
{
SetType(VarType::Measurement);
2020-10-03 17:52:31 +02:00
VInternalVariable::SetValue(d->shiftBase);
}
//---------------------------------------------------------------------------------------------------------------------
/**
* @brief VMeasurement create measurement for individual table
2020-10-03 17:52:31 +02:00
* @param name measurement's base value
* @param base value in base size and height
*/
VMeasurement::VMeasurement(VContainer *data, quint32 index, const QString &name, const qreal &base,
2020-10-03 17:52:31 +02:00
const QString &formula, bool ok)
2023-07-15 09:58:28 +02:00
: VVariable(name),
d(new VMeasurementData(data, index, formula, ok, base))
{
SetType(VarType::Measurement);
VInternalVariable::SetValue(base);
}
//---------------------------------------------------------------------------------------------------------------------
2023-07-15 09:58:28 +02:00
COPY_CONSTRUCTOR_IMPL_2(VMeasurement, VVariable)
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::operator=(const VMeasurement &m) -> VMeasurement &
{
2023-07-15 09:58:28 +02:00
if (&m == this)
{
return *this;
}
VVariable::operator=(m);
d = m.d;
return *this;
}
//---------------------------------------------------------------------------------------------------------------------
2023-07-13 16:49:20 +02:00
VMeasurement::VMeasurement(VMeasurement &&m) noexcept
2023-07-15 09:58:28 +02:00
: VVariable(std::move(m)),
d(std::move(m.d)) // NOLINT(bugprone-use-after-move)
2023-07-15 09:58:28 +02:00
{
}
//---------------------------------------------------------------------------------------------------------------------
2023-07-15 09:58:28 +02:00
auto VMeasurement::operator=(VMeasurement &&m) noexcept -> VMeasurement &
{
VVariable::operator=(m);
std::swap(d, m.d);
return *this;
}
//---------------------------------------------------------------------------------------------------------------------
2023-07-15 09:58:28 +02:00
VMeasurement::~VMeasurement() = default;
2023-10-31 08:42:09 +01:00
//---------------------------------------------------------------------------------------------------------------------
auto VMeasurement::GetKnownMeasurementsId() const -> QUuid
{
return d->dbId;
}
//---------------------------------------------------------------------------------------------------------------------
void VMeasurement::SetKnownMeasurementsId(const QUuid &id)
{
d->dbId = id;
}
2020-10-03 17:52:31 +02:00
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::CorrectionHash(qreal baseA, qreal baseB, qreal baseC) -> QString
2020-10-03 17:52:31 +02:00
{
QStringList hashBlocks{QString::number(baseA)};
if (baseB > 0)
{
hashBlocks.append(QString::number(baseB));
}
if (baseC > 0)
{
hashBlocks.append(QString::number(baseC));
}
2023-10-18 14:23:55 +02:00
return hashBlocks.join(';'_L1);
2020-10-03 17:52:31 +02:00
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::CalcValue() const -> qreal
{
2020-10-03 17:52:31 +02:00
if (qFuzzyIsNull(d->currentBaseA))
{
return VInternalVariable::GetValue();
}
2020-10-03 17:52:31 +02:00
// Formula for calculation gradation
const qreal kA = d->stepA > 0 ? (d->currentBaseA - d->baseA) / d->stepA : 0;
const qreal kB = d->stepB > 0 ? (d->currentBaseB - d->baseB) / d->stepB : 0;
const qreal kC = d->stepC > 0 ? (d->currentBaseC - d->baseC) / d->stepC : 0;
return d->shiftBase + kA * d->shiftA + kB * d->shiftB + kC * d->shiftC + Correction();
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::Correction() const -> qreal
2020-10-03 17:52:31 +02:00
{
const QString hash = CorrectionHash(d->currentBaseA, d->currentBaseB, d->currentBaseC);
if (d->corrections.contains(hash))
{
2020-10-03 17:52:31 +02:00
return d->corrections.value(hash);
}
2020-10-03 17:52:31 +02:00
return 0;
}
//---------------------------------------------------------------------------------------------------------------------
/**
* @brief GetGuiText measurement name for tooltip
* @return measurement name
*/
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetGuiText() const -> QString
{
return d->gui_text;
}
//---------------------------------------------------------------------------------------------------------------------
2020-10-03 17:52:31 +02:00
void VMeasurement::SetGuiText(const QString &guiText)
{
2020-10-03 17:52:31 +02:00
d->gui_text = guiText;
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetFormula() const -> QString
{
return d->formula;
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::IsCustom() const -> bool
{
return GetName().indexOf(CustomMSign) == 0;
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::Index() const -> int
{
return static_cast<int>(d->index);
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::IsFormulaOk() const -> bool
{
return d->formulaOk;
}
2022-02-05 14:00:22 +01:00
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetMeasurementType() const -> MeasurementType
2022-02-05 14:00:22 +01:00
{
return d->varType;
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::IsNotUsed() const -> bool
{
2020-10-03 17:52:31 +02:00
return qFuzzyIsNull(d->shiftBase) && qFuzzyIsNull(d->shiftB) && qFuzzyIsNull(d->shiftA);
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetValue() const -> qreal
{
return CalcValue();
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetValue() -> qreal *
{
VInternalVariable::SetValue(CalcValue());
return VInternalVariable::GetValue();
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetData() -> VContainer *
{
return d->data.data();
}
//---------------------------------------------------------------------------------------------------------------------
2020-10-03 17:52:31 +02:00
void VMeasurement::SetBaseA(qreal base)
{
2020-10-03 17:52:31 +02:00
d->currentBaseA = base;
}
//---------------------------------------------------------------------------------------------------------------------
2020-10-03 17:52:31 +02:00
void VMeasurement::SetBaseB(qreal base)
{
2020-10-03 17:52:31 +02:00
d->currentBaseB = base;
}
//---------------------------------------------------------------------------------------------------------------------
2020-10-03 17:52:31 +02:00
void VMeasurement::SetBaseC(qreal base)
{
2020-10-03 17:52:31 +02:00
d->currentBaseC = base;
}
//---------------------------------------------------------------------------------------------------------------------
/**
* @brief GetBase return value in base size and height
* @return value
*/
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetBase() const -> qreal
{
2020-10-03 17:52:31 +02:00
return d->shiftBase;
}
//---------------------------------------------------------------------------------------------------------------------
2020-10-03 17:52:31 +02:00
void VMeasurement::SetBase(qreal value)
{
2020-10-03 17:52:31 +02:00
d->shiftBase = value;
}
//---------------------------------------------------------------------------------------------------------------------
/**
2020-10-03 17:52:31 +02:00
* @brief GetKheight return increment in heights
* @return increment
*/
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetShiftA() const -> qreal
{
2020-10-03 17:52:31 +02:00
return d->shiftA;
}
//---------------------------------------------------------------------------------------------------------------------
// cppcheck-suppress unusedFunction
2020-10-03 17:52:31 +02:00
void VMeasurement::SetShiftA(qreal value)
{
2020-10-03 17:52:31 +02:00
d->shiftA = value;
}
//---------------------------------------------------------------------------------------------------------------------
/**
2020-10-03 17:52:31 +02:00
* @brief GetKsize return increment in sizes
* @return increment
*/
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetShiftB() const -> qreal
{
2020-10-03 17:52:31 +02:00
return d->shiftB;
}
//---------------------------------------------------------------------------------------------------------------------
// cppcheck-suppress unusedFunction
2020-10-03 17:52:31 +02:00
void VMeasurement::SetShiftB(qreal value)
{
d->shiftB = value;
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetShiftC() const -> qreal
2020-10-03 17:52:31 +02:00
{
return d->shiftC;
}
//---------------------------------------------------------------------------------------------------------------------
void VMeasurement::SetShiftC(qreal value)
{
d->shiftC = value;
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetStepA() const -> qreal
2020-10-03 17:52:31 +02:00
{
return d->shiftA;
}
//---------------------------------------------------------------------------------------------------------------------
void VMeasurement::SetStepA(qreal value)
{
d->stepA = value;
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetStepB() const -> qreal
2020-10-03 17:52:31 +02:00
{
return d->stepB;
}
//---------------------------------------------------------------------------------------------------------------------
void VMeasurement::SetStepB(qreal value)
{
d->stepB = value;
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetStepC() const -> qreal
2020-10-03 17:52:31 +02:00
{
return d->stepC;
}
//---------------------------------------------------------------------------------------------------------------------
void VMeasurement::SetStepC(qreal value)
{
d->stepC = value;
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::IsSpecialUnits() const -> bool
2020-10-03 17:52:31 +02:00
{
return d->specialUnits;
}
//---------------------------------------------------------------------------------------------------------------------
void VMeasurement::SetSpecialUnits(bool special)
{
d->specialUnits = special;
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetDimension() const -> IMD
{
return d->dimension;
}
//---------------------------------------------------------------------------------------------------------------------
void VMeasurement::SetDimension(IMD type)
{
d->dimension = type;
}
2020-10-03 17:52:31 +02:00
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetCorrection(qreal baseA, qreal baseB, qreal baseC) const -> qreal
2020-10-03 17:52:31 +02:00
{
return d->corrections.value(VMeasurement::CorrectionHash(baseA, baseB, baseC), 0);
}
//---------------------------------------------------------------------------------------------------------------------
2023-05-03 13:07:02 +02:00
auto VMeasurement::GetCorrections() const -> QMap<QString, qreal>
2020-10-03 17:52:31 +02:00
{
return d->corrections;
}
//---------------------------------------------------------------------------------------------------------------------
void VMeasurement::SetCorrections(const QMap<QString, qreal> &corrections)
{
2020-10-03 17:52:31 +02:00
d->corrections = corrections;
}
2023-10-19 16:35:29 +02:00
//---------------------------------------------------------------------------------------------------------------------
auto VMeasurement::GetImage() const -> VPatternImage
{
return d->image;
}
//---------------------------------------------------------------------------------------------------------------------
void VMeasurement::SetImage(const VPatternImage &image)
{
d->image = image;
}