wxArtProvider class is used to customize the look of wxWidgets application.
When wxWidgets needs to display an icon or a bitmap (e.g. in the standard file dialog), it does not use a hard-coded resource but asks wxArtProvider for it instead. This way users can plug in their own wxArtProvider class and easily replace standard art with their own version.
All that is needed is to derive a class from wxArtProvider, override either its wxArtProvider::CreateBitmap() and/or its wxArtProvider::CreateIconBundle() methods and register the provider with wxArtProvider::Push():
{
protected:
{ ... }
};
...
wxArtProvider::Push(new MyProvider);
wxArtProvider class is used to customize the look of wxWidgets application.
Definition: artprov.h:270
virtual wxIconBundle CreateIconBundle(const wxArtID &id, const wxArtClient &client)
This method is similar to CreateBitmap() but can be used when a bitmap (or an icon) exists in several...
virtual wxBitmapBundle CreateBitmapBundle(const wxArtID &id, const wxArtClient &client, const wxSize &size)
Override this method to create the requested art resources available in more than one size.
virtual wxBitmap CreateBitmap(const wxArtID &id, const wxArtClient &client, const wxSize &size)
Derived art provider classes may override this method to create requested art resource.
Contains representations of the same bitmap in different resolutions.
Definition: bmpbndl.h:100
This class encapsulates the concept of a platform-dependent bitmap, either monochrome or colour or co...
Definition: bitmap.h:212
This class contains multiple copies of an icon in different sizes.
Definition: iconbndl.h:21
A wxSize is a useful data structure for graphics operations.
Definition: gdicmn.h:940
String class for passing textual data to or receiving it from wxWidgets.
Definition: string.h:315
If you need bitmap images (of the same artwork) that should be displayed at different sizes you should probably consider overriding wxArtProvider::CreateIconBundle and supplying icon bundles that contain different bitmap sizes.
There's another way of taking advantage of this class: you can use it in your code and use platform native icons as provided by wxArtProvider::GetBitmapBundle or wxArtProvider::GetIcon.
Identifying art resources
Every bitmap and icon bundle are known to wxArtProvider under a unique ID that is used when requesting a resource from it. The ID is represented by the wxArtID type and can have one of these predefined values (you can see bitmaps represented by these constants in the Art Provider Sample):
wxART_ERROR
wxART_QUESTION
wxART_WARNING
wxART_INFORMATION
wxART_ADD_BOOKMARK
wxART_DEL_BOOKMARK
wxART_HELP_SIDE_PANEL
wxART_HELP_SETTINGS
wxART_HELP_BOOK
wxART_HELP_FOLDER
wxART_HELP_PAGE
wxART_GO_BACK
wxART_GO_FORWARD
wxART_GO_UP
wxART_GO_DOWN
wxART_GO_TO_PARENT
wxART_GO_HOME
wxART_GOTO_FIRST (since 2.9.2)
|
wxART_GOTO_LAST (since 2.9.2)
wxART_PRINT
wxART_HELP
wxART_TIP
wxART_REPORT_VIEW
wxART_LIST_VIEW
wxART_NEW_DIR
wxART_FOLDER
wxART_FOLDER_OPEN
wxART_GO_DIR_UP
wxART_EXECUTABLE_FILE
wxART_NORMAL_FILE
wxART_TICK_MARK
wxART_CROSS_MARK
wxART_MISSING_IMAGE
wxART_NEW
wxART_FILE_OPEN
wxART_FILE_SAVE
|
wxART_FILE_SAVE_AS
wxART_DELETE
wxART_COPY
wxART_CUT
wxART_PASTE
wxART_UNDO
wxART_REDO
wxART_PLUS (since 2.9.2)
wxART_MINUS (since 2.9.2)
wxART_CLOSE
wxART_QUIT
wxART_FIND
wxART_FIND_AND_REPLACE
wxART_FULL_SCREEN (since 3.1.0)
wxART_EDIT (since 3.1.0)
wxART_HARDDISK
wxART_FLOPPY
wxART_CDROM
wxART_REMOVABLE
wxART_WX_LOGO (since 3.1.6)
|
- Note
- When building with
wxNO_IMPLICIT_WXSTRING_ENCODING
defined (see wxString Overview for more details), you need to explicitly use wxASCII_STR() around these constants.
Additionally, any string recognized by custom art providers registered using wxArtProvider::Push may be used.
- Note
- When running under GTK+ 2, GTK+ stock item IDs (e.g.
"gtk-cdrom"
) may be used as well: #ifdef __WXGTK__
#endif
const char * wxART_MENU
Definition: artprov.h:20
static wxBitmap GetBitmap(const wxArtID &id, const wxArtClient &client=wxART_OTHER, const wxSize &size=wxDefaultSize)
Query registered providers for bitmap with given ID.
For a list of the GTK+ stock items please refer to the GTK+ documentation page. It is also possible to load icons from the current icon theme by specifying their name (without extension and directory components). Icon themes recognized by GTK+ follow the freedesktop.org Icon Themes specification. Note that themes are not guaranteed to contain all icons, so wxArtProvider may return wxNullBitmap or wxNullIcon. The default theme is typically installed in /usr/share/icons/hicolor
.
Clients
The client is the entity that calls wxArtProvider's GetBitmap() or GetIcon() function. It is represented by wxClientID type and can have one of these values:
wxART_TOOLBAR
wxART_MENU
wxART_BUTTON
wxART_FRAME_ICON
wxART_CMN_DIALOG
wxART_HELP_BROWSER
wxART_MESSAGE_BOX
wxART_OTHER
(used for all requests that don't fit into any of the categories above)
Client ID serve as a hint to wxArtProvider that is supposed to help it to choose the best looking bitmap. For example it is often desirable to use slightly different icons in menus and toolbars even though they represent the same action (e.g. wxART_FILE_OPEN). Remember that this is really only a hint for wxArtProvider – it is common that wxArtProvider::GetBitmap returns identical bitmap for different client values!
- See also
- Art Provider Sample for an example of wxArtProvider usage; stock ID list
|
static bool | Delete (wxArtProvider *provider) |
| Delete the given provider. More...
|
|
static wxBitmap | GetBitmap (const wxArtID &id, const wxArtClient &client=wxART_OTHER, const wxSize &size=wxDefaultSize) |
| Query registered providers for bitmap with given ID. More...
|
|
static wxBitmapBundle | GetBitmapBundle (const wxArtID &id, const wxArtClient &client=wxART_OTHER, const wxSize &size=wxDefaultSize) |
| Query registered providers for a bundle of bitmaps with given ID. More...
|
|
static wxIcon | GetIcon (const wxArtID &id, const wxArtClient &client=wxART_OTHER, const wxSize &size=wxDefaultSize) |
| Same as wxArtProvider::GetBitmap, but return a wxIcon object (or wxNullIcon on failure). More...
|
|
static wxSize | GetNativeDIPSizeHint (const wxArtClient &client) |
| Returns native icon size for use specified by client hint in DIPs. More...
|
|
static wxSize | GetNativeSizeHint (const wxArtClient &client, wxWindow *win=NULL) |
| Returns native icon size for use specified by client hint. More...
|
|
static wxSize | GetDIPSizeHint (const wxArtClient &client) |
| Returns a suitable size hint for the given wxArtClient in DIPs. More...
|
|
static wxSize | GetSizeHint (const wxArtClient &client, wxWindow *win=NULL) |
| Returns a suitable size hint for the given wxArtClient. More...
|
|
static wxIconBundle | GetIconBundle (const wxArtID &id, const wxArtClient &client=wxART_OTHER) |
| Query registered providers for icon bundle with given ID. More...
|
|
static bool | HasNativeProvider () |
| Returns true if the platform uses native icons provider that should take precedence over any customizations. More...
|
|
static void | Insert (wxArtProvider *provider) |
|
static bool | Pop () |
| Remove latest added provider and delete it. More...
|
|
static void | Push (wxArtProvider *provider) |
| Register new art provider and add it to the top of providers stack (i.e. More...
|
|
static void | PushBack (wxArtProvider *provider) |
| Register new art provider and add it to the bottom of providers stack. More...
|
|
static bool | Remove (wxArtProvider *provider) |
| Remove a provider from the stack if it is on it. More...
|
|
static wxArtID | GetMessageBoxIconId (int flags) |
| Helper used by GetMessageBoxIcon(): return the art id corresponding to the standard wxICON_INFORMATION/WARNING/ERROR/QUESTION flags (only one can be set) More...
|
|
static wxIcon | GetMessageBoxIcon (int flags) |
| Helper used by several generic classes: return the icon corresponding to the standard wxICON_INFORMATION/WARNING/ERROR/QUESTION flags (only one can be set) More...
|
|