2015-02-12 15:16:25 +00:00
|
|
|
// Aseprite
|
2017-06-16 15:18:22 +00:00
|
|
|
// Copyright (C) 2001-2017 David Capello
|
2015-02-12 15:16:25 +00:00
|
|
|
//
|
2016-08-26 20:02:58 +00:00
|
|
|
// This program is distributed under the terms of
|
|
|
|
// the End-User License Agreement for Aseprite.
|
2013-08-06 00:20:19 +00:00
|
|
|
|
|
|
|
#ifndef APP_DOCUMENT_H_INCLUDED
|
|
|
|
#define APP_DOCUMENT_H_INCLUDED
|
2014-03-29 22:40:17 +00:00
|
|
|
#pragma once
|
2013-08-06 00:20:19 +00:00
|
|
|
|
2015-08-19 13:03:29 +00:00
|
|
|
#include "app/extra_cel.h"
|
2014-08-22 02:39:20 +00:00
|
|
|
#include "app/file/format_options.h"
|
2016-11-08 15:36:37 +00:00
|
|
|
#include "app/rw_lock.h"
|
2016-07-11 17:16:01 +00:00
|
|
|
#include "app/transformation.h"
|
2013-08-06 00:20:19 +00:00
|
|
|
#include "base/disable_copying.h"
|
2015-05-20 19:56:08 +00:00
|
|
|
#include "base/mutex.h"
|
2013-08-06 00:20:19 +00:00
|
|
|
#include "base/shared_ptr.h"
|
|
|
|
#include "base/unique_ptr.h"
|
2015-06-14 00:29:16 +00:00
|
|
|
#include "doc/blend_mode.h"
|
2015-01-19 01:05:33 +00:00
|
|
|
#include "doc/color.h"
|
2014-03-12 22:25:09 +00:00
|
|
|
#include "doc/document.h"
|
2014-12-28 23:39:11 +00:00
|
|
|
#include "doc/frame.h"
|
2014-10-21 01:21:31 +00:00
|
|
|
#include "doc/pixel_format.h"
|
2014-11-24 03:09:22 +00:00
|
|
|
#include "gfx/rect.h"
|
2013-08-06 00:20:19 +00:00
|
|
|
|
2014-04-20 22:53:27 +00:00
|
|
|
#include <string>
|
|
|
|
|
2014-10-21 01:21:31 +00:00
|
|
|
namespace doc {
|
2013-08-06 00:20:19 +00:00
|
|
|
class Cel;
|
|
|
|
class Layer;
|
|
|
|
class Mask;
|
2015-06-11 20:44:27 +00:00
|
|
|
class MaskBoundaries;
|
2013-08-06 00:20:19 +00:00
|
|
|
class Sprite;
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace gfx {
|
|
|
|
class Region;
|
|
|
|
}
|
|
|
|
|
|
|
|
namespace app {
|
|
|
|
class DocumentApi;
|
|
|
|
class DocumentUndo;
|
2015-01-19 01:05:33 +00:00
|
|
|
class Transaction;
|
2013-08-06 00:20:19 +00:00
|
|
|
|
2014-10-21 01:21:31 +00:00
|
|
|
using namespace doc;
|
2013-08-06 00:20:19 +00:00
|
|
|
|
|
|
|
enum DuplicateType {
|
|
|
|
DuplicateExactCopy,
|
|
|
|
DuplicateWithFlattenLayers,
|
|
|
|
};
|
|
|
|
|
|
|
|
// An application document. It is the class used to contain one file
|
|
|
|
// opened and being edited by the user (a sprite).
|
2016-11-08 15:36:37 +00:00
|
|
|
class Document : public doc::Document,
|
|
|
|
public RWLock {
|
2013-08-06 00:20:19 +00:00
|
|
|
public:
|
|
|
|
Document(Sprite* sprite);
|
|
|
|
~Document();
|
|
|
|
|
|
|
|
// Returns a high-level API: observable and undoable methods.
|
2015-01-19 01:05:33 +00:00
|
|
|
DocumentApi getApi(Transaction& transaction);
|
2013-08-06 00:20:19 +00:00
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Main properties
|
|
|
|
|
2015-01-19 01:05:33 +00:00
|
|
|
const DocumentUndo* undoHistory() const { return m_undo; }
|
|
|
|
DocumentUndo* undoHistory() { return m_undo; }
|
|
|
|
|
|
|
|
color_t bgColor() const;
|
|
|
|
color_t bgColor(Layer* layer) const;
|
2013-08-06 00:20:19 +00:00
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Notifications
|
|
|
|
|
|
|
|
void notifyGeneralUpdate();
|
2015-08-12 20:32:17 +00:00
|
|
|
void notifySpritePixelsModified(Sprite* sprite, const gfx::Region& region, frame_t frame);
|
2014-12-08 17:57:56 +00:00
|
|
|
void notifyExposeSpritePixels(Sprite* sprite, const gfx::Region& region);
|
2013-08-06 00:20:19 +00:00
|
|
|
void notifyLayerMergedDown(Layer* srcLayer, Layer* targetLayer);
|
2014-12-28 23:39:11 +00:00
|
|
|
void notifyCelMoved(Layer* fromLayer, frame_t fromFrame, Layer* toLayer, frame_t toFrame);
|
|
|
|
void notifyCelCopied(Layer* fromLayer, frame_t fromFrame, Layer* toLayer, frame_t toFrame);
|
2014-11-12 14:24:26 +00:00
|
|
|
void notifySelectionChanged();
|
2013-08-06 00:20:19 +00:00
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// File related properties
|
|
|
|
|
|
|
|
bool isModified() const;
|
|
|
|
bool isAssociatedToFile() const;
|
|
|
|
void markAsSaved();
|
|
|
|
|
2014-05-02 20:04:55 +00:00
|
|
|
// You can use this to indicate that we've destroyed (or we cannot
|
|
|
|
// trust) the file associated with the document (e.g. when we
|
|
|
|
// cancel a Save operation in the middle). So it's impossible to
|
|
|
|
// back to the saved state using the UndoHistory.
|
|
|
|
void impossibleToBackToSavedState();
|
|
|
|
|
2015-04-09 12:02:23 +00:00
|
|
|
// Returns true if it does make sense to create a backup in this
|
|
|
|
// document. For example, it doesn't make sense to create a backup
|
|
|
|
// for an unmodified document.
|
|
|
|
bool needsBackup() const;
|
|
|
|
|
2013-08-06 00:20:19 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Loaded options from file
|
|
|
|
|
2015-04-01 15:35:18 +00:00
|
|
|
void setFormatOptions(const base::SharedPtr<FormatOptions>& format_options);
|
|
|
|
base::SharedPtr<FormatOptions> getFormatOptions() { return m_format_options; }
|
2013-08-06 00:20:19 +00:00
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Boundaries
|
|
|
|
|
2015-06-11 20:44:27 +00:00
|
|
|
void generateMaskBoundaries(const Mask* mask = nullptr);
|
2013-08-06 00:20:19 +00:00
|
|
|
|
2015-06-11 20:44:27 +00:00
|
|
|
const MaskBoundaries* getMaskBoundaries() const {
|
|
|
|
return m_maskBoundaries.get();
|
|
|
|
}
|
2013-08-06 00:20:19 +00:00
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Extra Cel (it is used to draw pen preview, pixels in movement, etc.)
|
|
|
|
|
2015-08-19 13:03:29 +00:00
|
|
|
ExtraCelRef extraCel() const { return m_extraCel; }
|
|
|
|
void setExtraCel(const ExtraCelRef& extraCel) { m_extraCel = extraCel; }
|
2014-08-27 12:43:42 +00:00
|
|
|
|
2013-08-06 00:20:19 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Mask
|
|
|
|
|
|
|
|
// Returns the current mask, it can be empty. The mask could be not
|
|
|
|
// empty but hidden to the user if the setMaskVisible(false) was
|
|
|
|
// used called before.
|
2014-07-30 04:28:15 +00:00
|
|
|
Mask* mask() const { return m_mask; }
|
2013-08-06 00:20:19 +00:00
|
|
|
|
|
|
|
// Sets the current mask. The new mask will be visible by default,
|
|
|
|
// so you don't need to call setMaskVisible(true).
|
|
|
|
void setMask(const Mask* mask);
|
|
|
|
|
|
|
|
// Returns true only when the mask is not empty, and was not yet
|
|
|
|
// hidden using setMaskVisible (e.g. when the user "deselect the
|
|
|
|
// mask").
|
|
|
|
bool isMaskVisible() const;
|
|
|
|
|
|
|
|
// Changes the visibility state of the mask (it is useful only if
|
|
|
|
// the getMask() is not empty and the user can see that the mask is
|
|
|
|
// being hidden and shown to him).
|
|
|
|
void setMaskVisible(bool visible);
|
|
|
|
|
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Transformation
|
|
|
|
|
2016-07-11 17:16:01 +00:00
|
|
|
Transformation getTransformation() const;
|
|
|
|
void setTransformation(const Transformation& transform);
|
2013-08-06 00:20:19 +00:00
|
|
|
void resetTransformation();
|
|
|
|
|
2017-06-16 15:18:22 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Last point used to draw straight lines using freehand tools + Shift key
|
|
|
|
// (EditorCustomizationDelegate::isStraightLineFromLastPoint() modifier)
|
|
|
|
|
|
|
|
static gfx::Point NoLastDrawingPoint();
|
|
|
|
gfx::Point lastDrawingPoint() const { return m_lastDrawingPoint; }
|
|
|
|
void setLastDrawingPoint(const gfx::Point& pos) { m_lastDrawingPoint = pos; }
|
|
|
|
|
2013-08-06 00:20:19 +00:00
|
|
|
//////////////////////////////////////////////////////////////////////
|
|
|
|
// Copying
|
|
|
|
|
|
|
|
void copyLayerContent(const Layer* sourceLayer, Document* destDoc, Layer* destLayer) const;
|
|
|
|
Document* duplicate(DuplicateType type) const;
|
|
|
|
|
2014-07-31 03:19:58 +00:00
|
|
|
protected:
|
2014-08-15 02:07:47 +00:00
|
|
|
virtual void onContextChanged() override;
|
2014-07-31 03:19:58 +00:00
|
|
|
|
2013-08-06 00:20:19 +00:00
|
|
|
private:
|
|
|
|
// Undo and redo information about the document.
|
|
|
|
base::UniquePtr<DocumentUndo> m_undo;
|
|
|
|
|
|
|
|
// True if this sprite is associated to a file in the file-system.
|
|
|
|
bool m_associated_to_file;
|
|
|
|
|
|
|
|
// Selected mask region boundaries
|
2015-06-11 20:44:27 +00:00
|
|
|
base::UniquePtr<doc::MaskBoundaries> m_maskBoundaries;
|
2013-08-06 00:20:19 +00:00
|
|
|
|
|
|
|
// Data to save the file in the same format that it was loaded
|
2015-04-01 15:35:18 +00:00
|
|
|
base::SharedPtr<FormatOptions> m_format_options;
|
2013-08-06 00:20:19 +00:00
|
|
|
|
|
|
|
// Extra cel used to draw extra stuff (e.g. editor's pen preview, pixels in movement, etc.)
|
2015-08-19 13:03:29 +00:00
|
|
|
ExtraCelRef m_extraCel;
|
2013-08-06 00:20:19 +00:00
|
|
|
|
|
|
|
// Current mask.
|
|
|
|
base::UniquePtr<Mask> m_mask;
|
|
|
|
bool m_maskVisible;
|
|
|
|
|
|
|
|
// Current transformation.
|
2016-07-11 17:16:01 +00:00
|
|
|
Transformation m_transformation;
|
2013-08-06 00:20:19 +00:00
|
|
|
|
2017-06-16 15:18:22 +00:00
|
|
|
gfx::Point m_lastDrawingPoint;
|
|
|
|
|
2013-08-06 00:20:19 +00:00
|
|
|
DISABLE_COPYING(Document);
|
|
|
|
};
|
|
|
|
|
|
|
|
} // namespace app
|
|
|
|
|
|
|
|
#endif
|