Commit | Line | Data |
---|---|---|
661dc384 JS |
1 | ///////////////////////////////////////////////////////////////////////////// |
2 | // Name: gifdecod.h | |
3 | // Purpose: wxGIFDecoder, GIF reader for wxImage and wxAnimation | |
4 | // Author: Guillermo Rodriguez Garcia <guille@iies.es> | |
3c87527e | 5 | // Version: 3.02 |
83413d6d GRG |
6 | // CVS-ID: $Id$ |
7 | // Copyright: (c) 1999 Guillermo Rodriguez Garcia | |
661dc384 JS |
8 | // Licence: wxWindows licence |
9 | ///////////////////////////////////////////////////////////////////////////// | |
10 | ||
11 | #ifndef _WX_GIFDECOD_H | |
12 | #define _WX_GIFDECOD_H | |
13 | ||
14 | #ifdef __GNUG__ | |
15 | #pragma interface "gifdecod.h" | |
16 | #endif | |
17 | ||
18 | #include "wx/setup.h" | |
19 | ||
83413d6d GRG |
20 | #if wxUSE_STREAMS && wxUSE_GIF |
21 | ||
661dc384 JS |
22 | #include "wx/stream.h" |
23 | #include "wx/image.h" | |
24 | ||
25 | ||
e4b8154a | 26 | // -------------------------------------------------------------------------- |
8141573c | 27 | // Constants |
e4b8154a GRG |
28 | // -------------------------------------------------------------------------- |
29 | ||
8141573c GRG |
30 | // Error codes: |
31 | // Note that the error code wxGIF_TRUNCATED means that the image itself | |
32 | // is most probably OK, but the decoder didn't reach the end of the data | |
33 | // stream; this means that if it was not reading directly from file, | |
34 | // the stream will not be correctly positioned. the | |
35 | // | |
36 | enum | |
37 | { | |
38 | wxGIF_OK = 0, /* everything was OK */ | |
39 | wxGIF_INVFORMAT, /* error in gif header */ | |
40 | wxGIF_MEMERR, /* error allocating memory */ | |
41 | wxGIF_TRUNCATED /* file appears to be truncated */ | |
42 | }; | |
43 | ||
44 | // Disposal method | |
45 | // Experimental; subject to change. | |
46 | // | |
e4b8154a GRG |
47 | enum |
48 | { | |
49 | wxGIF_D_UNSPECIFIED = -1, /* not specified */ | |
50 | wxGIF_D_DONOTDISPOSE = 0, /* do not dispose */ | |
51 | wxGIF_D_TOBACKGROUND = 1, /* restore to background colour */ | |
52 | wxGIF_D_TOPREVIOUS = 2 /* restore to previous image */ | |
53 | }; | |
54 | ||
e4b8154a GRG |
55 | |
56 | #define MAX_BLOCK_SIZE 256 /* max. block size */ | |
57 | ||
58 | ||
59 | // -------------------------------------------------------------------------- | |
60 | // wxGIFDecoder class | |
61 | // -------------------------------------------------------------------------- | |
62 | ||
63 | // internal class for storing GIF image data | |
64 | class GIFImage | |
661dc384 | 65 | { |
e4b8154a | 66 | public: |
661dc384 JS |
67 | unsigned int w; /* width */ |
68 | unsigned int h; /* height */ | |
69 | unsigned int left; /* x coord (in logical screen) */ | |
70 | unsigned int top; /* y coord (in logical screen) */ | |
71 | int transparent; /* transparent color (-1 = none) */ | |
3c87527e | 72 | int disposal; /* disposal method (-1 = unspecified) */ |
661dc384 JS |
73 | long delay; /* delay in ms (-1 = unused) */ |
74 | unsigned char *p; /* bitmap */ | |
75 | unsigned char *pal; /* palette */ | |
e4b8154a GRG |
76 | GIFImage *next; /* next image */ |
77 | GIFImage *prev; /* prev image */ | |
78 | }; | |
661dc384 | 79 | |
76443e70 | 80 | |
b31ba288 | 81 | class WXDLLEXPORT wxGIFDecoder |
661dc384 JS |
82 | { |
83 | private: | |
e4b8154a | 84 | // logical screen |
661dc384 JS |
85 | unsigned int m_screenw; /* logical screen width */ |
86 | unsigned int m_screenh; /* logical screen height */ | |
87 | int m_background; /* background color (-1 = none) */ | |
88 | ||
e4b8154a | 89 | // image data |
661dc384 JS |
90 | bool m_anim; /* animated GIF */ |
91 | int m_nimages; /* number of images */ | |
92 | int m_image; /* current image */ | |
e4b8154a GRG |
93 | GIFImage *m_pimage; /* pointer to current image */ |
94 | GIFImage *m_pfirst; /* pointer to first image */ | |
95 | GIFImage *m_plast; /* pointer to last image */ | |
661dc384 | 96 | |
e4b8154a | 97 | // decoder state vars |
661dc384 JS |
98 | int m_restbits; /* remaining valid bits */ |
99 | unsigned int m_restbyte; /* remaining bytes in this block */ | |
100 | unsigned int m_lastbyte; /* last byte read */ | |
76443e70 GRG |
101 | unsigned char m_buffer[MAX_BLOCK_SIZE]; /* buffer for reading */ |
102 | unsigned char *m_bufp; /* pointer to next byte in buffer */ | |
661dc384 | 103 | |
e4b8154a GRG |
104 | // input stream |
105 | wxInputStream *m_f; /* input stream */ | |
661dc384 JS |
106 | |
107 | private: | |
108 | int getcode(int bits, int abfin); | |
e4b8154a | 109 | int dgif(GIFImage *img, int interl, int bits); |
661dc384 | 110 | |
e4b8154a | 111 | protected: |
661dc384 JS |
112 | // get data of current frame |
113 | int GetFrameIndex() const; | |
114 | unsigned char* GetData() const; | |
115 | unsigned char* GetPalette() const; | |
116 | unsigned int GetWidth() const; | |
117 | unsigned int GetHeight() const; | |
118 | unsigned int GetLeft() const; | |
119 | unsigned int GetTop() const; | |
120 | int GetDisposalMethod() const; | |
121 | int GetTransparentColour() const; | |
122 | long GetDelay() const; | |
123 | ||
124 | // get global data | |
125 | unsigned int GetLogicalScreenWidth() const; | |
126 | unsigned int GetLogicalScreenHeight() const; | |
127 | int GetBackgroundColour() const; | |
128 | int GetNumberOfFrames() const; | |
129 | bool IsAnimation() const; | |
130 | ||
131 | // move through the animation | |
132 | bool GoFirstFrame(); | |
133 | bool GoLastFrame(); | |
134 | bool GoNextFrame(bool cyclic = FALSE); | |
135 | bool GoPrevFrame(bool cyclic = FALSE); | |
136 | bool GoFrame(int which); | |
e4b8154a GRG |
137 | |
138 | public: | |
139 | // constructor, destructor, etc. | |
140 | wxGIFDecoder(wxInputStream *s, bool anim = FALSE); | |
141 | ~wxGIFDecoder(); | |
142 | bool CanRead(); | |
143 | int ReadGIF(); | |
144 | void Destroy(); | |
145 | ||
146 | // convert current frame to wxImage | |
147 | bool ConvertToImage(wxImage *image) const; | |
661dc384 JS |
148 | }; |
149 | ||
150 | ||
83413d6d | 151 | #endif // wxUSE_STREAM && wxUSE_GIF |
661dc384 JS |
152 | #endif // _WX_GIFDECOD_H |
153 |