]> git.saurik.com Git - wxWidgets.git/blame - src/os2/frame.cpp
corrected dynamic class implementation
[wxWidgets.git] / src / os2 / frame.cpp
CommitLineData
0e320a79
DW
1/////////////////////////////////////////////////////////////////////////////
2// Name: frame.cpp
0d53fc34 3// Purpose: wxFrame
f0a56ab0 4// Author: David Webster
0e320a79 5// Modified by:
29435d81 6// Created: 10/27/99
0e320a79 7// RCS-ID: $Id$
f0a56ab0 8// Copyright: (c) David Webster
0e320a79
DW
9// Licence: wxWindows licence
10/////////////////////////////////////////////////////////////////////////////
11
21802234
DW
12// For compilers that support precompilation, includes "wx.h".
13#include "wx/wxprec.h"
14
15#ifndef WX_PRECOMP
51c1d535
DW
16 #include "wx/defs.h"
17 #include "wx/object.h"
18 #include "wx/dynarray.h"
19 #include "wx/list.h"
20 #include "wx/hash.h"
21 #include "wx/string.h"
22 #include "wx/intl.h"
23 #include "wx/log.h"
24 #include "wx/event.h"
21802234
DW
25 #include "wx/setup.h"
26 #include "wx/frame.h"
27 #include "wx/menu.h"
28 #include "wx/app.h"
29 #include "wx/utils.h"
30 #include "wx/dialog.h"
31 #include "wx/settings.h"
32 #include "wx/dcclient.h"
33#endif // WX_PRECOMP
34
35#include "wx/os2/private.h"
f38374d0
DW
36
37#if wxUSE_STATUSBAR
38 #include "wx/statusbr.h"
ea51d98d 39 #include "wx/generic/statusbr.h"
f38374d0
DW
40#endif // wxUSE_STATUSBAR
41
42#if wxUSE_TOOLBAR
43 #include "wx/toolbar.h"
44#endif // wxUSE_TOOLBAR
45
0e320a79 46#include "wx/menuitem.h"
21802234 47#include "wx/log.h"
0e320a79 48
f38374d0
DW
49// ----------------------------------------------------------------------------
50// globals
51// ----------------------------------------------------------------------------
52
21802234
DW
53extern wxWindowList wxModelessWindows;
54extern wxList WXDLLEXPORT wxPendingDelete;
55extern wxChar wxFrameClassName[];
19193a2c
KB
56
57#if wxUSE_MENUS_NATIVE
21802234 58extern wxMenu *wxCurrentPopupMenu;
19193a2c 59#endif
0e320a79 60
19193a2c
KB
61extern void wxAssociateWinWithHandle( HWND hWnd
62 ,wxWindowOS2* pWin
b7084589 63 );
51c1d535 64
f38374d0
DW
65// ----------------------------------------------------------------------------
66// event tables
67// ----------------------------------------------------------------------------
68
0d53fc34
VS
69BEGIN_EVENT_TABLE(wxFrame, wxFrameBase)
70 EVT_ACTIVATE(wxFrame::OnActivate)
71 EVT_SYS_COLOUR_CHANGED(wxFrame::OnSysColourChanged)
0e320a79
DW
72END_EVENT_TABLE()
73
8d7ddd02 74IMPLEMENT_DYNAMIC_CLASS(wxFrame, wxWindow)
0e320a79 75
f38374d0
DW
76// ============================================================================
77// implementation
78// ============================================================================
0e320a79 79
f38374d0
DW
80// ----------------------------------------------------------------------------
81// static class members
82// ----------------------------------------------------------------------------
7e99520b 83#if wxUSE_STATUSBAR
0e320a79 84
f38374d0 85#if wxUSE_NATIVE_STATUSBAR
0d53fc34 86 bool wxFrame::m_bUseNativeStatusBar = TRUE;
f38374d0 87#else
0d53fc34 88 bool wxFrame::m_bUseNativeStatusBar = FALSE;
f38374d0 89#endif
0e320a79 90
7e99520b
DW
91#endif //wxUSE_STATUSBAR
92
f38374d0
DW
93// ----------------------------------------------------------------------------
94// creation/destruction
95// ----------------------------------------------------------------------------
96
0d53fc34 97void wxFrame::Init()
0e320a79 98{
80d83cbc 99 m_bIconized = FALSE;
f38374d0 100
21802234 101#if wxUSE_TOOLTIPS
a885d89a 102 m_hWndToolTip = 0;
21802234 103#endif
ea51d98d
DW
104 // Data to save/restore when calling ShowFullScreen
105 m_lFsStyle = 0L;
106 m_lFsOldWindowStyle = 0L;
107 m_nFsStatusBarFields = 0;
108 m_nFsStatusBarHeight = 0;
109 m_nFsToolBarHeight = 0;
110 m_bFsIsMaximized = FALSE;
111 m_bFsIsShowing = FALSE;
64e0c5c6
DW
112 m_bIsShown = FALSE;
113 m_pWinLastFocused = (wxWindow *)NULL;
40bd6154 114
51c1d535
DW
115 m_hFrame = NULL;
116 m_hTitleBar = NULL;
117 m_hHScroll = NULL;
118 m_hVScroll = NULL;
119
40bd6154
DW
120 //
121 // Initialize SWP's
122 //
123 memset(&m_vSwp, 0, sizeof(SWP));
124 memset(&m_vSwpClient, 0, sizeof(SWP));
125 memset(&m_vSwpTitleBar, 0, sizeof(SWP));
126 memset(&m_vSwpMenuBar, 0, sizeof(SWP));
127 memset(&m_vSwpHScroll, 0, sizeof(SWP));
128 memset(&m_vSwpVScroll, 0, sizeof(SWP));
129 memset(&m_vSwpStatusBar, 0, sizeof(SWP));
130 memset(&m_vSwpToolBar, 0, sizeof(SWP));
0d53fc34 131} // end of wxFrame::Init
ea51d98d 132
0d53fc34 133bool wxFrame::Create(
ea51d98d
DW
134 wxWindow* pParent
135, wxWindowID vId
136, const wxString& rsTitle
137, const wxPoint& rPos
138, const wxSize& rSize
a885d89a 139, long lulStyle
ea51d98d
DW
140, const wxString& rsName
141)
f38374d0 142{
ea51d98d
DW
143 int nX = rPos.x;
144 int nY = rPos.y;
145 int nWidth = rSize.x;
146 int nHeight = rSize.y;
51c1d535 147 bool bOk = FALSE;
ea51d98d
DW
148
149 SetName(rsName);
a885d89a 150 m_windowStyle = lulStyle;
ea51d98d 151 m_frameMenuBar = NULL;
7e99520b 152#if wxUSE_TOOLBAR
ea51d98d 153 m_frameToolBar = NULL;
7e99520b
DW
154#endif //wxUSE_TOOLBAR
155
156#if wxUSE_STATUSBAR
ea51d98d 157 m_frameStatusBar = NULL;
7e99520b 158#endif //wxUSE_STATUSBAR
ea51d98d
DW
159
160 SetBackgroundColour(wxSystemSettings::GetSystemColour(wxSYS_COLOUR_APPWORKSPACE));
161
162 if (vId > -1 )
163 m_windowId = vId;
164 else
165 m_windowId = (int)NewControlId();
166
80d83cbc 167 if (pParent)
ea51d98d
DW
168 pParent->AddChild(this);
169
170 m_bIconized = FALSE;
171
ea51d98d
DW
172 if ((m_windowStyle & wxFRAME_FLOAT_ON_PARENT) == 0)
173 pParent = NULL;
174
51c1d535
DW
175 bOk = OS2Create( m_windowId
176 ,pParent
177 ,wxFrameClassName
178 ,this
179 ,rsTitle
180 ,nX
181 ,nY
182 ,nWidth
183 ,nHeight
184 ,lulStyle
185 );
186 if (bOk)
187 {
188 if (!pParent)
189 wxTopLevelWindows.Append(this);
190 wxModelessWindows.Append(this);
191 }
192 return(bOk);
0d53fc34 193} // end of wxFrame::Create
0e320a79 194
0d53fc34 195wxFrame::~wxFrame()
0e320a79 196{
ea51d98d 197 m_isBeingDeleted = TRUE;
e604d44b 198
ea51d98d 199 wxTopLevelWindows.DeleteObject(this);
0e320a79 200
ea51d98d 201 DeleteAllBars();
29435d81 202
ea51d98d
DW
203 if (wxTheApp && (wxTopLevelWindows.Number() == 0))
204 {
205 wxTheApp->SetTopWindow(NULL);
0e320a79 206
ea51d98d
DW
207 if (wxTheApp->GetExitOnFrameDelete())
208 {
4d098649 209 ::WinPostMsg(NULL, WM_QUIT, 0, 0);
ea51d98d
DW
210 }
211 }
5b3ed311 212
ea51d98d
DW
213 wxModelessWindows.DeleteObject(this);
214
215 //
216 // For some reason, wxWindows can activate another task altogether
217 // when a frame is destroyed after a modal dialog has been invoked.
218 // Try to bring the parent to the top.
219 //
220 // MT:Only do this if this frame is currently the active window, else weird
221 // things start to happen.
222 //
223 if (wxGetActiveWindow() == this)
0e320a79 224 {
ea51d98d
DW
225 if (GetParent() && GetParent()->GetHWND())
226 {
ea51d98d
DW
227 ::WinSetWindowPos( (HWND) GetParent()->GetHWND()
228 ,HWND_TOP
80d83cbc
DW
229 ,0
230 ,0
231 ,0
232 ,0
233 ,SWP_ZORDER
ea51d98d
DW
234 );
235 }
0e320a79 236 }
0d53fc34 237} // end of wxFrame::~wxFrame
0e320a79 238
ea51d98d 239//
0e320a79 240// Get size *available for subwindows* i.e. excluding menu bar, toolbar etc.
ea51d98d 241//
0d53fc34 242void wxFrame::DoGetClientSize(
80d83cbc
DW
243 int* pX
244, int* pY
245) const
0e320a79 246{
80d83cbc 247 RECTL vRect;
40bd6154 248 ::WinQueryWindowRect(GetHwnd(), &vRect);
51523f25 249
5fb9d2be
DW
250 //
251 // No need to use statusbar code as in WIN32 as the FORMATFRAME
252 // window procedure ensures PM knows about the new frame client
253 // size internally. A ::WinQueryWindowRect is all that is needed!
254 //
255
80d83cbc 256 if (pX)
51c1d535 257 *pX = vRect.xRight - vRect.xLeft;
80d83cbc 258 if (pY)
51c1d535 259 *pY = vRect.yTop - vRect.yBottom;
0d53fc34 260} // end of wxFrame::DoGetClientSize
0e320a79 261
a885d89a 262//
0e320a79
DW
263// Set the client size (i.e. leave the calculation of borders etc.
264// to wxWindows)
80d83cbc 265//
0d53fc34 266void wxFrame::DoSetClientSize(
80d83cbc
DW
267 int nWidth
268, int nHeight
269)
0e320a79 270{
80d83cbc 271 HWND hWnd = GetHwnd();
80d83cbc 272 RECTL vRect;
a7ef993c 273 RECTL vRect2;
0e320a79 274
40bd6154 275 ::WinQueryWindowRect(GetHwnd(), &vRect);
51c1d535 276 ::WinQueryWindowRect(GetHwnd(), &vRect2);
21802234 277
80d83cbc
DW
278 //
279 // Find the difference between the entire window (title bar and all)
280 // and the client area; add this to the new client size to move the
281 // window. Remember OS/2's backwards y coord system!
282 //
283 int nActualWidth = vRect2.xRight - vRect2.xLeft - vRect.xRight + nWidth;
284 int nActualHeight = vRect2.yTop + vRect2.yTop - vRect.yTop + nHeight;
29435d81 285
f38374d0 286#if wxUSE_STATUSBAR
80d83cbc
DW
287 if ( GetStatusBar() )
288 {
289 int nStatusX;
290 int nStatusY;
291
292 GetStatusBar()->GetClientSize( &nStatusX
293 ,&nStatusY
294 );
295 nActualHeight += nStatusY;
296 }
f38374d0 297#endif // wxUSE_STATUSBAR
29435d81 298
80d83cbc
DW
299 wxPoint vPoint(GetClientAreaOrigin());
300 nActualWidth += vPoint.y;
301 nActualHeight += vPoint.x;
302
303 POINTL vPointl;
304
305 vPointl.x = vRect2.xLeft;
64e0c5c6 306 vPointl.y = vRect2.yTop;
80d83cbc 307
64e0c5c6 308 ::WinSetWindowPos( hWnd
80d83cbc
DW
309 ,HWND_TOP
310 ,vPointl.x
311 ,vPointl.y
312 ,nActualWidth
313 ,nActualHeight
314 ,SWP_MOVE | SWP_SIZE | SWP_SHOW
315 );
316
317 wxSizeEvent vEvent( wxSize( nWidth
318 ,nHeight
319 )
320 ,m_windowId
321 );
322 vEvent.SetEventObject(this);
323 GetEventHandler()->ProcessEvent(vEvent);
0d53fc34 324} // end of wxFrame::DoSetClientSize
80d83cbc 325
0d53fc34 326void wxFrame::DoGetSize(
80d83cbc
DW
327 int* pWidth
328, int* pHeight
329) const
330{
331 RECTL vRect;
21802234 332
51c1d535 333 ::WinQueryWindowRect(m_hFrame, &vRect);
80d83cbc
DW
334 *pWidth = vRect.xRight - vRect.xLeft;
335 *pHeight = vRect.yTop - vRect.yBottom;
0d53fc34 336} // end of wxFrame::DoGetSize
21802234 337
0d53fc34 338void wxFrame::DoGetPosition(
80d83cbc
DW
339 int* pX
340, int* pY
341) const
342{
343 RECTL vRect;
a885d89a 344 POINTL vPoint;
29435d81 345
51c1d535 346 ::WinQueryWindowRect(m_hFrame, &vRect);
0e320a79 347
3febf684
DW
348 *pX = vRect.xRight - vRect.xLeft;
349 *pY = vRect.yTop - vRect.yBottom;
0d53fc34 350} // end of wxFrame::DoGetPosition
0e320a79 351
f38374d0
DW
352// ----------------------------------------------------------------------------
353// variations around ::ShowWindow()
354// ----------------------------------------------------------------------------
355
0d53fc34 356void wxFrame::DoShowWindow(
426d5745 357 int bShowCmd
80d83cbc 358)
0e320a79 359{
51c1d535 360 ::WinShowWindow(m_hFrame, (BOOL)bShowCmd);
64e0c5c6 361 m_bIconized = bShowCmd == SWP_MINIMIZE;
0d53fc34 362} // end of wxFrame::DoShowWindow
21802234 363
0d53fc34 364bool wxFrame::Show(
80d83cbc
DW
365 bool bShow
366)
0e320a79 367{
426d5745
DW
368 SWP vSwp;
369
370 DoShowWindow((int)bShow);
21802234 371
80d83cbc 372 if (bShow)
f38374d0 373 {
80d83cbc
DW
374 wxActivateEvent vEvent(wxEVT_ACTIVATE, TRUE, m_windowId);
375
51c1d535 376 ::WinQueryWindowPos(m_hFrame, &vSwp);
d8530167 377 m_bIconized = vSwp.fl & SWP_MINIMIZE;
51c1d535
DW
378 ::WinSendMsg(m_hFrame, WM_UPDATEFRAME, (MPARAM)~0, 0);
379 ::WinEnableWindow(m_hFrame, TRUE);
80d83cbc
DW
380 vEvent.SetEventObject(this);
381 GetEventHandler()->ProcessEvent(vEvent);
f38374d0
DW
382 }
383 else
384 {
80d83cbc 385 //
f38374d0 386 // Try to highlight the correct window (the parent)
80d83cbc
DW
387 //
388 if (GetParent())
f38374d0 389 {
80d83cbc
DW
390 HWND hWndParent = GetHwndOf(GetParent());
391
426d5745 392 ::WinQueryWindowPos(hWndParent, &vSwp);
d8530167 393 m_bIconized = vSwp.fl & SWP_MINIMIZE;
f38374d0 394 if (hWndParent)
80d83cbc
DW
395 ::WinSetWindowPos( hWndParent
396 ,HWND_TOP
426d5745
DW
397 ,vSwp.x
398 ,vSwp.y
399 ,vSwp.cx
400 ,vSwp.cy
401 ,SWP_ZORDER | SWP_ACTIVATE | SWP_SHOW | SWP_MOVE
80d83cbc 402 );
a0606634 403 ::WinEnableWindow(hWndParent, TRUE);
f38374d0
DW
404 }
405 }
f38374d0 406 return TRUE;
0d53fc34 407} // end of wxFrame::Show
f38374d0 408
0d53fc34 409void wxFrame::Iconize(
80d83cbc
DW
410 bool bIconize
411)
f38374d0 412{
80d83cbc 413 DoShowWindow(bIconize ? SWP_MINIMIZE : SWP_RESTORE);
0d53fc34 414} // end of wxFrame::Iconize
0e320a79 415
0d53fc34 416void wxFrame::Maximize(
80d83cbc 417 bool bMaximize)
0e320a79 418{
80d83cbc 419 DoShowWindow(bMaximize ? SWP_MAXIMIZE : SWP_RESTORE);
0d53fc34 420} // end of wxFrame::Maximize
f38374d0 421
0d53fc34 422void wxFrame::Restore()
f38374d0 423{
80d83cbc 424 DoShowWindow(SWP_RESTORE);
0d53fc34 425} // end of wxFrame::Restore
0e320a79 426
0d53fc34 427bool wxFrame::IsIconized() const
0e320a79 428{
80d83cbc 429 SWP vSwp;
80d83cbc 430
51c1d535 431 ::WinQueryWindowPos(m_hFrame, &vSwp);
a885d89a 432
80d83cbc
DW
433 if (vSwp.fl & SWP_MINIMIZE)
434 ((wxFrame*)this)->m_bIconized = TRUE;
435 else
436 ((wxFrame*)this)->m_bIconized = FALSE;
437 return m_bIconized;
0d53fc34 438} // end of wxFrame::IsIconized
0e320a79 439
21802234 440// Is it maximized?
0d53fc34 441bool wxFrame::IsMaximized() const
0e320a79 442{
80d83cbc
DW
443 SWP vSwp;
444 bool bIconic;
445
51c1d535 446 ::WinQueryWindowPos(m_hFrame, &vSwp);
80d83cbc 447 return (vSwp.fl & SWP_MAXIMIZE);
0d53fc34 448} // end of wxFrame::IsMaximized
0e320a79 449
0d53fc34 450void wxFrame::SetIcon(
0fe536e3
DW
451 const wxIcon& rIcon
452)
0e320a79 453{
0fe536e3 454 wxFrameBase::SetIcon(rIcon);
f38374d0 455
426d5745 456 if ((m_icon.GetHICON()) != NULLHANDLE)
f38374d0 457 {
51c1d535 458 ::WinSendMsg( m_hFrame
f23208ca 459 ,WM_SETICON
426d5745 460 ,(MPARAM)((HPOINTER)m_icon.GetHICON())
f23208ca
DW
461 ,NULL
462 );
51c1d535 463 ::WinSendMsg( m_hFrame
f23208ca
DW
464 ,WM_UPDATEFRAME
465 ,(MPARAM)FCF_ICON
466 ,(MPARAM)0
467 );
f38374d0 468 }
0d53fc34 469} // end of wxFrame::SetIcon
0e320a79 470
21802234 471#if wxUSE_STATUSBAR
0d53fc34 472wxStatusBar* wxFrame::OnCreateStatusBar(
0fe536e3 473 int nNumber
a885d89a 474, long lulStyle
0fe536e3
DW
475, wxWindowID vId
476, const wxString& rName
477)
0e320a79 478{
0fe536e3 479 wxStatusBar* pStatusBar = NULL;
f6bcfd97
BP
480 SWP vSwp;
481 ERRORID vError;
482 wxString sError;
0e320a79 483
0fe536e3 484 pStatusBar = wxFrameBase::OnCreateStatusBar( nNumber
a885d89a 485 ,lulStyle
0fe536e3
DW
486 ,vId
487 ,rName
5b3ed311
DW
488 );
489
490 if( !pStatusBar )
f6bcfd97 491 return NULL;
f6bcfd97 492
51c1d535
DW
493 ::WinSetParent( pStatusBar->GetHWND()
494 ,m_hFrame
495 ,FALSE
496 );
497 ::WinSetOwner( pStatusBar->GetHWND()
498 ,m_hFrame
499 );
7e99520b 500 //
5b3ed311 501 // to show statusbar
f6bcfd97 502 //
51c1d535
DW
503 if(::WinIsWindowShowing(m_hFrame))
504 ::WinSendMsg(m_hFrame, WM_UPDATEFRAME, (MPARAM)~0, 0);
7e99520b 505
0fe536e3 506 return pStatusBar;
0d53fc34 507} // end of wxFrame::OnCreateStatusBar
0e320a79 508
0d53fc34 509void wxFrame::PositionStatusBar()
0e320a79 510{
f6bcfd97
BP
511 SWP vSwp;
512 ERRORID vError;
513 wxString sError;
514
0fe536e3
DW
515 //
516 // Native status bar positions itself
517 //
518 if (m_frameStatusBar)
f38374d0 519 {
a885d89a 520 int nWidth;
a885d89a 521 int nStatbarWidth;
0fe536e3
DW
522 int nStatbarHeight;
523 HWND hWndClient;
524 RECTL vRect;
51c1d535 525 RECTL vFRect;
0fe536e3 526
51c1d535
DW
527 ::WinQueryWindowRect(m_hFrame, &vRect);
528 ::WinMapWindowPoints(m_hFrame, HWND_DESKTOP, (PPOINTL)&vRect, 2);
529 vFRect = vRect;
530 ::WinCalcFrameRect(m_hFrame, &vRect, TRUE);
0fe536e3 531 nWidth = vRect.xRight - vRect.xLeft;
a885d89a 532
0fe536e3
DW
533 m_frameStatusBar->GetSize( &nStatbarWidth
534 ,&nStatbarHeight
535 );
f38374d0 536
0fe536e3 537 //
f38374d0
DW
538 // Since we wish the status bar to be directly under the client area,
539 // we use the adjusted sizes without using wxSIZE_NO_ADJUSTMENTS.
0fe536e3 540 //
51c1d535
DW
541 m_frameStatusBar->SetSize( vRect.xLeft - vFRect.xLeft
542 ,vRect.yBottom - vFRect.yBottom
0fe536e3
DW
543 ,nWidth
544 ,nStatbarHeight
545 );
f6bcfd97
BP
546 if (!::WinQueryWindowPos(m_frameStatusBar->GetHWND(), &vSwp))
547 {
548 vError = ::WinGetLastError(vHabmain);
549 sError = wxPMErrorToStr(vError);
51c1d535 550 wxLogError("Error setting parent for StautsBar. Error: %s\n", sError);
f6bcfd97
BP
551 return;
552 }
f38374d0 553 }
0d53fc34 554} // end of wxFrame::PositionStatusBar
21802234 555#endif // wxUSE_STATUSBAR
0e320a79 556
19193a2c 557#if wxUSE_MENUS_NATIVE
0d53fc34 558void wxFrame::DetachMenuBar()
0e320a79 559{
21802234 560 if (m_frameMenuBar)
0e320a79 561 {
29435d81 562 m_frameMenuBar->Detach();
0e320a79 563 m_frameMenuBar = NULL;
21802234 564 }
0d53fc34 565} // end of wxFrame::DetachMenuBar
21802234 566
0d53fc34 567void wxFrame::SetMenuBar(
a885d89a 568 wxMenuBar* pMenuBar
0fe536e3 569)
21802234 570{
c3cea748
DW
571 ERRORID vError;
572 wxString sError;
dae16775
DW
573 HWND hTitlebar = NULLHANDLE;
574 HWND hHScroll = NULLHANDLE;
575 HWND hVScroll = NULLHANDLE;
576 HWND hMenuBar = NULLHANDLE;
577 SWP vSwp;
578 SWP vSwpTitlebar;
579 SWP vSwpVScroll;
580 SWP vSwpHScroll;
581 SWP vSwpMenu;
c3cea748 582
0fe536e3 583 if (!pMenuBar)
21802234
DW
584 {
585 DetachMenuBar();
29a99be3 586
64e0c5c6
DW
587 //
588 // Actually remove the menu from the frame
589 //
590 m_hMenu = (WXHMENU)0;
591 InternalSetMenuBar();
29a99be3 592 }
64e0c5c6 593 else // set new non NULL menu bar
c3cea748 594 {
64e0c5c6 595 m_frameMenuBar = NULL;
c3cea748 596
64e0c5c6
DW
597 //
598 // Can set a menubar several times.
599 // TODO: how to prevent a memory leak if you have a currently-unattached
600 // menubar? wxWindows assumes that the frame will delete the menu (otherwise
601 // there are problems for MDI).
602 //
603 if (pMenuBar->GetHMenu())
604 {
605 m_hMenu = pMenuBar->GetHMenu();
606 }
607 else
608 {
609 pMenuBar->Detach();
610 m_hMenu = pMenuBar->Create();
611 if (!m_hMenu)
612 return;
613 }
614 InternalSetMenuBar();
615 m_frameMenuBar = pMenuBar;
0367c1c0 616 pMenuBar->Attach((wxFrame*)this);
c3cea748 617 }
0d53fc34 618} // end of wxFrame::SetMenuBar
0e320a79 619
0d53fc34 620void wxFrame::AttachMenuBar(
893758d5
DW
621 wxMenuBar* pMenubar
622)
623{
19193a2c
KB
624 wxFrameBase::AttachMenuBar(pMenubar);
625
893758d5
DW
626 m_frameMenuBar = pMenubar;
627
628 if (!pMenubar)
629 {
630 //
631 // Actually remove the menu from the frame
632 //
633 m_hMenu = (WXHMENU)0;
634 InternalSetMenuBar();
635 }
636 else // Set new non NULL menu bar
637 {
638 //
639 // Can set a menubar several times.
640 //
641 if (pMenubar->GetHMenu())
642 {
643 m_hMenu = pMenubar->GetHMenu();
644 }
645 else
646 {
647 if (pMenubar->IsAttached())
648 pMenubar->Detach();
649
650 m_hMenu = pMenubar->Create();
651
652 if (!m_hMenu)
653 return;
654 }
655 InternalSetMenuBar();
656 }
0d53fc34 657} // end of wxFrame::AttachMenuBar
893758d5 658
0d53fc34 659void wxFrame::InternalSetMenuBar()
0e320a79 660{
64e0c5c6
DW
661 ERRORID vError;
662 wxString sError;
663 //
664 // Set the parent and owner of the menubar to be the frame
665 //
51c1d535 666 if (!::WinSetParent(m_hMenu, m_hFrame, FALSE))
64e0c5c6
DW
667 {
668 vError = ::WinGetLastError(vHabmain);
669 sError = wxPMErrorToStr(vError);
670 wxLogError("Error setting parent for submenu. Error: %s\n", sError);
671 }
672
51c1d535 673 if (!::WinSetOwner(m_hMenu, m_hFrame))
64e0c5c6
DW
674 {
675 vError = ::WinGetLastError(vHabmain);
676 sError = wxPMErrorToStr(vError);
677 wxLogError("Error setting parent for submenu. Error: %s\n", sError);
678 }
b7084589 679 ::WinSendMsg(m_hFrame, WM_UPDATEFRAME, (MPARAM)FCF_MENU, (MPARAM)0);
0d53fc34 680} // end of wxFrame::InternalSetMenuBar
19193a2c 681#endif // wxUSE_MENUS_NATIVE
0e320a79 682
a885d89a
DW
683//
684// Responds to colour changes, and passes event on to children
685//
0d53fc34 686void wxFrame::OnSysColourChanged(
a885d89a
DW
687 wxSysColourChangedEvent& rEvent
688)
0e320a79
DW
689{
690 SetBackgroundColour(wxSystemSettings::GetSystemColour(wxSYS_COLOUR_APPWORKSPACE));
691 Refresh();
692
7e99520b 693#if wxUSE_STATUSBAR
a885d89a 694 if (m_frameStatusBar)
0e320a79 695 {
a885d89a
DW
696 wxSysColourChangedEvent vEvent2;
697
698 vEvent2.SetEventObject(m_frameStatusBar);
699 m_frameStatusBar->GetEventHandler()->ProcessEvent(vEvent2);
0e320a79 700 }
7e99520b 701#endif //wxUSE_STATUSBAR
0e320a79 702
a885d89a 703 //
0e320a79 704 // Propagate the event to the non-top-level children
a885d89a
DW
705 //
706 wxWindow::OnSysColourChanged(rEvent);
0d53fc34 707} // end of wxFrame::OnSysColourChanged
21802234 708
542875a8 709// Pass TRUE to show full screen, FALSE to restore.
0d53fc34 710bool wxFrame::ShowFullScreen(
542875a8
DW
711 bool bShow
712, long lStyle
713)
714{
64e0c5c6 715 if (bShow)
542875a8
DW
716 {
717 if (IsFullScreen())
718 return FALSE;
719
64e0c5c6
DW
720 m_bFsIsShowing = TRUE;
721 m_lFsStyle = lStyle;
542875a8 722
7e99520b 723#if wxUSE_TOOLBAR
19193a2c 724 wxToolBar* pTheToolBar = GetToolBar();
7e99520b
DW
725#endif //wxUSE_TOOLBAR
726
727#if wxUSE_STATUSBAR
19193a2c 728 wxStatusBar* pTheStatusBar = GetStatusBar();
7e99520b 729#endif //wxUSE_STATUSBAR
542875a8 730
64e0c5c6 731 int nDummyWidth;
542875a8 732
7e99520b 733#if wxUSE_TOOLBAR
64e0c5c6
DW
734 if (pTheToolBar)
735 pTheToolBar->GetSize(&nDummyWidth, &m_nFsToolBarHeight);
7e99520b
DW
736#endif //wxUSE_TOOLBAR
737
738#if wxUSE_STATUSBAR
64e0c5c6
DW
739 if (pTheStatusBar)
740 pTheStatusBar->GetSize(&nDummyWidth, &m_nFsStatusBarHeight);
7e99520b 741#endif //wxUSE_STATUSBAR
542875a8 742
7e99520b 743#if wxUSE_TOOLBAR
64e0c5c6
DW
744 //
745 // Zap the toolbar, menubar, and statusbar
746 //
747 if ((lStyle & wxFULLSCREEN_NOTOOLBAR) && pTheToolBar)
542875a8 748 {
64e0c5c6
DW
749 pTheToolBar->SetSize(-1,0);
750 pTheToolBar->Show(FALSE);
542875a8 751 }
7e99520b 752#endif //wxUSE_TOOLBAR
542875a8 753
64e0c5c6
DW
754 if (lStyle & wxFULLSCREEN_NOMENUBAR)
755 {
b7084589
DW
756 ::WinSetParent(m_hMenu, m_hFrame, FALSE);
757 ::WinSetOwner(m_hMenu, m_hFrame);
758 ::WinSendMsg((HWND)m_hFrame, WM_UPDATEFRAME, (MPARAM)FCF_MENU, (MPARAM)0);
64e0c5c6 759 }
542875a8 760
7e99520b 761#if wxUSE_STATUSBAR
64e0c5c6 762 //
542875a8 763 // Save the number of fields in the statusbar
64e0c5c6
DW
764 //
765 if ((lStyle & wxFULLSCREEN_NOSTATUSBAR) && pTheStatusBar)
542875a8 766 {
64e0c5c6 767 m_nFsStatusBarFields = pTheStatusBar->GetFieldsCount();
542875a8 768 SetStatusBar((wxStatusBar*) NULL);
64e0c5c6 769 delete pTheStatusBar;
542875a8
DW
770 }
771 else
64e0c5c6 772 m_nFsStatusBarFields = 0;
7e99520b 773#endif //wxUSE_STATUSBAR
542875a8 774
64e0c5c6
DW
775 //
776 // Zap the frame borders
777 //
542875a8 778
64e0c5c6
DW
779 //
780 // Save the 'normal' window style
781 //
b7084589 782 m_lFsOldWindowStyle = ::WinQueryWindowULong(m_hFrame, QWL_STYLE);
542875a8 783
64e0c5c6 784 //
b7084589 785 // Save the old position, width & height, maximize state
64e0c5c6
DW
786 //
787 m_vFsOldSize = GetRect();
788 m_bFsIsMaximized = IsMaximized();
542875a8 789
64e0c5c6 790 //
b7084589 791 // Decide which window style flags to turn off
64e0c5c6
DW
792 //
793 LONG lNewStyle = m_lFsOldWindowStyle;
794 LONG lOffFlags = 0;
542875a8 795
64e0c5c6
DW
796 if (lStyle & wxFULLSCREEN_NOBORDER)
797 lOffFlags |= FCF_BORDER;
798 if (lStyle & wxFULLSCREEN_NOCAPTION)
799 lOffFlags |= (FCF_TASKLIST | FCF_SYSMENU);
542875a8 800
64e0c5c6 801 lNewStyle &= (~lOffFlags);
542875a8 802
64e0c5c6
DW
803 //
804 // Change our window style to be compatible with full-screen mode
805 //
b7084589 806 ::WinSetWindowULong((HWND)m_hFrame, QWL_STYLE, (ULONG)lNewStyle);
542875a8 807
64e0c5c6
DW
808 //
809 // Resize to the size of the desktop
810 int nWidth;
811 int nHeight;
542875a8 812
64e0c5c6 813 RECTL vRect;
542875a8 814
64e0c5c6
DW
815 ::WinQueryWindowRect(HWND_DESKTOP, &vRect);
816 nWidth = vRect.xRight - vRect.xLeft;
817 //
818 // Rmember OS/2 is backwards!
819 //
820 nHeight = vRect.yTop - vRect.yBottom;
542875a8 821
64e0c5c6
DW
822 SetSize( nWidth
823 ,nHeight
824 );
542875a8 825
64e0c5c6
DW
826 //
827 // Now flush the window style cache and actually go full-screen
828 //
829 ::WinSetWindowPos( (HWND) GetParent()->GetHWND()
830 ,HWND_TOP
831 ,0
832 ,0
833 ,nWidth
834 ,nHeight
835 ,SWP_SIZE | SWP_SHOW
836 );
837
838 wxSizeEvent vEvent( wxSize( nWidth
839 ,nHeight
840 )
841 ,GetId()
842 );
542875a8 843
64e0c5c6 844 GetEventHandler()->ProcessEvent(vEvent);
542875a8
DW
845 return TRUE;
846 }
847 else
848 {
849 if (!IsFullScreen())
850 return FALSE;
851
64e0c5c6 852 m_bFsIsShowing = FALSE;
542875a8 853
7e99520b 854#if wxUSE_TOOLBAR
64e0c5c6 855 wxToolBar* pTheToolBar = GetToolBar();
542875a8 856
64e0c5c6
DW
857 //
858 // Restore the toolbar, menubar, and statusbar
859 //
860 if (pTheToolBar && (m_lFsStyle & wxFULLSCREEN_NOTOOLBAR))
542875a8 861 {
64e0c5c6
DW
862 pTheToolBar->SetSize(-1, m_nFsToolBarHeight);
863 pTheToolBar->Show(TRUE);
542875a8 864 }
7e99520b 865#endif //wxUSE_TOOLBAR
542875a8 866
7e99520b 867#if wxUSE_STATUSBAR
64e0c5c6 868 if ((m_lFsStyle & wxFULLSCREEN_NOSTATUSBAR) && (m_nFsStatusBarFields > 0))
542875a8 869 {
64e0c5c6 870 CreateStatusBar(m_nFsStatusBarFields);
5b3ed311 871// PositionStatusBar();
542875a8 872 }
7e99520b 873#endif //wxUSE_STATUSBAR
542875a8 874
64e0c5c6
DW
875 if ((m_lFsStyle & wxFULLSCREEN_NOMENUBAR) && (m_hMenu != 0))
876 {
b7084589
DW
877 ::WinSetParent(m_hMenu, m_hFrame, FALSE);
878 ::WinSetOwner(m_hMenu, m_hFrame);
879 ::WinSendMsg(m_hFrame, WM_UPDATEFRAME, (MPARAM)FCF_MENU, (MPARAM)0);
64e0c5c6
DW
880 }
881 Maximize(m_bFsIsMaximized);
882
b7084589 883 ::WinSetWindowULong( m_hFrame
64e0c5c6
DW
884 ,QWL_STYLE
885 ,(ULONG)m_lFsOldWindowStyle
886 );
887 ::WinSetWindowPos( (HWND) GetParent()->GetHWND()
888 ,HWND_TOP
889 ,m_vFsOldSize.x
890 ,m_vFsOldSize.y
891 ,m_vFsOldSize.width
892 ,m_vFsOldSize.height
893 ,SWP_SIZE | SWP_SHOW
894 );
542875a8
DW
895 return TRUE;
896 }
0d53fc34 897} // end of wxFrame::ShowFullScreen
542875a8 898
a885d89a
DW
899//
900// Frame window
901//
0d53fc34 902bool wxFrame::OS2Create(
a885d89a
DW
903 int nId
904, wxWindow* pParent
905, const wxChar* zWclass
906, wxWindow* pWxWin
907, const wxChar* zTitle
908, int nX
909, int nY
910, int nWidth
911, int nHeight
912, long ulStyle
913)
21802234 914{
f23208ca
DW
915 ULONG ulCreateFlags = 0L;
916 ULONG ulStyleFlags = 0L;
914589c2 917 ULONG ulExtraFlags = 0L;
f23208ca
DW
918 FRAMECDATA vFrameCtlData;
919 HWND hParent = NULLHANDLE;
f23208ca
DW
920 HWND hTitlebar = NULLHANDLE;
921 HWND hHScroll = NULLHANDLE;
922 HWND hVScroll = NULLHANDLE;
51c1d535
DW
923 HWND hFrame = NULLHANDLE;
924 HWND hClient = NULLHANDLE;
b963e7d5
DW
925 SWP vSwp[10];
926 RECTL vRect[10];
40bd6154 927 USHORT uCtlCount;
51c1d535
DW
928 ERRORID vError;
929 wxString sError;
a885d89a
DW
930
931 m_hDefaultIcon = (WXHICON) (wxSTD_FRAME_ICON ? wxSTD_FRAME_ICON : wxDEFAULT_FRAME_ICON);
a0606634 932
f23208ca
DW
933 if (pParent)
934 hParent = GetWinHwnd(pParent);
935 else
936 hParent = HWND_DESKTOP;
a885d89a 937
914589c2 938 if (ulStyle == wxDEFAULT_FRAME_STYLE)
f23208ca 939 ulCreateFlags = FCF_SIZEBORDER | FCF_TITLEBAR | FCF_SYSMENU |
f6bcfd97 940 FCF_MINMAX | FCF_TASKLIST;
a885d89a 941 else
a885d89a 942 {
914589c2 943 if ((ulStyle & wxCAPTION) == wxCAPTION)
f23208ca 944 ulCreateFlags = FCF_TASKLIST;
914589c2 945 else
f23208ca 946 ulCreateFlags = FCF_NOMOVEWITHOWNER;
914589c2 947
f6bcfd97
BP
948 if ((ulStyle & wxVSCROLL) == wxVSCROLL)
949 ulCreateFlags |= FCF_VERTSCROLL;
950 if ((ulStyle & wxHSCROLL) == wxHSCROLL)
951 ulCreateFlags |= FCF_HORZSCROLL;
914589c2 952 if (ulStyle & wxMINIMIZE_BOX)
f23208ca 953 ulCreateFlags |= FCF_MINBUTTON;
914589c2 954 if (ulStyle & wxMAXIMIZE_BOX)
f23208ca 955 ulCreateFlags |= FCF_MAXBUTTON;
914589c2 956 if (ulStyle & wxTHICK_FRAME)
f23208ca 957 ulCreateFlags |= FCF_DLGBORDER;
914589c2 958 if (ulStyle & wxSYSTEM_MENU)
f23208ca 959 ulCreateFlags |= FCF_SYSMENU;
914589c2 960 if (ulStyle & wxCAPTION)
f23208ca 961 ulCreateFlags |= FCF_TASKLIST;
914589c2
DW
962 if (ulStyle & wxCLIP_CHILDREN)
963 {
964 // Invalid for frame windows under PM
965 }
a885d89a 966
914589c2 967 if (ulStyle & wxTINY_CAPTION_VERT)
f23208ca 968 ulCreateFlags |= FCF_TASKLIST;
914589c2 969 if (ulStyle & wxTINY_CAPTION_HORIZ)
f23208ca
DW
970 ulCreateFlags |= FCF_TASKLIST;
971
914589c2 972 if ((ulStyle & wxTHICK_FRAME) == 0)
f23208ca 973 ulCreateFlags |= FCF_BORDER;
914589c2
DW
974 if (ulStyle & wxFRAME_TOOL_WINDOW)
975 ulExtraFlags = kFrameToolWindow;
21802234 976
914589c2 977 if (ulStyle & wxSTAY_ON_TOP)
f23208ca 978 ulCreateFlags |= FCF_SYSMODAL;
914589c2 979 }
f23208ca
DW
980 if ((ulStyle & wxMINIMIZE) || (ulStyle & wxICONIZE))
981 ulStyleFlags |= WS_MINIMIZED;
982 if (ulStyle & wxMAXIMIZE)
983 ulStyleFlags |= WS_MAXIMIZED;
984
a885d89a
DW
985 //
986 // Clear the visible flag, we always call show
987 //
f23208ca 988 ulStyleFlags &= (unsigned long)~WS_VISIBLE;
a885d89a 989 m_bIconized = FALSE;
f23208ca
DW
990
991 //
992 // Set the frame control block
993 //
994 vFrameCtlData.cb = sizeof(vFrameCtlData);
995 vFrameCtlData.flCreateFlags = ulCreateFlags;
996 vFrameCtlData.hmodResources = 0L;
997 vFrameCtlData.idResources = 0;
998
999 //
51c1d535
DW
1000 // Create the frame window: We break ranks with other ports now
1001 // and instead of calling down into the base wxWindow class' OS2Create
1002 // we do all our own stuff here. We will set the needed pieces
1003 // of wxWindow manually, here.
f23208ca 1004 //
f23208ca 1005
51c1d535
DW
1006 hFrame = ::WinCreateStdWindow( hParent
1007 ,ulStyleFlags // frame-window style
1008 ,&ulCreateFlags // window style
1009 ,(PSZ)zWclass // class name
1010 ,(PSZ)zTitle // window title
1011 ,0L // default client style
1012 ,NULLHANDLE // resource in executable file
1013 ,0 // resource id
1014 ,&hClient // receives client window handle
1015 );
1016 if (!hFrame)
f23208ca 1017 {
51c1d535
DW
1018 vError = ::WinGetLastError(vHabmain);
1019 sError = wxPMErrorToStr(vError);
1020 wxLogError("Error creating frame. Error: %s\n", sError);
f23208ca
DW
1021 return FALSE;
1022 }
dae16775 1023
7e99520b 1024 //
51c1d535 1025 // wxWindow class' m_hWnd set here and needed associations
5b3ed311 1026 //
51c1d535
DW
1027 m_hFrame = hFrame;
1028 m_hWnd = hClient;
1029 wxAssociateWinWithHandle(m_hWnd, this);
1030 wxAssociateWinWithHandle(m_hFrame, this);
5b3ed311 1031
8d854fa9
DW
1032 m_backgroundColour.Set(wxString("GREY"));
1033
1034 LONG lColor = (LONG)m_backgroundColour.GetPixel();
1035
1036 if (!::WinSetPresParam( m_hWnd
1037 ,PP_BACKGROUNDCOLOR
1038 ,sizeof(LONG)
1039 ,(PVOID)&lColor
1040 ))
1041 {
1042 vError = ::WinGetLastError(vHabmain);
1043 sError = wxPMErrorToStr(vError);
1044 wxLogError("Error creating frame. Error: %s\n", sError);
1045 return FALSE;
1046 }
1047
51c1d535
DW
1048 //
1049 // Now need to subclass window. Instead of calling the SubClassWin in wxWindow
1050 // we manually subclass here because we don't want to use the main wxWndProc
1051 // by default
1052 //
1053 m_fnOldWndProc = (WXFARPROC) ::WinSubclassWindow(m_hFrame, (PFNWP)wxFrameMainWndProc);
5b3ed311 1054
f23208ca
DW
1055 //
1056 // Now size everything. If adding a menu the client will need to be resized.
1057 //
e604d44b 1058
51c1d535 1059 if (!::WinSetWindowPos( m_hFrame
f23208ca
DW
1060 ,HWND_TOP
1061 ,nX
1062 ,nY
1063 ,nWidth
1064 ,nHeight
f6bcfd97 1065 ,SWP_SIZE | SWP_MOVE | SWP_ACTIVATE | SWP_ZORDER
f23208ca 1066 ))
51c1d535
DW
1067 {
1068 vError = ::WinGetLastError(vHabmain);
1069 sError = wxPMErrorToStr(vError);
1070 wxLogError("Error sizing frame. Error: %s\n", sError);
1071 return FALSE;
1072 }
1073 //
1074 // We may have to be smarter here when variable sized toolbars are added!
1075 //
1076 if (!::WinSetWindowPos( m_hWnd
1077 ,HWND_TOP
fb83aca5
DW
1078 ,nX // + 20
1079 ,nY // + 20
1080 ,nWidth // - 60
1081 ,nHeight // - 60
51c1d535
DW
1082 ,SWP_SIZE | SWP_MOVE | SWP_ACTIVATE | SWP_ZORDER
1083 ))
1084 {
1085 vError = ::WinGetLastError(vHabmain);
1086 sError = wxPMErrorToStr(vError);
1087 wxLogError("Error sizing client. Error: %s\n", sError);
f23208ca 1088 return FALSE;
51c1d535 1089 }
a885d89a 1090 return TRUE;
0d53fc34 1091} // end of wxFrame::OS2Create
0e320a79 1092
a885d89a 1093//
0e320a79
DW
1094// Default activation behaviour - set the focus for the first child
1095// subwindow found.
a885d89a 1096//
0d53fc34 1097void wxFrame::OnActivate(
a885d89a
DW
1098 wxActivateEvent& rEvent
1099)
0e320a79 1100{
c4955899 1101 if ( rEvent.GetActive() )
0e320a79 1102 {
c4955899
DW
1103 // restore focus to the child which was last focused
1104 wxLogTrace(_T("focus"), _T("wxFrame %08x activated."), m_hWnd);
21802234 1105
c4955899
DW
1106 wxWindow* pParent = m_pWinLastFocused ? m_pWinLastFocused->GetParent()
1107 : NULL;
1108 if (!pParent)
1109 {
1110 pParent = this;
1111 }
21802234 1112
c4955899
DW
1113 wxSetFocusToChild( pParent
1114 ,&m_pWinLastFocused
1115 );
1116 }
1117 else // deactivating
1118 {
1119 //
1120 // Remember the last focused child if it is our child
1121 //
1122 m_pWinLastFocused = FindFocus();
1123
1124 for (wxWindowList::Node* pNode = GetChildren().GetFirst();
1125 pNode;
1126 pNode = pNode->GetNext())
1127 {
1128 // FIXME all this is totally bogus - we need to do the same as wxPanel,
1129 // but how to do it without duplicating the code?
1130
1131 // restore focus
1132 wxWindow* pChild = pNode->GetData();
1133
1134 if (!pChild->IsTopLevel()
21802234 1135#if wxUSE_TOOLBAR
c4955899 1136 && !wxDynamicCast(pChild, wxToolBar)
21802234
DW
1137#endif // wxUSE_TOOLBAR
1138#if wxUSE_STATUSBAR
c4955899 1139 && !wxDynamicCast(pChild, wxStatusBar)
21802234 1140#endif // wxUSE_STATUSBAR
c4955899
DW
1141 )
1142 {
1143 pChild->SetFocus();
1144 return;
1145 }
21802234 1146 }
0e320a79 1147 }
0d53fc34 1148} // end of wxFrame::OnActivate
0e320a79 1149
f38374d0
DW
1150// ----------------------------------------------------------------------------
1151// wxFrame size management: we exclude the areas taken by menu/status/toolbars
1152// from the client area, so the client area is what's really available for the
1153// frame contents
1154// ----------------------------------------------------------------------------
0e320a79
DW
1155
1156// Checks if there is a toolbar, and returns the first free client position
0d53fc34 1157wxPoint wxFrame::GetClientAreaOrigin() const
0e320a79 1158{
a885d89a
DW
1159 wxPoint vPoint(0, 0);
1160
7e99520b 1161#if wxUSE_TOOLBAR
0e320a79
DW
1162 if (GetToolBar())
1163 {
a885d89a
DW
1164 int nWidth;
1165 int nHeight;
1166
1167 GetToolBar()->GetSize( &nWidth
1168 ,&nHeight
1169 );
0e320a79
DW
1170
1171 if (GetToolBar()->GetWindowStyleFlag() & wxTB_VERTICAL)
1172 {
a885d89a 1173 vPoint.x += nWidth;
0e320a79
DW
1174 }
1175 else
1176 {
a885d89a
DW
1177 // PM is backwards from windows
1178 vPoint.y += nHeight;
0e320a79
DW
1179 }
1180 }
7e99520b 1181#endif //wxUSE_TOOLBAR
a885d89a 1182 return vPoint;
0d53fc34 1183} // end of wxFrame::GetClientAreaOrigin
0e320a79 1184
f38374d0
DW
1185// ----------------------------------------------------------------------------
1186// tool/status bar stuff
1187// ----------------------------------------------------------------------------
1188
21802234 1189#if wxUSE_TOOLBAR
f38374d0 1190
0d53fc34 1191wxToolBar* wxFrame::CreateToolBar(
a885d89a
DW
1192 long lStyle
1193, wxWindowID vId
1194, const wxString& rName
1195)
0e320a79 1196{
a885d89a
DW
1197 if (wxFrameBase::CreateToolBar( lStyle
1198 ,vId
1199 ,rName
1200 ))
0e320a79 1201 {
0e320a79 1202 PositionToolBar();
0e320a79 1203 }
f38374d0 1204 return m_frameToolBar;
0d53fc34 1205} // end of wxFrame::CreateToolBar
0e320a79 1206
0d53fc34 1207void wxFrame::PositionToolBar()
0e320a79 1208{
a885d89a
DW
1209 HWND hWndClient;
1210 RECTL vRect;
1211
40bd6154 1212 ::WinQueryWindowRect(GetHwnd(), &vRect);
0e320a79 1213
f38374d0 1214#if wxUSE_STATUSBAR
a885d89a 1215 if (GetStatusBar())
0e320a79 1216 {
a885d89a
DW
1217 int nStatusX;
1218 int nStatusY;
1219
1220 GetStatusBar()->GetClientSize( &nStatusX
1221 ,&nStatusY
1222 );
1223 // PM is backwards from windows
1224 vRect.yBottom += nStatusY;
0e320a79 1225 }
f38374d0 1226#endif // wxUSE_STATUSBAR
0e320a79 1227
1c84ee88 1228 if ( m_frameToolBar )
0e320a79 1229 {
a885d89a
DW
1230 int nToolbarWidth;
1231 int nToolbarHeight;
1232
1c84ee88 1233 m_frameToolBar->GetSize( &nToolbarWidth
a885d89a
DW
1234 ,&nToolbarHeight
1235 );
0e320a79 1236
a885d89a 1237 if (GetToolBar()->GetWindowStyleFlag() & wxTB_VERTICAL)
0e320a79 1238 {
a885d89a 1239 nToolbarHeight = vRect.yBottom;
0e320a79
DW
1240 }
1241 else
1242 {
a885d89a 1243 nToolbarWidth = vRect.xRight;
21802234 1244 }
f38374d0 1245
a885d89a
DW
1246 //
1247 // Use the 'real' PM position here
1248 //
1249 GetToolBar()->SetSize( 0
1250 ,0
1251 ,nToolbarWidth
1252 ,nToolbarHeight
1253 ,wxSIZE_NO_ADJUSTMENTS
1254 );
21802234 1255 }
0d53fc34 1256} // end of wxFrame::PositionToolBar
21802234
DW
1257#endif // wxUSE_TOOLBAR
1258
f38374d0
DW
1259// ----------------------------------------------------------------------------
1260// frame state (iconized/maximized/...)
1261// ----------------------------------------------------------------------------
1262
a885d89a 1263//
21802234
DW
1264// propagate our state change to all child frames: this allows us to emulate X
1265// Windows behaviour where child frames float independently of the parent one
1266// on the desktop, but are iconized/restored with it
a885d89a 1267//
0d53fc34 1268void wxFrame::IconizeChildFrames(
a885d89a
DW
1269 bool bIconize
1270)
21802234 1271{
a885d89a
DW
1272 for (wxWindowList::Node* pNode = GetChildren().GetFirst();
1273 pNode;
1274 pNode = pNode->GetNext() )
21802234 1275 {
a885d89a 1276 wxWindow* pWin = pNode->GetData();
21802234 1277
a885d89a 1278 if (pWin->IsKindOf(CLASSINFO(wxFrame)) )
21802234 1279 {
a885d89a 1280 ((wxFrame *)pWin)->Iconize(bIconize);
0e320a79
DW
1281 }
1282 }
0d53fc34 1283} // end of wxFrame::IconizeChildFrames
0e320a79 1284
21802234
DW
1285// ===========================================================================
1286// message processing
1287// ===========================================================================
1288
1289// ---------------------------------------------------------------------------
1290// preprocessing
1291// ---------------------------------------------------------------------------
0d53fc34 1292bool wxFrame::OS2TranslateMessage(
a885d89a
DW
1293 WXMSG* pMsg
1294)
21802234 1295{
a885d89a 1296 //
21802234 1297 // try the menu bar accels
a885d89a
DW
1298 //
1299 wxMenuBar* pMenuBar = GetMenuBar();
1300
19193a2c 1301 if (!pMenuBar)
21802234
DW
1302 return FALSE;
1303
19193a2c 1304#if wxUSE_ACCEL && wxUSE_MENUS_NATIVE
a885d89a 1305 const wxAcceleratorTable& rAcceleratorTable = pMenuBar->GetAccelTable();
e604d44b 1306 return rAcceleratorTable.Translate(GetHWND(), pMsg);
7e99520b
DW
1307#else
1308 return FALSE;
1309#endif //wxUSE_ACCEL
0d53fc34 1310} // end of wxFrame::OS2TranslateMessage
21802234
DW
1311
1312// ---------------------------------------------------------------------------
1313// our private (non virtual) message handlers
1314// ---------------------------------------------------------------------------
0d53fc34 1315bool wxFrame::HandlePaint()
21802234 1316{
a885d89a
DW
1317 RECTL vRect;
1318
e604d44b 1319 if (::WinQueryUpdateRect(GetHWND(), &vRect))
29435d81 1320 {
a885d89a 1321 if (m_bIconized)
29435d81 1322 {
a885d89a
DW
1323 //
1324 // Icons in PM are the same as "pointers"
1325 //
1326 HPOINTER hIcon;
29435d81 1327
a885d89a 1328 if (m_icon.Ok())
b7084589 1329 hIcon = (HPOINTER)::WinSendMsg(m_hFrame, WM_QUERYICON, 0L, 0L);
a885d89a
DW
1330 else
1331 hIcon = (HPOINTER)m_hDefaultIcon;
1332
1333 //
21802234
DW
1334 // Hold a pointer to the dc so long as the OnPaint() message
1335 // is being processed
a885d89a
DW
1336 //
1337 RECTL vRect2;
64e0c5c6 1338 HPS hPs = ::WinBeginPaint(GetHwnd(), NULLHANDLE, &vRect2);
29435d81 1339
a885d89a 1340 //
29435d81 1341 // Erase background before painting or we get white background
a885d89a
DW
1342 //
1343 OS2DefWindowProc(WM_ERASEBACKGROUND, (MPARAM)hPs, (MPARAM)&vRect2);
29435d81 1344
a885d89a 1345 if (hIcon)
29435d81 1346 {
a885d89a
DW
1347 HWND hWndClient;
1348 RECTL vRect3;
21802234 1349
40bd6154 1350 ::WinQueryWindowRect(GetHwnd(), &vRect3);
29435d81 1351
a885d89a
DW
1352 static const int nIconWidth = 32;
1353 static const int nIconHeight = 32;
1354 int nIconX = (int)((vRect3.xRight - nIconWidth)/2);
1355 int nIconY = (int)((vRect3.yBottom + nIconHeight)/2);
29435d81 1356
a885d89a 1357 ::WinDrawPointer(hPs, nIconX, nIconY, hIcon, DP_NORMAL);
29435d81 1358 }
a885d89a 1359 ::WinEndPaint(hPs);
29435d81
DW
1360 return TRUE;
1361 }
1362 else
1363 {
8d854fa9 1364 return(wxWindow::HandlePaint());
29435d81
DW
1365 }
1366 }
1367 else
1368 {
1369 // nothing to paint - processed
1370 return TRUE;
1371 }
29435d81 1372 return FALSE;
0d53fc34 1373} // end of wxFrame::HandlePaint
21802234 1374
0d53fc34 1375bool wxFrame::HandleSize(
a885d89a
DW
1376 int nX
1377, int nY
1378, WXUINT nId
1379)
21802234 1380{
a885d89a 1381 bool bProcessed = FALSE;
21802234 1382
a885d89a 1383 switch (nId)
21802234 1384 {
a885d89a
DW
1385 case kSizeNormal:
1386 //
1387 // Only do it it if we were iconized before, otherwise resizing the
21802234
DW
1388 // parent frame has a curious side effect of bringing it under it's
1389 // children
a885d89a 1390 if (!m_bIconized )
21802234
DW
1391 break;
1392
a885d89a 1393 //
21802234 1394 // restore all child frames too
a885d89a 1395 //
21802234 1396 IconizeChildFrames(FALSE);
3febf684 1397 (void)SendIconizeEvent(FALSE);
21802234 1398
a885d89a 1399 //
21802234 1400 // fall through
a885d89a 1401 //
21802234 1402
a885d89a
DW
1403 case kSizeMax:
1404 m_bIconized = FALSE;
21802234
DW
1405 break;
1406
a885d89a
DW
1407 case kSizeMin:
1408 //
1409 // Iconize all child frames too
1410 //
21802234 1411 IconizeChildFrames(TRUE);
3febf684 1412 (void)SendIconizeEvent();
a885d89a 1413 m_bIconized = TRUE;
21802234
DW
1414 break;
1415 }
f38374d0 1416
a885d89a 1417 if (!m_bIconized)
21802234 1418 {
a885d89a 1419 //
29435d81 1420 // forward WM_SIZE to status bar control
a885d89a 1421 //
f38374d0
DW
1422#if wxUSE_NATIVE_STATUSBAR
1423 if (m_frameStatusBar && m_frameStatusBar->IsKindOf(CLASSINFO(wxStatusBar95)))
1424 {
a885d89a
DW
1425 wxSizeEvent vEvent( wxSize( nX
1426 ,nY
1427 )
1428 ,m_frameStatusBar->GetId()
1429 );
f38374d0 1430
a885d89a
DW
1431 vEvent.SetEventObject(m_frameStatusBar);
1432 m_frameStatusBar->OnSize(vEvent);
f38374d0
DW
1433 }
1434#endif // wxUSE_NATIVE_STATUSBAR
1435
51c1d535 1436 PositionStatusBar();
7e99520b 1437#if wxUSE_TOOLBAR
21802234 1438 PositionToolBar();
7e99520b
DW
1439#endif // wxUSE_TOOLBAR
1440
a885d89a
DW
1441 wxSizeEvent vEvent( wxSize( nX
1442 ,nY
1443 )
1444 ,m_windowId
1445 );
21802234 1446
a885d89a
DW
1447 vEvent.SetEventObject(this);
1448 bProcessed = GetEventHandler()->ProcessEvent(vEvent);
21802234 1449 }
a885d89a 1450 return bProcessed;
0d53fc34 1451} // end of wxFrame::HandleSize
21802234 1452
0d53fc34 1453bool wxFrame::HandleCommand(
a885d89a
DW
1454 WXWORD nId
1455, WXWORD nCmd
1456, WXHWND hControl
1457)
21802234 1458{
a885d89a 1459 if (hControl)
21802234 1460 {
a885d89a 1461 //
21802234 1462 // In case it's e.g. a toolbar.
a885d89a
DW
1463 //
1464 wxWindow* pWin = wxFindWinFromHandle(hControl);
1465
1466 if (pWin)
1467 return pWin->OS2Command( nCmd
1468 ,nId
1469 );
21802234
DW
1470 }
1471
a885d89a
DW
1472 //
1473 // Handle here commands from menus and accelerators
1474 //
5b3ed311 1475 if (nCmd == CMDSRC_MENU || nCmd == CMDSRC_ACCELERATOR)
21802234 1476 {
19193a2c 1477#if wxUSE_MENUS_NATIVE
a885d89a 1478 if (wxCurrentPopupMenu)
21802234 1479 {
a885d89a
DW
1480 wxMenu* pPopupMenu = wxCurrentPopupMenu;
1481
21802234
DW
1482 wxCurrentPopupMenu = NULL;
1483
a885d89a
DW
1484 return pPopupMenu->OS2Command( nCmd
1485 ,nId
1486 );
19193a2c 1487 return TRUE;
21802234 1488 }
19193a2c 1489#endif
21802234 1490
a885d89a 1491 if (ProcessCommand(nId))
21802234
DW
1492 {
1493 return TRUE;
1494 }
1495 }
21802234 1496 return FALSE;
0d53fc34 1497} // end of wxFrame::HandleCommand
21802234 1498
0d53fc34 1499bool wxFrame::HandleMenuSelect(
a885d89a
DW
1500 WXWORD nItem
1501, WXWORD nFlags
1502, WXHMENU hMenu
1503)
21802234 1504{
e604d44b
DW
1505 if( !nFlags )
1506 {
1507 MENUITEM mItem;
1508 MRESULT rc;
1509
51c1d535 1510 rc = ::WinSendMsg(hMenu, MM_QUERYITEM, MPFROM2SHORT(nItem, TRUE), (MPARAM)&mItem);
e604d44b
DW
1511
1512 if(rc && !(mItem.afStyle & (MIS_SUBMENU | MIS_SEPARATOR)))
1513 {
1514 wxMenuEvent vEvent(wxEVT_MENU_HIGHLIGHT, nItem);
1515
1516 vEvent.SetEventObject(this);
1517 GetEventHandler()->ProcessEvent(vEvent); // return value would be ignored by PM
1518 }
1519 }
1520 return TRUE;
0d53fc34 1521} // end of wxFrame::HandleMenuSelect
21802234
DW
1522
1523// ---------------------------------------------------------------------------
51c1d535 1524// Main Frame window proc
21802234 1525// ---------------------------------------------------------------------------
51c1d535
DW
1526MRESULT EXPENTRY wxFrameMainWndProc(
1527 HWND hWnd
1528, ULONG ulMsg
1529, MPARAM wParam
1530, MPARAM lParam
1531)
1532{
1533 MRESULT rc = (MRESULT)0;
1534 bool bProcessed = FALSE;
1535 wxFrame* pWnd = NULL;
1536
1537 pWnd = (wxFrame*) wxFindWinFromHandle((WXHWND) hWnd);
1538 switch (ulMsg)
1539 {
1540 case WM_QUERYFRAMECTLCOUNT:
1541 if(pWnd && pWnd->m_fnOldWndProc)
1542 {
1543 USHORT uItemCount = SHORT1FROMMR(pWnd->m_fnOldWndProc(hWnd, ulMsg, wParam, lParam));
1544
1545 rc = MRFROMSHORT(uItemCount);
1546 }
1547 break;
1548
1549 case WM_FORMATFRAME:
1550/////////////////////////////////////////////////////////////////////////////////
1551// Applications that subclass frame controls may find that the frame is already
1552// subclassed the number of frame controls is variable.
1553// The WM_FORMATFRAME and WM_QUERYFRAMECTLCOUNT messages must always be
1554// subclassed by calling the previous window procedure and modifying its result.
1555////////////////////////////////////////////////////////////////////////////////
1556 {
1557 int nItemCount;
1558 int i;
1559 PSWP pSWP = NULL;
1560 SWP vSwpStb;
1561 RECTL vRectl;
1562 RECTL vRstb;
1563 int nHeight=0;
1564
1565 pSWP = (PSWP)PVOIDFROMMP(wParam);
1566 nItemCount = SHORT1FROMMR(pWnd->m_fnOldWndProc(hWnd, ulMsg, wParam, lParam));
1567 if(pWnd->m_frameStatusBar)
1568 {
1569 ::WinQueryWindowRect(pWnd->m_frameStatusBar->GetHWND(), &vRstb);
1570 pWnd->m_frameStatusBar->GetSize(NULL, &nHeight);
1571 ::WinQueryWindowRect(pWnd->m_hFrame, &vRectl);
1572 ::WinMapWindowPoints(pWnd->m_hFrame, HWND_DESKTOP, (PPOINTL)&vRectl, 2);
1573 vRstb = vRectl;
1574 ::WinCalcFrameRect(pWnd->m_hFrame, &vRectl, TRUE);
1575
1576 vSwpStb.x = vRectl.xLeft - vRstb.xLeft;
1577 vSwpStb.y = vRectl.yBottom - vRstb.yBottom;
1578 vSwpStb.cx = vRectl.xRight - vRectl.xLeft - 1; //?? -1 ??
1579 vSwpStb.cy = nHeight;
1580 vSwpStb.fl = SWP_SIZE |SWP_MOVE | SWP_SHOW;
1581 vSwpStb.hwnd = pWnd->m_frameStatusBar->GetHWND();
1582 vSwpStb.hwndInsertBehind = HWND_TOP;
1583 }
1584 ::WinQueryWindowRect(pWnd->m_hFrame, &vRectl);
1585 ::WinMapWindowPoints(pWnd->m_hFrame, HWND_DESKTOP, (PPOINTL)&vRectl, 2);
1586 ::WinCalcFrameRect(pWnd->m_hFrame, &vRectl, TRUE);
1587 ::WinMapWindowPoints(HWND_DESKTOP, pWnd->m_hFrame, (PPOINTL)&vRectl, 2);
1588 for(i = 0; i < nItemCount; i++)
1589 {
1590 if(pWnd->m_hWnd && pSWP[i].hwnd == pWnd->m_hWnd)
1591 {
1592 pSWP[i].x = vRectl.xLeft;
1593 pSWP[i].y = vRectl.yBottom + nHeight;
1594 pSWP[i].cx = vRectl.xRight - vRectl.xLeft;
1595 pSWP[i].cy = vRectl.yTop - vRectl.yBottom - nHeight;
1596 pSWP[i].fl = SWP_SIZE | SWP_MOVE | SWP_SHOW;
1597 pSWP[i].hwndInsertBehind = HWND_TOP;
1598 }
1599 }
1600 bProcessed = TRUE;
1601 rc = MRFROMSHORT(nItemCount);
1602 }
1603 break;
1604
1605 default:
1606 if(pWnd && pWnd->m_fnOldWndProc)
1607 rc = pWnd->m_fnOldWndProc(hWnd, ulMsg, wParam, lParam);
1608 else
1609 rc = ::WinDefWindowProc(hWnd, ulMsg, wParam, lParam);
1610 }
1611 return rc;
1612} // end of wxFrameMainWndProc
1613
1614MRESULT EXPENTRY wxFrameWndProc(
1615 HWND hWnd
1616, ULONG ulMsg
1617, MPARAM wParam
1618, MPARAM lParam
1619)
1620{
1621 //
1622 // Trace all ulMsgs - useful for the debugging
1623 //
1624 HWND parentHwnd;
1625 wxFrame* pWnd = NULL;
1626
1627 parentHwnd = WinQueryWindow(hWnd,QW_PARENT);
1628 pWnd = (wxFrame*) wxFindWinFromHandle((WXHWND) hWnd);
1629
1630 //
1631 // When we get the first message for the HWND we just created, we associate
1632 // it with wxWindow stored in wxWndHook
1633 //
51c1d535
DW
1634
1635 MRESULT rc = (MRESULT)0;
1636 bool bProcessed = FALSE;
1637
1638 //
1639 // Stop right here if we don't have a valid handle in our wxWindow object.
1640 //
1641 if (pWnd && !pWnd->GetHWND())
1642 {
1643 pWnd->SetHWND((WXHWND) hWnd);
1644 rc = pWnd->OS2DefWindowProc(ulMsg, wParam, lParam );
1645 pWnd->SetHWND(0);
1646 }
1647 else
1648 {
d08f23a7
DW
1649 if (pWnd)
1650 rc = pWnd->OS2WindowProc(ulMsg, wParam, lParam);
1651 else
1652 rc = ::WinDefWindowProc(hWnd, ulMsg, wParam, lParam);
51c1d535
DW
1653 }
1654 return rc;
1655} // end of wxFrameWndProc
21802234 1656
0d53fc34 1657MRESULT wxFrame::OS2WindowProc(
a885d89a
DW
1658 WXUINT uMessage
1659, WXWPARAM wParam
1660, WXLPARAM lParam
1661)
21802234 1662{
a885d89a
DW
1663 MRESULT mRc = 0L;
1664 bool bProcessed = FALSE;
21802234 1665
a885d89a 1666 switch (uMessage)
21802234
DW
1667 {
1668 case WM_CLOSE:
a885d89a
DW
1669 //
1670 // If we can't close, tell the system that we processed the
21802234 1671 // message - otherwise it would close us
a885d89a
DW
1672 //
1673 bProcessed = !Close();
21802234
DW
1674 break;
1675
d08f23a7 1676 case WM_PAINT:
8d854fa9
DW
1677 bProcessed = HandlePaint();
1678 mRc = (MRESULT)FALSE;
1679 break;
d08f23a7 1680
8d854fa9
DW
1681 case WM_ERASEBACKGROUND:
1682 //
1683 // Returning TRUE to requests PM to paint the window background
1684 // in SYSCLR_WINDOW. We capture this here because the PS returned
1685 // in Frames is the PS for the whole frame, which we can't really
1686 // use at all. If you want to paint a different background, do it
1687 // in an OnPaint using a wxPaintDC.
1688 //
1689 mRc = (MRESULT)(TRUE);
d08f23a7
DW
1690 break;
1691
8d854fa9 1692 case WM_COMMAND:
21802234 1693 {
a885d89a
DW
1694 WORD wId;
1695 WORD wCmd;
1696 WXHWND hWnd;
1697
1698 UnpackCommand( (WXWPARAM)wParam
d08f23a7
DW
1699 ,(WXLPARAM)lParam
1700 ,&wId
1701 ,&hWnd
1702 ,&wCmd
1703 );
5b3ed311 1704
a885d89a
DW
1705 bProcessed = HandleCommand( wId
1706 ,wCmd
1707 ,(WXHWND)hWnd
1708 );
21802234
DW
1709 }
1710 break;
1711
1712 case WM_MENUSELECT:
1713 {
a885d89a
DW
1714 WXWORD wItem;
1715 WXWORD wFlags;
1716 WXHMENU hMenu;
1717
1718 UnpackMenuSelect( wParam
1719 ,lParam
1720 ,&wItem
1721 ,&wFlags
1722 ,&hMenu
1723 );
1724 bProcessed = HandleMenuSelect( wItem
1725 ,wFlags
1726 ,hMenu
1727 );
e604d44b 1728 mRc = (MRESULT)TRUE;
21802234
DW
1729 }
1730 break;
1731
d08f23a7
DW
1732 case WM_SIZE:
1733 {
1734 SHORT nScxold = SHORT1FROMMP(wParam); // Old horizontal size.
1735 SHORT nScyold = SHORT2FROMMP(wParam); // Old vertical size.
1736 SHORT nScxnew = SHORT1FROMMP(lParam); // New horizontal size.
1737 SHORT nScynew = SHORT2FROMMP(lParam); // New vertical size.
1738
1739 lParam = MRFROM2SHORT( nScxnew - 20
1740 ,nScynew - 30
1741 );
1742 }
1743 bProcessed = HandleSize(LOWORD(lParam), HIWORD(lParam), (WXUINT)wParam);
1744 mRc = (MRESULT)FALSE;
21802234
DW
1745 break;
1746
a885d89a 1747 case CM_QUERYDRAGIMAGE:
21802234 1748 {
a885d89a
DW
1749 HPOINTER hIcon;
1750
1751 if (m_icon.Ok())
e604d44b 1752 hIcon = (HPOINTER)::WinSendMsg(GetHWND(), WM_QUERYICON, 0L, 0L);
a885d89a
DW
1753 else
1754 hIcon = (HPOINTER)m_hDefaultIcon;
1755 mRc = (MRESULT)hIcon;
1756 bProcessed = mRc != 0;
21802234
DW
1757 }
1758 break;
21802234 1759 }
f38374d0 1760
a885d89a
DW
1761 if (!bProcessed )
1762 mRc = wxWindow::OS2WindowProc( uMessage
1763 ,wParam
1764 ,lParam
1765 );
e604d44b 1766 return (MRESULT)mRc;
0d53fc34 1767} // wxFrame::OS2WindowProc
21802234 1768
0d53fc34 1769void wxFrame::SetClient(WXHWND c_Hwnd)
5b3ed311 1770{
51c1d535 1771 // Duh...nothing to do under OS/2
5b3ed311
DW
1772}
1773
0d53fc34 1774void wxFrame::SetClient(
51c1d535
DW
1775 wxWindow* pWindow
1776)
5b3ed311 1777{
51c1d535
DW
1778 wxWindow* pOldClient = this->GetClient();
1779 bool bClientHasFocus = pOldClient && (pOldClient == wxWindow::FindFocus());
5b3ed311 1780
51c1d535 1781 if(pOldClient == pWindow) // nothing to do
5b3ed311 1782 return;
51c1d535
DW
1783 if(pWindow == NULL) // just need to remove old client
1784 {
1785 if(pOldClient == NULL) // nothing to do
1786 return;
5b3ed311 1787
51c1d535 1788 if(bClientHasFocus )
5b3ed311
DW
1789 this->SetFocus();
1790
51c1d535
DW
1791 pOldClient->Enable( FALSE );
1792 pOldClient->Show( FALSE );
1793 ::WinSetWindowUShort(pOldClient->GetHWND(), QWS_ID, (USHORT)pOldClient->GetId());
5b3ed311 1794 // to avoid OS/2 bug need to update frame
b7084589 1795 ::WinSendMsg((HWND)this->GetFrame(), WM_UPDATEFRAME, (MPARAM)~0, 0);
5b3ed311 1796 return;
51c1d535 1797 }
5b3ed311 1798
51c1d535
DW
1799 //
1800 // Else need to change client
1801 //
1802 if(bClientHasFocus)
5b3ed311
DW
1803 this->SetFocus();
1804
51c1d535
DW
1805 ::WinEnableWindowUpdate((HWND)GetHWND(), FALSE);
1806 if(pOldClient)
1807 {
1808 pOldClient->Enable(FALSE);
1809 pOldClient->Show(FALSE);
1810 ::WinSetWindowUShort(pOldClient->GetHWND(), QWS_ID, (USHORT)pOldClient->GetId());
1811 }
1812 pWindow->Reparent(this);
1813 ::WinSetWindowUShort(pWindow->GetHWND(), QWS_ID, FID_CLIENT);
1814 ::WinEnableWindowUpdate((HWND)GetHWND(), TRUE);
1815 pWindow->Enable();
1816 pWindow->Show(); // ensure client is showing
1817 if( this->IsShown() )
1818 {
1819 this->Show();
b7084589 1820 ::WinSendMsg(m_hFrame, WM_UPDATEFRAME, (MPARAM)~0, 0);
51c1d535 1821 }
5b3ed311
DW
1822}
1823
0d53fc34 1824wxWindow* wxFrame::GetClient()
5b3ed311 1825{
b7084589 1826 return wxFindWinFromHandle((WXHWND)::WinWindowFromID(m_hFrame, FID_CLIENT));
5b3ed311 1827}