| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288 | 
							- ///////////////////////////////////////////////////////////////////////////////
 
- // Name:        wx/headercol.h
 
- // Purpose:     declaration of wxHeaderColumn class
 
- // Author:      Vadim Zeitlin
 
- // Created:     2008-12-02
 
- // Copyright:   (c) 2008 Vadim Zeitlin <vadim@wxwidgets.org>
 
- // Licence:     wxWindows licence
 
- ///////////////////////////////////////////////////////////////////////////////
 
- #ifndef _WX_HEADERCOL_H_
 
- #define _WX_HEADERCOL_H_
 
- #include "wx/bitmap.h"
 
- #if wxUSE_HEADERCTRL
 
- // ----------------------------------------------------------------------------
 
- // constants
 
- // ----------------------------------------------------------------------------
 
- enum
 
- {
 
-     // special value for column width meaning unspecified/default
 
-     wxCOL_WIDTH_DEFAULT = -1,
 
-     // size the column automatically to fit all values
 
-     wxCOL_WIDTH_AUTOSIZE = -2
 
- };
 
- // bit masks for the various column attributes
 
- enum
 
- {
 
-     // column can be resized (included in default flags)
 
-     wxCOL_RESIZABLE   = 1,
 
-     // column can be clicked to toggle the sort order by its contents
 
-     wxCOL_SORTABLE    = 2,
 
-     // column can be dragged to change its order (included in default)
 
-     wxCOL_REORDERABLE = 4,
 
-     // column is not shown at all
 
-     wxCOL_HIDDEN      = 8,
 
-     // default flags for wxHeaderColumn ctor
 
-     wxCOL_DEFAULT_FLAGS = wxCOL_RESIZABLE | wxCOL_REORDERABLE
 
- };
 
- // ----------------------------------------------------------------------------
 
- // wxHeaderColumn: interface for a column in a header of controls such as
 
- //                 wxListCtrl, wxDataViewCtrl or wxGrid
 
- // ----------------------------------------------------------------------------
 
- class WXDLLIMPEXP_CORE wxHeaderColumn
 
