[qet] [4088] ImagePropertiesWidget : use QPropertyUndoCommand instead of ItemResizerCommand

[ Thread Index | Date Index | More lists.tuxfamily.org/qet Archives ]


Revision: 4088
Author:   blacksun
Date:     2015-08-06 19:08:45 +0200 (Thu, 06 Aug 2015)
Log Message:
-----------
ImagePropertiesWidget : use QPropertyUndoCommand instead of ItemResizerCommand 

Modified Paths:
--------------
    trunk/sources/ui/imagepropertieswidget.cpp
    trunk/sources/ui/imagepropertieswidget.h

Removed Paths:
-------------
    trunk/sources/undocommand/itemresizercommand.cpp
    trunk/sources/undocommand/itemresizercommand.h

Modified: trunk/sources/ui/imagepropertieswidget.cpp
===================================================================
--- trunk/sources/ui/imagepropertieswidget.cpp	2015-08-06 16:34:38 UTC (rev 4087)
+++ trunk/sources/ui/imagepropertieswidget.cpp	2015-08-06 17:08:45 UTC (rev 4088)
@@ -18,9 +18,8 @@
 #include "imagepropertieswidget.h"
 #include "ui_imagepropertieswidget.h"
 #include "diagramimageitem.h"
-#include <QUndoCommand>
-#include "itemresizercommand.h"
 #include "diagram.h"
+#include "QPropertyUndoCommand/qpropertyundocommand.h"
 
 /**
  * @brief ImagePropertiesWidget::ImagePropertiesWidget
@@ -57,13 +56,9 @@
 	this->setEnabled(true);
 	if (m_image == image) return;
 	if (m_image)
-	{
-		disconnect(m_image, SIGNAL(destroyed()), this, SLOT(imageWasDeleted()));
 		disconnect(m_image, &QGraphicsObject::scaleChanged, this, &ImagePropertiesWidget::updateUi);
-	}
 
 	m_image = image;
-	connect(m_image, SIGNAL(destroyed()), this, SLOT(imageWasDeleted()));
 	connect(m_image, &QGraphicsObject::scaleChanged, this, &ImagePropertiesWidget::updateUi);
 	m_movable = image->isMovable();
 	m_scale = m_image->scale();
@@ -82,7 +77,9 @@
 	{
 		if (m_live_edit) disconnect(m_image, &QGraphicsObject::scaleChanged, this, &ImagePropertiesWidget::updateUi);
 
-		m_image->diagram()->undoStack().push(associatedUndo());
+		QUndoCommand *undo = associatedUndo();
+		if (undo)
+			m_image->diagram()->undoStack().push(undo);
 
 		if (m_live_edit) connect(m_image, &QGraphicsObject::scaleChanged, this, &ImagePropertiesWidget::updateUi);
 	}
@@ -130,13 +127,19 @@
 
 /**
  * @brief ImagePropertiesWidget::associatedUndo
- * @return the change in an undo command (ItemResizerCommand)
+ * @return the change in an undo command (ItemResizerCommand).
+ * If there is no change return nullptr
  */
 QUndoCommand* ImagePropertiesWidget::associatedUndo()
 {
+
 	qreal value = ui->m_scale_slider->value();
 	value /= 100;
-	return new ItemResizerCommand(m_image, m_scale, value, tr("une image"));
+	if (m_scale == value) return nullptr;
+	QPropertyUndoCommand *undo = new QPropertyUndoCommand(m_image, "scale", m_scale, value);
+	undo->enableAnimation();
+	undo->setText(tr("Modifier la taille d'une image"));
+	return undo;
 }
 
 /**
@@ -161,10 +164,6 @@
 		m_image->setScale(scale / 100);
 }
 
-void ImagePropertiesWidget::imageWasDeleted() {
-	m_image = nullptr;
-}
-
 /**
  * @brief ImagePropertiesWidget::on_m_lock_pos_cb_clicked
  * Set movable or not the image according to corresponding check box

Modified: trunk/sources/ui/imagepropertieswidget.h
===================================================================
--- trunk/sources/ui/imagepropertieswidget.h	2015-08-06 16:34:38 UTC (rev 4087)
+++ trunk/sources/ui/imagepropertieswidget.h	2015-08-06 17:08:45 UTC (rev 4088)
@@ -18,7 +18,6 @@
 #ifndef IMAGEPROPERTIESWIDGET_H
 #define IMAGEPROPERTIESWIDGET_H
 
-#include <QWidget>
 #include "PropertiesEditor/propertieseditorwidget.h"
 
 class DiagramImageItem;
@@ -50,8 +49,6 @@
 
 	private slots:
 		void on_m_scale_slider_valueChanged(int value);
-		void imageWasDeleted();
-
 		void on_m_lock_pos_cb_clicked();
 
 	private:

Deleted: trunk/sources/undocommand/itemresizercommand.cpp
===================================================================
--- trunk/sources/undocommand/itemresizercommand.cpp	2015-08-06 16:34:38 UTC (rev 4087)
+++ trunk/sources/undocommand/itemresizercommand.cpp	2015-08-06 17:08:45 UTC (rev 4088)
@@ -1,97 +0,0 @@
-/*
-	Copyright 2006-2015 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 <http://www.gnu.org/licenses/>.
-*/
-#include "itemresizercommand.h"
-#include "qetgraphicsitem.h"
-#include "diagram.h"
-
-/**
- * @brief ItemResizerCommand::ItemResizerCommand
- * Change the size of @qgi
- * @param qgi item to resize
- * @param old_ old size
- * @param new_ new size
- * @param text text to display
- * @param parent undo parent
- */
-ItemResizerCommand::ItemResizerCommand (QetGraphicsItem *qgi, const qreal &old_, const qreal &new_, const QString &text, QUndoCommand *parent):
-	QUndoCommand(parent),
-	m_qgi (qgi),
-	m_old_size (old_),
-	m_new_size (new_),
-	m_diagram (qgi->diagram()),
-	m_text (text),
-	m_first_redo(true)
-{
-	m_animation.setTargetObject(m_qgi);
-	m_animation.setPropertyName("scale");
-	m_animation.setStartValue(m_old_size);
-	m_animation.setEndValue(m_new_size);
-}
-
-/**
- * @brief ItemResizerCommand::~ItemResizerCommand
- */
-ItemResizerCommand::~ItemResizerCommand() {}
-
-/**
- * @brief ItemResizerCommand::mergeWith
- * Try to merge this command with other command
- * @param other
- * @return true if was merged, else false
- */
-bool ItemResizerCommand::mergeWith(const QUndoCommand *other)
-{
-	if (id() != other->id() || other->childCount()) return false;
-	ItemResizerCommand const *undo = static_cast<const ItemResizerCommand *>(other);
-	if (m_qgi != undo->m_qgi) return false;
-	m_new_size = undo->m_new_size;
-	m_animation.setEndValue(m_new_size);
-	return true;
-}
-
-/**
- * @brief ItemResizerCommand::undo
- */
-void ItemResizerCommand::undo()
-{
-	m_diagram -> showMe();
-	m_animation.setDirection(QAnimationGroup::Backward);
-	m_animation.start();
-	QUndoCommand::undo();
-}
-
-/**
- * @brief ItemResizerCommand::redo
- */
-void ItemResizerCommand::redo()
-{
-	m_diagram -> showMe();
-	setText(m_old_size < m_new_size ? QObject::tr("Agrandire %1 à %2 %").arg(m_text).arg(m_new_size*100) :
-									  QObject::tr("Réduire %1 à %2 %").arg(m_text).arg(m_new_size*100));
-	if(m_first_redo)
-	{
-		m_qgi -> setScale(m_new_size);
-		m_first_redo = false;
-	}
-	else
-	{
-		m_animation.setDirection(QAnimationGroup::Forward);
-		m_animation.start();
-	}
-	QUndoCommand::redo();
-}

