]>
git.saurik.com Git - wxWidgets.git/blob - include/wx/ownerdrw.h
   1 /////////////////////////////////////////////////////////////////////////////// 
   3 // Purpose:     interface for owner-drawn GUI elements 
   4 // Author:      Vadim Zeitlin 
   8 // Copyright:   (c) 1998 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr> 
   9 // Licence:     wxWindows licence 
  10 /////////////////////////////////////////////////////////////////////////////// 
  17 #if defined(__GNUG__) && !defined(NO_GCC_PRAGMA) 
  18     #pragma interface "ownerdrw.h" 
  21 #include "wx/bitmap.h" 
  22 #include "wx/colour.h" 
  25 // ---------------------------------------------------------------------------- 
  26 // wxOwnerDrawn - a mix-in base class, derive from it to implement owner-drawn 
  29 // wxOwnerDrawn supports drawing of an item with non standard font, color and 
  30 // also supports 3 bitmaps: either a checked/unchecked bitmap for a checkable 
  31 // element or one unchangeable bitmap otherwise. 
  32 // ---------------------------------------------------------------------------- 
  34 class WXDLLEXPORT wxOwnerDrawn
 
  38   wxOwnerDrawn(const wxString
& str 
= wxEmptyString
, 
  39                bool bCheckable 
= FALSE
, 
  40                bool bMenuItem 
= FALSE
); // FIXME kludge for colors 
  41   virtual ~wxOwnerDrawn() { } 
  44   void SetFont(const wxFont
& font
) 
  45       { m_font 
= font
; m_bOwnerDrawn 
= TRUE
; } 
  47   wxFont
& GetFont() const { return (wxFont 
&)m_font
; } 
  49   void SetTextColour(const wxColour
& colText
) 
  50       { m_colText 
= colText
; m_bOwnerDrawn 
= TRUE
; } 
  52   wxColour
& GetTextColour() const { return (wxColour
&) m_colText
; } 
  54   void SetBackgroundColour(const wxColour
& colBack
) 
  55       { m_colBack 
= colBack
; m_bOwnerDrawn 
= TRUE
; } 
  57   wxColour
& GetBackgroundColour() const 
  58       { return (wxColour
&) m_colBack 
; } 
  60   void SetBitmaps(const wxBitmap
& bmpChecked
, 
  61                   const wxBitmap
& bmpUnchecked 
= wxNullBitmap
) 
  62       { m_bmpChecked 
= bmpChecked
; 
  63         m_bmpUnchecked 
= bmpUnchecked
; 
  64         m_bOwnerDrawn 
= TRUE
; } 
  66   void SetBitmap(const wxBitmap
& bmpChecked
) 
  67       { m_bmpChecked 
= bmpChecked
; 
  68         m_bOwnerDrawn 
= TRUE
; } 
  70   void SetDisabledBitmap( const wxBitmap
& bmpDisabled 
) 
  71       { m_bmpDisabled 
= bmpDisabled
; 
  72         m_bOwnerDrawn 
= TRUE
; } 
  74   const wxBitmap
& GetBitmap(bool bChecked 
= TRUE
) const 
  75       { return (bChecked 
? m_bmpChecked 
: m_bmpUnchecked
); } 
  77   const wxBitmap
& GetDisabledBitmap() const 
  78       { return m_bmpDisabled
; } 
  80   // the height of the menu checkmark (or bitmap) is determined by the font 
  81   // for the current item, but the width should be always the same (for the 
  82   // items to be aligned), so by default it's taken to be the same as for 
  83   // the last item (and default width for the first one). 
  85   // NB: default is too small for bitmaps, but ok for checkmarks. 
  86   void SetMarginWidth(int nWidth
) 
  88       ms_nLastMarginWidth 
= m_nMarginWidth 
= (size_t) nWidth
; 
  89       if ( ((size_t) nWidth
) != ms_nDefaultMarginWidth 
) 
  93   int GetMarginWidth() const { return (int) m_nMarginWidth
; } 
  94   static int GetDefaultMarginWidth() { return (int) ms_nDefaultMarginWidth
; } 
  97   void SetName(const wxString
& strName
)  { m_strName 
= strName
; } 
  98   const wxString
& GetName() const { return m_strName
;    } 
  99   void SetCheckable(bool checkable
) { m_bCheckable 
= checkable
; } 
 100   bool IsCheckable() const { return m_bCheckable
; } 
 102   // this is for menu items only: accel string is drawn right aligned after the 
 103   // menu item if not empty 
 104   void SetAccelString(const wxString
& strAccel
) { m_strAccel 
= strAccel
; } 
 106   // this function might seem strange, but if it returns FALSE it means that 
 107   // no non-standard attribute are set, so there is no need for this control 
 108   // to be owner-drawn. Moreover, you can force owner-drawn to FALSE if you 
 109   // want to change, say, the color for the item but only if it is owner-drawn 
 110   // (see wxMenuItem::wxMenuItem for example) 
 111   bool IsOwnerDrawn() const { return m_bOwnerDrawn
;   } 
 113   // switch on/off owner-drawing the item 
 114   void SetOwnerDrawn(bool ownerDrawn 
= TRUE
) { m_bOwnerDrawn 
= ownerDrawn
; } 
 115   void ResetOwnerDrawn() { m_bOwnerDrawn 
= FALSE
;  } 
 118   // constants used in OnDrawItem 
 119   // (they have the same values as corresponding Win32 constants) 
 122     wxODDrawAll       
= 0x0001,   // redraw entire control 
 123     wxODSelectChanged 
= 0x0002,   // selection changed (see Status.Select) 
 124     wxODFocusChanged  
= 0x0004    // keyboard focus changed (see Status.Focus) 
 129     wxODSelected  
= 0x0001,         // control is currently selected 
 130     wxODGrayed    
= 0x0002,         // item is to be grayed 
 131     wxODDisabled  
= 0x0004,         // item is to be drawn as disabled 
 132     wxODChecked   
= 0x0008,         // item is to be checked 
 133     wxODHasFocus  
= 0x0010,         // item has the keyboard focus 
 134     wxODDefault   
= 0x0020          // item is the default item 
 137   // virtual functions to implement drawing (return TRUE if processed) 
 138   virtual bool OnMeasureItem(size_t *pwidth
, size_t *pheight
); 
 139   virtual bool OnDrawItem(wxDC
& dc
, const wxRect
& rc
, wxODAction act
, wxODStatus stat
); 
 142   wxString  m_strName
,      // label for a manu item 
 143             m_strAccel
;     // the accel string ("Ctrl-F17") if any 
 146   static size_t ms_nDefaultMarginWidth
; // menu check mark width 
 147   static size_t ms_nLastMarginWidth
;    // handy for aligning all items 
 149   bool      m_bCheckable
,   // used only for menu or check listbox items 
 150             m_bOwnerDrawn
;  // true if something is non standard 
 152   wxFont    m_font
;         // font to use for drawing 
 153   wxColour  m_colText
,      // color ----"---"---"---- 
 154             m_colBack
;      // background color 
 155   wxBitmap  m_bmpChecked
,   // bitmap to put near the item 
 156             m_bmpUnchecked
, // (checked is used also for 'uncheckable' items) 
 159   size_t    m_nHeight
,      // font height 
 160             m_nMinHeight
,   // minimum height, as determined by user's system settings 
 161             m_nMarginWidth
; // space occupied by bitmap to the left of the item 
 164 #endif // wxUSE_OWNER_DRAWN