2013-11-15 13:41:26 +01:00
|
|
|
|
/************************************************************************
|
2013-09-18 21:16:19 +02:00
|
|
|
|
**
|
2013-11-15 13:50:05 +01:00
|
|
|
|
** @file vitem.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-09-18 21:16:19 +02: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-09-18 21:16:19 +02:00
|
|
|
|
**
|
2013-11-15 13:41:26 +01:00
|
|
|
|
** Valentina is free software: you can redistribute it and/or modify
|
2013-09-18 21:16:19 +02: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.
|
|
|
|
|
**
|
2013-10-27 13:36:29 +01:00
|
|
|
|
** Valentina is distributed in the hope that it will be useful,
|
2013-09-18 21:16:19 +02:00
|
|
|
|
** 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-09-18 21:16:19 +02:00
|
|
|
|
|
2013-08-29 12:31:50 +02:00
|
|
|
|
#ifndef VITEM_H
|
|
|
|
|
#define VITEM_H
|
|
|
|
|
|
|
|
|
|
#include <QGraphicsPathItem>
|
|
|
|
|
#include <QObject>
|
|
|
|
|
|
|
|
|
|
/**
|
|
|
|
|
* @brief VItem клас, що реалізує деталь на сцені.
|
|
|
|
|
*/
|
2013-11-04 21:35:15 +01:00
|
|
|
|
class VItem : public QObject, public QGraphicsPathItem
|
|
|
|
|
{
|
2013-08-29 12:31:50 +02:00
|
|
|
|
Q_OBJECT
|
|
|
|
|
public:
|
|
|
|
|
/**
|
|
|
|
|
* @brief VItem конструктор за замовчуванням
|
|
|
|
|
*Конструктор генерує пусту деталь з номером в списку, що дорівнює 0.
|
|
|
|
|
*/
|
2013-11-13 15:07:40 +01:00
|
|
|
|
VItem ():numInOutList(0), paper(0){}
|
2013-08-29 12:31:50 +02:00
|
|
|
|
/**
|
|
|
|
|
* @brief VItem конструктор
|
|
|
|
|
* @param numInList номер в списку деталей, що передається у вікно де
|
|
|
|
|
*укладаються деталі.
|
|
|
|
|
* @param parent батьківський об'єкт на сцені для даного. За замовчуванням немає.
|
|
|
|
|
*/
|
2013-11-13 15:07:40 +01:00
|
|
|
|
VItem (int numInList, QGraphicsItem * parent = 0):QGraphicsPathItem (parent), numInOutList(numInList),
|
|
|
|
|
paper(0){}
|
2013-08-29 12:31:50 +02:00
|
|
|
|
/**
|
|
|
|
|
* @brief VItem конструктор
|
|
|
|
|
* @param path зображення що буде показуватися на сцені - об’єкт класу QPainterPath.
|
|
|
|
|
* @param numInList номер в списку деталей, що передається у вікно де
|
|
|
|
|
*укладаються деталі.
|
|
|
|
|
* @param parent батьківський об'єкт на сцені для даного. За замовчуванням немає.
|
|
|
|
|
*/
|
2013-10-27 09:10:39 +01:00
|
|
|
|
VItem ( const QPainterPath & path, int numInList, QGraphicsItem * parent = 0 );
|
2013-08-29 12:31:50 +02:00
|
|
|
|
/**
|
|
|
|
|
* @brief Rotate повертає об'єкт на кут в градусах
|
|
|
|
|
* @param angle кут в градусах на який повертається деталь.
|
|
|
|
|
*/
|
2013-10-27 09:10:39 +01:00
|
|
|
|
void Rotate ( qreal angle );
|
2013-11-13 15:07:40 +01:00
|
|
|
|
QGraphicsRectItem *getPaper() const {return paper;}
|
|
|
|
|
void setPaper(QGraphicsRectItem *value) {paper = value;}
|
2013-08-29 12:31:50 +02:00
|
|
|
|
public slots:
|
|
|
|
|
/**
|
|
|
|
|
* @brief LengthChanged слот який обробляє сигнал зміни довжини листа.
|
|
|
|
|
*/
|
2013-10-27 09:10:39 +01:00
|
|
|
|
void LengthChanged();
|
2013-08-29 12:31:50 +02:00
|
|
|
|
/**
|
|
|
|
|
* @brief SetIndexInList встановлює номер деталі в списку деталей.
|
|
|
|
|
* @param index номер в списку.
|
|
|
|
|
*/
|
2013-10-27 09:10:39 +01:00
|
|
|
|
inline void SetIndexInList( qint32 index ) {numInOutList = index;}
|
2013-08-29 12:31:50 +02:00
|
|
|
|
protected:
|
|
|
|
|
/**
|
|
|
|
|
* @brief itemChange модифікація стандартного методу itemChange. Виконується перехоплення зміни
|
|
|
|
|
*положення і зміни батька.
|
|
|
|
|
* @param change
|
|
|
|
|
* @param value
|
|
|
|
|
* @return
|
|
|
|
|
*/
|
2013-10-27 09:10:39 +01:00
|
|
|
|
QVariant itemChange ( GraphicsItemChange change, const QVariant &value );
|
2013-08-29 12:31:50 +02:00
|
|
|
|
/**
|
|
|
|
|
* @brief checkItemChange перевіряє вихід деталі за рамки листа і факт колізії. Посилає відповідні
|
|
|
|
|
*сигнали.
|
|
|
|
|
*/
|
2013-10-27 09:10:39 +01:00
|
|
|
|
void checkItemChange ();
|
2013-08-29 12:31:50 +02:00
|
|
|
|
private:
|
2013-11-13 15:07:40 +01:00
|
|
|
|
Q_DISABLE_COPY(VItem)
|
2013-08-29 12:31:50 +02:00
|
|
|
|
/**
|
|
|
|
|
* @brief numInOutList для зберігання інформації про колізії від кожної деталі необхідно знати її
|
|
|
|
|
*номер.
|
|
|
|
|
*/
|
|
|
|
|
qint32 numInOutList;
|
2013-11-13 15:07:40 +01:00
|
|
|
|
QGraphicsRectItem* paper;
|
2013-08-29 12:31:50 +02:00
|
|
|
|
signals:
|
|
|
|
|
/**
|
|
|
|
|
* @brief itemOut сигнал виходу за межі листа. Посилається у будь-якому випадку.
|
|
|
|
|
* @param numInOutList номер деталі яка вийшла за межі листа або тепер знаходиться в межах листа.
|
|
|
|
|
* @param flag був вихід чи ні.
|
|
|
|
|
*/
|
2013-10-27 09:10:39 +01:00
|
|
|
|
void itemOut ( int numInOutList, bool flag );
|
2013-08-29 12:31:50 +02:00
|
|
|
|
/**
|
|
|
|
|
* @brief itemColliding сигнал колізії деталі з іншими. Посилається як для додавання деталі до
|
|
|
|
|
*списку тих що перетинаються, так і для виключення його з такого.
|
|
|
|
|
* @param list список усіх деталей які приймають участь в колізії включаючи самого себе.
|
|
|
|
|
* @param number 1 - перетин є, 0 - перетину немає.
|
|
|
|
|
*/
|
2013-10-27 09:10:39 +01:00
|
|
|
|
void itemColliding ( QList<QGraphicsItem *> list, int number );
|
2013-08-29 12:31:50 +02:00
|
|
|
|
};
|
|
|
|
|
#endif // VITEM_H
|