if ((point.x >= m_x) && (point.x <= m_x+m_width))
{
- int image_w,image_h;
-
+ int image_w = -1;
+ int image_h;
+
// assuming every image (normal and selected ) has the same size !
- theTree->m_imageListNormal->GetSize(m_image, image_w, image_h);
- if (point.x<=m_x+image_w+1)
+ if ((m_image!=-1) && theTree->m_imageListNormal)
+ theTree->m_imageListNormal->GetSize(m_image, image_w, image_h);
+
+ if ((image_w != -1) && (point.x <= m_x + image_w + 1))
flags|=wxTREE_HITTEST_ONITEMICON;
- else
+ else
flags|=wxTREE_HITTEST_ONITEMLABEL;
return this;
void wxTreeCtrl::Init()
{
- m_current =
+ m_current =
m_key_current =
m_anchor = (wxGenericTreeItem *) NULL;
m_hasFocus = FALSE;
wxScrolledWindow::Create( parent, id, pos, size, style|wxHSCROLL|wxVSCROLL, name );
+#if wxUSE_VALIDATORS
SetValidator( validator );
+#endif
SetBackgroundColour( *wxWHITE );
- m_dottedPen = wxPen( *wxBLACK, 0, 0 );
+ m_dottedPen = wxPen( "GREY", 0, wxDOT );
return TRUE;
}
{
item->SetHilight(FALSE);
RefreshLine(item);
-
+
if (item->HasChildren())
{
wxArrayGenericTreeItems& children = item->GetChildren();
// To stop we must have crt_item<last_item
// Algorithm :
// Tag all next children, when no more children,
-// Move to parent (not to tag)
+// Move to parent (not to tag)
// Keep going... if we found last_item, we stop.
bool wxTreeCtrl::TagNextChildren(wxGenericTreeItem *crt_item, wxGenericTreeItem *last_item, bool select)
{
size_t count = children.Count();
for (size_t n=(size_t)(index+1); n<count; ++n)
- if (TagAllChildrenUntilLast(children[n], last_item, select)) return true;
+ if (TagAllChildrenUntilLast(children[n], last_item, select)) return TRUE;
return TagNextChildren(parent, last_item, select);
}
{
crt_item->SetHilight(select);
RefreshLine(crt_item);
-
- if (crt_item==last_item) return true;
+
+ if (crt_item==last_item) return TRUE;
if (crt_item->HasChildren())
{
wxArrayGenericTreeItems& children = crt_item->GetChildren();
size_t count = children.Count();
for ( size_t n = 0; n < count; ++n )
- if (TagAllChildrenUntilLast(children[n], last_item, select)) return true;
+ if (TagAllChildrenUntilLast(children[n], last_item, select)) return TRUE;
}
-
- return false;
+
+ return FALSE;
}
void wxTreeCtrl::SelectItemRange(wxGenericTreeItem *item1, wxGenericTreeItem *item2)
wxGenericTreeItem *first=NULL, *last=NULL;
// choice first' and 'last' between item1 and item2
- if (item1->GetY()<item2->GetY())
+ if (item1->GetY()<item2->GetY())
{
first=item1;
last=item2;
}
- else
+ else
{
first=item2;
last=item1;
}
bool select=m_current->HasHilight();
-
+
if (TagAllChildrenUntilLast(first,last,select)) return;
- TagNextChildren(first,last,select);
+ TagNextChildren(first,last,select);
}
-void wxTreeCtrl::SelectItem(const wxTreeItemId& itemId,
- bool unselect_others,
+void wxTreeCtrl::SelectItem(const wxTreeItemId& itemId,
+ bool unselect_others,
bool extended_select)
-{
+{
+ wxCHECK_RET( itemId.IsOk(), _T("invalid tree item") );
+
bool is_single=!(GetWindowStyleFlag() & wxTR_MULTIPLE);
//wxCHECK_RET( ( (!unselect_others) && is_single),
// _T("this is a single selection tree") );
// to keep going anyhow !!!
- if (is_single)
+ if (is_single)
{
- unselect_others=true;
- extended_select=false;
+ unselect_others=TRUE;
+ extended_select=FALSE;
}
wxGenericTreeItem *item = itemId.m_pItem;
-
+
wxTreeEvent event( wxEVT_COMMAND_TREE_SEL_CHANGING, GetId() );
event.m_item = item;
event.m_itemOld = m_current;
event.SetEventObject( this );
// TODO : Here we don't send any selection mode yet !
-
+
if ( GetEventHandler()->ProcessEvent( event ) && event.WasVetoed() )
return;
}
// shift press
- if (extended_select)
+ if (extended_select)
{
if (m_current == NULL) m_current=m_key_current=GetRootItem().m_pItem;
// don't change the mark (m_current)
}
else
{
- bool select=true; // the default
+ bool select=TRUE; // the default
// Check if we need to toggle hilight (ctrl mode)
if (!unselect_others)
}
void wxTreeCtrl::EnsureVisible(const wxTreeItemId& item)
-{
+{
if (!item.IsOk()) return;
wxGenericTreeItem *gitem = item.m_pItem;
{
m_imageListNormal->GetSize(i, width, height);
if(height > m_lineHeight) m_lineHeight = height;
- }
+ }
if (m_lineHeight<40) m_lineHeight+=4; // at least 4 pixels (odd such that a line can be drawn in between)
else m_lineHeight+=m_lineHeight/10; // otherwise 10% extra spacing
if (GetWindowStyleFlag() & wxTR_HAS_VARIABLE_ROW_HIGHT)
return item->GetHeight();
else
- return m_lineHeight;
+ return m_lineHeight;
}
void wxTreeCtrl::PaintItem(wxGenericTreeItem *item, wxDC& dc)
dc.SetPen( *wxGREY_PEN );
dc.SetBrush( *wxWHITE_BRUSH );
dc.DrawRectangle( horizX+(m_indent-5), y-4, 11, 9 );
+
dc.SetPen( *wxBLACK_PEN );
dc.DrawLine( horizX+(m_indent-2), y, horizX+(m_indent+3), y );
-
if (!item->IsExpanded())
- {
dc.DrawLine( horizX+m_indent, y-2, horizX+m_indent, y+3 );
- }
+
+ dc.SetPen( m_dottedPen );
}
if (item->HasHilight())
PaintItem(item, dc);
- dc.SetPen( *wxBLACK_PEN );
+ dc.SetPen( m_dottedPen );
dc.SetTextForeground( *wxBLACK );
dc.SetBrush( *wxWHITE_BRUSH );
}
PaintItem(item, dc);
- dc.SetPen( *wxBLACK_PEN );
+ dc.SetPen( m_dottedPen );
}
}
-
+
y = oldY+GetLineHeight(item);
if (item->IsExpanded())
wxPaintDC dc(this);
PrepareDC( dc );
dc.SetLogicalFunction(wxINVERT);
-
+
int w,h,y;
GetSize(&w,&h);
if (point.x>w) flags|=wxTREE_HITTEST_TORIGHT;
if (point.y<0) flags|=wxTREE_HITTEST_ABOVE;
if (point.y>h) flags|=wxTREE_HITTEST_BELOW;
-
+
return m_anchor->HitTest( wxPoint(x, y), this, flags);
}
}
void wxTreeCtrl::CalculateSize( wxGenericTreeItem *item, wxDC &dc )
-{
+{
long text_w = 0;
long text_h = 0;
// TODO : check for boldness. Here with suppose that font normal and bold
int horizX = level*m_indent;
CalculateSize( item, dc );
-
+
// set its position
item->SetX( horizX+m_indent+m_spacing );
item->SetY( y );