]> git.saurik.com Git - wxWidgets.git/blob - include/wx/os2/window.h
Unix implementation of wxDialUpManager.
[wxWidgets.git] / include / wx / os2 / window.h
1 /////////////////////////////////////////////////////////////////////////////
2 // Name: window.h
3 // Purpose: wxWindow class
4 // Author: David Webster
5 // Modified by:
6 // Created: ??/??/98
7 // RCS-ID: $Id$
8 // Copyright: (c) AUTHOR
9 // Licence: wxWindows licence
10 /////////////////////////////////////////////////////////////////////////////
11
12 #ifndef _WX_WINDOW_H_
13 #define _WX_WINDOW_H_
14
15 #ifdef __GNUG__
16 #pragma interface "window.h"
17 #endif
18
19 #define INCL_DOS
20 #define INCL_PM
21 #include <os2.h>
22
23 #define wxKEY_SHIFT 1
24 #define wxKEY_CTRL 2
25
26 // ---------------------------------------------------------------------------
27 // forward declarations
28 // ---------------------------------------------------------------------------
29
30 class WXDLLEXPORT wxWindow;
31 class WXDLLEXPORT wxButton;
32
33 #if wxUSE_DRAG_AND_DROP
34 class WXDLLEXPORT wxDropTarget;
35 #endif
36
37 #if wxUSE_WX_RESOURCES
38 class WXDLLEXPORT wxResourceTable;
39 class WXDLLEXPORT wxItemResource;
40 #endif
41
42 WXDLLEXPORT_DATA(extern const char*) wxPanelNameStr;
43
44 WXDLLEXPORT_DATA(extern const wxSize) wxDefaultSize;
45 WXDLLEXPORT_DATA(extern const wxPoint) wxDefaultPosition;
46
47 class WXDLLEXPORT wxWindow: public wxWindowBase
48 {
49 DECLARE_ABSTRACT_CLASS(wxWindow)
50
51 friend class wxDC;
52 friend class wxPaintDC;
53
54 public:
55 wxWindow() { Init(); };
56 inline wxWindow( wxWindow* parent
57 ,wxWindowID id
58 ,const wxPoint& pos = wxDefaultPosition
59 ,const wxSize& size = wxDefaultSize
60 ,long style = 0
61 ,const wxString& name = wxPanelNameStr
62 )
63 {
64 Init();
65 Create(parent, id, pos, size, style, name);
66 }
67
68 virtual ~wxWindow();
69
70 bool Create( wxWindow* parent
71 ,wxWindowID id
72 ,const wxPoint& pos = wxDefaultPosition
73 ,const wxSize& size = wxDefaultSize
74 ,long style = 0
75 ,const wxString& name = wxPanelNameStr
76 );
77
78 // ---------------------------------------------------------------------------
79 // wxWindowBase pure virtual implementations
80 // ---------------------------------------------------------------------------
81
82 // Z order
83 virtual void Raise();
84 virtual void Lower();
85 // Set the focus to this window
86 virtual void SetFocus();
87 // Warp the pointer the given position
88 virtual void WarpPointer(int x_pos, int y_pos) ;
89 // Capture/release mouse
90 virtual void CaptureMouse();
91 virtual void ReleaseMouse();
92 // Send the window a refresh event
93 virtual void Refresh(bool eraseBack = TRUE, const wxRect *rect = NULL);
94 // Clear the window
95 virtual void Clear();
96 // Set window's font
97 virtual bool SetFont(const wxFont& f);
98 // Get character size
99 virtual int GetCharHeight() const;
100 virtual int GetCharWidth() const;
101 virtual void GetTextExtent( const wxString& string
102 ,int* x
103 ,int* y
104 ,int* descent = NULL
105 ,int* externalLeading = NULL
106 ,const wxFont* theFont = NULL
107 ) const;
108
109 // Configure the window's scrollbar
110 virtual void SetScrollbar( int orient
111 ,int pos
112 ,int thumbVisible
113 ,int range
114 ,bool refresh = TRUE
115 );
116 virtual void SetScrollPos( int orient
117 ,int pos
118 ,bool refresh = TRUE
119 );
120 virtual int GetScrollPos(int orient) const;
121 virtual int GetScrollRange(int orient) const;
122 virtual int GetScrollThumb(int orient) const;
123 virtual void ScrollWindow( int dx
124 ,int dy
125 ,const wxRect* rect = NULL
126 );
127 #if wxUSE_DRAG_AND_DROP
128 void SetDropTarget(wxDropTarget *pDropTarget);
129 #endif
130 // coordinates translation
131 virtual void DoClientToScreen( int *x, int *y ) const;
132 virtual void DoScreenToClient( int *x, int *y ) const;
133
134 // retrieve the position/size of the window
135 virtual void DoGetPosition( int *x, int *y ) const;
136 virtual void DoGetSize( int *width, int *height ) const;
137 virtual void DoGetClientSize( int *width, int *height ) const;
138
139 // this is the virtual function to be overriden in any derived class which
140 // wants to change how SetSize() or Move() works - it is called by all
141 // versions of these functions in the base class
142 virtual void DoSetSize(int x, int y,
143 int width, int height,
144 int sizeFlags = wxSIZE_AUTO);
145
146 // same as DoSetSize() for the client size
147 virtual void DoSetClientSize(int width, int height);
148 virtual bool DoPopupMenu( wxMenu *menu, int x, int y );
149
150 // ---------------------------------------------------------------------------
151 // wxWindowBase virtual implementations that need to be overriden
152 // ---------------------------------------------------------------------------
153
154 // Fit the window around the items
155 virtual void Fit();
156 // Show or hide the window
157 virtual bool Show(bool show); // check if base implementation is OK
158 // Enable or disable the window
159 virtual bool Enable(bool enable); // check if base implementation is OK
160 // Set the cursor
161 virtual bool SetCursor(const wxCursor& cursor); // check if base implementation is OK
162
163 // ---------------------------------------------------------------------------
164 // additional functions
165 // ---------------------------------------------------------------------------
166
167 // Dialog support: override these and call
168 // base class members to add functionality
169 // that can't be done using validators.
170 void SetClientSize( int width, int height )
171 { DoSetClientSize(width, height); }
172
173 void SetClientSize( const wxSize& size )
174 { DoSetClientSize(size.x, size.y); }
175
176 void SetClientSize(const wxRect& rect)
177 { SetClientSize( rect.width, rect.height ); }
178
179 // Validate controls. If returns FALSE,
180 // validation failed: don't quit
181 virtual bool Validate();
182
183 // Return code for dialogs
184 inline void SetReturnCode(int retCode);
185 inline int GetReturnCode();
186
187
188 // Get the window with the focus
189 static wxWindow *FindFocus();
190
191 // Accept files for dragging
192 virtual void DragAcceptFiles(bool accept);
193
194 // Most windows have the concept of a label; for frames, this is the
195 // title; for items, this is the label or button text.
196 inline virtual wxString GetLabel() const { return GetTitle(); }
197
198 #if wxUSE_CARET && WXWIN_COMPATIBILITY
199 // Caret manipulation
200 virtual void CreateCaret(int w, int h);
201 virtual void CreateCaret(const wxBitmap *bitmap);
202 virtual void DestroyCaret();
203 virtual void ShowCaret(bool show);
204 virtual void SetCaretPos(int x, int y);
205 virtual void GetCaretPos(int *x, int *y) const;
206 #endif
207
208 // Handle a control command
209 virtual void OnCommand(wxWindow& win, wxCommandEvent& event);
210
211 // Get the default button, if there is one
212 inline virtual wxButton *GetDefaultItem() const;
213 inline virtual void SetDefaultItem(wxButton *but);
214
215 // Override to define new behaviour for default action (e.g. double clicking
216 // on a listbox)
217 virtual void OnDefaultAction(wxControl *initiatingItem);
218
219 // EventHandlers
220 void OnEraseBackground(wxEraseEvent& event);
221 void OnChar(wxKeyEvent& event);
222 void OnKeyDown(wxKeyEvent& event);
223 void OnKeyUp(wxKeyEvent& event);
224 void OnPaint(wxPaintEvent& event);
225 void OnIdle(wxIdleEvent& event);
226
227 // Accessors
228
229 WXHWND GetHWND() const { return m_hWnd; }
230 void SetHWND(WXHWND hWnd) { m_hWnd = hWnd; }
231 virtual WXWidget GetHandle() const { return GetHWND(); }
232
233 public:
234 // ---------------------------------------------------------------------------
235 // IMPLEMENTATION
236 // ---------------------------------------------------------------------------
237
238 // For implementation purposes - sometimes decorations make the client area
239 // smaller
240 virtual wxPoint GetClientAreaOrigin() const;
241
242 // Makes an adjustment to the window position (for example, a frame that has
243 // a toolbar that it manages itself).
244 virtual void AdjustForParentClientOrigin(int& x, int& y, int sizeFlags);
245
246 // Windows subclassing
247 void SubclassWin(WXHWND hWnd);
248 void UnsubclassWin();
249
250 WXFARPROC OS2GetOldWndProc() const { return m_oldWndProc; }
251 void OS2SetOldWndProc(WXFARPROC proc) { m_oldWndProc = proc; }
252
253 wxWindow *FindItem(long id) const;
254 wxWindow *FindItemByHWND(WXHWND hWnd, bool controlOnly = FALSE) const;
255
256 // Determine whether 3D effects are wanted
257 WXDWORD Determine3DEffects(WXDWORD defaultBorderStyle, bool *want3D) const;
258
259 // PM only: TRUE if this control is part of the main control
260 virtual bool ContainsHWND(WXHWND WXUNUSED(hWnd)) const { return FALSE; };
261
262 // Executes the default message
263 virtual long Default();
264
265 // Constraint implementation
266 void UnsetConstraints(wxLayoutConstraints *c);
267 // Back-pointer to other windows we're involved with, so if we delete
268 // this window, we must delete any constraints we're involved with.
269
270 wxObject *GetChild(int number) const ;
271
272 // Transfers data to any child controls
273 void OnInitDialog(wxInitDialogEvent& event);
274
275 protected:
276
277 // Caret data
278 int m_caretWidth;
279 int m_caretHeight;
280 bool m_caretEnabled;
281 bool m_caretShown;
282
283 wxButton * m_defaultItem;
284
285 public:
286 WXFARPROC m_oldWndProc;
287 int m_returnCode;
288 bool m_isBeingDeleted;
289 bool m_isShown;
290 bool m_winCaptured;
291 bool m_mouseInWindow;
292 bool m_backgroundTransparent;
293 // handles
294 WXHWND m_hWnd;
295 WXHMENU m_hMenu; // Menu, if any
296
297 // the size of one page for scrolling
298 int m_xThumbSize;
299 int m_yThumbSize;
300 long m_lDlgCode;
301
302 DECLARE_EVENT_TABLE()
303 private:
304 void Init();
305 void PMDetachWindowMenu();
306 };
307
308 ////////////////////////////////////////////////////////////////////////
309 //// INLINES
310
311 inline wxButton *wxWindow::GetDefaultItem() const { return m_defaultItem; }
312 inline void wxWindow::SetDefaultItem(wxButton *but) { m_defaultItem = but; }
313 inline void wxWindow::SetReturnCode(int retCode) { m_returnCode = retCode; }
314 inline int wxWindow::GetReturnCode() { return m_returnCode; }
315
316 // Get the active window.
317 wxWindow* WXDLLEXPORT wxGetActiveWindow();
318
319 #endif
320 // _WX_WINDOW_H_