]> git.saurik.com Git - wxWidgets.git/blame - include/wx/os2/bitmap.h
Fix missing documentation for several GDI functions.
[wxWidgets.git] / include / wx / os2 / bitmap.h
CommitLineData
0e320a79 1/////////////////////////////////////////////////////////////////////////////
3b9e3455 2// Name: wx/os2/bitmap.h
0e320a79 3// Purpose: wxBitmap class
d88de032 4// Author: David Webster
0e320a79 5// Modified by:
3b9e3455 6// Created: 11/28/99
0e320a79 7// RCS-ID: $Id$
d88de032 8// Copyright: (c) David Webster
65571936 9// Licence: wxWindows licence
0e320a79
DW
10/////////////////////////////////////////////////////////////////////////////
11
12#ifndef _WX_BITMAP_H_
13#define _WX_BITMAP_H_
14
58b16424 15#include "wx/os2/private.h"
3b9e3455 16#include "wx/os2/gdiimage.h"
0e320a79
DW
17#include "wx/gdicmn.h"
18#include "wx/palette.h"
19
b5dbe15d
VS
20class WXDLLIMPEXP_FWD_CORE wxDC;
21class WXDLLIMPEXP_FWD_CORE wxControl;
22class WXDLLIMPEXP_FWD_CORE wxBitmap;
23class WXDLLIMPEXP_FWD_CORE wxBitmapHandler;
24class WXDLLIMPEXP_FWD_CORE wxIcon;
25class WXDLLIMPEXP_FWD_CORE wxMask;
26class WXDLLIMPEXP_FWD_CORE wxCursor;
27class WXDLLIMPEXP_FWD_CORE wxControl;
6b5c2d52 28class WXDLLIMPEXP_FWD_CORE wxPixelDataBase;
0e320a79 29
3b9e3455
DW
30// ----------------------------------------------------------------------------
31// Bitmap data
32//
33// NB: this class is private, but declared here to make it possible inline
34// wxBitmap functions accessing it
35// ----------------------------------------------------------------------------
0e320a79 36
53a2db12 37class WXDLLIMPEXP_CORE wxBitmapRefData : public wxGDIImageRefData
0e320a79 38{
0e320a79
DW
39public:
40 wxBitmapRefData();
cd7ff808 41 wxBitmapRefData(const wxBitmapRefData &tocopy);
3b9e3455
DW
42 virtual ~wxBitmapRefData() { Free(); }
43
44 virtual void Free();
0e320a79
DW
45
46public:
3b9e3455
DW
47 int m_nNumColors;
48 wxPalette m_vBitmapPalette;
49 int m_nQuality;
0e320a79 50
3b9e3455
DW
51 // OS2-specific
52 // ------------
0e320a79 53
3b9e3455 54 wxDC* m_pSelectedInto;
3b9e3455 55
8bb6da4a
DW
56 //
57 // Optional mask for transparent drawing
58 //
3b9e3455 59 wxMask* m_pBitmapMask;
8bb6da4a 60}; // end of CLASS wxBitmapRefData
0e320a79 61
3b9e3455
DW
62// ----------------------------------------------------------------------------
63// wxBitmap: a mono or colour bitmap
64// ----------------------------------------------------------------------------
0e320a79 65
20e6714a
VZ
66class WXDLLIMPEXP_CORE wxBitmap : public wxGDIImage,
67 public wxBitmapHelpers
0e320a79 68{
0e320a79 69public:
3b9e3455
DW
70 // default ctor creates an invalid bitmap, you must Create() it later
71 wxBitmap() { Init(); }
72
73 // Copy constructors
74 inline wxBitmap(const wxBitmap& rBitmap)
f8855e47
VZ
75 : wxGDIImage(rBitmap)
76 {
77 Init();
78 SetHandle(rBitmap.GetHandle());
79 }
3b9e3455
DW
80
81 // Initialize with raw data
82 wxBitmap( const char bits[]
83 ,int nWidth
84 ,int nHeight
85 ,int nDepth = 1
86 );
87
88 // Initialize with XPM data
452418c4 89 wxBitmap(const char* const* bits);
459f812b 90#ifdef wxNEEDS_CHARPP
4a4bf7ee
SN
91 // needed for old GCC
92 wxBitmap(char** data)
93 {
5c33522f 94 *this = wxBitmap(const_cast<const char* const*>(data));
4a4bf7ee
SN
95 }
96#endif
3b9e3455 97
b6f4144e
DW
98 // Load a resource
99 wxBitmap( int nId
cbea3ec6 100 ,wxBitmapType lType = wxBITMAP_DEFAULT_TYPE
3b9e3455
DW
101 );
102
b6f4144e
DW
103 // For compatiability with other ports, under OS/2 does same as default ctor
104 inline wxBitmap( const wxString& WXUNUSED(rFilename)
6b5c2d52 105 ,wxBitmapType WXUNUSED(lType)
b6f4144e
DW
106 )
107 { Init(); }
3b9e3455 108 // New constructor for generalised creation from data
452418c4 109 wxBitmap( const void* pData
6b5c2d52 110 ,wxBitmapType lType
3b9e3455
DW
111 ,int nWidth
112 ,int nHeight
113 ,int nDepth = 1
114 );
115
116 // If depth is omitted, will create a bitmap compatible with the display
732d8c74
FM
117 wxBitmap( int nWidth, int nHeight, int nDepth = -1 )
118 {
119 Init();
120 (void)Create(nWidth, nHeight, nDepth);
121 }
122 wxBitmap( const wxSize& sz, int nDepth = -1 )
123 {
124 Init();
125 (void)Create(sz, nDepth);
126 }
3b9e3455 127
98edf626 128 wxBitmap( const wxImage& image, int depth = -1 )
fd859211
VS
129 { (void)CreateFromImage(image, depth); }
130
3b9e3455
DW
131 // we must have this, otherwise icons are silently copied into bitmaps using
132 // the copy ctor but the resulting bitmap is invalid!
133 inline wxBitmap(const wxIcon& rIcon)
134 { Init(); CopyFromIcon(rIcon); }
135
3b9e3455
DW
136 wxBitmap& operator=(const wxIcon& rIcon)
137 {
138 (void)CopyFromIcon(rIcon);
139
140 return(*this);
141 }
142
143 wxBitmap& operator=(const wxCursor& rCursor)
144 {
145 (void)CopyFromCursor(rCursor);
146 return (*this);
147 }
148
149 virtual ~wxBitmap();
150
98edf626 151 wxImage ConvertToImage() const;
ac04aa99 152 wxBitmap ConvertToDisabled(unsigned char brightness = 255) const;
fd859211 153
341366c6
DW
154 // get the given part of bitmap
155 wxBitmap GetSubBitmap(const wxRect& rRect) const;
156
3b9e3455
DW
157 // copies the contents and mask of the given (colour) icon to the bitmap
158 bool CopyFromIcon(const wxIcon& rIcon);
159
160 // copies the contents and mask of the given cursor to the bitmap
161 bool CopyFromCursor(const wxCursor& rCursor);
162
163 virtual bool Create( int nWidth
164 ,int nHeight
732d8c74 165 ,int nDepth = wxBITMAP_SCREEN_DEPTH
3b9e3455 166 );
732d8c74
FM
167 virtual bool Create(const wxSize& sz, int depth = wxBITMAP_SCREEN_DEPTH)
168 { return Create(sz.GetWidth(), sz.GetHeight(), depth); }
7f74897f
SC
169 virtual bool Create(int width, int height, const wxDC& WXUNUSED(dc))
170 { return Create(width,height); }
03647350 171
452418c4 172 virtual bool Create( const void* pData
6b5c2d52 173 ,wxBitmapType lType
3b9e3455
DW
174 ,int nWidth
175 ,int nHeight
176 ,int nDepth = 1
177 );
b6f4144e 178 virtual bool LoadFile( int nId
cbea3ec6 179 ,wxBitmapType lType = wxBITMAP_DEFAULT_TYPE
3b9e3455 180 );
c90c3400 181 virtual bool LoadFile( const wxString& rName
cbea3ec6 182 ,wxBitmapType lType = wxBITMAP_DEFAULT_TYPE
c90c3400 183 );
3b9e3455 184 virtual bool SaveFile( const wxString& rName
6b5c2d52 185 ,wxBitmapType lType
3b9e3455
DW
186 ,const wxPalette* pCmap = NULL
187 );
188
189 inline wxBitmapRefData* GetBitmapData() const
190 { return (wxBitmapRefData *)m_refData; }
191
6b5c2d52
SN
192 // raw bitmap access support functions
193 void *GetRawData(wxPixelDataBase& data, int bpp);
194 void UngetRawData(wxPixelDataBase& data);
195
3b9e3455 196 inline int GetQuality() const
58b16424 197 { return (GetBitmapData() ? GetBitmapData()->m_nQuality : 0); }
3b9e3455
DW
198
199 void SetQuality(int nQ);
200
201 wxPalette* GetPalette() const
d3b9f782 202 { return (GetBitmapData() ? (& GetBitmapData()->m_vBitmapPalette) : NULL); }
3b9e3455
DW
203
204 void SetPalette(const wxPalette& rPalette);
205
206 inline wxMask* GetMask() const
d3b9f782 207 { return (GetBitmapData() ? GetBitmapData()->m_pBitmapMask : NULL); }
3b9e3455
DW
208
209 void SetMask(wxMask* pMask) ;
210
3b9e3455
DW
211 // Implementation
212public:
58b16424
DW
213 inline void SetHBITMAP(WXHBITMAP hBmp)
214 { SetHandle((WXHANDLE)hBmp); }
3b9e3455
DW
215
216 inline WXHBITMAP GetHBITMAP() const
217 { return (WXHBITMAP)GetHandle(); }
218
219 inline void SetSelectedInto(wxDC* pDc)
58b16424 220 { if (GetBitmapData()) GetBitmapData()->m_pSelectedInto = pDc; }
3b9e3455
DW
221
222 inline wxDC* GetSelectedInto() const
d3b9f782 223 { return (GetBitmapData() ? GetBitmapData()->m_pSelectedInto : NULL); }
3b9e3455 224
79c09341 225 inline bool IsMono(void) const { return m_bIsMono; }
1759c491 226
4f72fe4f 227 // An OS/2 version that probably doesn't do anything like the msw version
3b9e3455 228 wxBitmap GetBitmapForDC(wxDC& rDc) const;
0e320a79 229
3b9e3455
DW
230protected:
231 // common part of all ctors
232 void Init();
0e320a79 233
3b9e3455
DW
234 inline virtual wxGDIImageRefData* CreateData() const
235 { return new wxBitmapRefData; }
0e320a79 236
fd859211 237 bool CreateFromImage(const wxImage& image, int depth);
341366c6 238
8f884a0d 239 virtual wxGDIRefData *CloneGDIRefData(const wxGDIRefData *data) const;
cd7ff808 240
3b9e3455
DW
241private:
242 bool CopyFromIconOrCursor(const wxGDIImage& rIcon);
0e320a79 243
79c09341 244 bool m_bIsMono;
3b9e3455 245 DECLARE_DYNAMIC_CLASS(wxBitmap)
341366c6 246}; // end of CLASS wxBitmap
d88de032 247
3b9e3455
DW
248// ----------------------------------------------------------------------------
249// wxMask: a mono bitmap used for drawing bitmaps transparently.
250// ----------------------------------------------------------------------------
0e320a79 251
53a2db12 252class WXDLLIMPEXP_CORE wxMask : public wxObject
3b9e3455
DW
253{
254public:
255 wxMask();
cd7ff808 256 wxMask( const wxMask& tocopy);
3b9e3455
DW
257
258 // Construct a mask from a bitmap and a colour indicating the transparent
259 // area
260 wxMask( const wxBitmap& rBitmap
261 ,const wxColour& rColour
262 );
263
264 // Construct a mask from a bitmap and a palette index indicating the
265 // transparent area
266 wxMask( const wxBitmap& rBitmap
267 ,int nPaletteIndex
268 );
269
270 // Construct a mask from a mono bitmap (copies the bitmap).
271 wxMask(const wxBitmap& rBitmap);
272
273 // construct a mask from the givne bitmap handle
274 wxMask(WXHBITMAP hBmp)
275 { m_hMaskBitmap = hBmp; }
276
277 virtual ~wxMask();
278
279 bool Create( const wxBitmap& bitmap
280 ,const wxColour& rColour
281 );
282 bool Create( const wxBitmap& rBitmap
283 ,int nPaletteIndex
284 );
285 bool Create(const wxBitmap& rBitmap);
286
287 // Implementation
288 WXHBITMAP GetMaskBitmap() const
289 { return m_hMaskBitmap; }
290 void SetMaskBitmap(WXHBITMAP hBmp)
291 { m_hMaskBitmap = hBmp; }
0e320a79 292
0e320a79 293protected:
3b9e3455
DW
294 WXHBITMAP m_hMaskBitmap;
295 DECLARE_DYNAMIC_CLASS(wxMask)
8bb6da4a 296}; // end of CLASS wxMask
3b9e3455
DW
297
298// ----------------------------------------------------------------------------
299// wxBitmapHandler is a class which knows how to load/save bitmaps to/from file
300// ----------------------------------------------------------------------------
0e320a79 301
53a2db12 302class WXDLLIMPEXP_CORE wxBitmapHandler : public wxGDIImageHandler
3b9e3455 303{
0e320a79 304public:
3b9e3455
DW
305 inline wxBitmapHandler()
306 { m_lType = wxBITMAP_TYPE_INVALID; }
307
308 inline wxBitmapHandler( const wxString& rName
309 ,const wxString& rExt
e86f2cc8 310 ,wxBitmapType lType
3b9e3455
DW
311 )
312 : wxGDIImageHandler( rName
313 ,rExt
314 ,lType)
315 {
316 }
317
318 // keep wxBitmapHandler derived from wxGDIImageHandler compatible with the
319 // old class which worked only with bitmaps
320 virtual bool Create( wxBitmap* pBitmap
452418c4 321 ,const void* pData
e86f2cc8 322 ,wxBitmapType lType
3b9e3455
DW
323 ,int nWidth
324 ,int nHeight
325 ,int nDepth = 1
326 );
327 virtual bool LoadFile( wxBitmap* pBitmap
b6f4144e 328 ,int nId
e86f2cc8 329 ,wxBitmapType lType
3b9e3455
DW
330 ,int nDesiredWidth
331 ,int nDesiredHeight
332 );
c90c3400
SN
333 virtual bool LoadFile( wxBitmap* pBitmap
334 ,const wxString& rName
e86f2cc8 335 ,wxBitmapType lType
c90c3400
SN
336 ,int nDesiredWidth
337 ,int nDesiredHeight
338 );
3b9e3455
DW
339 virtual bool SaveFile( wxBitmap* pBitmap
340 ,const wxString& rName
e86f2cc8 341 ,wxBitmapType lType
3b9e3455 342 ,const wxPalette* pPalette = NULL
e86f2cc8 343 ) const;
3b9e3455
DW
344
345 virtual bool Create( wxGDIImage* pImage
452418c4 346 ,const void* pData
6b5c2d52 347 ,wxBitmapType lFlags
3b9e3455
DW
348 ,int nWidth
349 ,int nHeight
350 ,int nDepth = 1
351 );
352 virtual bool Load( wxGDIImage* pImage
b6f4144e 353 ,int nId
6b5c2d52 354 ,wxBitmapType lFlags
3b9e3455
DW
355 ,int nDesiredWidth
356 ,int nDesiredHeight
357 );
6b5c2d52
SN
358 virtual bool Save( const wxGDIImage* pImage
359 ,const wxString& rName
360 ,wxBitmapType lType
e86f2cc8 361 ) const;
3b9e3455 362private:
7e1e6965
WS
363 inline virtual bool Load( wxGDIImage* WXUNUSED(pImage)
364 ,const wxString& WXUNUSED(rName)
4b3f61d1 365 ,WXHANDLE WXUNUSED(hPs)
6b5c2d52 366 ,wxBitmapType WXUNUSED(lFlags)
7e1e6965
WS
367 ,int WXUNUSED(nDesiredWidth)
368 ,int WXUNUSED(nDesiredHeight)
b6f4144e 369 )
7e1e6965 370 { return false; }
3b9e3455 371 DECLARE_DYNAMIC_CLASS(wxBitmapHandler)
8bb6da4a 372}; // end of CLASS wxBitmapHandler
3b9e3455 373
0e320a79
DW
374#endif
375 // _WX_BITMAP_H_