]> git.saurik.com Git - wxWidgets.git/blame - include/wx/msw/textctrl.h
Dramatically optimise inserting many items in wxGenericListCtrl.
[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
53a2db12 15class WXDLLIMPEXP_CORE 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
fa2f57be
VZ
44 // overridden wxTextEntry methods
45 // ------------------------------
4438caf4
VZ
46
47 virtual wxString GetValue() const;
fa2f57be
VZ
48 virtual wxString GetRange(long from, long to) const;
49
28fdd8db 50 virtual bool IsEmpty() const;
bfc6fde4 51
fa2f57be
VZ
52 virtual void WriteText(const wxString& text);
53 virtual void AppendText(const wxString& text);
54 virtual void Clear();
a5aa8086 55
bfc6fde4
VZ
56 virtual int GetLineLength(long lineNo) const;
57 virtual wxString GetLineText(long lineNo) const;
58 virtual int GetNumberOfLines() const;
59
fa2f57be 60 virtual void SetMaxLength(unsigned long len);
a1b82138 61
fa2f57be 62 virtual void GetSelection(long *from, long *to) const;
a1b82138 63
fa2f57be
VZ
64 virtual void Redo();
65 virtual bool CanRedo() const;
bfc6fde4 66
fa2f57be
VZ
67 virtual void SetInsertionPointEnd();
68 virtual long GetInsertionPoint() const;
69 virtual wxTextPos GetLastPosition() const;
70
71 // implement base class pure virtuals
72 // ----------------------------------
a1b82138 73
fa2f57be 74 virtual bool IsModified() const;
3a9fa0d6 75 virtual void MarkDirty();
a1b82138
VZ
76 virtual void DiscardEdits();
77
94af7d45
VZ
78#ifdef __WIN32__
79 virtual bool EmulateKeyPress(const wxKeyEvent& event);
80#endif // __WIN32__
81
4bc1afd5
VZ
82#if wxUSE_RICHEDIT
83 // apply text attribute to the range of text (only works with richedit
84 // controls)
85 virtual bool SetStyle(long start, long end, const wxTextAttr& style);
5bf75ae7 86 virtual bool SetDefaultStyle(const wxTextAttr& style);
e00a5d3c 87 virtual bool GetStyle(long position, wxTextAttr& style);
4bc1afd5
VZ
88#endif // wxUSE_RICHEDIT
89
a1b82138
VZ
90 // translate between the position (which is just an index in the text ctrl
91 // considering all its contents as a single strings) and (x, y) coordinates
92 // which represent column and line.
93 virtual long XYToPosition(long x, long y) const;
0efe5ba7 94 virtual bool PositionToXY(long pos, long *x, long *y) const;
a1b82138
VZ
95
96 virtual void ShowPosition(long pos);
6726a6b0 97 virtual wxTextCtrlHitTestResult HitTest(const wxPoint& pt, long *pos) const;
3b830ce0
VZ
98 virtual wxTextCtrlHitTestResult HitTest(const wxPoint& pt,
99 wxTextCoord *col,
100 wxTextCoord *row) const
101 {
102 return wxTextCtrlBase::HitTest(pt, col, row);
103 }
a1b82138 104
e3a6a6b2 105 // Caret handling (Windows only)
e3a6a6b2
VZ
106 bool ShowNativeCaret(bool show = true);
107 bool HideNativeCaret() { return ShowNativeCaret(false); }
108
4438caf4
VZ
109 // Implementation from now on
110 // --------------------------
03647350 111
20a0e999
VZ
112#if wxUSE_DRAG_AND_DROP && wxUSE_RICHEDIT
113 virtual void SetDropTarget(wxDropTarget *dropTarget);
114#endif // wxUSE_DRAG_AND_DROP && wxUSE_RICHEDIT
e702ff0f 115
b2d5a7ee
VZ
116 virtual void SetWindowStyleFlag(long style);
117
bfc6fde4
VZ
118 virtual void Command(wxCommandEvent& event);
119 virtual bool MSWCommand(WXUINT param, WXWORD id);
2bae4332 120 virtual WXHBRUSH MSWControlColor(WXHDC hDC, WXHWND hWnd);
f6bcfd97 121
396bdd5a 122#if wxUSE_RICHEDIT
c57e3339
VZ
123 virtual bool MSWOnNotify(int idCtrl, WXLPARAM lParam, WXLPARAM *result);
124
aac7e7fe
VZ
125 int GetRichVersion() const { return m_verRichEdit; }
126 bool IsRich() const { return m_verRichEdit != 0; }
f6bcfd97 127
81fb185e
VZ
128 // rich edit controls are not compatible with normal ones and we must set
129 // the colours and font for them otherwise
f6bcfd97
BP
130 virtual bool SetBackgroundColour(const wxColour& colour);
131 virtual bool SetForegroundColour(const wxColour& colour);
81fb185e 132 virtual bool SetFont(const wxFont& font);
715ce94d
JS
133#else
134 bool IsRich() const { return false; }
a1b82138 135#endif // wxUSE_RICHEDIT
396bdd5a 136
8ef51d67
JS
137#if wxUSE_INKEDIT && wxUSE_RICHEDIT
138 bool IsInkEdit() const { return m_isInkEdit != 0; }
139#else
140 bool IsInkEdit() const { return false; }
141#endif
142
bfc6fde4 143 virtual void AdoptAttributesFromHWND();
5fb9fcfc 144
fa2f57be 145 virtual bool AcceptsFocusFromKeyboard() const;
c50f1fb9 146
a047aff2
JS
147 // returns true if the platform should explicitly apply a theme border
148 virtual bool CanApplyThemeBorder() const;
149
4438caf4 150 // callbacks
4438caf4
VZ
151 void OnDropFiles(wxDropFilesEvent& event);
152 void OnChar(wxKeyEvent& event); // Process 'enter' if required
153
154 void OnCut(wxCommandEvent& event);
155 void OnCopy(wxCommandEvent& event);
156 void OnPaste(wxCommandEvent& event);
157 void OnUndo(wxCommandEvent& event);
158 void OnRedo(wxCommandEvent& event);
2b5f62a0
VZ
159 void OnDelete(wxCommandEvent& event);
160 void OnSelectAll(wxCommandEvent& event);
4438caf4
VZ
161
162 void OnUpdateCut(wxUpdateUIEvent& event);
163 void OnUpdateCopy(wxUpdateUIEvent& event);
164 void OnUpdatePaste(wxUpdateUIEvent& event);
165 void OnUpdateUndo(wxUpdateUIEvent& event);
166 void OnUpdateRedo(wxUpdateUIEvent& event);
2b5f62a0
VZ
167 void OnUpdateDelete(wxUpdateUIEvent& event);
168 void OnUpdateSelectAll(wxUpdateUIEvent& event);
169
170 // Show a context menu for Rich Edit controls (the standard
171 // EDIT control has one already)
26f60eb6 172 void OnContextMenu(wxContextMenuEvent& event);
4438caf4 173
e3a6a6b2
VZ
174 // be sure the caret remains invisible if the user
175 // called HideNativeCaret() before
176 void OnSetFocus(wxFocusEvent& event);
177
6f02a879
VZ
178 // intercept WM_GETDLGCODE
179 virtual WXLRESULT MSWWindowProc(WXUINT nMsg, WXWPARAM wParam, WXLPARAM lParam);
180
181 virtual bool MSWShouldPreProcessMessage(WXMSG* pMsg);
182 virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const;
6f02a879 183
2bda0e17 184protected:
aac7e7fe
VZ
185 // common part of all ctors
186 void Init();
187
3c75d8ba
PC
188 virtual bool DoLoadFile(const wxString& file, int fileType);
189
9b99c1e3
VZ
190 // creates the control of appropriate class (plain or rich edit) with the
191 // styles corresponding to m_windowStyle
192 //
193 // this is used by ctor/Create() and when we need to recreate the control
194 // later
195 bool MSWCreateText(const wxString& value,
196 const wxPoint& pos,
197 const wxSize& size);
198
ee2ec18e 199 virtual void DoSetValue(const wxString &value, int flags = 0);
f6519b40 200
6ce83213
VZ
201 virtual wxPoint DoPositionToCoords(long pos) const;
202
4fa80851
VZ
203 // return true if this control has a user-set limit on amount of text (i.e.
204 // the limit is due to a previous call to SetMaxLength() and not built in)
205 bool HasSpaceLimit(unsigned int *len) const;
206
789295bf
VZ
207 // call this to increase the size limit (will do nothing if the current
208 // limit is big enough)
d7eee191
VZ
209 //
210 // returns true if we increased the limit to allow entering more text,
211 // false if we hit the limit set by SetMaxLength() and so didn't change it
212 bool AdjustSpaceLimit();
789295bf 213
7411f983 214#if wxUSE_RICHEDIT && (!wxUSE_UNICODE || wxUSE_UNICODE_MSLU)
79d26b32
VZ
215 // replace the selection or the entire control contents with the given text
216 // in the specified encoding
7411f983
VZ
217 bool StreamIn(const wxString& value, wxFontEncoding encoding, bool selOnly);
218
219 // get the contents of the control out as text in the given encoding
220 wxString StreamOut(wxFontEncoding encoding, bool selOnly = false) const;
aac7e7fe
VZ
221#endif // wxUSE_RICHEDIT
222
79d26b32
VZ
223 // replace the contents of the selection or of the entire control with the
224 // given text
dd1c1631
VZ
225 void DoWriteText(const wxString& text,
226 int flags = SetValue_SendEvent | SetValue_SelectionOnly);
79d26b32 227
fa2f57be
VZ
228 // set the selection (possibly without scrolling the caret into view)
229 void DoSetSelection(long from, long to, int flags);
aac7e7fe 230
a5aa8086
VZ
231 // get the length of the line containing the character at the given
232 // position
233 long GetLengthOfLineContainingPos(long pos) const;
234
bfbb0b4c 235 // send TEXT_UPDATED event, return true if it was handled, false otherwise
5036ea90
VZ
236 bool SendUpdateEvent();
237
f68586e5 238 virtual wxSize DoGetBestSize() const;
bfc6fde4 239
d7eee191 240#if wxUSE_RICHEDIT
a8abba41
VZ
241 // Apply the character-related parts of wxTextAttr to the given selection
242 // or the entire control if start == end == -1.
243 //
244 // This function is private and should only be called for rich edit
245 // controls and with (from, to) already in correct order, i.e. from <= to.
246 bool MSWSetCharFormat(const wxTextAttr& attr, long from = -1, long to = -1);
247
248 // Same as above for paragraph-related parts of wxTextAttr. Note that this
249 // can only be applied to the selection as RichEdit doesn't support setting
250 // the paragraph styles globally.
251 bool MSWSetParaFormat(const wxTextAttr& attr, long from, long to);
252
253
aac7e7fe 254 // we're using RICHEDIT (and not simple EDIT) control if this field is not
4f7c00f2
VZ
255 // 0, it also gives the version of the RICHEDIT control being used
256 // (although not directly: 1 is for 1.0, 2 is for either 2.0 or 3.0 as we
257 // can't nor really need to distinguish between them and 4 is for 4.1)
aac7e7fe 258 int m_verRichEdit;
2b5f62a0 259#endif // wxUSE_RICHEDIT
5036ea90 260
2c62dd25
VZ
261 // number of EN_UPDATE events sent by Windows when we change the controls
262 // text ourselves: we want this to be exactly 1
263 int m_updatesCount;
d7eee191 264
3c75d8ba 265private:
fa2f57be
VZ
266 virtual void EnableTextChangedEvents(bool enable)
267 {
268 m_updatesCount = enable ? -1 : -2;
269 }
270
3c75d8ba
PC
271 // implement wxTextEntry pure virtual: it implements all the operations for
272 // the simple EDIT controls
273 virtual WXHWND GetEditHWND() const { return m_hWnd; }
274
e2cf30aa
VS
275 void OnKeyDown(wxKeyEvent& event);
276
bfc6fde4 277 DECLARE_EVENT_TABLE()
fc7a2a60 278 DECLARE_DYNAMIC_CLASS_NO_COPY(wxTextCtrl)
2b5f62a0
VZ
279
280 wxMenu* m_privateContextMenu;
e3a6a6b2
VZ
281
282 bool m_isNativeCaretShown;
8ef51d67
JS
283
284#if wxUSE_INKEDIT && wxUSE_RICHEDIT
285 int m_isInkEdit;
286#endif
287
2bda0e17
KB
288};
289
fa2f57be 290#endif // _WX_TEXTCTRL_H_