Blob Blame Raw
#pragma once

#ifndef TOONZIMAGE_DATA_H
#define TOONZIMAGE_DATA_H

#include "tcommon.h"
#include "toonz/ttileset.h"
#include "tpalette.h"
#include "tstroke.h"
#include "toonzqt/dvmimedata.h"
#include "ttoonzimage.h"

#include <set>

#undef DVAPI
#undef DVVAR
#ifdef TOONZQT_EXPORTS
#define DVAPI DV_EXPORT_API
#define DVVAR DV_EXPORT_VAR
#else
#define DVAPI DV_IMPORT_API
#define DVVAR DV_IMPORT_VAR
#endif

class TTileSetCM32;
class StrokesData;
class ToonzScene;

//===================================================================
// RasterImageData
//-------------------------------------------------------------------

class RasterImageData : public DvMimeData {
protected:
  double m_dpiX, m_dpiY;
  std::vector<TRectD> m_rects;
  std::vector<TStroke> m_strokes;
  std::vector<TStroke> m_originalStrokes;
  TAffine m_transformation;
  TDimension m_dim;

public:
  RasterImageData();
  ~RasterImageData();

  virtual void setData(const TRasterP &copiedRaster, const TPaletteP &palette,
                       double dpiX, double dpiY, const TDimension &dim,
                       const std::vector<TRectD> &rects,
                       const std::vector<TStroke> &strokes,
                       const std::vector<TStroke> &originalStrokes,
                       const TAffine &transformation) = 0;

  virtual void getData(TRasterP &copiedRaster, double &dpiX, double &dpiY,
                       std::vector<TRectD> &rects,
                       std::vector<TStroke> &strokes,
                       std::vector<TStroke> &originalStrokes,
                       TAffine &transformation,
                       TPalette *targetPalette) const = 0;

  virtual StrokesData *toStrokesData(ToonzScene *scene) const = 0;
  virtual TPointD getDpi() const                              = 0;
  TDimension getDim() const { return m_dim; }

  RasterImageData *clone() const override = 0;

  // Necessary for undo purpose!!!!
  virtual int getMemorySize() const = 0;
};

//===================================================================
// ToonzImageData
//-------------------------------------------------------------------
/*-- SelectionToolで選択した画像のデータ --*/
class DVAPI ToonzImageData final : public RasterImageData {
  TRasterCM32P m_copiedRaster;
  TPaletteP m_palette;

  std::set<int> m_usedStyles;

public:
  ToonzImageData();
  ToonzImageData(const ToonzImageData &);
  ~ToonzImageData();
  // data <- floating ti;
  void setData(const TRasterP &copiedRaster, const TPaletteP &palette,
               double dpiX, double dpiY, const TDimension &dim,
               const std::vector<TRectD> &rects,
               const std::vector<TStroke> &strokes,
               const std::vector<TStroke> &originalStrokes,
               const TAffine &transformation) override;

  // floating ti <- data;
  void getData(TRasterP &copiedRaster, double &dpiX, double &dpiY,
               std::vector<TRectD> &rects, std::vector<TStroke> &strokes,
               std::vector<TStroke> &originalStrokes, TAffine &transformation,
               TPalette *targetPalette) const override;

  StrokesData *toStrokesData(ToonzScene *scene) const override;
  TPointD getDpi() const override { return TPointD(m_dpiX, m_dpiY); }

  ToonzImageData *clone() const override { return new ToonzImageData(*this); }
  int getMemorySize() const override;
};

//===================================================================
// FullColorImageData
//-------------------------------------------------------------------

class DVAPI FullColorImageData final : public RasterImageData {
  TRasterP m_copiedRaster;
  TPaletteP m_palette;

public:
  FullColorImageData();
  FullColorImageData(const FullColorImageData &);
  ~FullColorImageData();

  // data <- floating ti;
  void setData(const TRasterP &copiedRaster, const TPaletteP &palette,
               double dpiX, double dpiY, const TDimension &dim,
               const std::vector<TRectD> &rects,
               const std::vector<TStroke> &strokes,
               const std::vector<TStroke> &originalStrokes,
               const TAffine &transformation) override;

  // floating ti <- data;
  void getData(TRasterP &copiedRaster, double &dpiX, double &dpiY,
               std::vector<TRectD> &rects, std::vector<TStroke> &strokes,
               std::vector<TStroke> &originalStrokes, TAffine &transformation,
               TPalette *targetPalette) const override;

  StrokesData *toStrokesData(ToonzScene *scene) const override;
  TPointD getDpi() const override { return TPointD(m_dpiX, m_dpiY); }

  FullColorImageData *clone() const override {
    return new FullColorImageData(*this);
  }
  int getMemorySize() const override;
};

#endif