]> git.saurik.com Git - wxWidgets.git/blobdiff - src/motif/icon.cpp
wxWindow::Fit() infinite loop bug fixed
[wxWidgets.git] / src / motif / icon.cpp
index 834c9ff1ccfc71fa7fbfbac861f13cb89fd086eb..55d70fdd9af63070d1236cd6f7da51110649cd3b 100644 (file)
 #endif
 
 #include "wx/icon.h"
+#include "wx/window.h"
+
+#include <Xm/Xm.h>
+#include <X11/cursorfont.h>
+
+#include "wx/motif/private.h"
 
 #if !USE_SHARED_LIBRARIES
 IMPLEMENT_DYNAMIC_CLASS(wxIcon, wxBitmap)
 #endif
 
 /*
- * Icons
- */
-
-
-wxIconRefData::wxIconRefData()
-{
-    // TODO: init icon handle
-}
+* Icons
+*/
 
-wxIconRefData::~wxIconRefData()
+wxIcon::wxIcon()
 {
-    // TODO: destroy icon handle
 }
 
-wxIcon::wxIcon()
+// Create from XBM data
+wxIcon::wxIcon(const char bits[], int width, int height)
 {
+    (void) Create((void*) bits, wxBITMAP_TYPE_XBM_DATA, width, height, 1);
 }
 
-wxIcon::wxIcon(const char WXUNUSED(bits)[], int WXUNUSED(width), int WXUNUSED(height))
+// Create from XPM 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)
-
+               int desiredWidth, int desiredHeight)
+               
 {
     LoadFile(icon_file, flags, desiredWidth, desiredHeight);
 }
@@ -54,17 +57,17 @@ wxIcon::~wxIcon()
 }
 
 bool wxIcon::LoadFile(const wxString& filename, long type,
-    int desiredWidth, int desiredHeight)
+                      int desiredWidth, int desiredHeight)
 {
-  UnRef();
-
-  m_refData = new wxIconRefData;
-
-  wxBitmapHandler *handler = FindHandler(type);
-
-  if ( handler )
-       return handler->LoadFile(this, filename, type, desiredWidth, desiredHeight);
-  else
-       return FALSE;
+    UnRef();
+    
+    m_refData = new wxBitmapRefData;
+    
+    wxBitmapHandler *handler = FindHandler(type);
+    
+    if ( handler )
+        return handler->LoadFile(this, filename, type, desiredWidth, desiredHeight);
+    else
+        return FALSE;
 }