]>
git.saurik.com Git - wxWidgets.git/blob - interface/wx/artprov.h
   1 ///////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     interface of wxArtProvider 
   4 // Author:      wxWidgets team 
   6 // Licence:     wxWindows license 
   7 ///////////////////////////////////////////////////////////////////////////// 
  10     This type identifies the client of the art objects requested to wxArtProvider. 
  12 typedef wxString wxArtClient
; 
  15     This type identifies a specific art object which can be requested to wxArtProvider. 
  17 typedef wxString wxArtID
; 
  23     wxArtProvider class is used to customize the look of wxWidgets application. 
  25     When wxWidgets needs to display an icon or a bitmap (e.g. in the standard file 
  26     dialog), it does not use a hard-coded resource but asks wxArtProvider for it 
  27     instead. This way users can plug in their own wxArtProvider class and easily 
  28     replace standard art with their own version. 
  30     All that is needed is to derive a class from wxArtProvider, override either its 
  31     wxArtProvider::CreateBitmap() and/or its wxArtProvider::CreateIconBundle() methods 
  32     and register the provider with wxArtProvider::Push(): 
  35       class MyProvider : public wxArtProvider 
  38         wxBitmap CreateBitmap(const wxArtID& id, 
  39                               const wxArtClient& client, 
  42         // optionally override this one as well 
  43         wxIconBundle CreateIconBundle(const wxArtID& id, 
  44                                       const wxArtClient& client) 
  48       wxArtProvider::Push(new MyProvider); 
  51     If you need bitmap images (of the same artwork) that should be displayed at 
  52     different sizes you should probably consider overriding wxArtProvider::CreateIconBundle 
  53     and supplying icon bundles that contain different bitmap sizes. 
  55     There's another way of taking advantage of this class: you can use it in your 
  56     code and use platform native icons as provided by wxArtProvider::GetBitmap or 
  57     wxArtProvider::GetIcon. 
  59     @section artprovider_identify Identifying art resources 
  61     Every bitmap and icon bundle are known to wxArtProvider under an unique ID that 
  62     is used when requesting a resource from it. The ID is represented by wxArtID type 
  63     and can have one of these predefined values (you can see bitmaps represented by these 
  64     constants in the @ref page_samples_artprov): 
  72      @li wxART_ADD_BOOKMARK 
  73      @li wxART_DEL_BOOKMARK 
  74      @li wxART_HELP_SIDE_PANEL 
  75      @li wxART_HELP_SETTINGS 
  84      @li wxART_GO_TO_PARENT 
  95      @li wxART_EXECUTABLE_FILE 
 100      @li wxART_MISSING_IMAGE 
 104      @li wxART_FILE_SAVE_AS 
 113      @li wxART_FIND_AND_REPLACE 
 121     Additionally, any string recognized by custom art providers registered using 
 122     wxArtProvider::Push may be used. 
 125     When running under GTK+ 2, GTK+ stock item IDs (e.g. @c "gtk-cdrom") may be used 
 129         wxBitmap bmp = wxArtProvider::GetBitmap("gtk-cdrom", wxART_MENU); 
 132     For a list of the GTK+ stock items please refer to the GTK+ documentation page 
 133     http://library.gnome.org/devel/gtk/stable/gtk-Stock-Items.html. 
 134     Additionally, if wxGTK was compiled against GTK+ >= 2.4, then it is also 
 135     possible to load icons from current icon theme by specifying their name (without 
 136     extension and directory components). 
 137     Icon themes recognized by GTK+ follow the freedesktop.org Icon Themes specification 
 138     (see http://freedesktop.org/Standards/icon-theme-spec). 
 139     Note that themes are not guaranteed to contain all icons, so wxArtProvider may 
 140     return ::wxNullBitmap or ::wxNullIcon. 
 141     The default theme is typically installed in @c /usr/share/icons/hicolor. 
 144     @section artprovider_clients Clients 
 146     The @e client is the entity that calls wxArtProvider's GetBitmap() or GetIcon() function. 
 147     It is represented by wxClientID type and can have one of these values: 
 154     @li wxART_HELP_BROWSER 
 155     @li wxART_MESSAGE_BOX 
 156     @li wxART_OTHER (used for all requests that don't fit into any of the 
 159     Client ID serve as a hint to wxArtProvider that is supposed to help it to 
 160     choose the best looking bitmap. For example it is often desirable to use 
 161     slightly different icons in menus and toolbars even though they represent 
 162     the same action (e.g. wxART_FILE_OPEN). Remember that this is really only a 
 163     hint for wxArtProvider -- it is common that wxArtProvider::GetBitmap returns 
 164     identical bitmap for different client values! 
 169     @see the @ref page_samples_artprov for an example of wxArtProvider usage. 
 171 class wxArtProvider 
: public wxObject
 
 175         The destructor automatically removes the provider from the provider stack used 
 178     virtual ~wxArtProvider(); 
 181         Delete the given @a provider. 
 183     static bool Delete(wxArtProvider
* provider
); 
 186         Query registered providers for bitmap with given ID. 
 189             wxArtID unique identifier of the bitmap. 
 191             wxArtClient identifier of the client (i.e. who is asking for the bitmap). 
 193             Size of the returned bitmap or wxDefaultSize if size doesn't matter. 
 195         @return The bitmap if one of registered providers recognizes the ID or 
 196                 wxNullBitmap otherwise. 
 198     static wxBitmap 
GetBitmap(const wxArtID
& id
, 
 199                               const wxArtClient
& client 
= wxART_OTHER
, 
 200                               const wxSize
& size 
= wxDefaultSize
); 
 203         Same as wxArtProvider::GetBitmap, but return a wxIcon object 
 204         (or ::wxNullIcon on failure). 
 206     static wxIcon 
GetIcon(const wxArtID
& id
, 
 207                           const wxArtClient
& client 
= wxART_OTHER
, 
 208                           const wxSize
& size 
= wxDefaultSize
); 
 211         Returns native icon size for use specified by @a client hint. 
 213         If the platform has no commonly used default for this use or if 
 214         @a client is not recognized, returns wxDefaultSize. 
 216         @note In some cases, a platform may have @em several appropriate 
 217               native sizes (for example, wxART_FRAME_ICON for frame icons). 
 218               In that case, this method returns only one of them, picked 
 223     static wxSize 
GetNativeSizeHint(const wxArtClient
& client
); 
 226         Returns a suitable size hint for the given @e wxArtClient. 
 228         If @a platform_default is @true, return a size based on the current 
 229         platform using GetNativeSizeHint(), otherwise return the size from the 
 230         topmost wxArtProvider. @e wxDefaultSize may be returned if the client 
 231         doesn't have a specified size, like wxART_OTHER for example. 
 233         @see GetNativeSizeHint() 
 235     static wxSize 
GetSizeHint(const wxArtClient
& client
, 
 236                               bool platform_default 
= false); 
 239         Query registered providers for icon bundle with given ID. 
 242             wxArtID unique identifier of the icon bundle. 
 244             wxArtClient identifier of the client (i.e. who is asking for the icon 
 247         @return The icon bundle if one of registered providers recognizes the ID 
 248                 or wxNullIconBundle otherwise. 
 250     static wxIconBundle 
GetIconBundle(const wxArtID
& id
, 
 251                                       const wxArtClient
& client 
= wxART_OTHER
); 
 254         Returns true if the platform uses native icons provider that should 
 255         take precedence over any customizations. 
 257         This is true for any platform that has user-customizable icon themes, 
 258         currently only wxGTK. 
 260         A typical use for this method is to decide whether a custom art provider 
 261         should be plugged in using Push() or PushBack(). 
 265     static bool HasNativeProvider(); 
 268         @deprecated Use PushBack() instead. 
 270     static void Insert(wxArtProvider
* provider
); 
 273         Remove latest added provider and delete it. 
 278         Register new art provider and add it to the top of providers stack 
 279         (i.e. it will be queried as the first provider). 
 283     static void Push(wxArtProvider
* provider
); 
 286         Register new art provider and add it to the bottom of providers stack. 
 287         In other words, it will be queried as the last one, after all others, 
 288         including the default provider. 
 294     static void PushBack(wxArtProvider
* provider
); 
 297         Remove a provider from the stack if it is on it. The provider is not 
 298         deleted, unlike when using Delete(). 
 300     static bool Remove(wxArtProvider
* provider
); 
 305         Derived art provider classes must override this method to create requested art 
 306         resource. Note that returned bitmaps are cached by wxArtProvider and it is 
 307         therefore not necessary to optimize CreateBitmap() for speed (e.g. you may 
 308         create wxBitmap objects from XPMs here). 
 311             wxArtID unique identifier of the bitmap. 
 313             wxArtClient identifier of the client (i.e. who is asking for the bitmap). 
 314             This only servers as a hint. 
 316             Preferred size of the bitmap. The function may return a bitmap of different 
 317             dimensions, it will be automatically rescaled to meet client's request. 
 320         This is not part of wxArtProvider's public API, use wxArtProvider::GetBitmap 
 321         or wxArtProvider::GetIconBundle or wxArtProvider::GetIcon to query wxArtProvider 
 324         @see CreateIconBundle() 
 326     virtual wxBitmap 
CreateBitmap(const wxArtID
& id
, 
 327                                   const wxArtClient
& client
, 
 331         This method is similar to CreateBitmap() but can be used when a bitmap 
 332         (or an icon) exists in several sizes. 
 334     virtual wxIconBundle 
CreateIconBundle(const wxArtID
& id
, 
 335                                           const wxArtClient
& client
);