]> git.saurik.com Git - wxWidgets.git/blame - include/wx/msw/textctrl.h
added conversion to and from std::string and std::wstring (if wxUSE_STD_STRING)
[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
4438caf4 173 // callbacks
4438caf4
VZ
174 void OnDropFiles(wxDropFilesEvent& event);
175 void OnChar(wxKeyEvent& event); // Process 'enter' if required
176
177 void OnCut(wxCommandEvent& event);
178 void OnCopy(wxCommandEvent& event);
179 void OnPaste(wxCommandEvent& event);
180 void OnUndo(wxCommandEvent& event);
181 void OnRedo(wxCommandEvent& event);
2b5f62a0
VZ
182 void OnDelete(wxCommandEvent& event);
183 void OnSelectAll(wxCommandEvent& event);
4438caf4
VZ
184
185 void OnUpdateCut(wxUpdateUIEvent& event);
186 void OnUpdateCopy(wxUpdateUIEvent& event);
187 void OnUpdatePaste(wxUpdateUIEvent& event);
188 void OnUpdateUndo(wxUpdateUIEvent& event);
189 void OnUpdateRedo(wxUpdateUIEvent& event);
2b5f62a0
VZ
190 void OnUpdateDelete(wxUpdateUIEvent& event);
191 void OnUpdateSelectAll(wxUpdateUIEvent& event);
192
193 // Show a context menu for Rich Edit controls (the standard
194 // EDIT control has one already)
26f60eb6 195 void OnContextMenu(wxContextMenuEvent& event);
4438caf4 196
e3a6a6b2
VZ
197 // be sure the caret remains invisible if the user
198 // called HideNativeCaret() before
199 void OnSetFocus(wxFocusEvent& event);
200
6f02a879
VZ
201 // intercept WM_GETDLGCODE
202 virtual WXLRESULT MSWWindowProc(WXUINT nMsg, WXWPARAM wParam, WXLPARAM lParam);
203
204 virtual bool MSWShouldPreProcessMessage(WXMSG* pMsg);
205 virtual WXDWORD MSWGetStyle(long style, WXDWORD *exstyle) const;
206 virtual wxVisualAttributes GetDefaultAttributes() const;
207
2bda0e17 208protected:
aac7e7fe
VZ
209 // common part of all ctors
210 void Init();
211
9b99c1e3
VZ
212 // creates the control of appropriate class (plain or rich edit) with the
213 // styles corresponding to m_windowStyle
214 //
215 // this is used by ctor/Create() and when we need to recreate the control
216 // later
217 bool MSWCreateText(const wxString& value,
218 const wxPoint& pos,
219 const wxSize& size);
220
ee2ec18e 221 virtual void DoSetValue(const wxString &value, int flags = 0);
f6519b40 222
4fa80851
VZ
223 // return true if this control has a user-set limit on amount of text (i.e.
224 // the limit is due to a previous call to SetMaxLength() and not built in)
225 bool HasSpaceLimit(unsigned int *len) const;
226
789295bf
VZ
227 // call this to increase the size limit (will do nothing if the current
228 // limit is big enough)
d7eee191
VZ
229 //
230 // returns true if we increased the limit to allow entering more text,
231 // false if we hit the limit set by SetMaxLength() and so didn't change it
232 bool AdjustSpaceLimit();
789295bf 233
7411f983 234#if wxUSE_RICHEDIT && (!wxUSE_UNICODE || wxUSE_UNICODE_MSLU)
79d26b32
VZ
235 // replace the selection or the entire control contents with the given text
236 // in the specified encoding
7411f983
VZ
237 bool StreamIn(const wxString& value, wxFontEncoding encoding, bool selOnly);
238
239 // get the contents of the control out as text in the given encoding
240 wxString StreamOut(wxFontEncoding encoding, bool selOnly = false) const;
aac7e7fe
VZ
241#endif // wxUSE_RICHEDIT
242
79d26b32
VZ
243 // replace the contents of the selection or of the entire control with the
244 // given text
dd1c1631
VZ
245 void DoWriteText(const wxString& text,
246 int flags = SetValue_SendEvent | SetValue_SelectionOnly);
79d26b32 247
aac7e7fe 248 // set the selection possibly without scrolling the caret into view
bfbb0b4c 249 void DoSetSelection(long from, long to, bool scrollCaret = true);
aac7e7fe 250
2b5f62a0
VZ
251 // return true if there is a non empty selection in the control
252 bool HasSelection() const;
253
a5aa8086
VZ
254 // get the length of the line containing the character at the given
255 // position
256 long GetLengthOfLineContainingPos(long pos) const;
257
bfbb0b4c 258 // send TEXT_UPDATED event, return true if it was handled, false otherwise
5036ea90
VZ
259 bool SendUpdateEvent();
260
f68586e5 261 virtual wxSize DoGetBestSize() const;
bfc6fde4 262
d7eee191 263#if wxUSE_RICHEDIT
aac7e7fe
VZ
264 // we're using RICHEDIT (and not simple EDIT) control if this field is not
265 // 0, it also gives the version of the RICHEDIT control being used (1, 2 or
266 // 3 so far)
267 int m_verRichEdit;
2b5f62a0 268#endif // wxUSE_RICHEDIT
5036ea90 269
2c62dd25
VZ
270 // number of EN_UPDATE events sent by Windows when we change the controls
271 // text ourselves: we want this to be exactly 1
272 int m_updatesCount;
d7eee191 273
bfc6fde4
VZ
274private:
275 DECLARE_EVENT_TABLE()
fc7a2a60 276 DECLARE_DYNAMIC_CLASS_NO_COPY(wxTextCtrl)
2b5f62a0
VZ
277
278 wxMenu* m_privateContextMenu;
e3a6a6b2
VZ
279
280 bool m_isNativeCaretShown;
8ef51d67
JS
281
282#if wxUSE_INKEDIT && wxUSE_RICHEDIT
283 int m_isInkEdit;
284#endif
285
2bda0e17
KB
286};
287
288#endif
bbcdf8bc 289 // _WX_TEXTCTRL_H_