2013-11-15 13:41:26 +01:00
|
|
|
/************************************************************************
|
2013-10-27 12:59:34 +01:00
|
|
|
**
|
2013-11-15 13:50:05 +01:00
|
|
|
** @file dialogtriangle.h
|
2013-11-15 13:41:26 +01:00
|
|
|
** @author Roman Telezhinsky <dismine@gmail.com>
|
2013-11-15 13:50:05 +01:00
|
|
|
** @date November 15, 2013
|
2013-10-27 12:59:34 +01:00
|
|
|
**
|
2013-11-15 13:41:26 +01:00
|
|
|
** @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
|
|
|
|
** <https://bitbucket.org/dismine/valentina> All Rights Reserved.
|
2013-10-27 12:59:34 +01:00
|
|
|
**
|
2013-11-15 13:41:26 +01:00
|
|
|
** Valentina is free software: you can redistribute it and/or modify
|
2013-10-27 12:59:34 +01:00
|
|
|
** 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/>.
|
|
|
|
**
|
2013-11-15 13:41:26 +01:00
|
|
|
*************************************************************************/
|
2013-10-27 12:59:34 +01:00
|
|
|
|
2013-10-18 20:20:54 +02:00
|
|
|
#ifndef DIALOGTRIANGLE_H
|
|
|
|
#define DIALOGTRIANGLE_H
|
|
|
|
|
|
|
|
#include "dialogtool.h"
|
|
|
|
|
2013-11-04 21:35:15 +01:00
|
|
|
namespace Ui
|
|
|
|
{
|
|
|
|
class DialogTriangle;
|
2013-10-18 20:20:54 +02:00
|
|
|
}
|
|
|
|
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief The DialogTriangle class dialog for ToolTriangle. Help create point and edit option.
|
|
|
|
*/
|
2013-11-04 21:35:15 +01:00
|
|
|
class DialogTriangle : public DialogTool
|
|
|
|
{
|
2013-10-18 20:20:54 +02:00
|
|
|
Q_OBJECT
|
|
|
|
public:
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief DialogTriangle create dialog
|
|
|
|
* @param data container with data
|
|
|
|
* @param mode mode of creation tool
|
|
|
|
* @param parent parent widget
|
|
|
|
*/
|
2013-11-04 21:35:15 +01:00
|
|
|
DialogTriangle(const VContainer *data, Draw::Draws mode = Draw::Calculation, QWidget *parent = 0);
|
2013-10-26 19:55:06 +02:00
|
|
|
~DialogTriangle();
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief getAxisP1Id return id first point of axis
|
|
|
|
* @return id
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
inline qint64 getAxisP1Id() const {return axisP1Id;}
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief setAxisP1Id set id first point of axis
|
|
|
|
* @param value id
|
|
|
|
* @param id don't show this point in list
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
void setAxisP1Id(const qint64 &value, const qint64 &id);
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief getAxisP2Id return id second point of axis
|
|
|
|
* @return id
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
inline qint64 getAxisP2Id() const {return axisP2Id;}
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief setAxisP2Id set id second point of axis
|
|
|
|
* @param value id
|
|
|
|
* @param id don't show this point in list
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
void setAxisP2Id(const qint64 &value, const qint64 &id);
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief getFirstPointId return id of first point
|
|
|
|
* @return id
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
inline qint64 getFirstPointId() const {return firstPointId;}
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief setFirstPointId set id of first point
|
|
|
|
* @param value id
|
|
|
|
* @param id don't show this point in list
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
void setFirstPointId(const qint64 &value, const qint64 &id);
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief getSecondPointId return id of second point
|
|
|
|
* @return id
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
inline qint64 getSecondPointId() const {return secondPointId;}
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief setSecondPointId set id of second point
|
|
|
|
* @param value id
|
|
|
|
* @param id don't show this point in list
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
void setSecondPointId(const qint64 &value, const qint64 &id);
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief getPointName return name of point
|
|
|
|
* @return name
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
inline QString getPointName() const {return pointName;}
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief setPointName set name of point
|
|
|
|
* @param value name
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
void setPointName(const QString &value);
|
2013-10-18 20:20:54 +02:00
|
|
|
public slots:
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief ChoosedObject gets id and type of selected object. Save right data and ignore wrong.
|
|
|
|
* @param id id of point or detail
|
|
|
|
* @param type type of object
|
|
|
|
*/
|
2013-11-06 20:46:07 +01:00
|
|
|
virtual void ChoosedObject(qint64 id, const Scene::Scenes &type);
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief DialogAccepted save data and emit signal about closed dialog.
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
virtual void DialogAccepted();
|
2013-10-18 20:20:54 +02:00
|
|
|
private:
|
|
|
|
Q_DISABLE_COPY(DialogTriangle)
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief ui keeps information about user interface
|
|
|
|
*/
|
2013-10-18 20:20:54 +02:00
|
|
|
Ui::DialogTriangle *ui;
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief number number of handled objects
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
qint32 number;
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief pointName name of point
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
QString pointName;
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief axisP1Id id first point of axis
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
qint64 axisP1Id;
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief axisP2Id id second point of axis
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
qint64 axisP2Id;
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief firstPointId id first point of line
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
qint64 firstPointId;
|
2013-11-19 21:56:49 +01:00
|
|
|
/**
|
|
|
|
* @brief secondPointId id second point of line
|
|
|
|
*/
|
2013-10-26 19:55:06 +02:00
|
|
|
qint64 secondPointId;
|
2013-10-18 20:20:54 +02:00
|
|
|
};
|
|
|
|
|
|
|
|
#endif // DIALOGTRIANGLE_H
|