2 * Treeview class extra info
4 * Copyright 1998 Eric Kohl
5 * Copyright 1998 Alex Priem
8 #ifndef __WINE_TREEVIEW_H
9 #define __WINE_TREEVIEW_H
13 #define MINIMUM_INDENT 10
14 #define TV_REFRESH_DELAY 100 /* 100 ms delay between two refreshes */
15 #define TV_DEFAULTITEMHEIGHT 16
16 #define TVITEM_ALLOC 16 /* default nr of items to allocate at first try */
19 /* internal structures */
33 int iLevel
; /* indentation level:0=root level */
35 HTREEITEM parent
; /* handle to parent or 0 if at root*/
36 HTREEITEM firstChild
; /* handle to first child or 0 if no child*/
37 HTREEITEM sibling
; /* handle to next item in list, 0 if last */
38 HTREEITEM upsibling
; /* handle to previous item in list, 0 if first */
42 RECT expandBox
; /* expand box (+/-) coordinate */
46 typedef struct tagTREEVIEW_INFO
49 UINT bAutoSize
; /* merge with uInternalStatus */
51 UINT uNumItems
; /* number of valid TREEVIEW_ITEMs */
53 HTREEITEM uMaxHandle
; /* needed for delete_item */
54 HTREEITEM TopRootItem
; /* handle to first item in treeview */
55 INT cdmode
; /* last custom draw setting */
56 UINT uItemHeight
; /* item height, -1 for default item height */
57 UINT uRealItemHeight
;/* current item height in pixels */
58 UINT uVisibleHeight
; /* visible height of treeview in pixels */
59 UINT uTotalHeight
; /* total height of treeview in pixels */
62 UINT uIndent
; /* indentation in pixels */
63 HTREEITEM selectedItem
; /* handle to selected item or 0 if none */
64 HTREEITEM focusItem
; /* handle to item that has focus, 0 if none */
65 HTREEITEM hotItem
; /* handle currently under cursor, 0 if none */
66 HTREEITEM editItem
; /* handle to item currently editted, 0 if none */
67 HTREEITEM firstVisible
; /* handle to first visible item */
68 HTREEITEM dropItem
; /* handle to item selected by drag cursor */
69 HIMAGELIST dragList
; /* Bitmap of dragged item */
70 INT cx
,cy
; /* current x/y place in list */
78 WNDPROC wpEditOrig
; /* needed for subclassing edit control */
79 HIMAGELIST himlNormal
;
81 LPTVSORTCB pCallBackSort
; /* ptr to TVSORTCB struct for callback sorting */
82 TREEVIEW_ITEM
*items
; /* itemlist */
83 INT
*freeList
; /* bitmap indicating which elements are valid */
84 /* 1=valid, 0=free; */
85 /* size of list= uNumPtrsAlloced/32 */
90 /* bitflags for infoPtr->uInternalStatus */
92 #define TV_HSCROLL 0x01 /* treeview too large to fit in window */
93 #define TV_VSCROLL 0x02 /* (horizontal/vertical) */
94 #define TV_LDRAG 0x04 /* Lbutton pushed to start drag */
95 #define TV_LDRAGGING 0x08 /* Lbutton pushed, mouse moved. */
96 #define TV_RDRAG 0x10 /* dito Rbutton */
97 #define TV_RDRAGGING 0x20
99 /* bitflags for infoPtr->timer */
101 #define TV_REFRESH_TIMER 1
102 #define TV_EDIT_TIMER 2
103 #define TV_REFRESH_TIMER_SET 1
104 #define TV_EDIT_TIMER_SET 2
107 extern VOID
TREEVIEW_Register (VOID
);
108 extern VOID
TREEVIEW_Unregister (VOID
);
110 #endif /* __WINE_TREEVIEW_H */