]> git.saurik.com Git - wxWidgets.git/blame - include/wx/msw/textctrl.h
Compile fix (VC++ 6 doesn't like wxString::Format with only 1 arg: gives several...
[wxWidgets.git] / include / wx / msw / textctrl.h
CommitLineData
2bda0e17 1/////////////////////////////////////////////////////////////////////////////
d7eee191 2// Name: wx/msw/textctrl.h
2bda0e17
KB
3// Purpose: wxTextCtrl class
4// Author: Julian Smart
5// Modified by:
6// Created: 01/02/97
7// RCS-ID: $Id$
bbcdf8bc 8// Copyright: (c) Julian Smart
65571936 9// Licence: wxWindows licence
2bda0e17
KB
10/////////////////////////////////////////////////////////////////////////////
11
bbcdf8bc
JS
12#ifndef _WX_TEXTCTRL_H_
13#define _WX_TEXTCTRL_H_
2bda0e17 14
a1b82138 15class WXDLLEXPORT wxTextCtrl : public wxTextCtrlBase
2bda0e17 16{
ae29de83 17public:
bfc6fde4
VZ
18 // creation
19 // --------
a1b82138 20
aac7e7fe 21 wxTextCtrl() { Init(); }
bfc6fde4 22 wxTextCtrl(wxWindow *parent, wxWindowID id,
a1b82138
VZ
23 const wxString& value = wxEmptyString,
24 const wxPoint& pos = wxDefaultPosition,
25 const wxSize& size = wxDefaultSize,
26 long style = 0,
27 const wxValidator& validator = wxDefaultValidator,
28 const wxString& name = wxTextCtrlNameStr)
29 {
aac7e7fe
VZ
30 Init();
31
a1b82138
VZ
32 Create(parent, id, value, pos, size, style, validator, name);
33 }
d3c7fc99 34 virtual ~wxTextCtrl();
bfc6fde4
VZ
35
36 bool Create(wxWindow *parent, wxWindowID id,
a1b82138
VZ
37 const wxString& value = wxEmptyString,
38 const wxPoint& pos = wxDefaultPosition,
39 const wxSize& size = wxDefaultSize,
40 long style = 0,
41 const wxValidator& validator = wxDefaultValidator,
42 const wxString& name = wxTextCtrlNameStr);
bfc6fde4 43
a1b82138
VZ
44 // implement base class pure virtuals
45 // ----------------------------------
4438caf4
VZ
46
47 virtual wxString GetValue() const;
28fdd8db 48 virtual bool IsEmpty() const;
bfc6fde4 49
a5aa8086
VZ
50 virtual wxString GetRange(long from, long to) const;
51
bfc6fde4
VZ
52 virtual int GetLineLength(long lineNo) const;
53 virtual wxString GetLineText(long lineNo) const;
54 virtual int GetNumberOfLines() const;
55
a1b82138
VZ
56 virtual bool IsModified() const;
57 virtual bool IsEditable() const;
58
a1b82138
VZ
59 virtual void GetSelection(long* from, long* to) const;
60
bfc6fde4
VZ
61 // operations
62 // ----------
63
a1b82138
VZ
64 // editing
65 virtual void Clear();
66 virtual void Replace(long from, long to, const wxString& value);
67 virtual void Remove(long from, long to);
68
3306aec1
JS
69 // load the control's contents from the file
70 virtual bool DoLoadFile(const wxString& file, int fileType);
a1b82138
VZ
71
72 // clears the dirty flag
3a9fa0d6 73 virtual void MarkDirty();
a1b82138
VZ
74 virtual void DiscardEdits();
75
d7eee191
VZ
76 virtual void SetMaxLength(unsigned long len);
77
a1b82138
VZ
78 // writing text inserts it at the current position, appending always
79 // inserts it at the end
80 virtual void WriteText(const wxString& text);
81 virtual void AppendText(const wxString& text);
82
94af7d45
VZ
83#ifdef __WIN32__
84 virtual bool EmulateKeyPress(const wxKeyEvent& event);
85#endif // __WIN32__
86
4bc1afd5
VZ
87#if wxUSE_RICHEDIT
88 // apply text attribute to the range of text (only works with richedit
89 // controls)
90 virtual bool SetStyle(long start, long end, const wxTextAttr& style);
5bf75ae7 91 virtual bool SetDefaultStyle(const wxTextAttr& style);
e00a5d3c 92 virtual bool GetStyle(long position, wxTextAttr& style);
4bc1afd5
VZ
93#endif // wxUSE_RICHEDIT
94
a1b82138
VZ
95 // translate between the position (which is just an index in the text ctrl
96 // considering all its contents as a single strings) and (x, y) coordinates
97 // which represent column and line.
98 virtual long XYToPosition(long x, long y) const;
0efe5ba7 99 virtual bool PositionToXY(long pos, long *x, long *y) const;
a1b82138
VZ
100
101 virtual void ShowPosition(long pos);
6726a6b0 102 virtual wxTextCtrlHitTestResult HitTest(const wxPoint& pt, long *pos) const;
3b830ce0
VZ
103 virtual wxTextCtrlHitTestResult HitTest(const wxPoint& pt,
104 wxTextCoord *col,
105 wxTextCoord *row) const
106 {
107 return wxTextCtrlBase::HitTest(pt, col, row);
108 }
a1b82138 109
bfc6fde4
VZ
110 // Clipboard operations
111 virtual void Copy();
112 virtual void Cut();
113 virtual void Paste();
114
ca8b28f2
JS
115 virtual bool CanCopy() const;
116 virtual bool CanCut() const;
117 virtual bool CanPaste() const;
118
119 // Undo/redo
120 virtual void Undo();
121 virtual void Redo();
122
123 virtual bool CanUndo() const;
124 virtual bool CanRedo() const;
125
a1b82138 126 // Insertion point
bfc6fde4
VZ
127 virtual void SetInsertionPoint(long pos);
128 virtual void SetInsertionPointEnd();
a1b82138 129 virtual long GetInsertionPoint() const;
7d8268a1 130 virtual wxTextPos GetLastPosition() const;
a1b82138 131
bfc6fde4
VZ
132 virtual void SetSelection(long from, long to);
133 virtual void SetEditable(bool editable);
134
e3a6a6b2
VZ
135 // Caret handling (Windows only)
136
137 bool ShowNativeCaret(bool show = true);
138 bool HideNativeCaret() { return ShowNativeCaret(false); }
139
4438caf4
VZ
140 // Implementation from now on
141 // --------------------------
e702ff0f 142
b2d5a7ee
VZ
143 virtual void SetWindowStyleFlag(long style);
144
bfc6fde4
VZ
145 virtual void Command(wxCommandEvent& event);
146 virtual bool MSWCommand(WXUINT param, WXWORD id);
2bae4332 147 virtual WXHBRUSH MSWControlColor(WXHDC hDC, WXHWND hWnd);
f6bcfd97 148
396bdd5a 149#if wxUSE_RICHEDIT
c57e3339
VZ
150 virtual bool MSWOnNotify(int idCtrl, WXLPARAM lParam, WXLPARAM *result);
151
aac7e7fe
VZ
152 int GetRichVersion() const { return m_verRichEdit; }
153 bool IsRich() const { return m_verRichEdit != 0; }
f6bcfd97
BP
154
155 // rich edit controls are not compatible with normal ones and wem ust set
156 // the colours for them otherwise
157 virtual bool SetBackgroundColour(const wxColour& colour);
158 virtual bool SetForegroundColour(const wxColour& colour);
715ce94d
JS
159#else
160 bool IsRich() const { return false; }
a1b82138 161#endif // wxUSE_RICHEDIT
396bdd5a 162
8ef51d67
JS
163#if wxUSE_INKEDIT && wxUSE_RICHEDIT
164 bool IsInkEdit() const { return m_isInkEdit != 0; }
165#else
166 bool IsInkEdit() const { return false; }
167#endif
168
bfc6fde4 169 virtual void AdoptAttributesFromHWND();
5fb9fcfc 170
c50f1fb9
VZ
171 virtual bool AcceptsFocus() const;
172
a047aff2
JS
173 // returns true if the platform should explicitly apply a theme border
174 virtual bool CanApplyThemeBorder() const;
175
4438caf4 176 // callbacks
4438caf4
VZ
177 void OnDropFiles(wxDropFilesEvent& event);
178 void OnChar(wxKeyEvent& event); // Process 'enter' if required
179
180 void OnCut(wxCommandEvent& event);
181 void OnCopy(wxCommandEvent& event);
182 void OnPaste(wxCommandEvent& event);
183 void OnUndo(wxCommandEvent& event);
184 void OnRedo(wxCommandEvent& event);
2b5f62a0
VZ
185 void OnDelete(wxCommandEvent& event);
186 void OnSelectAll(wxCommandEvent& event);
4438caf4
VZ
187
188 void OnUpdateCut(wxUpdateUIEvent& event);
189 void OnUpdateCopy(wxUpdateUIEvent& event);
190 void OnUpdatePaste(wxUpdateUIEvent& event);
191 void OnUpdateUndo(wxUpdateUIEvent& event);
192 void OnUpdateRedo(wxUpdateUIEvent& event);
2b5f62a0
VZ
193 void OnUpdateDelete(wxUpdateUIEvent& event);
194 void OnUpdateSelectAll(wxUpdateUIEvent& event);
195
196 // Show a context menu for Rich Edit controls (the standard
197 // EDIT control has one already)
26f60eb6 198 void OnContextMenu(wxContextMenuEvent& event);
4438caf4 199
e3a6a6b2
VZ
200 // be sure the caret remains invisible if the user
201 // called HideNativeCaret() before
202 void OnSetFocus(wxFocusEvent& event);
203
6f02a879
VZ
204 // intercept WM_GETDLGCODE
205 virtual WXLRESULT MSWWindowProc(WXUINT nMsg, WXWPARAM wParam, WXLPARAM lParam);
206
207 virtual bool MSWShouldPreProcessMessage(WXMSG* pMsg);
208 virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const;
209 virtual wxVisualAttributes GetDefaultAttributes() const;
210
2bda0e17 211protected:
aac7e7fe
VZ
212 // common part of all ctors
213 void Init();
214
9b99c1e3
VZ
215 // creates the control of appropriate class (plain or rich edit) with the
216 // styles corresponding to m_windowStyle
217 //
218 // this is used by ctor/Create() and when we need to recreate the control
219 // later
220 bool MSWCreateText(const wxString& value,
221 const wxPoint& pos,
222 const wxSize& size);
223
ee2ec18e 224 virtual void DoSetValue(const wxString &value, int flags = 0);
f6519b40 225
4fa80851
VZ
226 // return true if this control has a user-set limit on amount of text (i.e.
227 // the limit is due to a previous call to SetMaxLength() and not built in)
228 bool HasSpaceLimit(unsigned int *len) const;
229
789295bf
VZ
230 // call this to increase the size limit (will do nothing if the current
231 // limit is big enough)
d7eee191
VZ
232 //
233 // returns true if we increased the limit to allow entering more text,
234 // false if we hit the limit set by SetMaxLength() and so didn't change it
235 bool AdjustSpaceLimit();
789295bf 236
7411f983 237#if wxUSE_RICHEDIT && (!wxUSE_UNICODE || wxUSE_UNICODE_MSLU)
79d26b32
VZ
238 // replace the selection or the entire control contents with the given text
239 // in the specified encoding
7411f983
VZ
240 bool StreamIn(const wxString& value, wxFontEncoding encoding, bool selOnly);
241
242 // get the contents of the control out as text in the given encoding
243 wxString StreamOut(wxFontEncoding encoding, bool selOnly = false) const;
aac7e7fe
VZ
244#endif // wxUSE_RICHEDIT
245
79d26b32
VZ
246 // replace the contents of the selection or of the entire control with the
247 // given text
dd1c1631
VZ
248 void DoWriteText(const wxString& text,
249 int flags = SetValue_SendEvent | SetValue_SelectionOnly);
79d26b32 250
aac7e7fe 251 // set the selection possibly without scrolling the caret into view
bfbb0b4c 252 void DoSetSelection(long from, long to, bool scrollCaret = true);
aac7e7fe 253
2b5f62a0
VZ
254 // return true if there is a non empty selection in the control
255 bool HasSelection() const;
256
a5aa8086
VZ
257 // get the length of the line containing the character at the given
258 // position
259 long GetLengthOfLineContainingPos(long pos) const;
260
bfbb0b4c 261 // send TEXT_UPDATED event, return true if it was handled, false otherwise
5036ea90
VZ
262 bool SendUpdateEvent();
263
f68586e5 264 virtual wxSize DoGetBestSize() const;
bfc6fde4 265
d7eee191 266#if wxUSE_RICHEDIT
aac7e7fe
VZ
267 // we're using RICHEDIT (and not simple EDIT) control if this field is not
268 // 0, it also gives the version of the RICHEDIT control being used (1, 2 or
269 // 3 so far)
270 int m_verRichEdit;
2b5f62a0 271#endif // wxUSE_RICHEDIT
5036ea90 272
2c62dd25
VZ
273 // number of EN_UPDATE events sent by Windows when we change the controls
274 // text ourselves: we want this to be exactly 1
275 int m_updatesCount;
d7eee191 276
bfc6fde4
VZ
277private:
278 DECLARE_EVENT_TABLE()
fc7a2a60 279 DECLARE_DYNAMIC_CLASS_NO_COPY(wxTextCtrl)
2b5f62a0
VZ
280
281 wxMenu* m_privateContextMenu;
e3a6a6b2
VZ
282
283 bool m_isNativeCaretShown;
8ef51d67
JS
284
285#if wxUSE_INKEDIT && wxUSE_RICHEDIT
286 int m_isInkEdit;
287#endif
288
2bda0e17
KB
289};
290
291#endif
bbcdf8bc 292 // _WX_TEXTCTRL_H_