]> git.saurik.com Git - wxWidgets.git/blobdiff - include/wx/msw/palette.h
no real changes, just refactor/simplify the code to remove duplication and unnecessar...
[wxWidgets.git] / include / wx / msw / palette.h
index 4383c44a3f7c85df05a989e9871e8dddb1e1aae7..ee404a18816a2ba2b2b34fff804795e32f65e5f9 100644 (file)
@@ -1,65 +1,51 @@
 /////////////////////////////////////////////////////////////////////////////
-// Name:        palette.h
+// Name:        wx/msw/palette.h
 // Purpose:     wxPalette class
 // Author:      Julian Smart
 // Modified by:
 // Created:     01/02/97
 // RCS-ID:      $Id$
 // Copyright:   (c) Julian Smart
-// Licence:    wxWindows licence
+// Licence:     wxWindows licence
 /////////////////////////////////////////////////////////////////////////////
 
 #ifndef _WX_PALETTE_H_
 #define _WX_PALETTE_H_
 
-#ifdef __GNUG__
-#pragma interface "palette.h"
-#endif
-
 #include "wx/gdiobj.h"
 
-class WXDLLEXPORT wxPalette;
-
-class WXDLLEXPORT wxPaletteRefData: public wxGDIRefData
+class WXDLLEXPORT wxPalette : public wxPaletteBase
 {
-    friend class WXDLLEXPORT wxPalette;
 public:
-    wxPaletteRefData(void);
-    ~wxPaletteRefData(void);
-protected:
- WXHPALETTE m_hPalette;
-};
+    wxPalette() { }
+    wxPalette(int n,
+              unsigned char *red, unsigned char *green, unsigned char *blue)
+    {
+        Create(n, red, green, blue);
+    }
 
-#define M_PALETTEDATA ((wxPaletteRefData *)m_refData)
+    bool Create(int n,
+                unsigned char *red, unsigned char *green, unsigned char *blue);
 
-class WXDLLEXPORT wxPalette: public wxGDIObject
-{
-  DECLARE_DYNAMIC_CLASS(wxPalette)
+    virtual int GetColoursCount() const;
 
-public:
-  wxPalette(void);
-  inline wxPalette(const wxPalette& palette) { Ref(palette); }
-
-  wxPalette(int n, const unsigned char *red, const unsigned char *green, const unsigned char *blue);
-  ~wxPalette(void);
-  bool Create(int n, const unsigned char *red, const unsigned char *green, const unsigned char *blue);
-  int GetPixel(const unsigned char red, const unsigned char green, const unsigned char blue) const;
-  bool GetRGB(int pixel, unsigned char *red, unsigned char *green, unsigned char *blue) const;
+    int
+    GetPixel(unsigned char red, unsigned char green, unsigned char blue) const;
 
-  virtual bool Ok(void) const { return (m_refData != NULL) ; }
+    bool
+    GetRGB(int pixel,
+           unsigned char *red, unsigned char *green, unsigned char *blue) const;
 
-  inline wxPalette& operator = (const wxPalette& palette) { if (*this == palette) return (*this); Ref(palette); return *this; }
-  inline bool operator == (const wxPalette& palette) { return m_refData == palette.m_refData; }
-  inline bool operator != (const wxPalette& palette) { return m_refData != palette.m_refData; }
+    // implemetation
+    WXHPALETTE GetHPALETTE() const;
+    void SetHPALETTE(WXHPALETTE pal);
 
-  virtual bool FreeResource(bool force = FALSE);
+protected:
+    virtual wxGDIRefData *CreateGDIRefData() const;
+    virtual wxGDIRefData *CloneGDIRefData(const wxGDIRefData *data) const;
 
-  inline WXHPALETTE GetHPALETTE(void) const { return (M_PALETTEDATA ? M_PALETTEDATA->m_hPalette : 0); }
-  void SetHPALETTE(WXHPALETTE pal);
+private:
+    DECLARE_DYNAMIC_CLASS(wxPalette)
 };
 
-#define wxColorMap wxPalette
-#define wxColourMap wxPalette
-
-#endif
-    // _WX_PALETTE_H_
+#endif // _WX_PALETTE_H_