/*
Copyright 2006-2017 The QElectroTech Team
This file is part of QElectroTech.
QElectroTech 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 2 of the License, or
(at your option) any later version.
QElectroTech 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 QElectroTech. If not, see .
*/
#ifndef ELEMENTS_MOVER_H
#define ELEMENTS_MOVER_H
#include
#include "diagramcontent.h"
class ConductorTextItem;
class Diagram;
/**
This class manages the interactive movement of different items (elements,
conductors, text items etc...) on a particular diagram.
A movement work in 3 steps:
1: beginMovement -> init a new movement
2: continueMovement -> continue the curent movement
3: endMovement -> finish the curent movement
A movement in progress must finish befor start a new movement. We can know if
element mover is ready for a new movement by calling isReady().
*/
class ElementsMover {
// constructors, destructor
public:
ElementsMover();
virtual ~ElementsMover();
private:
ElementsMover(const ElementsMover &);
// methods
public:
bool isReady() const;
int beginMovement(Diagram *, QGraphicsItem * = 0);
void continueMovement(const QPointF &);
void endMovement();
// attributes
private:
bool movement_running_;
QPointF current_movement_;
Diagram *diagram_;
QGraphicsItem *movement_driver_;
DiagramContent moved_content_;
};
#endif