#define PIXELS_PER_UNIT 10
+// ----------------------------------------------------------------------------
+// Aqua arrows
+// ----------------------------------------------------------------------------
+
+ /* XPM */
+ static char *aqua_arrow_right[] = {
+ /* columns rows colors chars-per-pixel */
+ "13 11 4 1",
+ " c None",
+ "b c #C0C0C0",
+ "c c #707070",
+ "d c #A0A0A0",
+ /* pixels */
+ " b ",
+ " ddb ",
+ " cccdb ",
+ " cccccd ",
+ " ccccccdb ",
+ " ccccccccd",
+ " ccccccdb ",
+ " cccccb ",
+ " cccdb ",
+ " ddb ",
+ " b "
+ };
+
+ /* XPM */
+ static char *aqua_arrow_down[] = {
+ /* columns rows colors chars-per-pixel */
+ "13 11 4 1",
+ " c None",
+ "b c #C0C0C0",
+ "c c #707070",
+ "d c #A0A0A0",
+ /* pixels */
+ " ",
+ " ",
+ " bdcccccccdb ",
+ " dcccccccd ",
+ " bcccccccb ",
+ " dcccccd ",
+ " bcccccb ",
+ " bcccd ",
+ " dcd ",
+ " bcb ",
+ " d "
+ };
+
// -----------------------------------------------------------------------------
// private classes
// -----------------------------------------------------------------------------
style |= wxTR_AQUA_BUTTONS;
#endif
+ if (style & wxTR_AQUA_BUTTONS)
+ {
+ m_arrowRight = new wxBitmap( aqua_arrow_right );
+ m_arrowDown = new wxBitmap( aqua_arrow_down );
+ }
+ else
+ {
+ m_arrowRight = NULL;
+ m_arrowDown = NULL;
+ }
wxScrolledWindow::Create( parent, id, pos, size,
style|wxHSCROLL|wxVSCROLL, name );
{
delete m_hilightBrush;
delete m_hilightUnfocusedBrush;
+
+ if (m_arrowRight) delete m_arrowRight;
+ if (m_arrowDown) delete m_arrowDown;
DeleteAllItems();
m_anchor = new wxGenericTreeItem((wxGenericTreeItem *)NULL, text,
image, selImage, data);
+ if ( data != NULL )
+ {
+ data->m_pItem = (long) m_anchor;
+ }
+
if (HasFlag(wxTR_HIDE_ROOT))
{
// if root is hidden, make sure we can navigate
m_anchor->SetHasPlus();
Expand(m_anchor);
}
- if ( data != NULL )
- {
- data->m_pItem = (long) m_anchor;
- }
if (!HasFlag(wxTR_MULTIPLE))
{
void wxGenericTreeCtrl::UnselectAll()
{
- UnselectAllChildren((wxGenericTreeItem*) GetRootItem().m_pItem);
+ wxTreeItemId rootItem = GetRootItem();
+
+ // the tree might not have the root item at all
+ if ( rootItem )
+ {
+ UnselectAllChildren((wxGenericTreeItem*) rootItem.m_pItem);
+ }
}
// Recursive function !
{
// draw the twisty button here
- wxPoint button[3];
- dc.SetBrush(*m_hilightBrush);
-
if (HasFlag(wxTR_AQUA_BUTTONS))
{
- dc.SetPen(*wxTRANSPARENT_PEN);
-
if (item->IsExpanded())
- {
- button[0].x = x-6;
- button[0].y = y_mid-2;
- button[1].x = x+6;
- button[1].y = y_mid-2;
- button[2].x = x;
- button[2].y = y_mid+7;
- }
+ dc.DrawBitmap( *m_arrowDown, x-5, y_mid-6, TRUE );
else
- {
- button[0].y = y_mid-6;
- button[0].x = x-2;
- button[1].y = y_mid+6;
- button[1].x = x-2;
- button[2].y = y_mid;
- button[2].x = x+7;
- }
+ dc.DrawBitmap( *m_arrowRight, x-5, y_mid-6, TRUE );
}
else
{
+ dc.SetBrush(*m_hilightBrush);
dc.SetPen(*wxBLACK_PEN);
+ wxPoint button[3];
if (item->IsExpanded())
{
button[2].y = y_mid;
button[2].x = x+3;
}
+ dc.DrawPolygon(3, button);
+ dc.SetPen(m_dottedPen);
}
- dc.DrawPolygon(3, button);
-
- dc.SetPen(m_dottedPen);
}
else // if (HasFlag(wxTR_HAS_BUTTONS))
{