]>
git.saurik.com Git - wxWidgets.git/blob - interface/wx/textentry.h
   1 ///////////////////////////////////////////////////////////////////////////// 
   2 // Name:        wx/textentry.h 
   3 // Purpose:     interface of wxTextEntry 
   4 // Author:      Vadim Zeitlin 
   5 // Created:     2009-03-01 (extracted from wx/textctrl.h) 
   7 // Copyright:   (c) 2009 Vadim Zeitlin <vadim@wxwindows.org> 
   8 // Licence:     wxWindows licence 
   9 ///////////////////////////////////////////////////////////////////////////// 
  14     Common base class for single line text entry fields. 
  16     This class is not a control itself, as it doesn't derive from wxWindow. 
  17     Instead it is used as a base class by other controls, notably wxTextCtrl 
  18     and wxComboBox and gathers the methods common to both of them. 
  23     @see wxTextCtrl, wxComboBox 
  31         Appends the text to the end of the text control. 
  34             Text to write to the text control. 
  37             After the text is appended, the insertion point will be at the 
  38             end of the text control. If this behaviour is not desired, the 
  39             programmer should use GetInsertionPoint() and SetInsertionPoint(). 
  43     virtual void AppendText(const wxString
& text
); 
  46         Call this function to enable auto-completion of the text typed in a 
  47         single-line text control using the given @a choices. 
  49         Notice that currently this function is only implemented in wxGTK2, 
  50         wxMSW and wxOSX/Cocoa ports and does nothing under the other platforms. 
  55             @true if the auto-completion was enabled or @false if the operation 
  56             failed, typically because auto-completion is not supported by the 
  59         @see AutoCompleteFileNames() 
  61     bool AutoComplete(const wxArrayString
& choices
); 
  64         Enable auto-completion using the provided completer object. 
  66         This method should be used instead of AutoComplete() overload taking 
  67         the array of possible completions if the total number of strings is too 
  68         big as it allows to return the completions dynamically, depending on 
  69         the text already entered by user and so is more efficient. 
  71         The specified @a completer object will be used to retrieve the list of 
  72         possible completions for the already entered text and will be deleted 
  73         by wxTextEntry itself when it's not needed any longer. 
  75         Notice that you need to include @c wx/textcompleter.h in order to 
  76         define your class inheriting from wxTextCompleter. 
  78         Currently this method is only implemented in wxMSW and wxOSX/Cocoa. 
  83             The object to be used for generating completions if non-@NULL. If 
  84             it is @NULL, auto-completion is disabled. The wxTextEntry object 
  85             takes ownership of this pointer and will delete it in any case 
  86             (i.e. even if this method returns @false). 
  89             @true if the auto-completion was enabled or @false if the operation 
  90             failed, typically because auto-completion is not supported by the 
  95     bool AutoComplete(wxTextCompleter 
*completer
); 
  98         Call this function to enable auto-completion of the text typed in a 
  99         single-line text control using all valid file system paths. 
 101         Notice that currently this function is only implemented in wxMSW port 
 102         and does nothing under the other platforms. 
 107             @true if the auto-completion was enabled or @false if the operation 
 108             failed, typically because auto-completion is not supported by the 
 113     bool AutoCompleteFileNames(); 
 116         Call this function to enable auto-completion of the text using the file 
 119         Unlike AutoCompleteFileNames() which completes both file names and 
 120         directories, this function only completes the directory names. 
 122         Notice that currently this function is only implemented in wxMSW port 
 123         and does nothing under the other platforms. 
 128             @true if the auto-completion was enabled or @false if the operation 
 129             failed, typically because auto-completion is not supported by the 
 134     bool AutoCompleteDirectories(); 
 137         Returns @true if the selection can be copied to the clipboard. 
 139     virtual bool CanCopy() const; 
 142         Returns @true if the selection can be cut to the clipboard. 
 144     virtual bool CanCut() const; 
 147         Returns @true if the contents of the clipboard can be pasted into the 
 150         On some platforms (Motif, GTK) this is an approximation and returns 
 151         @true if the control is editable, @false otherwise. 
 153     virtual bool CanPaste() const; 
 156         Returns @true if there is a redo facility available and the last 
 157         operation can be redone. 
 159     virtual bool CanRedo() const; 
 162         Returns @true if there is an undo facility available and the last 
 163         operation can be undone. 
 165     virtual bool CanUndo() const; 
 168         Sets the new text control value. 
 170         It also marks the control as not-modified which means that IsModified() 
 171         would return @false immediately after the call to ChangeValue(). 
 173         The insertion point is set to the start of the control (i.e. position 
 176         This functions does not generate the @c wxEVT_COMMAND_TEXT_UPDATED 
 177         event but otherwise is identical to SetValue(). 
 179         See @ref overview_events_prog for more information. 
 184             The new value to set. It may contain newline characters if the text 
 185             control is multi-line. 
 187     virtual void ChangeValue(const wxString
& value
); 
 190         Clears the text in the control. 
 192         Note that this function will generate a @c wxEVT_COMMAND_TEXT_UPDATED 
 193         event, i.e. its effect is identical to calling @c SetValue(""). 
 195     virtual void Clear(); 
 198         Copies the selected text to the clipboard. 
 203         Returns the insertion point, or cursor, position. 
 205         This is defined as the zero based index of the character position to 
 206         the right of the insertion point. For example, if the insertion point 
 207         is at the end of the single-line text control, it is equal to both 
 208         GetLastPosition() and @c "GetValue().Length()" (but notice that the latter 
 209         equality is not necessarily true for multiline edit controls which may 
 210         use multiple new line characters). 
 212         The following code snippet safely returns the character at the insertion 
 213         point or the zero character if the point is at the end of the control. 
 216         char GetCurrentChar(wxTextCtrl *tc) { 
 217             if (tc->GetInsertionPoint() == tc->GetLastPosition()) 
 219             return tc->GetValue[tc->GetInsertionPoint()]; 
 223     virtual long GetInsertionPoint() const; 
 226         Returns the zero based index of the last position in the text control, 
 227         which is equal to the number of characters in the control. 
 229     virtual wxTextPos 
GetLastPosition() const; 
 232         Returns the string containing the text starting in the positions 
 233         @a from and up to @a to in the control. 
 235         The positions must have been returned by another wxTextCtrl method. 
 236         Please note that the positions in a multiline wxTextCtrl do @b not 
 237         correspond to the indices in the string returned by GetValue() because 
 238         of the different new line representations (@c CR or @c CR LF) and so 
 239         this method should be used to obtain the correct results instead of 
 240         extracting parts of the entire value. It may also be more efficient, 
 241         especially if the control contains a lot of data. 
 243     virtual wxString 
GetRange(long from
, long to
) const; 
 246         Gets the current selection span. 
 248         If the returned values are equal, there was no selection. Please note 
 249         that the indices returned may be used with the other wxTextCtrl methods 
 250         but don't necessarily represent the correct indices into the string 
 251         returned by GetValue() for multiline controls under Windows (at least,) 
 252         you should use GetStringSelection() to get the selected text. 
 255             The returned first position. 
 257             The returned last position. 
 260         In wxPerl this method takes no parameters and returns a 
 261         2-element list (from, to). 
 264     virtual void GetSelection(long* from
, long* to
) const; 
 267         Gets the text currently selected in the control. 
 269         If there is no selection, the returned string is empty. 
 271     virtual wxString 
GetStringSelection() const; 
 274         Gets the contents of the control. 
 276         Notice that for a multiline text control, the lines will be separated 
 277         by (Unix-style) @c \\n characters, even under Windows where they are 
 278         separated by a @c \\r\\n sequence in the native control. 
 280     virtual wxString 
GetValue() const; 
 283         Returns @true if the controls contents may be edited by user (note that 
 284         it always can be changed by the program). 
 286         In other words, this functions returns @true if the control hasn't been 
 287         put in read-only mode by a previous call to SetEditable(). 
 289     virtual bool IsEditable() const; 
 292         Returns @true if the control is currently empty. 
 294         This is the same as @c GetValue().empty() but can be much more 
 295         efficient for the multiline controls containing big amounts of text. 
 299     virtual bool IsEmpty() const; 
 302         Pastes text from the clipboard to the text item. 
 304     virtual void Paste(); 
 307         If there is a redo facility and the last operation can be redone, 
 308         redoes the last operation. 
 310         Does nothing if there is no redo facility. 
 315         Removes the text starting at the first given position up to 
 316         (but not including) the character at the last position. 
 318         This function puts the current insertion point position at @a to as a 
 326     virtual void Remove(long from
, long to
); 
 329         Replaces the text starting at the first position up to 
 330         (but not including) the character at the last position with the given text. 
 332         This function puts the current insertion point position at @a to as a 
 340             The value to replace the existing text with. 
 342     virtual void Replace(long from
, long to
, const wxString
& value
); 
 345         Makes the text item editable or read-only, overriding the 
 346         @b wxTE_READONLY flag. 
 349             If @true, the control is editable. If @false, the control is 
 354     virtual void SetEditable(bool editable
); 
 357         Sets the insertion point at the given position. 
 360             Position to set, in the range from 0 to GetLastPosition() inclusive. 
 362     virtual void SetInsertionPoint(long pos
); 
 365         Sets the insertion point at the end of the text control. 
 367         This is equivalent to calling wxTextCtrl::SetInsertionPoint() with 
 368         wxTextCtrl::GetLastPosition() argument. 
 370     virtual void SetInsertionPointEnd(); 
 373         This function sets the maximum number of characters the user can enter 
 376         In other words, it allows to limit the text value length to @a len not 
 377         counting the terminating @c NUL character. 
 379         If @a len is 0, the previously set max length limit, if any, is discarded 
 380         and the user may enter as much text as the underlying native text control widget 
 381         supports (typically at least 32Kb). 
 382         If the user tries to enter more characters into the text control when it 
 383         already is filled up to the maximal length, a @c wxEVT_COMMAND_TEXT_MAXLEN 
 384         event is sent to notify the program about it (giving it the possibility 
 385         to show an explanatory message, for example) and the extra input is discarded. 
 387         Note that in wxGTK this function may only be used with single line text controls. 
 389     virtual void SetMaxLength(unsigned long len
); 
 392         Selects the text starting at the first position up to (but not 
 393         including) the character at the last position. 
 395         If both parameters are equal to -1 all text in the control is selected. 
 397         Notice that the insertion point will be moved to @a from by this 
 407     virtual void SetSelection(long from
, long to
); 
 410         Selects all text in the control. 
 414     virtual void SelectAll(); 
 417         Sets a hint shown in an empty unfocused text control. 
 419         The hints are usually used to indicate to the user what is supposed to 
 420         be entered into the given entry field, e.g. a common use of them is to 
 421         show an explanation of what can be entered in a wxSearchCtrl. 
 423         The hint is shown (usually greyed out) for an empty control until it 
 424         gets focus and is shown again if the control loses it and remains 
 425         empty. It won't be shown once the control has a non-empty value, 
 426         although it will be shown again if the control contents is cleared. 
 427         Because of this, it generally only makes sense to use hints with the 
 428         controls which are initially empty. 
 430         Notice that hints are known as <em>cue banners</em> under MSW or 
 431         <em>placeholder strings</em> under OS X. 
 433         @remarks For the platforms without native hints support (and currently 
 434             only the MSW port does have it and even there it is only used under 
 435             Windows Vista and later only), the implementation has several known 
 436             limitations. Notably, the hint display will not be properly updated 
 437             if you change wxTextEntry contents programmatically when the hint 
 438             is displayed using methods other than SetValue() or ChangeValue() 
 439             or others which use them internally (e.g. Clear()). In other words, 
 440             currently you should avoid calling methods such as WriteText() or 
 441             Replace() when using hints and the text control is empty. 
 445     virtual bool SetHint(const wxString
& hint
); 
 448         Returns the current hint string. 
 450         See SetHint() for more information about hints. 
 454     virtual wxString 
GetHint() const; 
 458         Attempts to set the control margins. When margins are given as wxPoint, 
 459         x indicates the left and y the top margin. Use -1 to indicate that 
 460         an existing value should be used. 
 463             @true if setting of all requested margins was successful. 
 467     bool SetMargins(const wxPoint
& pt
); 
 468     bool SetMargins(wxCoord left
, wxCoord top 
= -1); 
 472         Returns the margins used by the control. The @c x field of the returned 
 473         point is the horizontal margin and the @c y field is the vertical one. 
 475         @remarks If given margin cannot be accurately determined, its value 
 476                 will be set to -1. On some platforms you cannot obtain valid 
 477                 margin values until you have called SetMargins(). 
 483     wxPoint 
GetMargins() const; 
 486         Sets the new text control value. 
 488         It also marks the control as not-modified which means that IsModified() 
 489         would return @false immediately after the call to SetValue(). 
 491         The insertion point is set to the start of the control (i.e. position 
 494         Note that, unlike most other functions changing the controls values, 
 495         this function generates a @c wxEVT_COMMAND_TEXT_UPDATED event. To avoid 
 496         this you can use ChangeValue() instead. 
 499             The new value to set. It may contain newline characters if the text 
 500             control is multi-line. 
 502     virtual void SetValue(const wxString
& value
); 
 505         If there is an undo facility and the last operation can be undone, 
 506         undoes the last operation. 
 508         Does nothing if there is no undo facility. 
 513         Writes the text into the text control at the current insertion position. 
 516             Text to write to the text control. 
 519             Newlines in the text string are the only control characters 
 520             allowed, and they will cause appropriate line breaks. 
 521             See operator<<() and AppendText() for more convenient ways of 
 522             writing to the window. 
 523             After the write operation, the insertion point will be at the end 
 524             of the inserted text, so subsequent write operations will be appended. 
 525             To append text after the user may have interacted with the control, 
 526             call wxTextCtrl::SetInsertionPointEnd() before writing. 
 528     virtual void WriteText(const wxString
& text
);