1 /////////////////////////////////////////////////////////////////////////////
3 // Purpose: wxImage JPEG handler
4 // Author: Vaclav Slavik
6 // Copyright: (c) Vaclav Slavik
7 // Licence: wxWindows licence
8 /////////////////////////////////////////////////////////////////////////////
11 We don't put pragma implement in this file because it is already present in
15 // For compilers that support precompilation, includes "wx.h".
16 #include "wx/wxprec.h"
27 #include "wx/bitmap.h"
37 #include "wx/filefn.h"
38 #include "wx/wfstream.h"
40 #include "wx/module.h"
42 //-----------------------------------------------------------------------------
44 //-----------------------------------------------------------------------------
46 #if !USE_SHARED_LIBRARIES
47 IMPLEMENT_DYNAMIC_CLASS(wxTIFFHandler
,wxImageHandler
)
51 _tiffReadProc(thandle_t handle
, tdata_t buf
, tsize_t size
)
53 wxInputStream
*stream
= (wxInputStream
*) handle
;
54 stream
->Read( (void*) buf
, (size_t) size
);
55 return stream
->LastRead();
59 _tiffWriteProc(thandle_t handle
, tdata_t buf
, tsize_t size
)
61 wxOutputStream
*stream
= (wxOutputStream
*) handle
;
62 stream
->Write( (void*) buf
, (size_t) size
);
63 return stream
->LastWrite();
67 _tiffSeekProc(thandle_t handle
, toff_t off
, int whence
)
69 wxInputStream
*stream
= (wxInputStream
*) handle
;
73 case SEEK_SET
: mode
= wxFromStart
; break;
74 case SEEK_CUR
: mode
= wxFromCurrent
; break;
75 case SEEK_END
: mode
= wxFromEnd
; break;
76 default: mode
= wxFromCurrent
; break;
79 return (toff_t
)stream
->SeekI( (off_t
)off
, mode
);
83 _tiffCloseProc(thandle_t
WXUNUSED(handle
))
89 _tiffSizeProc(thandle_t handle
)
91 wxInputStream
*stream
= (wxInputStream
*) handle
;
92 return (toff_t
) stream
->GetSize();
96 _tiffMapProc(thandle_t
WXUNUSED(handle
), tdata_t
* pbase
, toff_t
* psize
)
102 _tiffUnmapProc(thandle_t
WXUNUSED(handle
), tdata_t base
, toff_t size
)
107 TIFFwxOpen(wxInputStream
&stream
, const char* name
, const char* mode
)
109 TIFF
* tif
= TIFFClientOpen(name
, mode
,
111 _tiffReadProc
, _tiffWriteProc
,
112 _tiffSeekProc
, _tiffCloseProc
, _tiffSizeProc
,
113 _tiffMapProc
, _tiffUnmapProc
);
116 tif
->tif_fd
= (int) &stream
;
122 bool wxTIFFHandler
::LoadFile( wxImage
*image
, wxInputStream
& stream
, bool verbose
)
126 TIFF
*tif
= TIFFwxOpen( stream
, "image", "r" );
131 wxLogError( _("Error loading TIFF image.") );
140 TIFFGetField( tif
, TIFFTAG_IMAGEWIDTH
, &w
);
141 TIFFGetField( tif
, TIFFTAG_IMAGELENGTH
, &h
);
145 raster
= (uint32
*) _TIFFmalloc( npixels
* sizeof(uint32
) );
150 wxLogError( _("Not enough memory for loading TIFF image.") );
155 image
->Create( w
, h
);
159 wxLogError( _("Not enough memory for loading TIFF image.") );
166 if (!TIFFReadRGBAImage( tif
, w
, h
, raster
, 0 ))
169 wxLogError( _("Error reading TIFF image.") );
177 bool hasmask
= FALSE
;
179 unsigned char *ptr
= image
->GetData();
182 for (uint32 i
= 0; i
< h
; i
++)
184 for (uint32 j
= 0; w
< h
; j
++)
186 unsigned char alpha
= (unsigned char)(raster
[pos
] >> 24);
190 ptr
[0] = image
->GetMaskRed();
192 ptr
[0] = image
->GetMaskGreen();
194 ptr
[0] = image
->GetMaskBlue();
199 ptr
[0] = (unsigned char)(raster
[pos
] >> 16);
201 ptr
[0] = (unsigned char)(raster
[pos
] >> 8);
203 ptr
[0] = (unsigned char)(raster
[pos
]);
214 image
->SetMask( hasmask
);
221 bool wxTIFFHandler
::SaveFile( wxImage
*image
, wxOutputStream
& stream
, bool verbose
)
226 bool wxTIFFHandler
::DoCanRead( wxInputStream
& stream
)
228 unsigned char hdr
[2];
230 stream
.Read(&hdr
, 2);
231 stream
.SeekI(-2, wxFromCurrent
);
233 return ((hdr
[0] == 0x49 && hdr
[1] == 0x49) ||
234 (hdr
[0] == 0x4D && hdr
[1] == 0x4D));