- {
 
- public:
 
-     // ctors and dtor
 
-     // --------------
 
-     /*
 
-        Derived classes must provide ctors with the following signatures
 
-        (notice that they shouldn't be explicit to allow passing strings/bitmaps
 
-        directly to methods such wxHeaderCtrl::AppendColumn()):
 
-     wxHeaderColumn(const wxString& title,
 
-                    int width = wxCOL_WIDTH_DEFAULT,
 
-                    wxAlignment align = wxALIGN_NOT,
 
-                    int flags = wxCOL_DEFAULT_FLAGS);
 
-     wxHeaderColumn(const wxBitmap &bitmap,
 
-                    int width = wxDVC_DEFAULT_WIDTH,
 
-                    wxAlignment align = wxALIGN_CENTER,
 
-                    int flags = wxCOL_DEFAULT_FLAGS);
 
-     */
 
-     // virtual dtor for the base class to avoid gcc warnings even though we
 
-     // don't normally delete the objects of this class via a pointer to
 
-     // wxHeaderColumn so it's not necessary, strictly speaking
 
-     virtual ~wxHeaderColumn() { }
 
-     // getters for various attributes
 
-     // ------------------------------
 
-     // notice that wxHeaderColumn only provides getters as this is all the
 
-     // wxHeaderCtrl needs, various derived class must also provide some way to
 
-     // change these attributes but this can be done either at the column level
 
-     // (in which case they should inherit from wxSettableHeaderColumn) or via
 
-     // the methods of the main control in which case you don't need setters in
 
-     // the column class at all
 
-     // title is the string shown for this column
 
-     virtual wxString GetTitle() const = 0;
 
-     // bitmap shown (instead of text) in the column header
 
-     virtual wxBitmap GetBitmap() const = 0;                                   \
 
-     // width of the column in pixels, can be set to wxCOL_WIDTH_DEFAULT meaning
 
-     // unspecified/default
 
-     virtual int GetWidth() const = 0;
 
-     // minimal width can be set for resizable columns to forbid resizing them
 
-     // below the specified size (set to 0 to remove)
 
-     virtual int GetMinWidth() const = 0;
 
-     // alignment of the text: wxALIGN_CENTRE, wxALIGN_LEFT or wxALIGN_RIGHT
 
-     virtual wxAlignment GetAlignment() const = 0;
 
-     // flags manipulations:
 
-     // --------------------
 
-     // notice that while we make GetFlags() pure virtual here and implement the
 
-     // individual flags access in terms of it, for some derived classes it is
 
-     // more natural to implement access to each flag individually, in which
 
-     // case they can use our GetFromIndividualFlags() helper below to implement
 
-     // GetFlags()
 
-     // retrieve all column flags at once: combination of wxCOL_XXX values above
 
-     virtual int GetFlags() const = 0;
 
-     bool HasFlag(int flag) const { return (GetFlags() & flag) != 0; }
 
-     // wxCOL_RESIZABLE
 
-     virtual bool IsResizeable() const
 
-         { return HasFlag(wxCOL_RESIZABLE); }
 
-     // wxCOL_SORTABLE
 
-     virtual bool IsSortable() const
 
-         { return HasFlag(wxCOL_SORTABLE); }
 
-     // wxCOL_REORDERABLE
 
-     virtual bool IsReorderable() const
 
-         { return HasFlag(wxCOL_REORDERABLE); }
 
-     // wxCOL_HIDDEN
 
-     virtual bool IsHidden() const
 
-         { return HasFlag(wxCOL_HIDDEN); }
 
-     bool IsShown() const
 
-         { return !IsHidden(); }
 
-     // sorting
 
-     // -------
 
-     // return true if the column is the one currently used for sorting
 
-     virtual bool IsSortKey() const = 0;
 
-     // for sortable columns indicate whether we should sort in ascending or
 
-     // descending order (this should only be taken into account if IsSortKey())
 
-     virtual bool IsSortOrderAscending() const = 0;
 
- protected:
 
-     // helper for the class overriding IsXXX()
 
-     int GetFromIndividualFlags() const;
 
- };
 
- // ----------------------------------------------------------------------------
 
- // wxSettableHeaderColumn: column which allows to change its fields too
 
- // ----------------------------------------------------------------------------
 
- class WXDLLIMPEXP_CORE wxSettableHeaderColumn : public wxHeaderColumn
 
- {
 
- public:
 
-     virtual void SetTitle(const wxString& title) = 0;
 
-     virtual void SetBitmap(const wxBitmap& bitmap) = 0;
 
-     virtual void SetWidth(int width) = 0;
 
-     virtual void SetMinWidth(int minWidth) = 0;
 
-     virtual void SetAlignment(wxAlignment align) = 0;
 
-     // see comment for wxHeaderColumn::GetFlags() about the relationship
 
-     // between SetFlags() and Set{Sortable,Reorderable,...}
 
-     // change, set, clear, toggle or test for any individual flag
 
-     virtual void SetFlags(int flags) = 0;
 
-     void ChangeFlag(int flag, bool set);
 
-     void SetFlag(int flag);
 
-     void ClearFlag(int flag);
 
-     void ToggleFlag(int flag);
 
-     virtual void SetResizeable(bool resizable)
 
-         { ChangeFlag(wxCOL_RESIZABLE, resizable); }
 
-     virtual void SetSortable(bool sortable)
 
-         { ChangeFlag(wxCOL_SORTABLE, sortable); }
 
-     virtual void SetReorderable(bool reorderable)
 
-         { ChangeFlag(wxCOL_REORDERABLE, reorderable); }
 
-     virtual void SetHidden(bool hidden)
 
-         { ChangeFlag(wxCOL_HIDDEN, hidden); }
 
-     // This function can be called to indicate that this column is not used for
 
-     // sorting any more. Under some platforms it's not necessary to do anything
 
-     // in this case as just setting another column as a sort key takes care of
 
-     // everything but under MSW we currently need to call this explicitly to
 
-     // reset the sort indicator displayed on the column.
 
-     virtual void UnsetAsSortKey() { }
 
-     virtual void SetSortOrder(bool ascending) = 0;
 
-     void ToggleSortOrder() { SetSortOrder(!IsSortOrderAscending()); }
 
- protected:
 
-     // helper for the class overriding individual SetXXX() methods instead of
 
-     // overriding SetFlags()
 
-     void SetIndividualFlags(int flags);
 
- };
 
