// kimgio module for SGI images // // Copyright (C) 2004 Melchior FRANZ <mfranz@kde.org> // // This program is free software; you can redistribute it and/or // modify it under the terms of the Lesser GNU General Public License as // published by the Free Software Foundation; either version 2 of the // License, or (at your option) any later version. #ifndef KIMG_RGB_H #define KIMG_RGB_H #include <tqmap.h> #include <tqptrvector.h> class TQImage; class TQImageIO; extern "C" { void kimgio_rgb_read(TQImageIO *); void kimgio_rgb_write(TQImageIO *); } class RLEData : public TQMemArray<uchar> { public: RLEData() {} RLEData(const uchar *d, uint l, uint o) : m_offset(o) { duplicate(d, l); } bool operator<(const RLEData&) const; void write(TQDataStream& s); void print(TQString) const; // TODO remove uint offset() { return m_offset; } private: uint m_offset; }; class RLEMap : public TQMap<RLEData, uint> { public: RLEMap() : m_counter(0), m_offset(0) {} uint insert(const uchar *d, uint l); TQPtrVector<RLEData> vector(); void setBaseOffset(uint o) { m_offset = o; } private: uint m_counter; uint m_offset; }; class SGIImage { public: SGIImage(TQImageIO *); ~SGIImage(); bool readImage(TQImage&); bool writeImage(TQImage&); private: enum { NORMAL, DITHERED, SCREEN, COLORMAP }; // colormap TQImageIO *m_io; TQIODevice *m_dev; TQDataStream m_stream; TQ_UINT8 m_rle; TQ_UINT8 m_bpc; TQ_UINT16 m_dim; TQ_UINT16 m_xsize; TQ_UINT16 m_ysize; TQ_UINT16 m_zsize; TQ_UINT32 m_pixmin; TQ_UINT32 m_pixmax; char m_imagename[80]; TQ_UINT32 m_colormap; TQ_UINT32 *m_starttab; TQ_UINT32 *m_lengthtab; TQByteArray m_data; TQByteArray::Iterator m_pos; RLEMap m_rlemap; TQPtrVector<RLEData> m_rlevector; uint m_numrows; bool readData(TQImage&); bool getRow(uchar *dest); void writeHeader(); void writeRle(); void writeVerbatim(const TQImage&); bool scanData(const TQImage&); uint compact(uchar *, uchar *); uchar intensity(uchar); }; #endif