X-Git-Url: https://git.saurik.com/wxWidgets.git/blobdiff_plain/f97c985452b20a8c2f0bbfb1d0275298bf09fb45..5c2ddebecd17d3b10957178ba30f2873c0ec4611:/src/motif/icon.cpp diff --git a/src/motif/icon.cpp b/src/motif/icon.cpp index 0f3ff04a64..692175a812 100644 --- a/src/motif/icon.cpp +++ b/src/motif/icon.cpp @@ -9,25 +9,17 @@ // Licence: wxWindows licence ///////////////////////////////////////////////////////////////////////////// -#ifdef __GNUG__ +#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) #pragma implementation "icon.h" #endif #include "wx/icon.h" -#include "wx/window.h" -#include -#include +IMPLEMENT_DYNAMIC_CLASS(wxIcon, wxBitmap); -#include "wx/motif/private.h" - -#if !USE_SHARED_LIBRARIES -IMPLEMENT_DYNAMIC_CLASS(wxIcon, wxBitmap) -#endif - -/* - * Icons - */ +// ============================================================================ +// Icons +// ============================================================================ wxIcon::wxIcon() { @@ -40,34 +32,36 @@ wxIcon::wxIcon(const char bits[], int width, int height) } // Create from XPM data -wxIcon::wxIcon(const char **data) +wxIcon::wxIcon(char **data) { (void) Create((void*) data, wxBITMAP_TYPE_XPM_DATA, 0, 0, 0); } -wxIcon::wxIcon(const wxString& icon_file, long flags, - int desiredWidth, int desiredHeight) +wxIcon::wxIcon(const char **data) +{ + (void) Create((void*) data, wxBITMAP_TYPE_XPM_DATA, 0, 0, 0); +} +void wxIcon::CopyFromBitmap(const wxBitmap& bmp) { - LoadFile(icon_file, flags, desiredWidth, desiredHeight); + wxIcon *icon = (wxIcon*)(&bmp); + *this = *icon; } wxIcon::~wxIcon() { } -bool wxIcon::LoadFile(const wxString& filename, long type, - int desiredWidth, int desiredHeight) +bool wxIcon::LoadFile(const wxString& filename, wxBitmapType type, + int desiredWidth, int desiredHeight) { - UnRef(); - - m_refData = new wxBitmapRefData; - - wxBitmapHandler *handler = FindHandler(type); - - if ( handler ) - return handler->LoadFile(this, filename, type, desiredWidth, desiredHeight); - else - return FALSE; + UnRef(); + + wxBitmapHandler *handler = FindHandler(type); + + if ( handler ) + return handler->LoadFile(this, filename, type, + desiredWidth, desiredHeight); + else + return FALSE; } -