1 /////////////////////////////////////////////////////////////////////////////
 
   3 // Purpose:     SWIG interface file for wxListCtrl and related classes
 
   7 // Created:     10-June-1998
 
   9 // Copyright:   (c) 2002 by Total Control Software
 
  10 // Licence:     wxWindows license
 
  11 /////////////////////////////////////////////////////////////////////////////
 
  16 //---------------------------------------------------------------------------
 
  19 #include <wx/listctrl.h>
 
  22 MAKE_CONST_WXSTRING(ListCtrlNameStr);
 
  24 //---------------------------------------------------------------------------
 
  55     // Mask flags to tell app/GUI what fields of wxListItem are valid
 
  64 // State flags for indicating the state of an item
 
  65     wxLIST_STATE_DONTCARE,
 
  66     wxLIST_STATE_DROPHILITED,
 
  68     wxLIST_STATE_SELECTED,
 
  70     wxLIST_STATE_DISABLED,
 
  71     wxLIST_STATE_FILTERED,
 
  76 // Hit test flags, used in HitTest
 
  79     wxLIST_HITTEST_NOWHERE,
 
  80     wxLIST_HITTEST_ONITEMICON,
 
  81     wxLIST_HITTEST_ONITEMLABEL,
 
  82     wxLIST_HITTEST_ONITEMRIGHT,
 
  83     wxLIST_HITTEST_ONITEMSTATEICON,
 
  84     wxLIST_HITTEST_TOLEFT,
 
  85     wxLIST_HITTEST_TORIGHT,
 
  86     wxLIST_HITTEST_ONITEM,
 
  88 // GetSubItemRect constants    
 
  89     wxLIST_GETSUBITEMRECT_WHOLEITEM,
 
  93 // Flags for GetNextItem (MSW only except wxLIST_NEXT_ALL)
 
  96     wxLIST_NEXT_ABOVE,          // Searches for an item above the specified item
 
  97     wxLIST_NEXT_ALL,            // Searches for subsequent item by index
 
  98     wxLIST_NEXT_BELOW,          // Searches for an item below the specified item
 
  99     wxLIST_NEXT_LEFT,           // Searches for an item to the left of the specified item
 
 100     wxLIST_NEXT_RIGHT           // Searches for an item to the right of the specified item
 
 103 // Alignment flags for Arrange (MSW only except wxLIST_ALIGN_LEFT)
 
 106     wxLIST_ALIGN_DEFAULT,
 
 109     wxLIST_ALIGN_SNAP_TO_GRID
 
 112 // Column format (MSW only except wxLIST_FORMAT_LEFT)
 
 113 enum wxListColumnFormat
 
 117     wxLIST_FORMAT_CENTRE,
 
 118     wxLIST_FORMAT_CENTER = wxLIST_FORMAT_CENTRE
 
 121 // Autosize values for SetColumnWidth
 
 124     wxLIST_AUTOSIZE = -1,
 
 125     wxLIST_AUTOSIZE_USEHEADER = -2      // partly supported by generic version
 
 128 // Flag values for GetItemRect
 
 136 // Flag values for FindItem (MSW only)
 
 147 //---------------------------------------------------------------------------
 
 150 // wxListItemAttr: a structure containing the visual attributes of an item
 
 156     wxListItemAttr(const wxColour& colText = wxNullColour,
 
 157                    const wxColour& colBack = wxNullColour,
 
 158                    const wxFont& font = wxNullFont);
 
 162     void SetTextColour(const wxColour& colText);
 
 163     void SetBackgroundColour(const wxColour& colBack);
 
 164     void SetFont(const wxFont& font);
 
 167     bool HasTextColour();
 
 168     bool HasBackgroundColour();
 
 171     wxColour GetTextColour();
 
 172     wxColour GetBackgroundColour();
 
 175     void AssignFrom(const wxListItemAttr& source);
 
 177     %pythonPrepend Destroy "args[0].this.own(False)"
 
 178     %extend { void Destroy() { delete self; } }
 
 180     %property(BackgroundColour, GetBackgroundColour, SetBackgroundColour, doc="See `GetBackgroundColour` and `SetBackgroundColour`");
 
 181     %property(Font, GetFont, SetFont, doc="See `GetFont` and `SetFont`");
 
 182     %property(TextColour, GetTextColour, SetTextColour, doc="See `GetTextColour` and `SetTextColour`");
 
 188 //---------------------------------------------------------------------------
 
 192 // wxListItem: the item or column info, used to exchange data with wxListCtrl
 
 193 class wxListItem : public wxObject {
 
 200     void ClearAttributes();
 
 203     void SetMask(long mask);
 
 205     void SetColumn(int col);
 
 206     void SetState(long state);
 
 207     void SetStateMask(long stateMask);
 
 208     void SetText(const wxString& text);
 
 209     void SetImage(int image);
 
 210     void SetData(long data);
 
 212     void SetWidth(int width);
 
 213     void SetAlign(wxListColumnFormat align);
 
 215     void SetTextColour(const wxColour& colText);
 
 216     void SetBackgroundColour(const wxColour& colBack);
 
 217     void SetFont(const wxFont& font);
 
 224     const wxString& GetText();
 
 229     wxListColumnFormat GetAlign();
 
 231     wxListItemAttr *GetAttributes();
 
 232     bool HasAttributes();
 
 234     wxColour GetTextColour() const;
 
 235     wxColour GetBackgroundColour() const;
 
 236     wxFont GetFont() const;
 
 238     // these members are public for compatibility
 
 239     long            m_mask;     // Indicates what fields are valid
 
 240     long            m_itemId;   // The zero-based item position
 
 241     int             m_col;      // Zero-based column, if in report mode
 
 242     long            m_state;    // The state of the item
 
 243     long            m_stateMask;// Which flags of m_state are valid (uses same flags)
 
 244     wxString        m_text;     // The label/header text
 
 245     int             m_image;    // The zero-based index into an image list
 
 246     long            m_data;     // App-defined data
 
 249     int             m_format;   // left, right, centre
 
 250     int             m_width;    // width of column
 
 252     %property(Align, GetAlign, SetAlign, doc="See `GetAlign` and `SetAlign`");
 
 253     %property(Attributes, GetAttributes, doc="See `GetAttributes`");
 
 254     %property(BackgroundColour, GetBackgroundColour, SetBackgroundColour, doc="See `GetBackgroundColour` and `SetBackgroundColour`");
 
 255     %property(Column, GetColumn, SetColumn, doc="See `GetColumn` and `SetColumn`");
 
 256     %property(Data, GetData, SetData, doc="See `GetData` and `SetData`");
 
 257     %property(Font, GetFont, SetFont, doc="See `GetFont` and `SetFont`");
 
 258     %property(Id, GetId, SetId, doc="See `GetId` and `SetId`");
 
 259     %property(Image, GetImage, SetImage, doc="See `GetImage` and `SetImage`");
 
 260     %property(Mask, GetMask, SetMask, doc="See `GetMask` and `SetMask`");
 
 261     %property(State, GetState, SetState, doc="See `GetState` and `SetState`");
 
 262     %property(Text, GetText, SetText, doc="See `GetText` and `SetText`");
 
 263     %property(TextColour, GetTextColour, SetTextColour, doc="See `GetTextColour` and `SetTextColour`");
 
 264     %property(Width, GetWidth, SetWidth, doc="See `GetWidth` and `SetWidth`");
 
 268 //---------------------------------------------------------------------------
 
 272 // wxListEvent - the event class for the wxListCtrl notifications
 
 273 class wxListEvent: public wxNotifyEvent {
 
 275     wxListEvent(wxEventType commandType = wxEVT_NULL, int id = 0);
 
 287     %pythoncode { GetCode = GetKeyCode }
 
 291     %pythoncode { GetPosition = GetPoint }
 
 292     const wxString& GetLabel();
 
 293     const wxString& GetText();
 
 297     const wxListItem& GetItem();
 
 302     // was label editing canceled? (for wxEVT_COMMAND_LIST_END_LABEL_EDIT only)
 
 303     bool IsEditCancelled() const;
 
 304     void SetEditCanceled(bool editCancelled);
 
 306     %property(CacheFrom, GetCacheFrom, doc="See `GetCacheFrom`");
 
 307     %property(CacheTo, GetCacheTo, doc="See `GetCacheTo`");
 
 308     %property(Column, GetColumn, doc="See `GetColumn`");
 
 309     %property(Data, GetData, doc="See `GetData`");
 
 310     %property(Image, GetImage, doc="See `GetImage`");
 
 311     %property(Index, GetIndex, doc="See `GetIndex`");
 
 312     %property(Item, GetItem, doc="See `GetItem`");
 
 313     %property(KeyCode, GetKeyCode, doc="See `GetKeyCode`");
 
 314     %property(Label, GetLabel, doc="See `GetLabel`");
 
 315     %property(Mask, GetMask, doc="See `GetMask`");
 
 316     %property(Point, GetPoint, doc="See `GetPoint`");
 
 317     %property(Text, GetText, doc="See `GetText`");
 
 321 /* List control event types */
 
 322 %constant wxEventType wxEVT_COMMAND_LIST_BEGIN_DRAG;
 
 323 %constant wxEventType wxEVT_COMMAND_LIST_BEGIN_RDRAG;
 
 324 %constant wxEventType wxEVT_COMMAND_LIST_BEGIN_LABEL_EDIT;
 
 325 %constant wxEventType wxEVT_COMMAND_LIST_END_LABEL_EDIT;
 
 326 %constant wxEventType wxEVT_COMMAND_LIST_DELETE_ITEM;
 
 327 %constant wxEventType wxEVT_COMMAND_LIST_DELETE_ALL_ITEMS;
 
 328 %constant wxEventType wxEVT_COMMAND_LIST_ITEM_SELECTED;
 
 329 %constant wxEventType wxEVT_COMMAND_LIST_ITEM_DESELECTED;
 
 330 %constant wxEventType wxEVT_COMMAND_LIST_KEY_DOWN;
 
 331 %constant wxEventType wxEVT_COMMAND_LIST_INSERT_ITEM;
 
 332 %constant wxEventType wxEVT_COMMAND_LIST_COL_CLICK;
 
 333 %constant wxEventType wxEVT_COMMAND_LIST_ITEM_RIGHT_CLICK;
 
 334 %constant wxEventType wxEVT_COMMAND_LIST_ITEM_MIDDLE_CLICK;
 
 335 %constant wxEventType wxEVT_COMMAND_LIST_ITEM_ACTIVATED;
 
 336 %constant wxEventType wxEVT_COMMAND_LIST_CACHE_HINT;
 
 337 %constant wxEventType wxEVT_COMMAND_LIST_COL_RIGHT_CLICK;
 
 338 %constant wxEventType wxEVT_COMMAND_LIST_COL_BEGIN_DRAG;
 
 339 %constant wxEventType wxEVT_COMMAND_LIST_COL_DRAGGING;
 
 340 %constant wxEventType wxEVT_COMMAND_LIST_COL_END_DRAG;
 
 341 %constant wxEventType wxEVT_COMMAND_LIST_ITEM_FOCUSED;
 
 343 // WXWIN_COMPATIBILITY_2_4
 
 345 %constant wxEventType wxEVT_COMMAND_LIST_GET_INFO;
 
 346 %constant wxEventType wxEVT_COMMAND_LIST_SET_INFO;
 
 351 EVT_LIST_BEGIN_DRAG        = wx.PyEventBinder(wxEVT_COMMAND_LIST_BEGIN_DRAG       , 1)
 
 352 EVT_LIST_BEGIN_RDRAG       = wx.PyEventBinder(wxEVT_COMMAND_LIST_BEGIN_RDRAG      , 1)
 
 353 EVT_LIST_BEGIN_LABEL_EDIT  = wx.PyEventBinder(wxEVT_COMMAND_LIST_BEGIN_LABEL_EDIT , 1)
 
 354 EVT_LIST_END_LABEL_EDIT    = wx.PyEventBinder(wxEVT_COMMAND_LIST_END_LABEL_EDIT   , 1)
 
 355 EVT_LIST_DELETE_ITEM       = wx.PyEventBinder(wxEVT_COMMAND_LIST_DELETE_ITEM      , 1)
 
 356 EVT_LIST_DELETE_ALL_ITEMS  = wx.PyEventBinder(wxEVT_COMMAND_LIST_DELETE_ALL_ITEMS , 1)
 
 357 #WXWIN_COMPATIBILITY_2_4
 
 358 #EVT_LIST_GET_INFO          = wx.PyEventBinder(wxEVT_COMMAND_LIST_GET_INFO         , 1)
 
 359 #EVT_LIST_SET_INFO          = wx.PyEventBinder(wxEVT_COMMAND_LIST_SET_INFO         , 1)
 
 360 #END WXWIN_COMPATIBILITY_2_4
 
 361 EVT_LIST_ITEM_SELECTED     = wx.PyEventBinder(wxEVT_COMMAND_LIST_ITEM_SELECTED    , 1)
 
 362 EVT_LIST_ITEM_DESELECTED   = wx.PyEventBinder(wxEVT_COMMAND_LIST_ITEM_DESELECTED  , 1)
 
 363 EVT_LIST_KEY_DOWN          = wx.PyEventBinder(wxEVT_COMMAND_LIST_KEY_DOWN         , 1)
 
 364 EVT_LIST_INSERT_ITEM       = wx.PyEventBinder(wxEVT_COMMAND_LIST_INSERT_ITEM      , 1)
 
 365 EVT_LIST_COL_CLICK         = wx.PyEventBinder(wxEVT_COMMAND_LIST_COL_CLICK        , 1)
 
 366 EVT_LIST_ITEM_RIGHT_CLICK  = wx.PyEventBinder(wxEVT_COMMAND_LIST_ITEM_RIGHT_CLICK , 1)
 
 367 EVT_LIST_ITEM_MIDDLE_CLICK = wx.PyEventBinder(wxEVT_COMMAND_LIST_ITEM_MIDDLE_CLICK, 1)
 
 368 EVT_LIST_ITEM_ACTIVATED    = wx.PyEventBinder(wxEVT_COMMAND_LIST_ITEM_ACTIVATED   , 1)
 
 369 EVT_LIST_CACHE_HINT        = wx.PyEventBinder(wxEVT_COMMAND_LIST_CACHE_HINT       , 1)
 
 370 EVT_LIST_COL_RIGHT_CLICK   = wx.PyEventBinder(wxEVT_COMMAND_LIST_COL_RIGHT_CLICK  , 1)
 
 371 EVT_LIST_COL_BEGIN_DRAG    = wx.PyEventBinder(wxEVT_COMMAND_LIST_COL_BEGIN_DRAG   , 1)
 
 372 EVT_LIST_COL_DRAGGING      = wx.PyEventBinder(wxEVT_COMMAND_LIST_COL_DRAGGING     , 1)
 
 373 EVT_LIST_COL_END_DRAG      = wx.PyEventBinder(wxEVT_COMMAND_LIST_COL_END_DRAG     , 1)
 
 374 EVT_LIST_ITEM_FOCUSED      = wx.PyEventBinder(wxEVT_COMMAND_LIST_ITEM_FOCUSED     , 1)
 
 376 #WXWIN_COMPATIBILITY_2_4
 
 377 #EVT_LIST_GET_INFO = wx._deprecated(EVT_LIST_GET_INFO)
 
 378 #EVT_LIST_SET_INFO = wx._deprecated(EVT_LIST_SET_INFO)
 
 381 //---------------------------------------------------------------------------
 
 385 %{ // Python aware sorting function for wxPyListCtrl
 
 386     static int wxCALLBACK wxPyListCtrl_SortItems(long item1, long item2, long funcPtr) {
 
 388         PyObject* func = (PyObject*)funcPtr;
 
 389         wxPyBlock_t blocked = wxPyBeginBlockThreads();
 
 391         PyObject* args = Py_BuildValue("(ii)", item1, item2);
 
 392         PyObject* result = PyEval_CallObject(func, args);
 
 395             retval = PyInt_AsLong(result);
 
 399         wxPyEndBlockThreads(blocked);
 
 406 %{  // C++ Version of a Python aware class
 
 407 class wxPyListCtrl : public wxListCtrl {
 
 408     DECLARE_ABSTRACT_CLASS(wxPyListCtrl)
 
 410     wxPyListCtrl() : wxListCtrl() {}
 
 411     wxPyListCtrl(wxWindow* parent, wxWindowID id,
 
 415                  const wxValidator& validator,
 
 416                  const wxString& name) :
 
 417         wxListCtrl(parent, id, pos, size, style, validator, name) {}
 
 419     bool Create(wxWindow* parent, wxWindowID id,
 
 423                 const wxValidator& validator,
 
 424                 const wxString& name) {
 
 425         return wxListCtrl::Create(parent, id, pos, size, style, validator, name);
 
 428     DEC_PYCALLBACK_STRING_LONGLONG(OnGetItemText);
 
 429     DEC_PYCALLBACK_LISTATTR_LONG(OnGetItemAttr);
 
 431     // use the virtual version to avoid a confusing assert in the base class
 
 432     DEC_PYCALLBACK_INT_LONG_virtual(OnGetItemImage);
 
 433     DEC_PYCALLBACK_INT_LONGLONG(OnGetItemColumnImage);
 
 438 IMPLEMENT_ABSTRACT_CLASS(wxPyListCtrl, wxListCtrl);
 
 440 IMP_PYCALLBACK_STRING_LONGLONG(wxPyListCtrl, wxListCtrl, OnGetItemText);
 
 441 IMP_PYCALLBACK_LISTATTR_LONG(wxPyListCtrl, wxListCtrl, OnGetItemAttr);
 
 442 IMP_PYCALLBACK_INT_LONG_virtual(wxPyListCtrl, wxListCtrl, OnGetItemImage);
 
 443 IMP_PYCALLBACK_INT_LONGLONG(wxPyListCtrl, wxListCtrl, OnGetItemColumnImage); 
 
 449 // NOTE: The following option is set in _settings.i
 
 450 //     # Until the new native control for wxMac is up to par, still use the generic one.
 
 451 //     SystemOptions.SetOptionInt("mac.listctrl.always_use_generic", 1)
 
 453 MustHaveApp(wxPyListCtrl);
 
 455 %rename(ListCtrl) wxPyListCtrl;
 
 456 class wxPyListCtrl : public wxControl {
 
 459     %pythonAppend wxPyListCtrl         "self._setOORInfo(self);self._setCallbackInfo(self, ListCtrl)"
 
 460     %pythonAppend wxPyListCtrl()       ""
 
 462     wxPyListCtrl(wxWindow* parent, wxWindowID id = -1,
 
 463                  const wxPoint& pos = wxDefaultPosition,
 
 464                  const wxSize& size = wxDefaultSize,
 
 465                  long style = wxLC_ICON,
 
 466                  const wxValidator& validator = wxDefaultValidator,
 
 467                  const wxString& name = wxPyListCtrlNameStr);
 
 468     %RenameCtor(PreListCtrl, wxPyListCtrl());
 
 470     bool Create(wxWindow* parent, wxWindowID id = -1,
 
 471                  const wxPoint& pos = wxDefaultPosition,
 
 472                  const wxSize& size = wxDefaultSize,
 
 473                  long style = wxLC_ICON,
 
 474                  const wxValidator& validator = wxDefaultValidator,
 
 475                  const wxString& name = wxPyListCtrlNameStr);
 
 477     void _setCallbackInfo(PyObject* self, PyObject* _class);
 
 480     // Set the control colours
 
 481     bool SetForegroundColour(const wxColour& col);
 
 482     bool SetBackgroundColour(const wxColour& col);
 
 484     // Gets information about this column
 
 485     %pythonAppend GetColumn "if val is not None: val.thisown = 1";  // %newobject doesn't work with OOR typemap
 
 487         wxListItem* GetColumn(int col) {
 
 489             item.SetMask( wxLIST_MASK_STATE |
 
 497             if (self->GetColumn(col, item))
 
 498                 return new wxListItem(item);
 
 504     // Sets information about this column
 
 505     bool SetColumn(int col, wxListItem& item) ;
 
 507     // Gets the column width
 
 508     int GetColumnWidth(int col) const;
 
 510     // Sets the column width
 
 511     bool SetColumnWidth(int col, int width) ;
 
 513     // Gets the number of items that can fit vertically in the
 
 514     // visible area of the list control (list or report view)
 
 515     // or the total number of items in the list control (icon
 
 516     // or small icon view)
 
 517     int GetCountPerPage() const;
 
 519     // return the total area occupied by all the items (icon/small icon only)
 
 520     wxRect GetViewRect() const;
 
 522     // Gets the edit control for editing labels.
 
 523     wxTextCtrl* GetEditControl() const;
 
 525     // Gets information about the item
 
 526     %pythonAppend GetItem "if val is not None: val.thisown = 1";  // %newobject doesn't work with OOR typemap
 
 528         wxListItem* GetItem(long itemId, int col=0) {
 
 529             wxListItem* info = new wxListItem;
 
 530             info->m_itemId = itemId;
 
 532             info->m_mask = 0xFFFF;
 
 533             self->GetItem(*info);
 
 538     // Sets information about the item
 
 539     bool SetItem(wxListItem& info) ;
 
 541     // Sets a string field at a particular column
 
 542     %Rename(SetStringItem, long, SetItem(long index, int col, const wxString& label, int imageId = -1));
 
 544     // Gets the item state
 
 545     int  GetItemState(long item, long stateMask) const ;
 
 547     // Sets the item state
 
 548     bool SetItemState(long item, long state, long stateMask) ;
 
 550     // Sets the item image
 
 551     bool SetItemImage(long item, int image, int selImage=-1) ;
 
 552     bool SetItemColumnImage( long item, long column, int image );
 
 554     // Gets the item text
 
 555     wxString GetItemText(long item) const ;
 
 557     // Sets the item text
 
 558     void SetItemText(long item, const wxString& str) ;
 
 560     // Gets the item data
 
 561     long GetItemData(long item) const ;
 
 563     // Sets the item data
 
 564     bool SetItemData(long item, long data) ;
 
 567     //bool GetItemRect(long item, wxRect& rect, int code = wxLIST_RECT_BOUNDS) const ;
 
 568     //bool GetItemPosition(long item, wxPoint& pos) const ;
 
 570     // Gets the item position
 
 572         wxPoint GetItemPosition(long item) {
 
 574             self->GetItemPosition(item, pos);
 
 577         // Gets the item rectangle
 
 578         wxRect GetItemRect(long item, int code = wxLIST_RECT_BOUNDS) {
 
 580             self->GetItemRect(item, rect, code);
 
 584 // MSW only so far...        
 
 585 //         wxRect GetSubItemRect(long item, long subItem, int code = wxLIST_RECT_BOUNDS) {
 
 587 //             self->GetSubItemRect(item, subItem, rect, code);
 
 593     // Sets the item position
 
 594     bool SetItemPosition(long item, const wxPoint& pos) ;
 
 596     // Gets the number of items in the list control
 
 597     int GetItemCount() const;
 
 599     // Gets the number of columns in the list control
 
 600     int GetColumnCount() const;
 
 602     // get the horizontal and vertical components of the item spacing
 
 603     wxSize GetItemSpacing() const;
 
 604     %pythoncode { GetItemSpacing = wx._deprecated(GetItemSpacing) }
 
 607     void SetItemSpacing( int spacing, bool isSmall = false );
 
 608     %pythoncode { SetItemSpacing = wx._deprecated(SetItemSpacing) }
 
 611     // Gets the number of selected items in the list control
 
 612     int GetSelectedItemCount() const;
 
 614     // Gets the text colour of the listview
 
 615     wxColour GetTextColour() const;
 
 617     // Sets the text colour of the listview
 
 618     void SetTextColour(const wxColour& col);
 
 620     // Gets the index of the topmost visible item when in
 
 621     // list or report view
 
 622     long GetTopItem() const ;
 
 624     // Add or remove a single window style
 
 625     void SetSingleStyle(long style, bool add = true) ;
 
 627     // Set the whole window style
 
 628     void SetWindowStyleFlag(long style) ;
 
 630     // Searches for an item, starting from 'item'.
 
 631     // item can be -1 to find the first item that matches the
 
 633     // Returns the item or -1 if unsuccessful.
 
 634     long GetNextItem(long item, int geometry = wxLIST_NEXT_ALL, int state = wxLIST_STATE_DONTCARE) const ;
 
 636     // Gets one of the three image lists
 
 637     wxImageList *GetImageList(int which) const ;
 
 639     // Sets the image list
 
 640     void SetImageList(wxImageList *imageList, int which);
 
 642     %disownarg( wxImageList *imageList );
 
 643     void AssignImageList(wxImageList *imageList, int which);
 
 644     %cleardisown( wxImageList *imageList );
 
 646     // are we in report mode?
 
 647     bool InReportView() const;
 
 649     // returns True if it is a virtual list control
 
 650     bool IsVirtual() const;
 
 652     // refresh items selectively (only useful for virtual list controls)
 
 653     void RefreshItem(long item);
 
 654     void RefreshItems(long itemFrom, long itemTo);
 
 656     // Arranges the items
 
 657     bool Arrange(int flag = wxLIST_ALIGN_DEFAULT);
 
 660     bool DeleteItem(long item);
 
 663     bool DeleteAllItems() ;
 
 666     bool DeleteColumn(int col);
 
 668     // Deletes all columns
 
 669     bool DeleteAllColumns();
 
 671     // Clears items, and columns if there are any.
 
 676     wxTextCtrl* EditLabel(long item /*, wxClassInfo* textControlClass = CLASSINFO(wxTextCtrl)*/);
 
 678     // End label editing, optionally cancelling the edit
 
 679     bool EndEditLabel(bool cancel);
 
 681     void EditLabel(long item);
 
 684     // Ensures this item is visible
 
 685     bool EnsureVisible(long item) ;
 
 687     // Find an item whose label matches this string, starting from the item after 'start'
 
 688     // or the beginning if 'start' is -1.
 
 689     long FindItem(long start, const wxString& str, bool partial = false);
 
 691     // Find an item whose data matches this data, starting from the item after 'start'
 
 692     // or the beginning if 'start' is -1.
 
 693     %Rename(FindItemData,  long, FindItem(long start, long data));
 
 695     // Find an item nearest this position in the specified direction, starting from
 
 696     // the item after 'start' or the beginning if 'start' is -1.
 
 697     %Rename(FindItemAtPos,  long, FindItem(long start, const wxPoint& pt, int direction));
 
 701         long, HitTest(const wxPoint& point, int& OUTPUT),
 
 702         "HitTest(Point point) -> (item, where)",
 
 703         "Determines which item (if any) is at the specified point, giving
 
 704 details in the second return value (see wx.LIST_HITTEST flags.)", "");
 
 707         long, HitTest(const wxPoint& point, int& OUTPUT, long* OUTPUT),
 
 708         "HitTestSubItem(Point point) -> (item, where, subItem)",
 
 709         "Determines which item (if any) is at the specified point, giving details in
 
 710 the second return value (see wx.LIST_HITTEST flags) and also the subItem, if
 
 715     // Inserts an item, returning the index of the new item if successful,
 
 717     long InsertItem(wxListItem& info);
 
 719     // Insert a string item
 
 720     %Rename(InsertStringItem,
 
 721             long, InsertItem(long index, const wxString& label, int imageIndex=-1));
 
 723     // Insert an image item
 
 724     %Rename(InsertImageItem,
 
 725             long, InsertItem(long index, int imageIndex));
 
 727     // Insert an image/string item
 
 728     %Rename(InsertImageStringItem,
 
 729             long, InsertItem(long index, const wxString& label, int imageIndex));
 
 731     // For list view mode (only), inserts a column.
 
 732     %Rename(InsertColumnItem,  long, InsertColumn(long col, wxListItem& info));
 
 733     %pythoncode { InsertColumnInfo = InsertColumnItem }
 
 735     long InsertColumn(long col,
 
 736                       const wxString& heading,
 
 737                       int format = wxLIST_FORMAT_LEFT,
 
 740     // set the number of items in a virtual list control
 
 741     void SetItemCount(long count);
 
 743     // Scrolls the list control. If in icon, small icon or report view mode,
 
 744     // x specifies the number of pixels to scroll. If in list view mode, x
 
 745     // specifies the number of columns to scroll.
 
 746     // If in icon, small icon or list view mode, y specifies the number of pixels
 
 747     // to scroll. If in report view mode, y specifies the number of lines to scroll.
 
 748     bool ScrollList(int dx, int dy);
 
 750     void SetItemTextColour( long item, const wxColour& col);
 
 751     wxColour GetItemTextColour( long item ) const;
 
 752     void SetItemBackgroundColour( long item, const wxColour &col);
 
 753     wxColour GetItemBackgroundColour( long item ) const;
 
 756     void SetItemFont( long item, const wxFont &f);
 
 757     wxFont GetItemFont( long item ) const;
 
 762     def Select(self, idx, on=1):
 
 763         '''[de]select an item'''
 
 764         if on: state = wx.LIST_STATE_SELECTED
 
 766         self.SetItemState(idx, state, wx.LIST_STATE_SELECTED)
 
 768     def Focus(self, idx):
 
 769         '''Focus and show the given item'''
 
 770         self.SetItemState(idx, wx.LIST_STATE_FOCUSED, wx.LIST_STATE_FOCUSED)
 
 771         self.EnsureVisible(idx)
 
 773     def GetFocusedItem(self):
 
 774         '''get the currently focused item or -1 if none'''
 
 775         return self.GetNextItem(-1, wx.LIST_NEXT_ALL, wx.LIST_STATE_FOCUSED)
 
 777     def GetFirstSelected(self, *args):
 
 778         '''return first selected item, or -1 when none'''
 
 779         return self.GetNextSelected(-1)
 
 781     def GetNextSelected(self, item):
 
 782         '''return subsequent selected items, or -1 when no more'''
 
 783         return self.GetNextItem(item, wx.LIST_NEXT_ALL, wx.LIST_STATE_SELECTED)
 
 785     def IsSelected(self, idx):
 
 786         '''return True if the item is selected'''
 
 787         return (self.GetItemState(idx, wx.LIST_STATE_SELECTED) & wx.LIST_STATE_SELECTED) != 0
 
 789     def SetColumnImage(self, col, image):
 
 790         item = self.GetColumn(col)
 
 791         %# preserve all other attributes too
 
 792         item.SetMask( wx.LIST_MASK_STATE |
 
 798                       wx.LIST_MASK_FORMAT )
 
 800         self.SetColumn(col, item)
 
 802     def ClearColumnImage(self, col):
 
 803         self.SetColumnImage(col, -1)
 
 805     def Append(self, entry):
 
 806         '''Append an item to the list control.  The entry parameter should be a
 
 807            sequence with an item for each column'''
 
 813             pos = self.GetItemCount()
 
 814             self.InsertStringItem(pos, cvtfunc(entry[0]))
 
 815             for i in range(1, len(entry)):
 
 816                 self.SetStringItem(pos, i, cvtfunc(entry[i]))
 
 821     // bool SortItems(wxListCtrlCompare fn, long data);
 
 824         // func is a function which takes 2 long arguments: item1, item2.
 
 825         // item1 is the long data associated with a first item (NOT the index).
 
 826         // item2 is the long data associated with a second item (NOT the index).
 
 827         // The return value is a negative number if the first item should precede the second
 
 828         // item, a positive number of the second item should precede the first,
 
 829         // or zero if the two items are equivalent.
 
 830         bool SortItems(PyObject* func) {
 
 831             if (!PyCallable_Check(func))
 
 833             return self->SortItems((wxListCtrlCompare)wxPyListCtrl_SortItems, (long)func);
 
 839         wxWindow* GetMainWindow() {
 
 840         #if defined(__WXMSW__) || defined(__WXMAC__)
 
 843             return (wxWindow*)self->m_mainWin;
 
 848     static wxVisualAttributes
 
 849     GetClassDefaultAttributes(wxWindowVariant variant = wxWINDOW_VARIANT_NORMAL);
 
 851     %property(ColumnCount, GetColumnCount, doc="See `GetColumnCount`");
 
 852     %property(CountPerPage, GetCountPerPage, doc="See `GetCountPerPage`");
 
 853     %property(EditControl, GetEditControl, doc="See `GetEditControl`");
 
 854     %property(FocusedItem, GetFocusedItem, doc="See `GetFocusedItem`");
 
 855     %property(ImageList, GetImageList, SetImageList, doc="See `GetImageList` and `SetImageList`");
 
 856     %property(ItemCount, GetItemCount, SetItemCount, doc="See `GetItemCount` and `SetItemCount`");
 
 857     %property(MainWindow, GetMainWindow, doc="See `GetMainWindow`");
 
 858     %property(SelectedItemCount, GetSelectedItemCount, doc="See `GetSelectedItemCount`");
 
 859     %property(TextColour, GetTextColour, SetTextColour, doc="See `GetTextColour` and `SetTextColour`");
 
 860     %property(TopItem, GetTopItem, doc="See `GetTopItem`");
 
 861     %property(ViewRect, GetViewRect, doc="See `GetViewRect`");
 
 866 //---------------------------------------------------------------------------
 
 870 MustHaveApp(wxListView);
 
 872 // wxListView: a class which provides a little better API for list control
 
 873 class wxListView : public wxPyListCtrl
 
 876     %pythonAppend wxListView         "self._setOORInfo(self)"
 
 877     %pythonAppend wxListView()       ""
 
 879     wxListView( wxWindow *parent,
 
 881                 const wxPoint& pos = wxDefaultPosition,
 
 882                 const wxSize& size = wxDefaultSize,
 
 883                 long style = wxLC_REPORT,
 
 884                 const wxValidator& validator = wxDefaultValidator,
 
 885                 const wxString& name = wxPyListCtrlNameStr);
 
 886     %RenameCtor(PreListView, wxListView());
 
 888     bool Create( wxWindow *parent,
 
 890                 const wxPoint& pos = wxDefaultPosition,
 
 891                 const wxSize& size = wxDefaultSize,
 
 892                 long style = wxLC_REPORT,
 
 893                 const wxValidator& validator = wxDefaultValidator,
 
 894                 const wxString& name = wxPyListCtrlNameStr);
 
 896     // [de]select an item
 
 897     void Select(long n, bool on = true);
 
 899     // focus and show the given item
 
 900     void Focus(long index);
 
 902     // get the currently focused item or -1 if none
 
 903     long GetFocusedItem() const;
 
 905     // get first and subsequent selected items, return -1 when no more
 
 906     long GetNextSelected(long item) const;
 
 907     long GetFirstSelected() const;
 
 909     // return True if the item is selected
 
 910     bool IsSelected(long index);
 
 912     void SetColumnImage(int col, int image);
 
 913     void ClearColumnImage(int col);
 
 915     %property(FocusedItem, GetFocusedItem, doc="See `GetFocusedItem`");
 
 920 //---------------------------------------------------------------------------
 
 923     // Map renamed classes back to their common name for OOR
 
 924     wxPyPtrTypeMap_Add("wxListCtrl", "wxPyListCtrl");
 
 927 //---------------------------------------------------------------------------