]> git.saurik.com Git - wxWidgets.git/blame - include/wx/msw/textctrl.h
wxBORDER_THEME now means 'use an appropriate themed border' on all plaforms
[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 // --------------------------
20a0e999
VZ
142
143#if wxUSE_DRAG_AND_DROP && wxUSE_RICHEDIT
144 virtual void SetDropTarget(wxDropTarget *dropTarget);
145#endif // wxUSE_DRAG_AND_DROP && wxUSE_RICHEDIT
e702ff0f 146
b2d5a7ee
VZ
147 virtual void SetWindowStyleFlag(long style);
148
bfc6fde4
VZ
149 virtual void Command(wxCommandEvent& event);
150 virtual bool MSWCommand(WXUINT param, WXWORD id);
2bae4332 151 virtual WXHBRUSH MSWControlColor(WXHDC hDC, WXHWND hWnd);
f6bcfd97 152
396bdd5a 153#if wxUSE_RICHEDIT
c57e3339
VZ
154 virtual bool MSWOnNotify(int idCtrl, WXLPARAM lParam, WXLPARAM *result);
155
aac7e7fe
VZ
156 int GetRichVersion() const { return m_verRichEdit; }
157 bool IsRich() const { return m_verRichEdit != 0; }
f6bcfd97
BP
158
159 // rich edit controls are not compatible with normal ones and wem ust set
160 // the colours for them otherwise
161 virtual bool SetBackgroundColour(const wxColour& colour);
162 virtual bool SetForegroundColour(const wxColour& colour);
715ce94d
JS
163#else
164 bool IsRich() const { return false; }
a1b82138 165#endif // wxUSE_RICHEDIT
396bdd5a 166
8ef51d67
JS
167#if wxUSE_INKEDIT && wxUSE_RICHEDIT
168 bool IsInkEdit() const { return m_isInkEdit != 0; }
169#else
170 bool IsInkEdit() const { return false; }
171#endif
172
bfc6fde4 173 virtual void AdoptAttributesFromHWND();
5fb9fcfc 174
c50f1fb9
VZ
175 virtual bool AcceptsFocus() const;
176
a047aff2
JS
177 // returns true if the platform should explicitly apply a theme border
178 virtual bool CanApplyThemeBorder() const;
179
4438caf4 180 // callbacks
4438caf4
VZ
181 void OnDropFiles(wxDropFilesEvent& event);
182 void OnChar(wxKeyEvent& event); // Process 'enter' if required
183
184 void OnCut(wxCommandEvent& event);
185 void OnCopy(wxCommandEvent& event);
186 void OnPaste(wxCommandEvent& event);
187 void OnUndo(wxCommandEvent& event);
188 void OnRedo(wxCommandEvent& event);
2b5f62a0
VZ
189 void OnDelete(wxCommandEvent& event);
190 void OnSelectAll(wxCommandEvent& event);
4438caf4
VZ
191
192 void OnUpdateCut(wxUpdateUIEvent& event);
193 void OnUpdateCopy(wxUpdateUIEvent& event);
194 void OnUpdatePaste(wxUpdateUIEvent& event);
195 void OnUpdateUndo(wxUpdateUIEvent& event);
196 void OnUpdateRedo(wxUpdateUIEvent& event);
2b5f62a0
VZ
197 void OnUpdateDelete(wxUpdateUIEvent& event);
198 void OnUpdateSelectAll(wxUpdateUIEvent& event);
199
200 // Show a context menu for Rich Edit controls (the standard
201 // EDIT control has one already)
26f60eb6 202 void OnContextMenu(wxContextMenuEvent& event);
4438caf4 203
e3a6a6b2
VZ
204 // be sure the caret remains invisible if the user
205 // called HideNativeCaret() before
206 void OnSetFocus(wxFocusEvent& event);
207
6f02a879
VZ
208 // intercept WM_GETDLGCODE
209 virtual WXLRESULT MSWWindowProc(WXUINT nMsg, WXWPARAM wParam, WXLPARAM lParam);
210
211 virtual bool MSWShouldPreProcessMessage(WXMSG* pMsg);
212 virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const;
213 virtual wxVisualAttributes GetDefaultAttributes() const;
214
2bda0e17 215protected:
aac7e7fe
VZ
216 // common part of all ctors
217 void Init();
218
9b99c1e3
VZ
219 // creates the control of appropriate class (plain or rich edit) with the
220 // styles corresponding to m_windowStyle
221 //
222 // this is used by ctor/Create() and when we need to recreate the control
223 // later
224 bool MSWCreateText(const wxString& value,
225 const wxPoint& pos,
226 const wxSize& size);
227
ee2ec18e 228 virtual void DoSetValue(const wxString &value, int flags = 0);
f6519b40 229
4fa80851
VZ
230 // return true if this control has a user-set limit on amount of text (i.e.
231 // the limit is due to a previous call to SetMaxLength() and not built in)
232 bool HasSpaceLimit(unsigned int *len) const;
233
789295bf
VZ
234 // call this to increase the size limit (will do nothing if the current
235 // limit is big enough)
d7eee191
VZ
236 //
237 // returns true if we increased the limit to allow entering more text,
238 // false if we hit the limit set by SetMaxLength() and so didn't change it
239 bool AdjustSpaceLimit();
789295bf 240
7411f983 241#if wxUSE_RICHEDIT && (!wxUSE_UNICODE || wxUSE_UNICODE_MSLU)
79d26b32
VZ
242 // replace the selection or the entire control contents with the given text
243 // in the specified encoding
7411f983
VZ
244 bool StreamIn(const wxString& value, wxFontEncoding encoding, bool selOnly);
245
246 // get the contents of the control out as text in the given encoding
247 wxString StreamOut(wxFontEncoding encoding, bool selOnly = false) const;
aac7e7fe
VZ
248#endif // wxUSE_RICHEDIT
249
79d26b32
VZ
250 // replace the contents of the selection or of the entire control with the
251 // given text
dd1c1631
VZ
252 void DoWriteText(const wxString& text,
253 int flags = SetValue_SendEvent | SetValue_SelectionOnly);
79d26b32 254
aac7e7fe 255 // set the selection possibly without scrolling the caret into view
bfbb0b4c 256 void DoSetSelection(long from, long to, bool scrollCaret = true);
aac7e7fe 257
2b5f62a0
VZ
258 // return true if there is a non empty selection in the control
259 bool HasSelection() const;
260
a5aa8086
VZ
261 // get the length of the line containing the character at the given
262 // position
263 long GetLengthOfLineContainingPos(long pos) const;
264
bfbb0b4c 265 // send TEXT_UPDATED event, return true if it was handled, false otherwise
5036ea90
VZ
266 bool SendUpdateEvent();
267
f68586e5 268 virtual wxSize DoGetBestSize() const;
bfc6fde4 269
d7eee191 270#if wxUSE_RICHEDIT
aac7e7fe
VZ
271 // we're using RICHEDIT (and not simple EDIT) control if this field is not
272 // 0, it also gives the version of the RICHEDIT control being used (1, 2 or
273 // 3 so far)
274 int m_verRichEdit;
2b5f62a0 275#endif // wxUSE_RICHEDIT
5036ea90 276
2c62dd25
VZ
277 // number of EN_UPDATE events sent by Windows when we change the controls
278 // text ourselves: we want this to be exactly 1
279 int m_updatesCount;
d7eee191 280
bfc6fde4
VZ
281private:
282 DECLARE_EVENT_TABLE()
fc7a2a60 283 DECLARE_DYNAMIC_CLASS_NO_COPY(wxTextCtrl)
2b5f62a0
VZ
284
285 wxMenu* m_privateContextMenu;
e3a6a6b2
VZ
286
287 bool m_isNativeCaretShown;
8ef51d67
JS
288
289#if wxUSE_INKEDIT && wxUSE_RICHEDIT
290 int m_isInkEdit;
291#endif
292
2bda0e17
KB
293};
294
295#endif
bbcdf8bc 296 // _WX_TEXTCTRL_H_