mirror of
https://github.com/aseprite/aseprite.git
synced 2025-04-16 14:42:44 +00:00
Add DocumentEvent class so all DocumentObserver's member functions receive one parameter.
This commit is contained in:
parent
a37a505566
commit
cae19827f5
@ -24,6 +24,7 @@
|
|||||||
#include "base/mutex.h"
|
#include "base/mutex.h"
|
||||||
#include "base/scoped_lock.h"
|
#include "base/scoped_lock.h"
|
||||||
#include "base/unique_ptr.h"
|
#include "base/unique_ptr.h"
|
||||||
|
#include "document_event.h"
|
||||||
#include "document_observer.h"
|
#include "document_observer.h"
|
||||||
#include "document_undo.h"
|
#include "document_undo.h"
|
||||||
#include "file/format_options.h"
|
#include "file/format_options.h"
|
||||||
@ -70,7 +71,8 @@ Document::Document(Sprite* sprite)
|
|||||||
|
|
||||||
Document::~Document()
|
Document::~Document()
|
||||||
{
|
{
|
||||||
notifyObservers(&DocumentObserver::onRemoveSprite, this, m_sprite.get());
|
DocumentEvent ev(this, m_sprite);
|
||||||
|
notifyObservers<DocumentEvent&>(&DocumentObserver::onRemoveSprite, ev);
|
||||||
|
|
||||||
if (m_bound.seg)
|
if (m_bound.seg)
|
||||||
base_free(m_bound.seg);
|
base_free(m_bound.seg);
|
||||||
@ -132,7 +134,8 @@ void Document::addSprite(Sprite* sprite)
|
|||||||
ASSERT(m_sprite == NULL); // TODO add support for more sprites in the future (e.g. for .ico files)
|
ASSERT(m_sprite == NULL); // TODO add support for more sprites in the future (e.g. for .ico files)
|
||||||
m_sprite.reset(sprite);
|
m_sprite.reset(sprite);
|
||||||
|
|
||||||
notifyObservers(&DocumentObserver::onAddSprite, this, m_sprite.get());
|
DocumentEvent ev(this, m_sprite);
|
||||||
|
notifyObservers<DocumentEvent&>(&DocumentObserver::onAddSprite, ev);
|
||||||
}
|
}
|
||||||
|
|
||||||
const char* Document::getFilename() const
|
const char* Document::getFilename() const
|
||||||
|
67
src/document_event.h
Normal file
67
src/document_event.h
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
/* ASEPRITE
|
||||||
|
* Copyright (C) 2001-2012 David Capello
|
||||||
|
*
|
||||||
|
* This program 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.
|
||||||
|
*
|
||||||
|
* This program 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 this program; if not, write to the Free Software
|
||||||
|
* Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
|
||||||
|
*/
|
||||||
|
|
||||||
|
#ifndef DOCUMENT_EVENT_H_INCLUDED
|
||||||
|
#define DOCUMENT_EVENT_H_INCLUDED
|
||||||
|
|
||||||
|
#include "raster/frame_number.h"
|
||||||
|
|
||||||
|
class Cel;
|
||||||
|
class Document;
|
||||||
|
class Image;
|
||||||
|
class Layer;
|
||||||
|
class LayerImage;
|
||||||
|
class Sprite;
|
||||||
|
|
||||||
|
class DocumentEvent {
|
||||||
|
public:
|
||||||
|
DocumentEvent(Document* document,
|
||||||
|
Sprite* sprite = NULL,
|
||||||
|
Layer* layer = NULL,
|
||||||
|
Cel* cel = NULL,
|
||||||
|
Image* image = NULL,
|
||||||
|
int imageIndex = -1,
|
||||||
|
FrameNumber frame = FrameNumber())
|
||||||
|
: m_document(document)
|
||||||
|
, m_sprite(sprite)
|
||||||
|
, m_layer(layer)
|
||||||
|
, m_cel(cel)
|
||||||
|
, m_image(image)
|
||||||
|
, m_imageIndex(imageIndex)
|
||||||
|
, m_frame(frame) {
|
||||||
|
}
|
||||||
|
|
||||||
|
Document* document() const { return m_document; }
|
||||||
|
Sprite* sprite() const { return m_sprite; }
|
||||||
|
Layer* layer() const { return m_layer; }
|
||||||
|
Cel* cel() const { return m_cel; }
|
||||||
|
Image* image() const { return m_image; }
|
||||||
|
int imageIndex() const { return m_imageIndex; }
|
||||||
|
FrameNumber frame() const { return m_frame; }
|
||||||
|
|
||||||
|
private:
|
||||||
|
Document* m_document;
|
||||||
|
Sprite* m_sprite;
|
||||||
|
Layer* m_layer;
|
||||||
|
Cel* m_cel;
|
||||||
|
Image* m_image;
|
||||||
|
int m_imageIndex;
|
||||||
|
FrameNumber m_frame;
|
||||||
|
};
|
||||||
|
|
||||||
|
#endif
|
@ -21,9 +21,7 @@
|
|||||||
|
|
||||||
#include "raster/frame_number.h"
|
#include "raster/frame_number.h"
|
||||||
|
|
||||||
class Document;
|
class DocumentEvent;
|
||||||
class Layer;
|
|
||||||
class Sprite;
|
|
||||||
|
|
||||||
// Observer of document events. The default implementation does
|
// Observer of document events. The default implementation does
|
||||||
// nothing in each handler, so you can override the required events.
|
// nothing in each handler, so you can override the required events.
|
||||||
@ -31,23 +29,28 @@ class DocumentObserver {
|
|||||||
public:
|
public:
|
||||||
virtual ~DocumentObserver() { }
|
virtual ~DocumentObserver() { }
|
||||||
|
|
||||||
virtual void onAddSprite(Document* document, Sprite* sprite) { }
|
virtual void onAddSprite(DocumentEvent& ev) { }
|
||||||
|
virtual void onAddLayer(DocumentEvent& ev) { }
|
||||||
|
virtual void onAddFrame(DocumentEvent& ev) { }
|
||||||
|
virtual void onAddCel(DocumentEvent& ev) { }
|
||||||
|
|
||||||
virtual void onAddLayer(Document* document, Layer* layer) { }
|
virtual void onRemoveSprite(DocumentEvent& ev) { }
|
||||||
|
virtual void onRemoveLayer(DocumentEvent& ev) { }
|
||||||
|
virtual void onRemoveFrame(DocumentEvent& ev) { }
|
||||||
|
virtual void onRemoveCel(DocumentEvent& ev) { }
|
||||||
|
|
||||||
virtual void onAddFrame(Document* document, FrameNumber frame) { }
|
virtual void onSpriteSizeChanged(DocumentEvent& ev) { }
|
||||||
|
|
||||||
virtual void onRemoveSprite(Document* document, Sprite* sprite) { }
|
virtual void onLayerRestacked(DocumentEvent& ev) { }
|
||||||
|
|
||||||
virtual void onRemoveLayer(Document* document, Layer* layer) { }
|
virtual void onCelFrameChanged(DocumentEvent& ev) { }
|
||||||
|
virtual void onCelPositionChanged(DocumentEvent& ev) { }
|
||||||
|
virtual void onCelOpacityChanged(DocumentEvent& ev) { }
|
||||||
|
|
||||||
virtual void onRemoveFrame(Document* document, FrameNumber frame) { }
|
virtual void onFrameDurationChanged(DocumentEvent& ev) { }
|
||||||
|
|
||||||
// Called when the active cel data was modified (position, opacity, etc.).
|
virtual void onImageReplaced(DocumentEvent& ev) { }
|
||||||
virtual void onModifyCel(Document* document) { }
|
virtual void onImagePixelsModified(DocumentEvent& ev) { }
|
||||||
|
|
||||||
// Called when the active cel's image pixels were modified.
|
|
||||||
virtual void onModifyCelImage(Document* document) { }
|
|
||||||
|
|
||||||
// Called to destroy the observer. (Here you could call "delete this".)
|
// Called to destroy the observer. (Here you could call "delete this".)
|
||||||
virtual void dispose() { }
|
virtual void dispose() { }
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
|
|
||||||
#include "base/unique_ptr.h"
|
#include "base/unique_ptr.h"
|
||||||
#include "document.h"
|
#include "document.h"
|
||||||
|
#include "document_event.h"
|
||||||
#include "document_observer.h"
|
#include "document_observer.h"
|
||||||
#include "document_undo.h"
|
#include "document_undo.h"
|
||||||
#include "raster/algorithm/flip_image.h"
|
#include "raster/algorithm/flip_image.h"
|
||||||
@ -205,6 +206,9 @@ void UndoTransaction::setSpriteSize(int w, int h)
|
|||||||
m_undo->pushUndoer(new undoers::SetSpriteSize(m_undo->getObjects(), m_sprite));
|
m_undo->pushUndoer(new undoers::SetSpriteSize(m_undo->getObjects(), m_sprite));
|
||||||
|
|
||||||
m_sprite->setSize(w, h);
|
m_sprite->setSize(w, h);
|
||||||
|
|
||||||
|
DocumentEvent ev(m_document, m_sprite);
|
||||||
|
m_document->notifyObservers<DocumentEvent&>(&DocumentObserver::onSpriteSizeChanged, ev);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UndoTransaction::cropSprite(const gfx::Rect& bounds, int bgcolor)
|
void UndoTransaction::cropSprite(const gfx::Rect& bounds, int bgcolor)
|
||||||
@ -368,6 +372,9 @@ void UndoTransaction::replaceStockImage(int image_index, Image* new_image)
|
|||||||
|
|
||||||
// destroy the old image
|
// destroy the old image
|
||||||
image_free(old_image);
|
image_free(old_image);
|
||||||
|
|
||||||
|
DocumentEvent ev(m_document, m_sprite, NULL, NULL, new_image, image_index);
|
||||||
|
m_document->notifyObservers<DocumentEvent&>(&DocumentObserver::onImageReplaced, ev);
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@ -388,7 +395,8 @@ LayerImage* UndoTransaction::newLayer()
|
|||||||
// select the new layer
|
// select the new layer
|
||||||
setCurrentLayer(layer);
|
setCurrentLayer(layer);
|
||||||
|
|
||||||
m_document->notifyObservers<Document*, Layer*>(&DocumentObserver::onAddLayer, m_document, layer);
|
DocumentEvent ev(m_document, m_sprite, layer);
|
||||||
|
m_document->notifyObservers<DocumentEvent&>(&DocumentObserver::onAddLayer, ev);
|
||||||
|
|
||||||
return layer;
|
return layer;
|
||||||
}
|
}
|
||||||
@ -400,7 +408,8 @@ void UndoTransaction::removeLayer(Layer* layer)
|
|||||||
{
|
{
|
||||||
ASSERT(layer);
|
ASSERT(layer);
|
||||||
|
|
||||||
m_document->notifyObservers(&DocumentObserver::onRemoveLayer, m_document, layer);
|
DocumentEvent ev(m_document, m_sprite, layer);
|
||||||
|
m_document->notifyObservers<DocumentEvent&>(&DocumentObserver::onRemoveLayer, ev);
|
||||||
|
|
||||||
LayerFolder* parent = layer->get_parent();
|
LayerFolder* parent = layer->get_parent();
|
||||||
|
|
||||||
@ -438,6 +447,9 @@ void UndoTransaction::restackLayerAfter(Layer* layer, Layer* afterThis)
|
|||||||
m_undo->pushUndoer(new undoers::MoveLayer(m_undo->getObjects(), layer));
|
m_undo->pushUndoer(new undoers::MoveLayer(m_undo->getObjects(), layer));
|
||||||
|
|
||||||
layer->get_parent()->stackLayer(layer, afterThis);
|
layer->get_parent()->stackLayer(layer, afterThis);
|
||||||
|
|
||||||
|
DocumentEvent ev(m_document, m_sprite, layer);
|
||||||
|
m_document->notifyObservers<DocumentEvent&>(&DocumentObserver::onLayerRestacked, ev);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UndoTransaction::cropLayer(Layer* layer, int x, int y, int w, int h, int bgcolor)
|
void UndoTransaction::cropLayer(Layer* layer, int x, int y, int w, int h, int bgcolor)
|
||||||
@ -694,7 +706,8 @@ void UndoTransaction::newFrame()
|
|||||||
// go to next frame (the new one)
|
// go to next frame (the new one)
|
||||||
setCurrentFrame(newFrame);
|
setCurrentFrame(newFrame);
|
||||||
|
|
||||||
m_document->notifyObservers(&DocumentObserver::onAddFrame, m_document, newFrame);
|
DocumentEvent ev(m_document, m_sprite, NULL, NULL, NULL, -1, newFrame);
|
||||||
|
m_document->notifyObservers<DocumentEvent&>(&DocumentObserver::onAddFrame, ev);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UndoTransaction::newFrameForLayer(Layer* layer, FrameNumber frame)
|
void UndoTransaction::newFrameForLayer(Layer* layer, FrameNumber frame)
|
||||||
@ -731,7 +744,8 @@ void UndoTransaction::removeFrame(FrameNumber frame)
|
|||||||
{
|
{
|
||||||
ASSERT(frame >= 0);
|
ASSERT(frame >= 0);
|
||||||
|
|
||||||
m_document->notifyObservers(&DocumentObserver::onRemoveFrame, m_document, frame);
|
DocumentEvent ev(m_document, m_sprite, NULL, NULL, NULL, -1, frame);
|
||||||
|
m_document->notifyObservers<DocumentEvent&>(&DocumentObserver::onRemoveFrame, ev);
|
||||||
|
|
||||||
// Remove cels from this frame (and displace one position backward
|
// Remove cels from this frame (and displace one position backward
|
||||||
// all next frames)
|
// all next frames)
|
||||||
@ -818,6 +832,9 @@ void UndoTransaction::addCel(LayerImage* layer, Cel* cel)
|
|||||||
layer, cel));
|
layer, cel));
|
||||||
|
|
||||||
layer->addCel(cel);
|
layer->addCel(cel);
|
||||||
|
|
||||||
|
DocumentEvent ev(m_document, m_sprite, layer, cel);
|
||||||
|
m_document->notifyObservers<DocumentEvent&>(&DocumentObserver::onAddCel, ev);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UndoTransaction::removeCel(LayerImage* layer, Cel* cel)
|
void UndoTransaction::removeCel(LayerImage* layer, Cel* cel)
|
||||||
@ -825,6 +842,9 @@ void UndoTransaction::removeCel(LayerImage* layer, Cel* cel)
|
|||||||
ASSERT(layer);
|
ASSERT(layer);
|
||||||
ASSERT(cel);
|
ASSERT(cel);
|
||||||
|
|
||||||
|
DocumentEvent ev(m_document, m_sprite, layer, cel);
|
||||||
|
m_document->notifyObservers<DocumentEvent&>(&DocumentObserver::onRemoveCel, ev);
|
||||||
|
|
||||||
// find if the image that use the cel to remove, is used by
|
// find if the image that use the cel to remove, is used by
|
||||||
// another cels
|
// another cels
|
||||||
bool used = false;
|
bool used = false;
|
||||||
@ -861,6 +881,9 @@ void UndoTransaction::setCelFramePosition(Cel* cel, FrameNumber frame)
|
|||||||
m_undo->pushUndoer(new undoers::SetCelFrame(m_undo->getObjects(), cel));
|
m_undo->pushUndoer(new undoers::SetCelFrame(m_undo->getObjects(), cel));
|
||||||
|
|
||||||
cel->setFrame(frame);
|
cel->setFrame(frame);
|
||||||
|
|
||||||
|
DocumentEvent ev(m_document, m_sprite, NULL, cel);
|
||||||
|
m_document->notifyObservers<DocumentEvent&>(&DocumentObserver::onCelFrameChanged, ev);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UndoTransaction::setCelPosition(Cel* cel, int x, int y)
|
void UndoTransaction::setCelPosition(Cel* cel, int x, int y)
|
||||||
@ -871,6 +894,9 @@ void UndoTransaction::setCelPosition(Cel* cel, int x, int y)
|
|||||||
m_undo->pushUndoer(new undoers::SetCelPosition(m_undo->getObjects(), cel));
|
m_undo->pushUndoer(new undoers::SetCelPosition(m_undo->getObjects(), cel));
|
||||||
|
|
||||||
cel->setPosition(x, y);
|
cel->setPosition(x, y);
|
||||||
|
|
||||||
|
DocumentEvent ev(m_document, m_sprite, NULL, cel);
|
||||||
|
m_document->notifyObservers<DocumentEvent&>(&DocumentObserver::onCelPositionChanged, ev);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UndoTransaction::setFrameDuration(FrameNumber frame, int msecs)
|
void UndoTransaction::setFrameDuration(FrameNumber frame, int msecs)
|
||||||
@ -880,6 +906,9 @@ void UndoTransaction::setFrameDuration(FrameNumber frame, int msecs)
|
|||||||
m_undo->getObjects(), m_sprite, frame));
|
m_undo->getObjects(), m_sprite, frame));
|
||||||
|
|
||||||
m_sprite->setFrameDuration(frame, msecs);
|
m_sprite->setFrameDuration(frame, msecs);
|
||||||
|
|
||||||
|
DocumentEvent ev(m_document, m_sprite, NULL, NULL, NULL, -1, frame);
|
||||||
|
m_document->notifyObservers<DocumentEvent&>(&DocumentObserver::onFrameDurationChanged, ev);
|
||||||
}
|
}
|
||||||
|
|
||||||
void UndoTransaction::setConstantFrameRate(int msecs)
|
void UndoTransaction::setConstantFrameRate(int msecs)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user