1 /////////////////////////////////////////////////////////////////////////////
2 // Name: wx/os2/bitmap.h
3 // Purpose: wxBitmap class
4 // Author: David Webster
8 // Copyright: (c) David Webster
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
16 #pragma interface "bitmap.h"
19 #include "wx/os2/private.h"
20 #include "wx/os2/gdiimage.h"
21 #include "wx/gdicmn.h"
22 #include "wx/palette.h"
24 class WXDLLEXPORT wxDC
;
25 class WXDLLEXPORT wxControl
;
26 class WXDLLEXPORT wxBitmap
;
27 class WXDLLEXPORT wxBitmapHandler
;
28 class WXDLLEXPORT wxIcon
;
29 class WXDLLEXPORT wxMask
;
30 class WXDLLEXPORT wxCursor
;
31 class WXDLLEXPORT wxControl
;
32 class WXDLLEXPORT wxImage
;
34 // ----------------------------------------------------------------------------
37 // NB: this class is private, but declared here to make it possible inline
38 // wxBitmap functions accessing it
39 // ----------------------------------------------------------------------------
41 class WXDLLEXPORT wxBitmapRefData
: public wxGDIImageRefData
45 virtual ~wxBitmapRefData() { Free(); }
51 wxPalette m_vBitmapPalette
;
57 wxDC
* m_pSelectedInto
;
60 // Optional mask for transparent drawing
62 wxMask
* m_pBitmapMask
;
63 }; // end of CLASS wxBitmapRefData
65 // ----------------------------------------------------------------------------
66 // wxBitmap: a mono or colour bitmap
67 // ----------------------------------------------------------------------------
69 class WXDLLEXPORT wxBitmap
: public wxGDIImage
72 // default ctor creates an invalid bitmap, you must Create() it later
73 wxBitmap() { Init(); }
76 inline wxBitmap(const wxBitmap
& rBitmap
)
77 { Init(); Ref(rBitmap
); SetHandle(rBitmap
.GetHandle()); }
79 // Initialize with raw data
80 wxBitmap( const char bits
[]
86 // Initialize with XPM data
87 wxBitmap(const char** ppData
) { CreateFromXpm(ppData
); }
88 wxBitmap(char** ppData
) { CreateFromXpm((const char**)ppData
); }
92 ,long lType
= wxBITMAP_TYPE_BMP_RESOURCE
95 // For compatiability with other ports, under OS/2 does same as default ctor
96 inline wxBitmap( const wxString
& WXUNUSED(rFilename
)
100 // New constructor for generalised creation from data
101 wxBitmap( void* pData
108 // If depth is omitted, will create a bitmap compatible with the display
114 wxBitmap( const wxImage
& image
, int depth
= -1 )
115 { (void)CreateFromImage(image
, depth
); }
117 // we must have this, otherwise icons are silently copied into bitmaps using
118 // the copy ctor but the resulting bitmap is invalid!
119 inline wxBitmap(const wxIcon
& rIcon
)
120 { Init(); CopyFromIcon(rIcon
); }
122 wxBitmap
& operator=(const wxBitmap
& rBitmap
)
124 if ( m_refData
!= rBitmap
.m_refData
)
129 wxBitmap
& operator=(const wxIcon
& rIcon
)
131 (void)CopyFromIcon(rIcon
);
136 wxBitmap
& operator=(const wxCursor
& rCursor
)
138 (void)CopyFromCursor(rCursor
);
144 wxImage
ConvertToImage() const;
146 // get the given part of bitmap
147 wxBitmap
GetSubBitmap(const wxRect
& rRect
) const;
149 // copies the contents and mask of the given (colour) icon to the bitmap
150 bool CopyFromIcon(const wxIcon
& rIcon
);
152 // copies the contents and mask of the given cursor to the bitmap
153 bool CopyFromCursor(const wxCursor
& rCursor
);
155 virtual bool Create( int nWidth
159 virtual bool Create( void* pData
165 virtual bool LoadFile( int nId
166 ,long lType
= wxBITMAP_TYPE_BMP_RESOURCE
168 virtual bool SaveFile( const wxString
& rName
170 ,const wxPalette
* pCmap
= NULL
173 inline wxBitmapRefData
* GetBitmapData() const
174 { return (wxBitmapRefData
*)m_refData
; }
176 inline int GetQuality() const
177 { return (GetBitmapData() ? GetBitmapData()->m_nQuality
: 0); }
179 void SetQuality(int nQ
);
181 wxPalette
* GetPalette() const
182 { return (GetBitmapData() ? (& GetBitmapData()->m_vBitmapPalette
) : (wxPalette
*) NULL
); }
184 void SetPalette(const wxPalette
& rPalette
);
186 inline wxMask
* GetMask() const
187 { return (GetBitmapData() ? GetBitmapData()->m_pBitmapMask
: (wxMask
*) NULL
); }
189 void SetMask(wxMask
* pMask
) ;
191 inline bool operator==(const wxBitmap
& rBitmap
) const
192 { return m_refData
== rBitmap
.m_refData
; }
194 inline bool operator!=(const wxBitmap
& rBitmap
) const
195 { return m_refData
!= rBitmap
.m_refData
; }
197 #if WXWIN_COMPATIBILITY_2
198 void SetOk(bool bIsOk
);
199 #endif // WXWIN_COMPATIBILITY_2
201 #if WXWIN_COMPATIBILITY
202 inline wxPalette
* GetColourMap() const
203 { return GetPalette(); }
205 inline void SetColourMap(wxPalette
* pCmap
)
206 { SetPalette(*pCmap
); };
208 #endif // WXWIN_COMPATIBILITY
212 inline void SetHBITMAP(WXHBITMAP hBmp
)
213 { SetHandle((WXHANDLE
)hBmp
); }
215 inline WXHBITMAP
GetHBITMAP() const
216 { return (WXHBITMAP
)GetHandle(); }
218 inline void SetSelectedInto(wxDC
* pDc
)
219 { if (GetBitmapData()) GetBitmapData()->m_pSelectedInto
= pDc
; }
221 inline wxDC
* GetSelectedInto() const
222 { return (GetBitmapData() ? GetBitmapData()->m_pSelectedInto
: (wxDC
*) NULL
); }
224 inline bool IsMono(void) const { return m_bIsMono
; }
226 // An OS/2 version that probably doesn't do anything like the msw version
227 wxBitmap
GetBitmapForDC(wxDC
& rDc
) const;
230 // common part of all ctors
233 inline virtual wxGDIImageRefData
* CreateData() const
234 { return new wxBitmapRefData
; }
236 // creates the bitmap from XPM data, supposed to be called from ctor
237 bool CreateFromXpm(const char** ppData
);
238 bool CreateFromImage(const wxImage
& image
, int depth
);
241 bool CopyFromIconOrCursor(const wxGDIImage
& rIcon
);
244 DECLARE_DYNAMIC_CLASS(wxBitmap
)
245 }; // end of CLASS wxBitmap
247 // ----------------------------------------------------------------------------
248 // wxMask: a mono bitmap used for drawing bitmaps transparently.
249 // ----------------------------------------------------------------------------
251 class WXDLLEXPORT wxMask
: public wxObject
256 // Construct a mask from a bitmap and a colour indicating the transparent
258 wxMask( const wxBitmap
& rBitmap
259 ,const wxColour
& rColour
262 // Construct a mask from a bitmap and a palette index indicating the
264 wxMask( const wxBitmap
& rBitmap
268 // Construct a mask from a mono bitmap (copies the bitmap).
269 wxMask(const wxBitmap
& rBitmap
);
271 // construct a mask from the givne bitmap handle
272 wxMask(WXHBITMAP hBmp
)
273 { m_hMaskBitmap
= hBmp
; }
277 bool Create( const wxBitmap
& bitmap
278 ,const wxColour
& rColour
280 bool Create( const wxBitmap
& rBitmap
283 bool Create(const wxBitmap
& rBitmap
);
286 WXHBITMAP
GetMaskBitmap() const
287 { return m_hMaskBitmap
; }
288 void SetMaskBitmap(WXHBITMAP hBmp
)
289 { m_hMaskBitmap
= hBmp
; }
292 WXHBITMAP m_hMaskBitmap
;
293 DECLARE_DYNAMIC_CLASS(wxMask
)
294 }; // end of CLASS wxMask
296 // ----------------------------------------------------------------------------
297 // wxBitmapHandler is a class which knows how to load/save bitmaps to/from file
298 // ----------------------------------------------------------------------------
300 class WXDLLEXPORT wxBitmapHandler
: public wxGDIImageHandler
303 inline wxBitmapHandler()
304 { m_lType
= wxBITMAP_TYPE_INVALID
; }
306 inline wxBitmapHandler( const wxString
& rName
307 ,const wxString
& rExt
310 : wxGDIImageHandler( rName
316 // keep wxBitmapHandler derived from wxGDIImageHandler compatible with the
317 // old class which worked only with bitmaps
318 virtual bool Create( wxBitmap
* pBitmap
325 virtual bool LoadFile( wxBitmap
* pBitmap
331 virtual bool SaveFile( wxBitmap
* pBitmap
332 ,const wxString
& rName
334 ,const wxPalette
* pPalette
= NULL
337 virtual bool Create( wxGDIImage
* pImage
344 virtual bool Load( wxGDIImage
* pImage
350 virtual bool Save( wxGDIImage
* pImage
351 ,const wxString
& rName
355 inline virtual bool Load( wxGDIImage
* pImage
356 ,const wxString
& rName
363 DECLARE_DYNAMIC_CLASS(wxBitmapHandler
)
364 }; // end of CLASS wxBitmapHandler