]> git.saurik.com Git - wxWidgets.git/blame - include/wx/osx/bitmap.h
common drawing code for osx-cocoa and osx-carbon, also since 10.5 HIShapeRef is in...
[wxWidgets.git] / include / wx / osx / bitmap.h
CommitLineData
6762286d
SC
1/////////////////////////////////////////////////////////////////////////////
2// Name: bitmap.h
3// Purpose: wxBitmap class
4// Author: Stefan Csomor
5// Modified by:
6// Created: 1998-01-01
7// RCS-ID: $Id$
8// Copyright: (c) Stefan Csomor
9// Licence: wxWindows licence
10/////////////////////////////////////////////////////////////////////////////
11
12#ifndef _WX_BITMAP_H_
13#define _WX_BITMAP_H_
14
15#include "wx/palette.h"
16
17// Bitmap
18class WXDLLIMPEXP_FWD_CORE wxBitmap;
19class wxBitmapRefData ;
20class WXDLLIMPEXP_FWD_CORE wxBitmapHandler;
21class WXDLLIMPEXP_FWD_CORE wxControl;
22class WXDLLIMPEXP_FWD_CORE wxCursor;
23class WXDLLIMPEXP_FWD_CORE wxDC;
24class WXDLLIMPEXP_FWD_CORE wxIcon;
25class WXDLLIMPEXP_FWD_CORE wxImage;
26class WXDLLIMPEXP_FWD_CORE wxPixelDataBase;
27
28// A mask is a bitmap used for drawing bitmaps
29// Internally it is stored as a 8 bit deep memory chunk, 0 = black means the source will be drawn
30// 255 = white means the source will not be drawn, no other values will be present
31// 8 bit is chosen only for performance reasons, note also that this is the inverse value range
32// from alpha, where 0 = invisible , 255 = fully drawn
33
34class WXDLLIMPEXP_CORE wxMask: public wxObject
35{
36 DECLARE_DYNAMIC_CLASS(wxMask)
37
38public:
39 wxMask();
40
41 // Copy constructor
42 wxMask(const wxMask& mask);
43
44 // Construct a mask from a bitmap and a colour indicating
45 // the transparent area
46 wxMask(const wxBitmap& bitmap, const wxColour& colour);
47
48 // Construct a mask from a mono bitmap (black meaning show pixels, white meaning transparent)
49 wxMask(const wxBitmap& bitmap);
50
51 // implementation helper only : construct a mask from a 32 bit memory buffer
52 wxMask(const wxMemoryBuffer& buf, int width , int height , int bytesPerRow ) ;
53
54 virtual ~wxMask();
55
56 bool Create(const wxBitmap& bitmap, const wxColour& colour);
57 bool Create(const wxBitmap& bitmap);
58 bool Create(const wxMemoryBuffer& buf, int width , int height , int bytesPerRow ) ;
59
60 // Implementation below
61
62 void Init() ;
63
64 // a 8 bit depth mask
65 void* GetRawAccess() const;
66 int GetBytesPerRow() const { return m_bytesPerRow ; }
67 // renders/updates native representation when necessary
68 void RealizeNative() ;
69
70 WXHBITMAP GetHBITMAP() const ;
71
72
73private:
74 wxMemoryBuffer m_memBuf ;
75 int m_bytesPerRow ;
76 int m_width ;
77 int m_height ;
78
79 WXHBITMAP m_maskBitmap ;
80
81};
82
83class WXDLLIMPEXP_CORE wxBitmap: public wxBitmapBase
84{
85 DECLARE_DYNAMIC_CLASS(wxBitmap)
86
87 friend class WXDLLIMPEXP_FWD_CORE wxBitmapHandler;
88
89public:
90 wxBitmap(); // Platform-specific
91
92 // Initialize with raw data.
93 wxBitmap(const char bits[], int width, int height, int depth = 1);
94
95 // Initialize with XPM data
96 wxBitmap(const char* const* bits);
97
98 // Load a file or resource
99 wxBitmap(const wxString& name, wxBitmapType type = wxBITMAP_DEFAULT_TYPE);
100
101 // Constructor for generalised creation from data
102 wxBitmap(const void* data, wxBitmapType type, int width, int height, int depth = 1);
103
104 // If depth is omitted, will create a bitmap compatible with the display
105 wxBitmap(int width, int height, int depth = -1);
106
107 // Convert from wxImage:
108 wxBitmap(const wxImage& image, int depth = -1);
109
110 // Convert from wxIcon
111 wxBitmap(const wxIcon& icon) { CopyFromIcon(icon); }
112
113 virtual ~wxBitmap();
114
115 wxImage ConvertToImage() const;
116
117 // get the given part of bitmap
118 wxBitmap GetSubBitmap( const wxRect& rect ) const;
119
120 virtual bool Create(int width, int height, int depth = -1);
121 virtual bool Create(const void* data, wxBitmapType type, int width, int height, int depth = 1);
122 // virtual bool Create( WXHICON icon) ;
123 virtual bool LoadFile(const wxString& name, wxBitmapType type = wxBITMAP_DEFAULT_TYPE);
124 virtual bool SaveFile(const wxString& name, wxBitmapType type, const wxPalette *cmap = NULL) const;
125
126 wxBitmapRefData *GetBitmapData() const
127 { return (wxBitmapRefData *)m_refData; }
128
129 // copies the contents and mask of the given (colour) icon to the bitmap
130 virtual bool CopyFromIcon(const wxIcon& icon);
131
132 int GetWidth() const;
133 int GetHeight() const;
134 int GetDepth() const;
135 void SetWidth(int w);
136 void SetHeight(int h);
137 void SetDepth(int d);
138 void SetOk(bool isOk);
139
140#if wxUSE_PALETTE
141 wxPalette* GetPalette() const;
142 void SetPalette(const wxPalette& palette);
143#endif // wxUSE_PALETTE
144
145 wxMask *GetMask() const;
146 void SetMask(wxMask *mask) ;
147
148 static void InitStandardHandlers();
149
150 // raw bitmap access support functions, for internal use only
151 void *GetRawData(wxPixelDataBase& data, int bpp);
152 void UngetRawData(wxPixelDataBase& data);
153
154 // these functions are internal and shouldn't be used, they risk to
155 // disappear in the future
156 bool HasAlpha() const;
157 void UseAlpha();
158
159 // returns the 'native' implementation, a GWorldPtr for the content and one for the mask
160 WXHBITMAP GetHBITMAP( WXHBITMAP * mask = NULL ) const;
161
162 // returns a CGImageRef which must released after usage with CGImageRelease
163 CGImageRef CreateCGImage() const ;
164
165#if wxOSX_USE_COCOA_OR_IPHONE
166 // returns an autoreleased version of the image
167 WX_NSImage GetNSImage() const;
5c6eb3a8 168#endif
6762286d
SC
169 // returns a IconRef which must be retained before and released after usage
170 IconRef GetIconRef() const;
171 // returns a IconRef which must be released after usage
172 IconRef CreateIconRef() const;
173 // get read only access to the underlying buffer
174 void *GetRawAccess() const ;
175 // brackets to the underlying OS structure for read/write access
176 // makes sure that no cached images will be constructed until terminated
177 void *BeginRawAccess() ;
178 void EndRawAccess() ;
179
180protected:
181 virtual wxGDIRefData *CreateGDIRefData() const;
182 virtual wxGDIRefData *CloneGDIRefData(const wxGDIRefData *data) const;
183};
184
185#endif // _WX_BITMAP_H_