Deleted: trunk/sources/undocommand/itemresizercommand.h
===================================================================
--- trunk/sources/undocommand/itemresizercommand.h	2015-08-06 16:34:38 UTC (rev 4087)
+++ trunk/sources/undocommand/itemresizercommand.h	2015-08-06 17:08:45 UTC (rev 4088)
@@ -1,52 +0,0 @@
-/*
-	Copyright 2006-2015 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 <http://www.gnu.org/licenses/>.
-*/
-#ifndef ITEMRESIZERCOMMAND_H
-#define ITEMRESIZERCOMMAND_H
-
-#include <QUndoCommand>
-#include <QPropertyAnimation>
-
-class QetGraphicsItem;
-class Diagram;
-
-/**
- * @brief The ItemResizerCommand class
- * This Undo command manage the scale of QetGraphicsItem.
- */
-class ItemResizerCommand : public QUndoCommand
-{
-	public:
-		ItemResizerCommand (QetGraphicsItem *qgi, const qreal &old_, const qreal &new_,const QString  &text, QUndoCommand *parent = 0);
-		virtual ~ItemResizerCommand();
-
-	public:
-		virtual int id() const {return 3;}
-		virtual bool mergeWith(const QUndoCommand *other);
-		virtual void undo();
-		virtual void redo();
-
-	private:
-		QetGraphicsItem *m_qgi;
-		qreal m_old_size, m_new_size;
-		Diagram *m_diagram;
-		QString m_text;
-		QPropertyAnimation m_animation;
-		bool m_first_redo;
-};
-
-#endif // ITEMRESIZERCOMMAND_H


Mail converted by MHonArc 2.6.19+ http://listengine.tuxfamily.org/