- // ----------------------------------------------------------------------------
 
- // wxHeaderColumnSimple: trivial generic implementation of wxHeaderColumn
 
- // ----------------------------------------------------------------------------
 
- class wxHeaderColumnSimple : public wxSettableHeaderColumn
 
- {
 
- public:
 
-     // ctors and dtor
 
-     wxHeaderColumnSimple(const wxString& title,
 
-                          int width = wxCOL_WIDTH_DEFAULT,
 
-                          wxAlignment align = wxALIGN_NOT,
 
-                          int flags = wxCOL_DEFAULT_FLAGS)
 
-         : m_title(title),
 
-           m_width(width),
 
-           m_align(align),
 
-           m_flags(flags)
 
-     {
 
-         Init();
 
-     }
 
-     wxHeaderColumnSimple(const wxBitmap& bitmap,
 
-                          int width = wxCOL_WIDTH_DEFAULT,
 
-                          wxAlignment align = wxALIGN_CENTER,
 
-                          int flags = wxCOL_DEFAULT_FLAGS)
 
-         : m_bitmap(bitmap),
 
-           m_width(width),
 
-           m_align(align),
 
-           m_flags(flags)
 
-     {
 
-         Init();
 
-     }
 
-     // implement base class pure virtuals
 
-     virtual void SetTitle(const wxString& title) { m_title = title; }
 
-     virtual wxString GetTitle() const { return m_title; }
 
-     virtual void SetBitmap(const wxBitmap& bitmap) { m_bitmap = bitmap; }
 
-     wxBitmap GetBitmap() const { return m_bitmap; }
 
-     virtual void SetWidth(int width) { m_width = width; }
 
-     virtual int GetWidth() const { return m_width; }
 
-     virtual void SetMinWidth(int minWidth) { m_minWidth = minWidth; }
 
-     virtual int GetMinWidth() const { return m_minWidth; }
 
-     virtual void SetAlignment(wxAlignment align) { m_align = align; }
 
-     virtual wxAlignment GetAlignment() const { return m_align; }
 
-     virtual void SetFlags(int flags) { m_flags = flags; }
 
-     virtual int GetFlags() const { return m_flags; }
 
-     virtual bool IsSortKey() const { return m_sort; }
 
-     virtual void UnsetAsSortKey() { m_sort = false; }
 
-     virtual void SetSortOrder(bool ascending)
 
-     {
 
-         m_sort = true;
 
-         m_sortAscending = ascending;
 
-     }
 
-     virtual bool IsSortOrderAscending() const { return m_sortAscending; }
 
- private:
 
-     // common part of all ctors
 
-     void Init()
 
-     {
 
-         m_minWidth = 0;
 
-         m_sort = false;
 
-         m_sortAscending = true;
 
-     }
 
-     wxString m_title;
 
-     wxBitmap m_bitmap;
 
-     int m_width,
 
-         m_minWidth;
 
-     wxAlignment m_align;
 
-     int m_flags;
 
-     bool m_sort,
 
-          m_sortAscending;
 
- };
 
- #endif // wxUSE_HEADERCTRL
 
- #endif // _WX_HEADERCOL_H_
 
 
  |