]> git.saurik.com Git - wxWidgets.git/blame - include/wx/cocoa/bitmap.h
use wx-style header and commets; fix indentation to be 4 spaces; move Doxygen comment...
[wxWidgets.git] / include / wx / cocoa / bitmap.h
CommitLineData
a24aff65 1/////////////////////////////////////////////////////////////////////////////
1b88201f 2// Name: wx/cocoa/bitmap.h
a24aff65 3// Purpose: wxBitmap class
d135b1a5 4// Author: David Elliott
a24aff65 5// Modified by:
d135b1a5 6// Created: 2003/07/19
a24aff65 7// RCS-ID: $Id$
d135b1a5 8// Copyright: (c) 2003 David Elliott
1b88201f 9// Licence: wxWindows licence
a24aff65
DE
10/////////////////////////////////////////////////////////////////////////////
11
d135b1a5
DE
12#ifndef __WX_COCOA_BITMAP_H__
13#define __WX_COCOA_BITMAP_H__
a24aff65
DE
14
15#include "wx/palette.h"
16
17// Bitmap
b5dbe15d
VS
18class WXDLLIMPEXP_FWD_CORE wxBitmap;
19class WXDLLIMPEXP_FWD_CORE wxIcon;
20class WXDLLIMPEXP_FWD_CORE wxCursor;
21class WXDLLIMPEXP_FWD_CORE wxImage;
22class WXDLLIMPEXP_FWD_CORE wxPixelDataBase;
a24aff65 23
d135b1a5
DE
24// ========================================================================
25// wxMask
26// ========================================================================
d135b1a5 27
016b0643 28// A mask is a 1-bit alpha bitmap used for drawing bitmaps transparently.
a24aff65
DE
29class WXDLLEXPORT wxMask: public wxObject
30{
31 DECLARE_DYNAMIC_CLASS(wxMask)
a24aff65 32public:
016b0643 33 wxMask();
a24aff65 34
016b0643
DE
35 // Construct a mask from a bitmap and a colour indicating
36 // the transparent area
37 wxMask(const wxBitmap& bitmap, const wxColour& colour);
a24aff65 38
016b0643
DE
39 // Construct a mask from a bitmap and a palette index indicating
40 // the transparent area
41 wxMask(const wxBitmap& bitmap, int paletteIndex);
a24aff65 42
016b0643
DE
43 // Construct a mask from a mono bitmap (copies the bitmap).
44 wxMask(const wxBitmap& bitmap);
a24aff65 45
319fe103
DE
46 // Copy constructor
47 wxMask(const wxMask& src);
48
d3c7fc99 49 virtual ~wxMask();
a24aff65 50
016b0643
DE
51 bool Create(const wxBitmap& bitmap, const wxColour& colour);
52 bool Create(const wxBitmap& bitmap, int paletteIndex);
53 bool Create(const wxBitmap& bitmap);
a24aff65 54
016b0643
DE
55 // wxCocoa
56 inline WX_NSBitmapImageRep GetNSBitmapImageRep()
57 { return m_cocoaNSBitmapImageRep; }
a24aff65 58protected:
016b0643 59 WX_NSBitmapImageRep m_cocoaNSBitmapImageRep;
a24aff65
DE
60};
61
d135b1a5
DE
62// ========================================================================
63// wxBitmap
64// ========================================================================
65class WXDLLEXPORT wxBitmap: public wxGDIObject
a24aff65 66{
d135b1a5
DE
67// ------------------------------------------------------------------------
68// initialization
69// ------------------------------------------------------------------------
a24aff65 70public:
d135b1a5
DE
71 // Platform-specific default constructor
72 wxBitmap();
d135b1a5
DE
73 // Initialize with raw data.
74 wxBitmap(const char bits[], int width, int height, int depth = 1);
75 // Initialize with XPM data
452418c4 76 wxBitmap(const char* const* bits);
d135b1a5
DE
77 // Load a file or resource
78 wxBitmap(const wxString& name, wxBitmapType type = wxBITMAP_TYPE_BMP_RESOURCE);
d381b7df
DE
79 // Construct from Cocoa's NSImage
80 wxBitmap(NSImage* cocoaNSImage);
81 // Construct from Cocoa's NSBitmapImageRep
82 wxBitmap(NSBitmapImageRep* cocoaNSBitmapImageRep);
d135b1a5 83 // Constructor for generalised creation from data
452418c4 84 wxBitmap(const void* data, wxBitmapType type, int width, int height, int depth = 1);
d135b1a5
DE
85 // If depth is omitted, will create a bitmap compatible with the display
86 wxBitmap(int width, int height, int depth = -1);
87 // Convert from wxImage:
88 wxBitmap(const wxImage& image, int depth = -1)
89 { CreateFromImage(image, depth); }
b5df4fc7
DE
90 // Convert from wxIcon
91 wxBitmap(const wxIcon& icon) { CopyFromIcon(icon); }
92
d135b1a5 93 // destructor
d3c7fc99 94 virtual ~wxBitmap();
1b88201f 95
d135b1a5
DE
96// ------------------------------------------------------------------------
97// Implementation
98// ------------------------------------------------------------------------
a24aff65 99public:
d135b1a5
DE
100 // Initialize from wxImage
101 bool CreateFromImage(const wxImage& image, int depth=-1);
102
103 virtual bool Create(int width, int height, int depth = -1);
e82b00a7
DE
104 bool Create(NSImage* cocoaNSImage);
105 bool Create(NSBitmapImageRep* cocoaNSBitmapImageRep);
452418c4 106 virtual bool Create(const void* data, wxBitmapType type, int width, int height, int depth = 1);
d135b1a5
DE
107 virtual bool LoadFile(const wxString& name, wxBitmapType type = wxBITMAP_TYPE_BMP_RESOURCE);
108 virtual bool SaveFile(const wxString& name, wxBitmapType type, const wxPalette *cmap = NULL) const;
109
110 // copies the contents and mask of the given (colour) icon to the bitmap
111 virtual bool CopyFromIcon(const wxIcon& icon);
112
113 wxImage ConvertToImage() const;
114
115 // get the given part of bitmap
116 wxBitmap GetSubBitmap( const wxRect& rect ) const;
117
d135b1a5
DE
118 int GetWidth() const;
119 int GetHeight() const;
120 int GetDepth() const;
121 int GetQuality() const;
122 void SetWidth(int w);
123 void SetHeight(int h);
124 void SetDepth(int d);
125 void SetQuality(int q);
126 void SetOk(bool isOk);
127
b60c6e97
DE
128 // raw bitmap access support functions
129 void *GetRawData(wxPixelDataBase& data, int bpp);
130 void UngetRawData(wxPixelDataBase& data);
131
d135b1a5
DE
132 wxPalette* GetPalette() const;
133 void SetPalette(const wxPalette& palette);
134
135 wxMask *GetMask() const;
136 void SetMask(wxMask *mask) ;
137
138 int GetBitmapType() const;
1b88201f 139
d135b1a5
DE
140 // wxCocoa
141 WX_NSBitmapImageRep GetNSBitmapImageRep();
ab13160e 142 void SetNSBitmapImageRep(WX_NSBitmapImageRep bitmapImageRep);
9c54e4ae 143 WX_NSImage GetNSImage(bool useMask) const;
d135b1a5
DE
144
145 static void InitStandardHandlers() { }
146 static void CleanUpHandlers() { }
8f884a0d
VZ
147
148protected:
149 wxGDIRefData *CreateGDIRefData() const;
150 wxGDIRefData *CloneGDIRefData(const wxGDIRefData *data) const;
151
152 DECLARE_DYNAMIC_CLASS(wxBitmap)
a24aff65 153};
d135b1a5 154
452418c4
PC
155class WXDLLIMPEXP_CORE wxBitmapHandler: public wxBitmapHandlerBase
156{
157 DECLARE_ABSTRACT_CLASS(wxBitmapHandler)
158};
159
8f884a0d 160#endif // __WX_COCOA_BITMAP_H__