Main Page Class Hierarchy Alphabetical List Compound List File List Compound Members
|
00001 /******************************************************************************** 00002 * * 00003 * C o m b o B o x W i d g e t * 00004 * * 00005 ********************************************************************************* 00006 * Copyright (C) 1997,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: FXComboBox.h,v 1.46 2006/01/27 02:07:44 fox Exp $ * 00023 ********************************************************************************/ 00024 #ifndef FXCOMBOBOX_H 00025 #define FXCOMBOBOX_H 00026 00027 #ifndef FXPACKER_H 00028 #include "FXPacker.h" 00029 #endif 00030 00031 namespace FX { 00032 00033 00034 /// ComboBox styles 00035 enum { 00036 COMBOBOX_NO_REPLACE = 0, /// Leave the list the same 00037 COMBOBOX_REPLACE = 0x00020000, /// Replace current item with typed text 00038 COMBOBOX_INSERT_BEFORE = 0x00040000, /// Typed text inserted before current 00039 COMBOBOX_INSERT_AFTER = 0x00060000, /// Typed text inserted after current 00040 COMBOBOX_INSERT_FIRST = 0x00080000, /// Typed text inserted at begin of list 00041 COMBOBOX_INSERT_LAST = 0x00090000, /// Typed text inserted at end of list 00042 COMBOBOX_STATIC = 0x00100000, /// Unchangable text box 00043 COMBOBOX_NORMAL = 0 /// Can type text but list is not changed 00044 }; 00045 00046 00047 class FXTextField; 00048 class FXMenuButton; 00049 class FXList; 00050 class FXPopup; 00051 00052 00053 /** 00054 * A Combo Box provides a way to select a string from a list of strings. 00055 * Unless COMBOBOX_STATIC is passed, it also allows the user to enter a new 00056 * string into the text field, for example if the desired entry is not in the 00057 * list of strings. Passing COMBOBOX_REPLACE, COMBOBOX_INSERT_BEFORE, COMBOBOX_INSERT_AFTER, 00058 * COMBOBOX_INSERT_FIRST, or COMBOBOX_INSERT_LAST causes a newly entered text to replace the 00059 * current one in the list, or be added before or after the current entry, or to be added at 00060 * the beginning or end of the list. 00061 * Combo Box is intended to enter text; if you need to enter a choice from a list of 00062 * options, it is recommended that the List Box widget is used instead. 00063 * When the text in the field is changed, a SEL_COMMAND will be send to the target. 00064 * The Combo Box can also receive ID_GETSTRINGVALUE and ID_SETSTRINGVALUE and so 00065 * on, which will behave similar to Text Field in that they will retrieve or update 00066 * the value of the field. 00067 */ 00068 class FXAPI FXComboBox : public FXPacker { 00069 FXDECLARE(FXComboBox) 00070 protected: 00071 FXTextField *field; 00072 FXMenuButton *button; 00073 FXList *list; 00074 FXPopup *pane; 00075 protected: 00076 FXComboBox(){} 00077 private: 00078 FXComboBox(const FXComboBox&); 00079 FXComboBox &operator=(const FXComboBox&); 00080 public: 00081 long onFocusUp(FXObject*,FXSelector,void*); 00082 long onFocusDown(FXObject*,FXSelector,void*); 00083 long onFocusSelf(FXObject*,FXSelector,void*); 00084 long onMouseWheel(FXObject*,FXSelector,void*); 00085 long onTextButton(FXObject*,FXSelector,void*); 00086 long onTextChanged(FXObject*,FXSelector,void*); 00087 long onTextCommand(FXObject*,FXSelector,void*); 00088 long onListClicked(FXObject*,FXSelector,void*); 00089 long onFwdToText(FXObject*,FXSelector,void*); 00090 long onUpdFmText(FXObject*,FXSelector,void*); 00091 public: 00092 enum { 00093 ID_LIST=FXPacker::ID_LAST, 00094 ID_TEXT, 00095 ID_LAST 00096 }; 00097 public: 00098 00099 /// Construct a Combo Box widget with room to display cols columns of text 00100 FXComboBox(FXComposite *p,FXint cols,FXObject* tgt=NULL,FXSelector sel=0,FXuint opts=COMBOBOX_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); 00101 00102 /// Create server-side resources 00103 virtual void create(); 00104 00105 /// Detach server-side resources 00106 virtual void detach(); 00107 00108 /// Destroy server-side resources 00109 virtual void destroy(); 00110 00111 /// Enable combo box 00112 virtual void enable(); 00113 00114 /// Disable combo box 00115 virtual void disable(); 00116 00117 /// Return default width 00118 virtual FXint getDefaultWidth(); 00119 00120 /// Return default height 00121 virtual FXint getDefaultHeight(); 00122 00123 /// Perform layout 00124 virtual void layout(); 00125 00126 /// Return true if combobox is editable 00127 FXbool isEditable() const; 00128 00129 /// Set editable state 00130 void setEditable(FXbool edit=TRUE); 00131 00132 /// Set the text 00133 void setText(const FXString& text); 00134 00135 /// Get the text 00136 FXString getText() const; 00137 00138 /// Set the number of columns 00139 void setNumColumns(FXint cols); 00140 00141 /// Get the number of columns 00142 FXint getNumColumns() const; 00143 00144 /// Change text justification mode; default is JUSTIFY_LEFT 00145 void setJustify(FXuint mode); 00146 00147 /// Return text justification mode 00148 FXuint getJustify() const; 00149 00150 /// Return the number of items in the list 00151 FXint getNumItems() const; 00152 00153 /// Return the number of visible items 00154 FXint getNumVisible() const; 00155 00156 /// Set the number of visible items in the drop down list 00157 void setNumVisible(FXint nvis); 00158 00159 /// Return true if current item 00160 FXbool isItemCurrent(FXint index) const; 00161 00162 /// Set the current item (index is zero-based) 00163 void setCurrentItem(FXint index,FXbool notify=FALSE); 00164 00165 /// Get the current item's index 00166 FXint getCurrentItem() const; 00167 00168 /// Return the item at the given index 00169 FXString getItem(FXint index) const; 00170 00171 /// Replace the item at index 00172 FXint setItem(FXint index,const FXString& text,void* ptr=NULL); 00173 00174 /// Fill combo box by appending items from array of strings 00175 FXint fillItems(const FXchar** strings); 00176 00177 /// Fill combo box by appending items from newline separated strings 00178 FXint fillItems(const FXString& strings); 00179 00180 /// Insert a new item at index 00181 FXint insertItem(FXint index,const FXString& text,void* ptr=NULL); 00182 00183 /// Append an item to the list 00184 FXint appendItem(const FXString& text,void* ptr=NULL); 00185 00186 /// Prepend an item to the list 00187 FXint prependItem(const FXString& text,void* ptr=NULL); 00188 00189 /// Move item from oldindex to newindex 00190 FXint moveItem(FXint newindex,FXint oldindex); 00191 00192 /// Remove this item from the list 00193 void removeItem(FXint index); 00194 00195 /// Remove all items from the list 00196 void clearItems(); 00197 00198 /** 00199 * Search items by name, beginning from item start. If the start item 00200 * is -1 the search will start at the first item in the list. Flags 00201 * may be SEARCH_FORWARD or SEARCH_BACKWARD to control the search 00202 * direction; this can be combined with SEARCH_NOWRAP or SEARCH_WRAP 00203 * to control whether the search wraps at the start or end of the list. 00204 * The option SEARCH_IGNORECASE causes a case-insensitive match. Finally, 00205 * passing SEARCH_PREFIX causes searching for a prefix of the item name. 00206 * Return -1 if no matching item is found. 00207 */ 00208 FXint findItem(const FXString& text,FXint start=-1,FXuint flags=SEARCH_FORWARD|SEARCH_WRAP) const; 00209 00210 /** 00211 * Search items by associated user data, beginning from item start. If the 00212 * start item is -1 the search will start at the first item in the list. 00213 * Flags may be SEARCH_FORWARD or SEARCH_BACKWARD to control the 00214 * search direction; this can be combined with SEARCH_NOWRAP or SEARCH_WRAP 00215 * to control whether the search wraps at the start or end of the list. 00216 */ 00217 FXint findItemByData(const void *ptr,FXint start=-1,FXuint flags=SEARCH_FORWARD|SEARCH_WRAP) const; 00218 00219 /// Set text for specified item 00220 void setItemText(FXint index,const FXString& text); 00221 00222 /// Get text for specified item 00223 FXString getItemText(FXint index) const; 00224 00225 /// Set data pointer for specified item 00226 void setItemData(FXint index,void* ptr) const; 00227 00228 /// Get data pointer for specified item 00229 void* getItemData(FXint index) const; 00230 00231 /// Is the pane shown 00232 FXbool isPaneShown() const; 00233 00234 /// Sort items using current sort function 00235 void sortItems(); 00236 00237 /// Set text font 00238 void setFont(FXFont* fnt); 00239 00240 /// Get text font 00241 FXFont* getFont() const; 00242 00243 /// Set the combobox style. 00244 void setComboStyle(FXuint mode); 00245 00246 /// Get the combobox style. 00247 FXuint getComboStyle() const; 00248 00249 /// Set window background color 00250 virtual void setBackColor(FXColor clr); 00251 00252 /// Get background color 00253 FXColor getBackColor() const; 00254 00255 /// Change text color 00256 void setTextColor(FXColor clr); 00257 00258 /// Return text color 00259 FXColor getTextColor() const; 00260 00261 /// Change selected background color 00262 void setSelBackColor(FXColor clr); 00263 00264 /// Return selected background color 00265 FXColor getSelBackColor() const; 00266 00267 /// Change selected text color 00268 void setSelTextColor(FXColor clr); 00269 00270 /// Return selected text color 00271 FXColor getSelTextColor() const; 00272 00273 /// Return sort function 00274 FXListSortFunc getSortFunc() const; 00275 00276 /// Change sort function 00277 void setSortFunc(FXListSortFunc func); 00278 00279 /// Set the combobox help text 00280 void setHelpText(const FXString& txt); 00281 00282 /// Get the combobox help text 00283 const FXString& getHelpText() const; 00284 00285 /// Set the tool tip message for this combobox 00286 void setTipText(const FXString& txt); 00287 00288 /// Get the tool tip message for this combobox 00289 const FXString& getTipText() const; 00290 00291 /// Save combobox to a stream 00292 virtual void save(FXStream& store) const; 00293 00294 /// Load combobox from a stream 00295 virtual void load(FXStream& store); 00296 00297 /// Destructor 00298 virtual ~FXComboBox(); 00299 }; 00300 00301 } 00302 00303 #endif
Copyright © 1997-2005 Jeroen van der Zijp |