Blob Blame Raw
#pragma once

#ifndef TIIO_PSD_INCLUDED
#define TIIO_PSD_INCLUDED

#include "../../common/psdlib/psd.h"
#include "tlevel_io.h"

class TLevelReaderPsd : public TLevelReader {
public:
  TLevelReaderPsd(const TFilePath &path);
  ~TLevelReaderPsd();
  TImageReaderP getFrameReader(TFrameId fid);
  TLevelP loadInfo();

  const TImageInfo *getImageInfo(TFrameId fid) { return m_info; }
  const TImageInfo *getImageInfo() { return m_info; }

  void load(TRasterImageP &rasP, int shrinkX = 1, int shrinkY = 1,
            TRect region = TRect());
  TDimension getSize() const { return TDimension(m_lx, m_ly); }
  TRect getBBox() const { return TRect(0, 0, m_lx - 1, m_ly - 1); }

  void setLayerId(int layerId) { m_layerId = layerId; }
  // int m_IOError;

private:
  TFilePath m_path;
  int m_lx, m_ly;
  int m_layersCount;
  TPSDReader *m_psdreader;
  int m_layerId;
  std::map<TFrameId, int> m_frameTable;  // frameID, layerId
public:
  static TLevelReader *create(const TFilePath &f);
  TThread::Mutex m_mutex;
};

class TLevelWriterPsd : public TLevelWriter {
public:
  TLevelWriterPsd(const TFilePath &path, TPropertyGroup *winfo);
  ~TLevelWriterPsd();
  TImageWriterP getFrameWriter(TFrameId fid);

  void save(const TImageP &img, int layerId);

private:
public:
  static TLevelWriter *create(const TFilePath &f, TPropertyGroup *winfo) {
    return new TLevelWriterPsd(f, winfo);
  };
};

#endif  // TIIO_PSD_H