// Name: treelay.h
// Purpose: wxTreeLayout class
// Author: Julian Smart
-// Modified by:
+// Modified by:
// Created: 7/4/98
// RCS-ID: $Id$
// Copyright: (c) 1998 Julian Smart
#endif
// For compilers that support precompilation, includes "wx.h".
-#include <wx/wxprec.h>
+#include "wx/wxprec.h"
#ifdef __BORLANDC__
#pragma hdrstop
#endif
#ifndef WX_PRECOMP
-#include <wx/wx.h>
+#include "wx/dc.h"
+#include "wx/event.h"
#endif
#if wxUSE_TREELAYOUT
-#include <wx/treelay.h>
+#include "wx/treelay.h"
/*
* Abstract tree
{
if (topId != -1)
SetTopNode(topId);
-
+
long actualTopId = GetTopNode();
long id = actualTopId;
while (id != -1)
}
void wxTreeLayout::DrawNodes(wxDC& dc)
-{
+{
long id = GetTopNode();
while (id != -1)
{
}
void wxTreeLayout::DrawBranches(wxDC& dc)
-{
+{
long id = GetTopNode();
while (id != -1)
{
void wxTreeLayout::DrawNode(long id, wxDC& dc)
{
- char buf[80];
+ wxChar buf[80];
wxString name(GetNodeName(id));
- if (name != "")
- sprintf(buf, "%s", (const char*) name);
+ if (name != wxT(""))
+ wxSprintf(buf, wxT("%s"), (const wxChar*) name);
else
- sprintf(buf, "<unnamed>");
-
+ wxSprintf(buf, wxT("<unnamed>"));
+
long x = 80;
long y = 20;
dc.GetTextExtent(buf, &x, &y);
void wxTreeLayout::GetNodeSize(long id, long *x, long *y, wxDC& dc)
{
wxString name(GetNodeName(id));
- if (name != "")
+ if (name != wxT(""))
dc.GetTextExtent(name, x, y);
else
{
{
wxList children;
GetChildren(nodeId, children);
- int n = children.Number();
-
+ int n = children.GetCount();
+
if (m_orientation == FALSE)
{
// Left to right
GetNodeSize(parentId, &x, &y, dc);
SetNodeX(nodeId, (long)(GetNodeX(parentId) + m_xSpacing + x));
}
-
- wxNode *node = children.First();
+
+ wxNode *node = children.GetFirst();
while (node)
{
- CalcLayout((long)node->Data(), level+1, dc);
- node = node->Next();
+ CalcLayout((long)node->GetData(), level+1, dc);
+ node = node->GetNext();
}
-
+
// Y Calculations
long averageY;
ActivateNode(nodeId, TRUE);
-
+
if (n > 0)
{
averageY = 0;
- node = children.First();
+ node = children.GetFirst();
while (node)
{
- averageY += GetNodeY((long)node->Data());
- node = node->Next();
+ averageY += GetNodeY((long)node->GetData());
+ node = node->GetNext();
}
averageY = averageY / n;
SetNodeY(nodeId, averageY);
SetNodeY(nodeId, m_lastY);
long x, y;
GetNodeSize(nodeId, &x, &y, dc);
-
+
m_lastY = m_lastY + y + m_ySpacing;
}
}
else
{
// Top to bottom
-
+
// Y Calculations
if (level == 0)
SetNodeY(nodeId, m_topMargin);
GetNodeSize(parentId, &x, &y, dc);
SetNodeY(nodeId, (long)(GetNodeY(parentId) + m_ySpacing + y));
}
-
- wxNode *node = children.First();
+
+ wxNode *node = children.GetFirst();
while (node)
{
- CalcLayout((long)node->Data(), level+1, dc);
- node = node->Next();
+ CalcLayout((long)node->GetData(), level+1, dc);
+ node = node->GetNext();
}
-
+
// X Calculations
long averageX;
ActivateNode(nodeId, TRUE);
-
+
if (n > 0)
{
averageX = 0;
- node = children.First();
+ node = children.GetFirst();
while (node)
{
- averageX += GetNodeX((long)node->Data());
- node = node->Next();
+ averageX += GetNodeX((long)node->GetData());
+ node = node->GetNext();
}
averageX = averageX / n;
SetNodeX(nodeId, averageX);
SetNodeX(nodeId, m_lastX);
long x, y;
GetNodeSize(nodeId, &x, &y, dc);
-
+
m_lastX = m_lastX + x + m_xSpacing;
}
}
int i;
for (i = 0; i < n; i++)
{
- m_nodes[i].m_name = "";
+ m_nodes[i].m_name = wxT("");
m_nodes[i].m_active = FALSE;
m_nodes[i].m_parentId = -1;
m_nodes[i].m_x = 0;
if (m_num < (m_maxNodes -1 ))
{
long i = -1;
- if (parent != "")
+ if (parent != wxT(""))
i = NameToId(parent);
else m_parentNode = m_num;
+
+ m_nodes[m_num].m_parentId = i;
+ m_nodes[m_num].m_name = name;
+ m_nodes[m_num].m_x = m_nodes[m_num].m_y = 0;
+ m_nodes[m_num].m_clientData = 0;
+ m_num ++;
+
+ return (m_num - 1);
+ }
+ else
+ return -1;
+}
+
+long wxTreeLayoutStored::AddChild(const wxString& name, long parent)
+{
+ if (m_num < (m_maxNodes -1 ) && parent < m_num)
+ {
+ long i = -1;
+ if (parent != -1)
+ {
+ i = parent;
+ }
+ else
+ {
+ m_parentNode = m_num;
+ }
m_nodes[m_num].m_parentId = i;
m_nodes[m_num].m_name = name;
wxStoredNode* wxTreeLayoutStored::GetNode(long idx) const
{
wxASSERT(idx < m_num);
-
+
return &m_nodes[idx];
};
long wxTreeLayoutStored::GetNodeX(long id)
{
wxASSERT(id < m_num);
-
+
return (long)m_nodes[id].m_x;
}
long wxTreeLayoutStored::GetNodeY(long id)
{
wxASSERT(id < m_num);
-
+
return (long)m_nodes[id].m_y;
}
void wxTreeLayoutStored::SetNodeX(long id, long x)
{
wxASSERT(id < m_num);
-
+
m_nodes[id].m_x = (int)x;
}
void wxTreeLayoutStored::SetNodeY(long id, long y)
{
wxASSERT(id < m_num);
-
+
m_nodes[id].m_y = (int)y;
}
void wxTreeLayoutStored::SetNodeName(long id, const wxString& name)
{
wxASSERT(id < m_num);
-
+
m_nodes[id].m_name = name;
}
wxString wxTreeLayoutStored::GetNodeName(long id)
{
wxASSERT(id < m_num);
-
+
return m_nodes[id].m_name;
}
if (id != -1)
{
wxASSERT(id < m_num);
-
+
return m_nodes[id].m_parentId;
}
else
long wxTreeLayoutStored::GetNextNode(long id)
{
wxASSERT(id < m_num);
-
+
if ((id != -1) && (id < (m_num - 1)))
return id + 1;
else
void wxTreeLayoutStored::SetClientData(long id, long clientData)
{
wxASSERT(id < m_num);
-
+
m_nodes[id].m_clientData = clientData;
}
long wxTreeLayoutStored::GetClientData(long id) const
{
wxASSERT(id < m_num);
-
+
return m_nodes[id].m_clientData;
}
void wxTreeLayoutStored::ActivateNode(long id, bool active)
{
wxASSERT(id < m_num);
-
+
m_nodes[id].m_active = active;
}
bool wxTreeLayoutStored::NodeActive(long id)
{
wxASSERT(id < m_num);
-
+
return m_nodes[id].m_active;
}
wxPoint pt = event.GetPosition();
wxCoord x = pt.x;
wxCoord y = pt.y;
-
+
int i;
for (i = 0; i < m_maxNodes; i++)
{
- wxStoredNode* item = &m_nodes[i];
-
long width, height;
dc.GetTextExtent(m_nodes[i].m_name, &width, &height);
-
+
if ( (x >= (m_nodes[i].m_x-10)) && (x < (m_nodes[i].m_x + width+10)) &&
(y >= m_nodes[i].m_y-10) && (y < (m_nodes[i].m_y + height+10)) )
{
return m_nodes[i].m_name;
}
}
-
- return wxString("");
+
+ return wxString( wxT("") );
}
#endif