wxbitmapthis class encapsulates the concept of a platform-dependent bitmap, either monochrome or colour or colour with alpha channel support. derived from include files <wx/bitmap.h> predefined objects objects: wxnullbitmap see also wxbitmap overview, supported bitmap file formats, wxdc::blit, wxicon, wxcursor, wxbitmap, wxmemorydc members
wxbitmap::wxbitmap
wxbitmap::wxbitmapwxbitmap() default constructor. wxbitmap(const wxbitmap& bitmap) copy constructor, uses reference counting. to make a real copy, you can use:
wxbitmap newbitmap = oldbitmap.getsubbitmap( wxrect(0, 0, oldbitmap.getwidth(), oldbitmap.getheight()));wxbitmap(const void* data, int type, int width, int height, int depth = -1) creates a bitmap from the given data which is interpreted in platform-dependent manner.
wxbitmap(const char bits[], int width, int height creates a bitmap from an array of bits. you should only use this function for monochrome bitmaps (depth 1) in portable programs: in this case the bits parameter should contain an xbm image. for other bit depths, the behaviour is platform dependent: under windows, the data is passed without any changes to the underlying createbitmap() api. under other platforms, only monochrome bitmaps may be created using this constructor and wximage should be used for creating colour bitmaps from static data. wxbitmap(int width, int height, int depth = -1) creates a new bitmap. a depth of -1 indicates the depth of the current screen or visual. some platforms only support 1 for monochrome and -1 for the current colour setting. beginning with version 2.5.4 of wxwidgets a depth of 32 including an alpha channel is supported under msw, mac and gtk+. wxbitmap(const char* const* bits) creates a bitmap from xpm data. wxbitmap(const wxstring& name, long type) loads a bitmap from a file or resource. wxbitmap(const wximage& img, int depth = -1) creates bitmap object from the image. this has to be done to actually display an image as you cannot draw an image directly on a window. the resulting bitmap will use the provided colour depth (or that of the current system if depth is -1) which entails that a colour reduction has to take place. when in 8-bit mode (pseudocolour mode), the gtk port will use a color cube created on program start-up to look up colors. this ensures a very fast conversion, but the image quality won't be perfect (and could be better for photo images using more sophisticated dithering algorithms). on windows, if there is a palette present (set with setpalette), it will be used when creating the wxbitmap (most useful in 8-bit display mode). on other platforms, the palette is currently ignored. parameters bits
width
height
depth
name
type
the validity of these flags depends on the platform and wxwidgets configuration. if all possible wxwidgets settings are used, the windows platform supports bmp file, bmp resource, xpm data, and xpm. under wxgtk, the available formats are bmp file, xpm data, xpm file, and png file. under wxmotif, the available formats are xbm data, xbm file, xpm data, xpm file. in addition, wxbitmap can read all formats that wximage can, which currently include wxbitmap_type_jpeg, wxbitmap_type_tif, wxbitmap_type_png, wxbitmap_type_gif, wxbitmap_type_pcx, and wxbitmap_type_pnm. of course, you must have wximage handlers loaded. img
remarks the first form constructs a bitmap object with no data; an assignment or another member function such as create or loadfile must be called subsequently. the second and third forms provide copy constructors. note that these do not copy the bitmap data, but instead a pointer to the data, keeping a reference count. they are therefore very efficient operations. the fourth form constructs a bitmap from data whose type and value depends on the value of the type argument. the fifth form constructs a (usually monochrome) bitmap from an array of pixel values, under both x and windows. the sixth form constructs a new bitmap. the seventh form constructs a bitmap from pixmap (xpm) data, if wxwidgets has been configured to incorporate this feature. to use this constructor, you must first include an xpm file. for example, assuming that the file mybitmap.xpm contains an xpm array of character pointers called mybitmap:
#include "mybitmap.xpm" ... wxbitmap *bitmap = new wxbitmap(mybitmap);the eighth form constructs a bitmap from a file or resource. name can refer to a resource name under ms windows, or a filename under ms windows and x. under windows, type defaults to wxbitmap_type_bmp_resource. under x, type defaults to wxbitmap_type_xpm. see also wxpython note: constructors supported by wxpython are:
wxperl note: constructors supported by wxperl are:
wxbitmap::~wxbitmap~wxbitmap() destructor. see reference-counted object destruction for more info. if the application omits to delete the bitmap explicitly, the bitmap will be destroyed automatically by wxwidgets when the application exits. do not delete a bitmap that is selected into a memory device context.
wxbitmap::addhandlerstatic void addhandler(wxbitmaphandler* handler) adds a handler to the end of the static list of format handlers. handler
see also
wxbitmap::cleanuphandlersstatic void cleanuphandlers() deletes all bitmap handlers. this function is called by wxwidgets on exit.
wxbitmap::converttoimagewximage converttoimage() creates an image from a platform-dependent bitmap. this preserves mask information so that bitmaps and images can be converted back and forth without loss in that respect.
wxbitmap::copyfromiconbool copyfromicon(const wxicon& icon) creates the bitmap from an icon.
wxbitmap::createvirtual bool create(int width, int height, int depth = -1) creates a fresh bitmap. if the final argument is omitted, the display depth of the screen is used. virtual bool create(const void* data, int type, int width, int height, int depth = -1) creates a bitmap from the given data, which can be of arbitrary type. parameters width
height
depth
data
type
return value true if the call succeeded, false otherwise. remarks the first form works on all platforms. the portability of the second form depends on the type of data. see also
wxbitmap::findhandlerstatic wxbitmaphandler* findhandler(const wxstring& name) finds the handler with the given name. static wxbitmaphandler* findhandler(const wxstring& extension, wxbitmaptype bitmaptype) finds the handler associated with the given extension and type. static wxbitmaphandler* findhandler(wxbitmaptype bitmaptype) finds the handler associated with the given bitmap type. name
extension
bitmaptype
return value a pointer to the handler if found, null otherwise. see also
wxbitmap::getdepthint getdepth() const gets the colour depth of the bitmap. a value of 1 indicates a monochrome bitmap.
wxbitmap::gethandlersstatic wxlist& gethandlers() returns the static list of bitmap format handlers. see also
wxbitmap::getheightint getheight() const gets the height of the bitmap in pixels.
wxbitmap::getpalettewxpalette* getpalette() const gets the associated palette (if any) which may have been loaded from a file or set for the bitmap. see also
wxbitmap::getmaskwxmask* getmask() const gets the associated mask (if any) which may have been loaded from a file or set for the bitmap. see also
wxbitmap::getwidthint getwidth() const gets the width of the bitmap in pixels. see also
wxbitmap::getsubbitmapwxbitmap getsubbitmap(const wxrect&rect) const returns a sub bitmap of the current one as long as the rect belongs entirely to the bitmap. this function preserves bit depth and mask information.
wxbitmap::initstandardhandlersstatic void initstandardhandlers() adds the standard bitmap format handlers, which, depending on wxwidgets configuration, can be handlers for windows bitmap, windows bitmap resource, and xpm. this function is called by wxwidgets on startup. see also
wxbitmap::inserthandlerstatic void inserthandler(wxbitmaphandler* handler) adds a handler at the start of the static list of format handlers. handler
see also
wxbitmap::loadfilebool loadfile(const wxstring& name, wxbitmaptype type) loads a bitmap from a file or resource. parameters name
type
the validity of these flags depends on the platform and wxwidgets configuration. in addition, wxbitmap can read all formats that wximage can (wxbitmap_type_jpeg, wxbitmap_type_png, wxbitmap_type_gif, wxbitmap_type_pcx, wxbitmap_type_pnm). (of course you must have wximage handlers loaded.) return value true if the operation succeeded, false otherwise. remarks a palette may be associated with the bitmap if one exists (especially for colour windows bitmaps), and if the code supports it. you can check if one has been created by using the getpalette member. see also
wxbitmap::isokbool isok() const returns true if bitmap data is present.
wxbitmap::removehandlerstatic bool removehandler(const wxstring& name) finds the handler with the given name, and removes it. the handler is not deleted. name
return value true if the handler was found and removed, false otherwise. see also
wxbitmap::savefilebool savefile(const wxstring& name, wxbitmaptype type, wxpalette* palette = null) saves a bitmap in the named file. parameters name
type
the validity of these flags depends on the platform and wxwidgets configuration. in addition, wxbitmap can save all formats that wximage can (wxbitmap_type_jpeg, wxbitmap_type_png). (of course you must have wximage handlers loaded.) palette
true if the operation succeeded, false otherwise. remarks depending on how wxwidgets has been configured, not all formats may be available. see also
wxbitmap::setdepthvoid setdepth(int depth) sets the depth member (does not affect the bitmap data). parameters depth
wxbitmap::setheightvoid setheight(int height) sets the height member (does not affect the bitmap data). parameters height
wxbitmap::setmaskvoid setmask(wxmask* mask) sets the mask for this bitmap. remarks the bitmap object owns the mask once this has been called. see also
wxbitmap::setpalettevoid setpalette(const wxpalette& palette) sets the associated palette. (not implemented under gtk+). parameters palette
see also
wxbitmap::setwidthvoid setwidth(int width) sets the width member (does not affect the bitmap data). parameters width
wxbitmap::operator =wxbitmap& operator =(const wxbitmap& bitmap) assignment operator, using reference counting. parameters bitmap
return value returns 'this' object.
|