X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/b5c2a33438de94c80c55f1f0d4e96224236bf60f..6a06eecfb2c325b1844b9a7b004ba07d93219806:/src/osx/artmac.cpp?ds=sidebyside diff --git a/src/osx/artmac.cpp b/src/osx/artmac.cpp index 9142c143e8..267516cb7a 100644 --- a/src/osx/artmac.cpp +++ b/src/osx/artmac.cpp @@ -25,7 +25,7 @@ #include "wx/image.h" #endif -#if wxOSX_USE_COCOA_OR_CARBON +#include "wx/osx/private.h" // ---------------------------------------------------------------------------- // wxMacArtProvider @@ -34,8 +34,18 @@ class wxMacArtProvider : public wxArtProvider { protected: +#if wxOSX_USE_COCOA_OR_CARBON virtual wxIconBundle CreateIconBundle(const wxArtID& id, const wxArtClient& client); +#endif +#if wxOSX_USE_COCOA_OR_IPHONE + virtual wxBitmap CreateBitmap(const wxArtID& id, + const wxArtClient& client, + const wxSize& size) + { + return wxOSXCreateSystemBitmap(id, client, size); + } +#endif }; /* static */ void wxArtProvider::InitNativeProvider() @@ -43,13 +53,15 @@ protected: wxArtProvider::Push(new wxMacArtProvider); } +#if wxOSX_USE_COCOA_OR_CARBON + // ---------------------------------------------------------------------------- // helper macros // ---------------------------------------------------------------------------- #define CREATE_STD_ICON(iconId, xpmRc) \ { \ - wxIconBundle icon(_T(iconId), wxBITMAP_TYPE_ICON_RESOURCE); \ + wxIconBundle icon(wxT(iconId), wxBITMAP_TYPE_ICON_RESOURCE); \ return icon; \ } @@ -72,20 +84,20 @@ static wxIconBundle wxMacArtProvider_CreateIconBundle(const wxArtID& id) ART_MSGBOX(wxART_NORMAL_FILE, wxICON_NORMAL_FILE, deffile) ART_MSGBOX(wxART_EXECUTABLE_FILE, wxICON_EXECUTABLE_FILE, exefile) - ART_MSGBOX(wxART_CDROM, wxICON_CDROM, cdrom) - ART_MSGBOX(wxART_FLOPPY, wxICON_FLOPPY, floppy) - ART_MSGBOX(wxART_HARDDISK, wxICON_HARDDISK, harddisk) - ART_MSGBOX(wxART_REMOVABLE, wxICON_REMOVABLE, removable) - - ART_MSGBOX(wxART_DELETE, wxICON_DELETE, delete) - - ART_MSGBOX(wxART_GO_BACK, wxICON_GO_BACK, back) - ART_MSGBOX(wxART_GO_FORWARD, wxICON_GO_FORWARD, forward) - ART_MSGBOX(wxART_GO_HOME, wxICON_GO_HOME, home) - - ART_MSGBOX(wxART_HELP_SETTINGS, wxICON_HELP_SETTINGS, htmoptns) - ART_MSGBOX(wxART_HELP_PAGE, wxICON_HELP_PAGE, htmpage) - + ART_MSGBOX(wxART_CDROM, wxICON_CDROM, cdrom) + ART_MSGBOX(wxART_FLOPPY, wxICON_FLOPPY, floppy) + ART_MSGBOX(wxART_HARDDISK, wxICON_HARDDISK, harddisk) + ART_MSGBOX(wxART_REMOVABLE, wxICON_REMOVABLE, removable) + + ART_MSGBOX(wxART_DELETE, wxICON_DELETE, delete) + + ART_MSGBOX(wxART_GO_BACK, wxICON_GO_BACK, back) + ART_MSGBOX(wxART_GO_FORWARD, wxICON_GO_FORWARD, forward) + ART_MSGBOX(wxART_GO_HOME, wxICON_GO_HOME, home) + + ART_MSGBOX(wxART_HELP_SETTINGS, wxICON_HELP_SETTINGS, htmoptns) + ART_MSGBOX(wxART_HELP_PAGE, wxICON_HELP_PAGE, htmpage) + return wxNullIconBundle; } @@ -103,6 +115,7 @@ wxIconBundle wxMacArtProvider::CreateIconBundle(const wxArtID& id, const wxArtCl return wxMacArtProvider_CreateIconBundle(id); } +#endif // ---------------------------------------------------------------------------- // wxArtProvider::GetNativeSizeHint() @@ -117,8 +130,15 @@ wxSize wxArtProvider::GetNativeSizeHint(const wxArtClient& client) // "32 x 32 pixels is the recommended size" return wxSize(32, 32); } + else if ( client == wxART_BUTTON || client == wxART_MENU ) + { + // Mac UI doesn't use any images in neither buttons nor menus in + // general but the code using wxArtProvider can use wxART_BUTTON to + // find the icons of a roughly appropriate size for the buttons and + // 16x16 seems to be the best choice for this kind of use + return wxSize(16, 16); + } return wxDefaultSize; } -#endif // wxOSX_USE_COCOA_CARBON