]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/msw/palette.h
remove SetBackgroundStyle call from OnInternalIdle, it should be done from realize...
[wxWidgets.git] / include / wx / msw / palette.h
index bbeab7e7ddf3f04e4f0edf06d934383f22b14192..7d0cacec6a958e39248a8740cffe2bbbd665188d 100644 (file)
 
 #include "wx/gdiobj.h"
 
 
 #include "wx/gdiobj.h"
 
-class WXDLLIMPEXP_FWD_CORE wxPalette;
-
-class WXDLLEXPORT wxPaletteRefData: public wxGDIRefData
+class WXDLLIMPEXP_CORE wxPalette : public wxPaletteBase
 {
 {
-    friend class WXDLLIMPEXP_FWD_CORE wxPalette;
 public:
 public:
-    wxPaletteRefData(void);
-    virtual ~wxPaletteRefData(void);
-protected:
- WXHPALETTE m_hPalette;
-};
+    wxPalette() { }
+    wxPalette(int n,
+              const unsigned char *red, const unsigned char *green, const unsigned char *blue)
+    {
+        Create(n, red, green, blue);
+    }
 
 
-#define M_PALETTEDATA ((wxPaletteRefData *)m_refData)
-
-class WXDLLEXPORT wxPalette: public wxPaletteBase
-{
-public:
-    wxPalette();
-    wxPalette(int n, const unsigned char *red, const unsigned char *green, const unsigned char *blue);
-    virtual ~wxPalette(void);
-    bool Create(int n, const unsigned char *red, const unsigned char *green, const unsigned char *blue);
-    
-    int GetPixel(unsigned char red, unsigned char green, unsigned char blue) const;
-    bool GetRGB(int pixel, unsigned char *red, unsigned char *green, unsigned char *blue) const;
+    bool Create(int n,
+                const unsigned char *red, const unsigned char *green, const unsigned char *blue);
 
     virtual int GetColoursCount() const;
 
 
     virtual int GetColoursCount() const;
 
-    virtual bool Ok() const { return IsOk(); }
-    virtual bool IsOk(void) const { return (m_refData != NULL) ; }
+    int
+    GetPixel(unsigned char red, unsigned char green, unsigned char blue) const;
 
 
-    virtual bool FreeResource(bool force = false);
+    bool
+    GetRGB(int pixel,
+           unsigned char *red, unsigned char *green, unsigned char *blue) const;
 
     // implemetation
 
     // implemetation
-    inline WXHPALETTE GetHPALETTE(void) const { return (M_PALETTEDATA ? M_PALETTEDATA->m_hPalette : 0); }
+    WXHPALETTE GetHPALETTE() const;
     void SetHPALETTE(WXHPALETTE pal);
     void SetHPALETTE(WXHPALETTE pal);
-  
+
+protected:
+    virtual wxGDIRefData *CreateGDIRefData() const;
+    virtual wxGDIRefData *CloneGDIRefData(const wxGDIRefData *data) const;
+
 private:
     DECLARE_DYNAMIC_CLASS(wxPalette)
 };
 
 private:
     DECLARE_DYNAMIC_CLASS(wxPalette)
 };
 
-#endif
-    // _WX_PALETTE_H_
+#endif // _WX_PALETTE_H_