valentina/src/app/geometry/vpointf_p.h

85 lines
2.3 KiB
C
Raw Normal View History

/************************************************************************
**
** @file vpointf_p.h
** @author Roman Telezhynskyi <dismine(at)gmail.com>
** @date 20 8, 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) 2014 Valentina project
** <https://bitbucket.org/dismine/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/>.
**
*************************************************************************/
#ifndef VPOINTF_P_H
#define VPOINTF_P_H
#include <QSharedData>
#include "../options.h"
#include <QPointF>
#ifdef Q_CC_GNU
#pragma GCC diagnostic push
#pragma GCC diagnostic ignored "-Weffc++"
#endif
class VPointFData : public QSharedData
{
public:
VPointFData()
: _mx(0), _my(0), _x(0), _y(0)
{}
VPointFData(const VPointFData &point)
:QSharedData(point), _mx(point._mx), _my(point._my), _x(point._x), _y(point._y)
{}
VPointFData(const QPointF &point)
:_mx(0), _my(0), _x(point.x()), _y(point.y())
{}
VPointFData(qreal x, qreal y, qreal mx, qreal my)
:_mx(mx), _my(my), _x(x), _y(y)
{}
VPointFData(const QPointF &point, qreal mx, qreal my)
:_mx(mx), _my(my), _x(point.x()), _y(point.y())
{}
virtual ~VPointFData() {}
/** @brief _mx offset name respect to x */
qreal _mx;
/** @brief _my offset name respect to y */
qreal _my;
/** @brief _x x coordinate */
qreal _x;
/** @brief _y y coordinate */
qreal _y;
};
#ifdef Q_CC_GNU
#pragma GCC diagnostic pop
#endif
#endif // VPOINTF_P_H