#include "wx/image.h"
#endif
-#if wxOSX_USE_COCOA_OR_CARBON
+#include "wx/osx/private.h"
// ----------------------------------------------------------------------------
// wxMacArtProvider
class wxMacArtProvider : public wxArtProvider
{
protected:
- virtual wxBitmap CreateBitmap(const wxArtID& id, const wxArtClient& client,
- const wxSize& size);
+#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()
{
- wxArtProvider::Push(new wxMacArtProvider);
+ PushBack(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; \
}
ART_MSGBOX(wxART_FOLDER, wxICON_FOLDER, folder)
ART_MSGBOX(wxART_FOLDER_OPEN, wxICON_FOLDER_OPEN, folder_open)
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_FOLDER, wxICON_HELP_FOLDER, htmfoldr)
- ART_MSGBOX(wxART_HELP_PAGE, wxICON_HELP_PAGE, htmpage)
-
- ART_MSGBOX(wxART_PRINT, wxICON_PRINT, print)
-
return wxNullIconBundle;
}
return wxMacArtProvider_CreateIconBundle(id);
}
-// ----------------------------------------------------------------------------
-// CreateBitmap
-// ----------------------------------------------------------------------------
-
-wxBitmap wxMacArtProvider::CreateBitmap(const wxArtID& id,
- const wxArtClient& client,
- const wxSize& reqSize)
-{
- wxIconBundle ic(CreateIconBundle(id, client));
- if (ic.IsOk())
- {
- wxIcon theIcon(ic.GetIcon(reqSize));
- return wxBitmap(theIcon);
- }
-
- return wxNullBitmap;
-}
-
+#endif
// ----------------------------------------------------------------------------
// wxArtProvider::GetNativeSizeHint()
// "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