Main Page Class Hierarchy Alphabetical List Compound List File List Compound Members
|
00001 /******************************************************************************** 00002 * * 00003 * T r e e L i s t B o x W i d g e t * 00004 * * 00005 ********************************************************************************* 00006 * Copyright (C) 1999,2006 by Jeroen van der Zijp. All Rights Reserved. * 00007 ********************************************************************************* 00008 * This library is free software; you can redistribute it and/or * 00009 * modify it under the terms of the GNU Lesser General Public * 00010 * License as published by the Free Software Foundation; either * 00011 * version 2.1 of the License, or (at your option) any later version. * 00012 * * 00013 * This library is distributed in the hope that it will be useful, * 00014 * but WITHOUT ANY WARRANTY; without even the implied warranty of * 00015 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * 00016 * Lesser General Public License for more details. * 00017 * * 00018 * You should have received a copy of the GNU Lesser General Public * 00019 * License along with this library; if not, write to the Free Software * 00020 * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA. * 00021 ********************************************************************************* 00022 * $Id: FXTreeListBox.h,v 1.41 2006/01/22 17:58:11 fox Exp $ * 00023 ********************************************************************************/ 00024 #ifndef FXTREELISTBOX_H 00025 #define FXTREELISTBOX_H 00026 00027 #ifndef FXPACKER_H 00028 #include "FXPacker.h" 00029 #endif 00030 00031 namespace FX { 00032 00033 00034 /// Tree List Box styles 00035 enum { 00036 TREELISTBOX_NORMAL = 0 /// Normal style 00037 }; 00038 00039 00040 class FXButton; 00041 class FXMenuButton; 00042 class FXTreeList; 00043 class FXPopup; 00044 00045 00046 /** 00047 * The Tree List Box behaves very much like a List Box, except that 00048 * it supports a hierarchical, tree structured display of the items. 00049 * When an item is selected it issues a SEL_COMMAND message with the 00050 * pointer to the item. While manipulating the tree list, it may send 00051 * SEL_CHANGED messages to indicate which item the cursor is hovering over. 00052 */ 00053 class FXAPI FXTreeListBox : public FXPacker { 00054 FXDECLARE(FXTreeListBox) 00055 protected: 00056 FXButton *field; 00057 FXMenuButton *button; 00058 FXTreeList *tree; 00059 FXPopup *pane; 00060 protected: 00061 FXTreeListBox(){} 00062 private: 00063 FXTreeListBox(const FXTreeListBox&); 00064 FXTreeListBox& operator=(const FXTreeListBox&); 00065 public: 00066 long onFocusUp(FXObject*,FXSelector,void*); 00067 long onFocusDown(FXObject*,FXSelector,void*); 00068 long onFocusSelf(FXObject*,FXSelector,void*); 00069 long onMouseWheel(FXObject*,FXSelector,void*); 00070 long onFieldButton(FXObject*,FXSelector,void*); 00071 long onTreeUpdate(FXObject*,FXSelector,void*); 00072 long onTreeChanged(FXObject*,FXSelector,void*); 00073 long onTreeClicked(FXObject*,FXSelector,void*); 00074 public: 00075 enum{ 00076 ID_TREE=FXPacker::ID_LAST, 00077 ID_FIELD, 00078 ID_LAST 00079 }; 00080 public: 00081 00082 /// Construct tree list box 00083 FXTreeListBox(FXComposite *p,FXObject* tgt=NULL,FXSelector sel=0,FXuint opts=FRAME_SUNKEN|FRAME_THICK|TREELISTBOX_NORMAL,FXint x=0,FXint y=0,FXint w=0,FXint h=0,FXint pl=DEFAULT_PAD,FXint pr=DEFAULT_PAD,FXint pt=DEFAULT_PAD,FXint pb=DEFAULT_PAD); 00084 00085 /// Create server-side resources 00086 virtual void create(); 00087 00088 /// Detach server-side resources 00089 virtual void detach(); 00090 00091 /// Destroy server-side resources 00092 virtual void destroy(); 00093 00094 /// Perform layout 00095 virtual void layout(); 00096 00097 /// Enable widget 00098 virtual void enable(); 00099 00100 /// Disable widget 00101 virtual void disable(); 00102 00103 /// Return default with 00104 virtual FXint getDefaultWidth(); 00105 00106 /// Return default height 00107 virtual FXint getDefaultHeight(); 00108 00109 /// Return number of items 00110 FXint getNumItems() const; 00111 00112 /// Return number of visible items 00113 FXint getNumVisible() const; 00114 00115 /// Set number of visible items to determine default height 00116 void setNumVisible(FXint nvis); 00117 00118 /// Return first top-level item 00119 FXTreeItem* getFirstItem() const; 00120 00121 /// Return last top-level item 00122 FXTreeItem* getLastItem() const; 00123 00124 /// Fill tree list box by appending items from array of strings 00125 FXint fillItems(FXTreeItem* father,const FXchar** strings,FXIcon* oi=NULL,FXIcon* ci=NULL,void* ptr=NULL); 00126 00127 /// Fill tree list box by appending items from newline separated strings 00128 FXint fillItems(FXTreeItem* father,const FXString& strings,FXIcon* oi=NULL,FXIcon* ci=NULL,void* ptr=NULL); 00129 00130 /// Insert [possibly subclassed] item under father before other item 00131 FXTreeItem* insertItem(FXTreeItem* other,FXTreeItem* father,FXTreeItem* item); 00132 00133 /// Insert item with given text and optional icons, and user-data pointer under father before other item 00134 FXTreeItem* insertItem(FXTreeItem* other,FXTreeItem* father,const FXString& text,FXIcon* oi=NULL,FXIcon* ci=NULL,void* ptr=NULL); 00135 00136 /// Append [possibly subclassed] item as last child of father 00137 FXTreeItem* appendItem(FXTreeItem* father,FXTreeItem* item); 00138 00139 /// Append item with given text and optional icons, and user-data pointer as last child of father 00140 FXTreeItem* appendItem(FXTreeItem* father,const FXString& text,FXIcon* oi=NULL,FXIcon* ci=NULL,void* ptr=NULL); 00141 00142 /// Prepend [possibly subclassed] item as first child of father 00143 FXTreeItem* prependItem(FXTreeItem* father,FXTreeItem* item); 00144 00145 /// Prepend item with given text and optional icons, and user-data pointer as first child of father 00146 FXTreeItem* prependItem(FXTreeItem* father,const FXString& text,FXIcon* oi=NULL,FXIcon* ci=NULL,void* ptr=NULL); 00147 00148 /// Move item under father before other item 00149 FXTreeItem *moveItem(FXTreeItem* other,FXTreeItem* father,FXTreeItem* item); 00150 00151 /// Extract item 00152 FXTreeItem* extractItem(FXTreeItem* item); 00153 00154 /// Remove item 00155 void removeItem(FXTreeItem* item); 00156 00157 /// Remove all items in range [fm...to] 00158 void removeItems(FXTreeItem* fm,FXTreeItem* to); 00159 00160 /// Remove all items from list 00161 void clearItems(); 00162 00163 /** 00164 * Search items by name, beginning from item start. If the 00165 * start item is NULL the search will start at the first, top-most item 00166 * in the list. Flags may be SEARCH_FORWARD or SEARCH_BACKWARD to control 00167 * the search direction; this can be combined with SEARCH_NOWRAP or SEARCH_WRAP 00168 * to control whether the search wraps at the start or end of the list. 00169 * The option SEARCH_IGNORECASE causes a case-insensitive match. Finally, 00170 * passing SEARCH_PREFIX causes searching for a prefix of the item name. 00171 * Return NULL if no matching item is found. 00172 */ 00173 FXTreeItem* findItem(const FXString& text,FXTreeItem* start=NULL,FXuint flags=SEARCH_FORWARD|SEARCH_WRAP) const; 00174 00175 /** 00176 * Search items by associated user data, beginning from item start. If the 00177 * start item is NULL the search will start at the first, top-most item 00178 * in the list. Flags may be SEARCH_FORWARD or SEARCH_BACKWARD to control 00179 * the search direction; this can be combined with SEARCH_NOWRAP or SEARCH_WRAP 00180 * to control whether the search wraps at the start or end of the list. 00181 */ 00182 FXTreeItem* findItemByData(const void *ptr,FXTreeItem* start=NULL,FXuint flags=SEARCH_FORWARD|SEARCH_WRAP) const; 00183 00184 /// Return TRUE if item is the current item 00185 FXbool isItemCurrent(const FXTreeItem* item) const; 00186 00187 /// Return TRUE if item is leaf-item, i.e. has no children 00188 FXbool isItemLeaf(const FXTreeItem* item) const; 00189 00190 /// Sort the toplevel items with the sort function 00191 void sortRootItems(); 00192 00193 /// Sort all items recursively 00194 void sortItems(); 00195 00196 /// Sort child items of item 00197 void sortChildItems(FXTreeItem* item); 00198 00199 /// Change current item 00200 virtual void setCurrentItem(FXTreeItem* item,FXbool notify=FALSE); 00201 00202 /// Return current item 00203 FXTreeItem* getCurrentItem() const; 00204 00205 /// Change item label 00206 void setItemText(FXTreeItem* item,const FXString& text); 00207 00208 /// Return item label 00209 FXString getItemText(const FXTreeItem* item) const; 00210 00211 /// Change item's open icon, delete old one if it was owned 00212 void setItemOpenIcon(FXTreeItem* item,FXIcon* icon,FXbool owned=FALSE); 00213 00214 /// Return item's open icon 00215 FXIcon* getItemOpenIcon(const FXTreeItem* item) const; 00216 00217 /// Change item's closed icon, delete old one if it was owned 00218 void setItemClosedIcon(FXTreeItem* item,FXIcon* icon,FXbool owned=FALSE); 00219 00220 /// Return item's closed icon 00221 FXIcon* getItemClosedIcon(const FXTreeItem* item) const; 00222 00223 /// Change item's user data 00224 void setItemData(FXTreeItem* item,void* ptr) const; 00225 00226 /// Return item's user data 00227 void* getItemData(const FXTreeItem* item) const; 00228 00229 /// Return item sort function 00230 FXTreeListSortFunc getSortFunc() const; 00231 00232 /// Change item sort function 00233 void setSortFunc(FXTreeListSortFunc func); 00234 00235 /// Is the pane shown 00236 FXbool isPaneShown() const; 00237 00238 /// Change font 00239 void setFont(FXFont* fnt); 00240 00241 /// Return font 00242 FXFont* getFont() const; 00243 00244 /// Return list style 00245 FXuint getListStyle() const; 00246 00247 /// Change list style 00248 void setListStyle(FXuint style); 00249 00250 /// Change help text 00251 void setHelpText(const FXString& txt); 00252 00253 /// Return help text 00254 const FXString& getHelpText() const; 00255 00256 /// Change tip text 00257 void setTipText(const FXString& txt); 00258 00259 /// Return tip text 00260 const FXString& getTipText() const; 00261 00262 /// Save object to a stream 00263 virtual void save(FXStream& store) const; 00264 00265 /// Load object from a stream 00266 virtual void load(FXStream& store); 00267 00268 /// Destructor 00269 virtual ~FXTreeListBox(); 00270 }; 00271 00272 } 00273 00274 #endif
Copyright © 1997-2005 Jeroen van der Zijp |