git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@22133
c3d73ce0-8a6f-49c7-b76d-
6d57e0e08775
// is this a valid tree item?
bool IsOk() const { return m_pItem != 0; }
// is this a valid tree item?
bool IsOk() const { return m_pItem != 0; }
- // deprecated: only for compatibility
- operator wxTreeItemIdValue() const { return m_pItem; }
+ // operations
+ // invalidate the item
+ void Unset() { m_pItem = 0; }
+
+#if WXWIN_COMPATIBILITY_2_4
+ // deprecated: only for compatibility, don't work on 64 bit archs
+ wxTreeItemId(long item) { m_pItem = (wxTreeItemIdValue)item; }
+ operator long() const { return (long)m_pItem; }
+#endif // WXWIN_COMPATIBILITY_2_4
wxTreeItemIdValue m_pItem;
};
wxTreeItemIdValue m_pItem;
};
-WX_DEFINE_EXPORTED_ARRAY_NO_PTR(wxTreeItemId, wxArrayTreeItemIds);
+WX_DEFINE_EXPORTED_ARRAY_NO_PTR(wxTreeItemIdValue, wxArrayTreeItemIdsBase);
+
+class WXDLLEXPORT wxArrayTreeItemIds : public wxArrayTreeItemIdsBase
+{
+public:
+ void Add(const wxTreeItemId& id)
+ { wxArrayTreeItemIdsBase::Add(id.m_pItem); }
+};
// ----------------------------------------------------------------------------
// constants
// ----------------------------------------------------------------------------
// constants
#define TVM_SETTEXTCOLOR (TV_FIRST + 30)
#endif
#define TVM_SETTEXTCOLOR (TV_FIRST + 30)
#endif
-// a macro to hide the cast ugliness
-#define HITEM(item) (HTREEITEM)((item).m_pItem)
+// macros to hide the cast ugliness
+// --------------------------------
+
+// ptr is the real item id, i.e. wxTreeItemId::m_pItem
+#define HITEM_PTR(ptr) (HTREEITEM)(ptr)
+
+// item here is a wxTreeItemId
+#define HITEM(item) HITEM_PTR((item).m_pItem)
// the native control doesn't support multiple selections under MSW and we
// have 2 ways to emulate them: either using TVS_CHECKBOXES style and let
// the native control doesn't support multiple selections under MSW and we
// have 2 ways to emulate them: either using TVS_CHECKBOXES style and let
m_textCtrl = NULL;
m_hasAnyAttr = false;
m_dragImage = NULL;
m_textCtrl = NULL;
m_hasAnyAttr = false;
m_dragImage = NULL;
m_pVirtualRoot = NULL;
// initialize the global array of events now as it can't be done statically
m_pVirtualRoot = NULL;
// initialize the global array of events now as it can't be done statically
wxColour wxTreeCtrl::GetItemTextColour(const wxTreeItemId& item) const
{
wxColour wxTreeCtrl::GetItemTextColour(const wxTreeItemId& item) const
{
- wxMapTreeAttr::const_iterator it = m_attrs.find(item);
+ wxMapTreeAttr::const_iterator it = m_attrs.find(item.m_pItem);
return it == m_attrs.end() ? wxNullColour : it->second->GetTextColour();
}
wxColour wxTreeCtrl::GetItemBackgroundColour(const wxTreeItemId& item) const
{
return it == m_attrs.end() ? wxNullColour : it->second->GetTextColour();
}
wxColour wxTreeCtrl::GetItemBackgroundColour(const wxTreeItemId& item) const
{
- wxMapTreeAttr::const_iterator it = m_attrs.find(item);
+ wxMapTreeAttr::const_iterator it = m_attrs.find(item.m_pItem);
return it == m_attrs.end() ? wxNullColour : it->second->GetBackgroundColour();
}
wxFont wxTreeCtrl::GetItemFont(const wxTreeItemId& item) const
{
return it == m_attrs.end() ? wxNullColour : it->second->GetBackgroundColour();
}
wxFont wxTreeCtrl::GetItemFont(const wxTreeItemId& item) const
{
- wxMapTreeAttr::const_iterator it = m_attrs.find(item);
+ wxMapTreeAttr::const_iterator it = m_attrs.find(item.m_pItem);
return it == m_attrs.end() ? wxNullFont : it->second->GetFont();
}
return it == m_attrs.end() ? wxNullFont : it->second->GetFont();
}
const wxColour& col)
{
wxTreeItemAttr *attr;
const wxColour& col)
{
wxTreeItemAttr *attr;
- wxMapTreeAttr::iterator it = m_attrs.find(item);
+ wxMapTreeAttr::iterator it = m_attrs.find(item.m_pItem);
if ( it == m_attrs.end() )
{
m_hasAnyAttr = true;
if ( it == m_attrs.end() )
{
m_hasAnyAttr = true;
+ m_attrs[item.m_pItem] =
attr = new wxTreeItemAttr;
}
else
attr = new wxTreeItemAttr;
}
else
const wxColour& col)
{
wxTreeItemAttr *attr;
const wxColour& col)
{
wxTreeItemAttr *attr;
- wxMapTreeAttr::iterator it = m_attrs.find(item);
+ wxMapTreeAttr::iterator it = m_attrs.find(item.m_pItem);
if ( it == m_attrs.end() )
{
m_hasAnyAttr = true;
if ( it == m_attrs.end() )
{
m_hasAnyAttr = true;
+ m_attrs[item.m_pItem] =
attr = new wxTreeItemAttr;
}
else // already in the hash
attr = new wxTreeItemAttr;
}
else // already in the hash
void wxTreeCtrl::SetItemFont(const wxTreeItemId& item, const wxFont& font)
{
wxTreeItemAttr *attr;
void wxTreeCtrl::SetItemFont(const wxTreeItemId& item, const wxFont& font)
{
wxTreeItemAttr *attr;
- wxMapTreeAttr::iterator it = m_attrs.find(item);
+ wxMapTreeAttr::iterator it = m_attrs.find(item.m_pItem);
if ( it == m_attrs.end() )
{
m_hasAnyAttr = true;
if ( it == m_attrs.end() )
{
m_hasAnyAttr = true;
+ m_attrs[item.m_pItem] =
attr = new wxTreeItemAttr;
}
else // already in the hash
attr = new wxTreeItemAttr;
}
else // already in the hash
wxTreeItemId wxTreeCtrl::GetSelection() const
{
wxTreeItemId wxTreeCtrl::GetSelection() const
{
- wxCHECK_MSG( !(m_windowStyle & wxTR_MULTIPLE), NULL,
+ wxCHECK_MSG( !(m_windowStyle & wxTR_MULTIPLE), wxTreeItemId(),
wxT("this only works with single selection controls") );
return wxTreeItemId(TreeView_GetSelection(GetHwnd()));
wxT("this only works with single selection controls") );
return wxTreeItemId(TreeView_GetSelection(GetHwnd()));
- return DoInsertItem(wxTreeItemId(), 0,
+ return DoInsertItem(wxTreeItemId(), wxTreeItemId(),
text, image, selectedImage, data);
}
text, image, selectedImage, data);
}
size_t nCount = children.Count();
for ( size_t n = 0; n < nCount; n++ )
{
size_t nCount = children.Count();
for ( size_t n = 0; n < nCount; n++ )
{
- if ( !TreeView_DeleteItem(GetHwnd(), HITEM(children[n])) )
+ if ( !TreeView_DeleteItem(GetHwnd(), HITEM_PTR(children[n])) )
{
wxLogLastError(wxT("TreeView_DeleteItem"));
}
{
wxLogLastError(wxT("TreeView_DeleteItem"));
}
for ( size_t n = 0; n < count; n++ )
{
#if wxUSE_CHECKBOXES_IN_MULTI_SEL_TREE
for ( size_t n = 0; n < count; n++ )
{
#if wxUSE_CHECKBOXES_IN_MULTI_SEL_TREE
- SetItemCheck(selections[n], false);
+ SetItemCheck(HITEM_PTR(selections[n]), false);
#else // !wxUSE_CHECKBOXES_IN_MULTI_SEL_TREE
#else // !wxUSE_CHECKBOXES_IN_MULTI_SEL_TREE
- ::UnselectItem(GetHwnd(), HITEM(selections[n]));
+ ::UnselectItem(GetHwnd(), HITEM_PTR(selections[n]));
#endif // wxUSE_CHECKBOXES_IN_MULTI_SEL_TREE/!wxUSE_CHECKBOXES_IN_MULTI_SEL_TREE
}
}
#endif // wxUSE_CHECKBOXES_IN_MULTI_SEL_TREE/!wxUSE_CHECKBOXES_IN_MULTI_SEL_TREE
}
}
::SetFocus(GetHwnd(), htItem);
// reset on any click without Shift
::SetFocus(GetHwnd(), htItem);
// reset on any click without Shift
size_t count = GetSelections(selections);
if ( count == 0 ||
count > 1 ||
size_t count = GetSelections(selections);
if ( count == 0 ||
count > 1 ||
- HITEM(selections[0]) != htItem )
+ HITEM_PTR(selections[0]) != htItem )
{
// clear the previously selected items, if the
// user clicked outside of the present selection.
{
// clear the previously selected items, if the
// user clicked outside of the present selection.
}
// reset on any click without Shift
}
// reset on any click without Shift
{
// TreeView_GetItemRect() will return false if item is not visible,
// which may happen perfectly well
{
// TreeView_GetItemRect() will return false if item is not visible,
// which may happen perfectly well
- if ( TreeView_GetItemRect(GetHwnd(), HITEM(selections[n]),
+ if ( TreeView_GetItemRect(GetHwnd(), HITEM_PTR(selections[n]),
&rect, true) )
{
::InvalidateRect(GetHwnd(), &rect, false);
&rect, true) )
{
::InvalidateRect(GetHwnd(), &rect, false);