]> git.saurik.com Git - wxWidgets.git/blame_incremental - src/os2/frame.cpp
Corrected font calculation (use screen resolution now); and check for mask in m_image.cpp
[wxWidgets.git] / src / os2 / frame.cpp
... / ...
CommitLineData
1/////////////////////////////////////////////////////////////////////////////
2// Name: frame.cpp
3// Purpose: wxFrame
4// Author: David Webster
5// Modified by:
6// Created: 10/27/99
7// RCS-ID: $Id$
8// Copyright: (c) David Webster
9// Licence: wxWindows licence
10/////////////////////////////////////////////////////////////////////////////
11
12// For compilers that support precompilation, includes "wx.h".
13#include "wx/wxprec.h"
14
15#ifndef WX_PRECOMP
16 #include "wx/setup.h"
17 #include "wx/frame.h"
18 #include "wx/menu.h"
19 #include "wx/app.h"
20 #include "wx/utils.h"
21 #include "wx/dialog.h"
22 #include "wx/settings.h"
23 #include "wx/dcclient.h"
24#endif // WX_PRECOMP
25
26#include "wx/os2/private.h"
27
28#if wxUSE_STATUSBAR
29 #include "wx/statusbr.h"
30#endif // wxUSE_STATUSBAR
31
32#if wxUSE_TOOLBAR
33 #include "wx/toolbar.h"
34#endif // wxUSE_TOOLBAR
35
36#include "wx/menuitem.h"
37#include "wx/log.h"
38
39// ----------------------------------------------------------------------------
40// globals
41// ----------------------------------------------------------------------------
42
43extern wxWindowList wxModelessWindows;
44extern wxList WXDLLEXPORT wxPendingDelete;
45extern wxChar wxFrameClassName[];
46extern wxMenu *wxCurrentPopupMenu;
47
48// ----------------------------------------------------------------------------
49// event tables
50// ----------------------------------------------------------------------------
51
52BEGIN_EVENT_TABLE(wxFrame, wxFrameBase)
53 EVT_ACTIVATE(wxFrame::OnActivate)
54 EVT_SYS_COLOUR_CHANGED(wxFrame::OnSysColourChanged)
55END_EVENT_TABLE()
56
57IMPLEMENT_DYNAMIC_CLASS(wxFrame, wxWindow)
58
59// ============================================================================
60// implementation
61// ============================================================================
62
63// ----------------------------------------------------------------------------
64// static class members
65// ----------------------------------------------------------------------------
66
67#if wxUSE_NATIVE_STATUSBAR
68 bool wxFrame::m_useNativeStatusBar = TRUE;
69#else
70 bool wxFrame::m_useNativeStatusBar = FALSE;
71#endif
72
73// ----------------------------------------------------------------------------
74// creation/destruction
75// ----------------------------------------------------------------------------
76
77void wxFrame::Init()
78{
79 m_iconized = FALSE;
80
81#if wxUSE_TOOLTIPS
82 m_hwndToolTip = 0;
83#endif
84}
85
86bool wxFrame::Create(wxWindow *parent,
87 wxWindowID id,
88 const wxString& title,
89 const wxPoint& pos,
90 const wxSize& size,
91 long style,
92 const wxString& name)
93{
94 SetName(name);
95 m_windowStyle = style;
96 m_frameMenuBar = NULL;
97 m_frameToolBar = NULL;
98 m_frameStatusBar = NULL;
99
100 SetBackgroundColour(wxSystemSettings::GetSystemColour(wxSYS_COLOUR_APPWORKSPACE));
101
102 if ( id > -1 )
103 m_windowId = id;
104 else
105 m_windowId = (int)NewControlId();
106
107 if (parent) parent->AddChild(this);
108
109 int x = pos.x;
110 int y = pos.y;
111 int width = size.x;
112 int height = size.y;
113
114 m_iconized = FALSE;
115
116 // we pass NULL as parent to MSWCreate because frames with parents behave
117 // very strangely under Win95 shell
118 // Alteration by JACS: keep normal Windows behaviour (float on top of parent)
119 // with this style.
120 if ((m_windowStyle & wxFRAME_FLOAT_ON_PARENT) == 0)
121 parent = NULL;
122
123 if (!parent)
124 wxTopLevelWindows.Append(this);
125
126 OS2Create(m_windowId, parent, wxFrameClassName, this, title,
127 x, y, width, height, style);
128
129 wxModelessWindows.Append(this);
130 return TRUE;
131}
132
133wxFrame::~wxFrame()
134{
135 m_isBeingDeleted = TRUE;
136 wxTopLevelWindows.DeleteObject(this);
137
138// TODO:
139/*
140 DeleteAllBars();
141
142 if (wxTheApp && (wxTopLevelWindows.Number() == 0))
143 {
144 wxTheApp->SetTopWindow(NULL);
145
146 if (wxTheApp->GetExitOnFrameDelete())
147 {
148 PostQuitMessage(0);
149 }
150 }
151
152 wxModelessWindows.DeleteObject(this);
153
154 // For some reason, wxWindows can activate another task altogether
155 // when a frame is destroyed after a modal dialog has been invoked.
156 // Try to bring the parent to the top.
157 // MT:Only do this if this frame is currently the active window, else weird
158 // things start to happen
159 if ( wxGetActiveWindow() == this )
160 if (GetParent() && GetParent()->GetHWND())
161 ::BringWindowToTop((HWND) GetParent()->GetHWND());
162*/
163}
164
165// Get size *available for subwindows* i.e. excluding menu bar, toolbar etc.
166void wxFrame::DoGetClientSize(int *x, int *y) const
167{
168// TODO:
169/*
170 RECT rect;
171 ::GetClientRect(GetHwnd(), &rect);
172
173#if wxUSE_STATUSBAR
174 if ( GetStatusBar() )
175 {
176 int statusX, statusY;
177 GetStatusBar()->GetClientSize(&statusX, &statusY);
178 rect.bottom -= statusY;
179 }
180#endif // wxUSE_STATUSBAR
181
182 wxPoint pt(GetClientAreaOrigin());
183 rect.bottom -= pt.y;
184 rect.right -= pt.x;
185
186 if ( x )
187 *x = rect.right;
188 if ( y )
189 *y = rect.bottom;
190*/
191}
192
193// Set the client size (i.e. leave the calculation of borders etc.
194// to wxWindows)
195void wxFrame::DoSetClientSize(int width, int height)
196{
197 HWND hWnd = GetHwnd();
198
199// TODO:
200/*
201 RECT rect;
202 ::GetClientRect(hWnd, &rect);
203
204 RECT rect2;
205 GetWindowRect(hWnd, &rect2);
206
207 // Find the difference between the entire window (title bar and all)
208 // and the client area; add this to the new client size to move the
209 // window
210 int actual_width = rect2.right - rect2.left - rect.right + width;
211 int actual_height = rect2.bottom - rect2.top - rect.bottom + height;
212
213#if wxUSE_STATUSBAR
214 if ( GetStatusBar() )
215 {
216 int statusX, statusY;
217 GetStatusBar()->GetClientSize(&statusX, &statusY);
218 actual_height += statusY;
219 }
220#endif // wxUSE_STATUSBAR
221
222 wxPoint pt(GetClientAreaOrigin());
223 actual_width += pt.y;
224 actual_height += pt.x;
225
226 POINT point;
227 point.x = rect2.left;
228 point.y = rect2.top;
229
230 MoveWindow(hWnd, point.x, point.y, actual_width, actual_height, (BOOL)TRUE);
231
232 wxSizeEvent event(wxSize(width, height), m_windowId);
233 event.SetEventObject( this );
234 GetEventHandler()->ProcessEvent(event);
235*/
236}
237
238void wxFrame::DoGetSize(int *width, int *height) const
239{
240// TODO:
241/*
242 RECT rect;
243 GetWindowRect(GetHwnd(), &rect);
244 *width = rect.right - rect.left;
245 *height = rect.bottom - rect.top;
246*/
247}
248
249void wxFrame::DoGetPosition(int *x, int *y) const
250{
251// TODO:
252/*
253 RECT rect;
254 GetWindowRect(GetHwnd(), &rect);
255 POINT point;
256 point.x = rect.left;
257 point.y = rect.top;
258
259 *x = point.x;
260 *y = point.y;
261*/
262}
263
264// ----------------------------------------------------------------------------
265// variations around ::ShowWindow()
266// ----------------------------------------------------------------------------
267
268void wxFrame::DoShowWindow(int nShowCmd)
269{
270// TODO:
271/*
272 ::ShowWindow(GetHwnd(), nShowCmd);
273
274 m_iconized = nShowCmd == SW_MINIMIZE;
275*/
276}
277
278bool wxFrame::Show(bool show)
279{
280// TODO:
281/*
282 DoShowWindow(show ? SW_SHOW : SW_HIDE);
283
284 if ( show )
285 {
286 ::BringWindowToTop(GetHwnd());
287
288 wxActivateEvent event(wxEVT_ACTIVATE, TRUE, m_windowId);
289 event.SetEventObject( this );
290 GetEventHandler()->ProcessEvent(event);
291 }
292 else
293 {
294 // Try to highlight the correct window (the parent)
295 if ( GetParent() )
296 {
297 HWND hWndParent = GetHwndOf(GetParent());
298 if (hWndParent)
299 ::BringWindowToTop(hWndParent);
300 }
301 }
302*/
303 return TRUE;
304}
305
306void wxFrame::Iconize(bool iconize)
307{
308// DoShowWindow(iconize ? SW_MINIMIZE : SW_RESTORE);
309}
310
311void wxFrame::Maximize(bool maximize)
312{
313// DoShowWindow(maximize ? SW_MAXIMIZE : SW_RESTORE);
314}
315
316void wxFrame::Restore()
317{
318// DoShowWindow(SW_RESTORE);
319}
320
321bool wxFrame::IsIconized() const
322{
323// TODO:
324/*
325 ((wxFrame *)this)->m_iconized = (::IsIconic(GetHwnd()) != 0);
326 return m_iconized;
327*/
328 return FALSE;
329}
330
331// Is it maximized?
332bool wxFrame::IsMaximized() const
333{
334// TODO:
335/*
336 return (::IsZoomed(GetHwnd()) != 0);
337*/
338 return FALSE;
339}
340
341void wxFrame::SetIcon(const wxIcon& icon)
342{
343 wxFrameBase::SetIcon(icon);
344
345// TODO:
346/*
347 if ( m_icon.Ok() )
348 {
349 SendMessage(GetHwnd(), WM_SETICON,
350 (WPARAM)TRUE, (LPARAM)(HICON) m_icon.GetHICON());
351 }
352*/
353}
354
355#if wxUSE_STATUSBAR
356wxStatusBar *wxFrame::OnCreateStatusBar(int number,
357 long style,
358 wxWindowID id,
359 const wxString& name)
360{
361 wxStatusBar *statusBar = NULL;
362
363 statusBar = wxFrameBase::OnCreateStatusBar(number, style, id, name);
364
365 return statusBar;
366}
367
368void wxFrame::PositionStatusBar()
369{
370// TODO:
371/*
372 // native status bar positions itself
373 if ( m_frameStatusBar )
374 {
375 int w, h;
376 GetClientSize(&w, &h);
377 int sw, sh;
378 m_frameStatusBar->GetSize(&sw, &sh);
379
380 // Since we wish the status bar to be directly under the client area,
381 // we use the adjusted sizes without using wxSIZE_NO_ADJUSTMENTS.
382 m_frameStatusBar->SetSize(0, h, w, sh);
383 }
384*/
385}
386#endif // wxUSE_STATUSBAR
387
388void wxFrame::DetachMenuBar()
389{
390 if (m_frameMenuBar)
391 {
392 m_frameMenuBar->Detach();
393 m_frameMenuBar = NULL;
394 }
395}
396
397void wxFrame::SetMenuBar(wxMenuBar *menu_bar)
398{
399 if (!menu_bar)
400 {
401 DetachMenuBar();
402 return;
403 }
404
405 wxCHECK_RET( !menu_bar->GetFrame(), wxT("this menubar is already attached") );
406
407 if (m_frameMenuBar)
408 delete m_frameMenuBar;
409
410 m_hMenu = menu_bar->Create();
411
412 if ( !m_hMenu )
413 return;
414
415 InternalSetMenuBar();
416
417 m_frameMenuBar = menu_bar;
418 menu_bar->Attach(this);
419}
420
421void wxFrame::InternalSetMenuBar()
422{
423// TODO:
424/*
425 if ( !::SetMenu(GetHwnd(), (HMENU)m_hMenu) )
426 {
427 wxLogLastError("SetMenu");
428 }
429*/
430}
431
432// Responds to colour changes, and passes event on to children.
433void wxFrame::OnSysColourChanged(wxSysColourChangedEvent& event)
434{
435// TODO:
436/*
437 SetBackgroundColour(wxSystemSettings::GetSystemColour(wxSYS_COLOUR_APPWORKSPACE));
438 Refresh();
439
440 if ( m_frameStatusBar )
441 {
442 wxSysColourChangedEvent event2;
443 event2.SetEventObject( m_frameStatusBar );
444 m_frameStatusBar->GetEventHandler()->ProcessEvent(event2);
445 }
446
447 // Propagate the event to the non-top-level children
448 wxWindow::OnSysColourChanged(event);
449*/
450}
451
452/*
453 * Frame window
454 *
455 */
456
457bool wxFrame::OS2Create(int id, wxWindow *parent, const wxChar *wclass, wxWindow *wx_win, const wxChar *title,
458 int x, int y, int width, int height, long style)
459
460{
461 m_defaultIcon = (WXHICON) (wxSTD_FRAME_ICON ? wxSTD_FRAME_ICON : wxDEFAULT_FRAME_ICON);
462
463 // If child windows aren't properly drawn initially, WS_CLIPCHILDREN
464 // could be the culprit. But without it, you can get a lot of flicker.
465
466// TODO:
467/*
468 DWORD msflags = 0;
469 if ((style & wxCAPTION) == wxCAPTION)
470 msflags = WS_OVERLAPPED;
471 else
472 msflags = WS_POPUP;
473
474 if (style & wxMINIMIZE_BOX)
475 msflags |= WS_MINIMIZEBOX;
476 if (style & wxMAXIMIZE_BOX)
477 msflags |= WS_MAXIMIZEBOX;
478 if (style & wxTHICK_FRAME)
479 msflags |= WS_THICKFRAME;
480 if (style & wxSYSTEM_MENU)
481 msflags |= WS_SYSMENU;
482 if ((style & wxMINIMIZE) || (style & wxICONIZE))
483 msflags |= WS_MINIMIZE;
484 if (style & wxMAXIMIZE)
485 msflags |= WS_MAXIMIZE;
486 if (style & wxCAPTION)
487 msflags |= WS_CAPTION;
488 if (style & wxCLIP_CHILDREN)
489 msflags |= WS_CLIPCHILDREN;
490
491 // Keep this in wxFrame because it saves recoding this function
492 // in wxTinyFrame
493#if wxUSE_ITSY_BITSY
494 if (style & wxTINY_CAPTION_VERT)
495 msflags |= IBS_VERTCAPTION;
496 if (style & wxTINY_CAPTION_HORIZ)
497 msflags |= IBS_HORZCAPTION;
498#else
499 if (style & wxTINY_CAPTION_VERT)
500 msflags |= WS_CAPTION;
501 if (style & wxTINY_CAPTION_HORIZ)
502 msflags |= WS_CAPTION;
503#endif
504 if ((style & wxTHICK_FRAME) == 0)
505 msflags |= WS_BORDER;
506
507 WXDWORD extendedStyle = MakeExtendedStyle(style);
508
509#if !defined(__WIN16__) && !defined(__SC__)
510 if (style & wxFRAME_TOOL_WINDOW)
511 extendedStyle |= WS_EX_TOOLWINDOW;
512#endif
513
514 if (style & wxSTAY_ON_TOP)
515 extendedStyle |= WS_EX_TOPMOST;
516
517 m_iconized = FALSE;
518 if ( !wxWindow::MSWCreate(id, parent, wclass, wx_win, title, x, y, width, height,
519 msflags, NULL, extendedStyle) )
520 return FALSE;
521
522 // Seems to be necessary if we use WS_POPUP
523 // style instead of WS_OVERLAPPED
524 if (width > -1 && height > -1)
525 ::PostMessage(GetHwnd(), WM_SIZE, SIZE_RESTORED, MAKELPARAM(width, height));
526*/
527 return TRUE;
528}
529
530// Default activation behaviour - set the focus for the first child
531// subwindow found.
532void wxFrame::OnActivate(wxActivateEvent& event)
533{
534 for ( wxWindowList::Node *node = GetChildren().GetFirst();
535 node;
536 node = node->GetNext() )
537 {
538 // FIXME all this is totally bogus - we need to do the same as wxPanel,
539 // but how to do it without duplicating the code?
540
541 // restore focus
542 wxWindow *child = node->GetData();
543
544 if ( !child->IsTopLevel()
545#if wxUSE_TOOLBAR
546 && !wxDynamicCast(child, wxToolBar)
547#endif // wxUSE_TOOLBAR
548#if wxUSE_STATUSBAR
549 && !wxDynamicCast(child, wxStatusBar)
550#endif // wxUSE_STATUSBAR
551 )
552 {
553 child->SetFocus();
554 return;
555 }
556 }
557}
558
559// ----------------------------------------------------------------------------
560// wxFrame size management: we exclude the areas taken by menu/status/toolbars
561// from the client area, so the client area is what's really available for the
562// frame contents
563// ----------------------------------------------------------------------------
564
565// Checks if there is a toolbar, and returns the first free client position
566wxPoint wxFrame::GetClientAreaOrigin() const
567{
568 wxPoint pt(0, 0);
569 if (GetToolBar())
570 {
571 int w, h;
572 GetToolBar()->GetSize(& w, & h);
573
574 if (GetToolBar()->GetWindowStyleFlag() & wxTB_VERTICAL)
575 {
576 pt.x += w;
577 }
578 else
579 {
580 pt.y += h;
581 }
582 }
583 return pt;
584}
585
586void wxFrame::DoScreenToClient(int *x, int *y) const
587{
588 wxWindow::DoScreenToClient(x, y);
589
590 // We may be faking the client origin.
591 // So a window that's really at (0, 30) may appear
592 // (to wxWin apps) to be at (0, 0).
593 wxPoint pt(GetClientAreaOrigin());
594 *x -= pt.x;
595 *y -= pt.y;
596}
597
598void wxFrame::DoClientToScreen(int *x, int *y) const
599{
600 // We may be faking the client origin.
601 // So a window that's really at (0, 30) may appear
602 // (to wxWin apps) to be at (0, 0).
603 wxPoint pt1(GetClientAreaOrigin());
604 *x += pt1.x;
605 *y += pt1.y;
606
607 wxWindow::DoClientToScreen(x, y);
608}
609
610// ----------------------------------------------------------------------------
611// tool/status bar stuff
612// ----------------------------------------------------------------------------
613
614#if wxUSE_TOOLBAR
615
616wxToolBar* wxFrame::CreateToolBar(long style, wxWindowID id, const wxString& name)
617{
618 if ( wxFrameBase::CreateToolBar(style, id, name) )
619 {
620 PositionToolBar();
621 }
622
623 return m_frameToolBar;
624}
625
626void wxFrame::PositionToolBar()
627{
628// TODO:
629/*
630 RECT rect;
631 ::GetClientRect(GetHwnd(), &rect);
632
633#if wxUSE_STATUSBAR
634 if ( GetStatusBar() )
635 {
636 int statusX, statusY;
637 GetStatusBar()->GetClientSize(&statusX, &statusY);
638 rect.bottom -= statusY;
639 }
640#endif // wxUSE_STATUSBAR
641
642 if ( GetToolBar() )
643 {
644 int tw, th;
645 GetToolBar()->GetSize(&tw, &th);
646
647 if ( GetToolBar()->GetWindowStyleFlag() & wxTB_VERTICAL )
648 {
649 th = rect.bottom;
650 }
651 else
652 {
653 tw = rect.right;
654 }
655
656 // Use the 'real' MSW position here
657 GetToolBar()->SetSize(0, 0, tw, th, wxSIZE_NO_ADJUSTMENTS);
658 }
659*/
660}
661#endif // wxUSE_TOOLBAR
662
663// ----------------------------------------------------------------------------
664// frame state (iconized/maximized/...)
665// ----------------------------------------------------------------------------
666
667// propagate our state change to all child frames: this allows us to emulate X
668// Windows behaviour where child frames float independently of the parent one
669// on the desktop, but are iconized/restored with it
670void wxFrame::IconizeChildFrames(bool bIconize)
671{
672 for ( wxWindowList::Node *node = GetChildren().GetFirst();
673 node;
674 node = node->GetNext() )
675 {
676 wxWindow *win = node->GetData();
677
678 if ( win->IsKindOf(CLASSINFO(wxFrame)) )
679 {
680 ((wxFrame *)win)->Iconize(bIconize);
681 }
682 }
683}
684
685// ===========================================================================
686// message processing
687// ===========================================================================
688
689// ---------------------------------------------------------------------------
690// preprocessing
691// ---------------------------------------------------------------------------
692
693bool wxFrame::OS2TranslateMessage(WXMSG* pMsg)
694{
695// TODO:
696/*
697 if ( wxWindow::OS2TranslateMessage(pMsg) )
698 return TRUE;
699*/
700 // try the menu bar accels
701 wxMenuBar *menuBar = GetMenuBar();
702 if ( !menuBar )
703 return FALSE;
704
705 const wxAcceleratorTable& acceleratorTable = menuBar->GetAccelTable();
706 return acceleratorTable.Translate(this, pMsg);
707}
708
709// ---------------------------------------------------------------------------
710// our private (non virtual) message handlers
711// ---------------------------------------------------------------------------
712
713bool wxFrame::HandlePaint()
714{
715// TODO:
716/*
717 RECT rect;
718 if ( GetUpdateRect(GetHwnd(), &rect, FALSE) )
719 {
720 if ( m_iconized )
721 {
722 HICON hIcon = m_icon.Ok() ? GetHiconOf(m_icon)
723 : (HICON)m_defaultIcon;
724
725 // Hold a pointer to the dc so long as the OnPaint() message
726 // is being processed
727 PAINTSTRUCT ps;
728 HDC hdc = ::BeginPaint(GetHwnd(), &ps);
729
730 // Erase background before painting or we get white background
731 MSWDefWindowProc(WM_ICONERASEBKGND, (WORD)(LONG)ps.hdc, 0L);
732
733 if ( hIcon )
734 {
735 RECT rect;
736 ::GetClientRect(GetHwnd(), &rect);
737
738 // FIXME: why hardcoded?
739 static const int icon_width = 32;
740 static const int icon_height = 32;
741
742 int icon_x = (int)((rect.right - icon_width)/2);
743 int icon_y = (int)((rect.bottom - icon_height)/2);
744
745 ::DrawIcon(hdc, icon_x, icon_y, hIcon);
746 }
747
748 ::EndPaint(GetHwnd(), &ps);
749
750 return TRUE;
751 }
752 else
753 {
754 return wxWindow::HandlePaint();
755 }
756 }
757 else
758 {
759 // nothing to paint - processed
760 return TRUE;
761 }
762*/
763 return FALSE;
764}
765
766bool wxFrame::HandleSize(int x, int y, WXUINT id)
767{
768 bool processed = FALSE;
769
770// TODO:
771/*
772 switch ( id )
773 {
774 case SIZENORMAL:
775 // only do it it if we were iconized before, otherwise resizing the
776 // parent frame has a curious side effect of bringing it under it's
777 // children
778 if ( !m_iconized )
779 break;
780
781 // restore all child frames too
782 IconizeChildFrames(FALSE);
783
784 // fall through
785
786 case SIZEFULLSCREEN:
787 m_iconized = FALSE;
788 break;
789
790 case SIZEICONIC:
791 // iconize all child frames too
792 IconizeChildFrames(TRUE);
793
794 m_iconized = TRUE;
795 break;
796 }
797
798 if ( !m_iconized )
799 {
800 // forward WM_SIZE to status bar control
801#if wxUSE_NATIVE_STATUSBAR
802 if (m_frameStatusBar && m_frameStatusBar->IsKindOf(CLASSINFO(wxStatusBar95)))
803 {
804 wxSizeEvent event(wxSize(x, y), m_frameStatusBar->GetId());
805 event.SetEventObject( m_frameStatusBar );
806
807 ((wxStatusBar95 *)m_frameStatusBar)->OnSize(event);
808 }
809#endif // wxUSE_NATIVE_STATUSBAR
810
811 PositionStatusBar();
812 PositionToolBar();
813
814 wxSizeEvent event(wxSize(x, y), m_windowId);
815 event.SetEventObject( this );
816 processed = GetEventHandler()->ProcessEvent(event);
817 }
818*/
819 return processed;
820}
821
822bool wxFrame::HandleCommand(WXWORD id, WXWORD cmd, WXHWND control)
823{
824// TODO:
825/*
826 if ( control )
827 {
828 // In case it's e.g. a toolbar.
829 wxWindow *win = wxFindWinFromHandle(control);
830 if ( win )
831 return win->MSWCommand(cmd, id);
832 }
833
834 // handle here commands from menus and accelerators
835 if ( cmd == 0 || cmd == 1 )
836 {
837 if ( wxCurrentPopupMenu )
838 {
839 wxMenu *popupMenu = wxCurrentPopupMenu;
840 wxCurrentPopupMenu = NULL;
841
842 return popupMenu->MSWCommand(cmd, id);
843 }
844
845 if ( ProcessCommand(id) )
846 {
847 return TRUE;
848 }
849 }
850*/
851 return FALSE;
852}
853
854bool wxFrame::HandleMenuSelect(WXWORD nItem, WXWORD flags, WXHMENU hMenu)
855{
856 int item;
857 if ( flags == 0xFFFF && hMenu == 0 )
858 {
859 // menu was removed from screen
860 item = -1;
861 }
862// TODO:
863/*
864 else if ( !(flags & MF_POPUP) && !(flags & MF_SEPARATOR) )
865 {
866 item = nItem;
867 }
868 else
869 {
870 // don't give hints for separators (doesn't make sense) nor for the
871 // items opening popup menus (they don't have them anyhow)
872 return FALSE;
873 }
874*/
875 wxMenuEvent event(wxEVT_MENU_HIGHLIGHT, item);
876 event.SetEventObject( this );
877
878 return GetEventHandler()->ProcessEvent(event);
879}
880
881// ---------------------------------------------------------------------------
882// the window proc for wxFrame
883// ---------------------------------------------------------------------------
884
885MRESULT wxFrame::OS2WindowProc(HWND hwnd, WXUINT message, WXWPARAM wParam, WXLPARAM lParam)
886{
887 long rc = 0;
888 bool processed = FALSE;
889
890// TODO:
891/*
892 switch ( message )
893 {
894 case WM_CLOSE:
895 // if we can't close, tell the system that we processed the
896 // message - otherwise it would close us
897 processed = !Close();
898 break;
899
900 case WM_COMMAND:
901 {
902 WORD id, cmd;
903 WXHWND hwnd;
904 UnpackCommand((WXWPARAM)wParam, (WXLPARAM)lParam,
905 &id, &hwnd, &cmd);
906
907 processed = HandleCommand(id, cmd, (WXHWND)hwnd);
908 }
909 break;
910
911 case WM_MENUSELECT:
912 {
913 WXWORD item, flags;
914 WXHMENU hmenu;
915 UnpackMenuSelect(wParam, lParam, &item, &flags, &hmenu);
916
917 processed = HandleMenuSelect(item, flags, hmenu);
918 }
919 break;
920
921 case WM_PAINT:
922 processed = HandlePaint();
923 break;
924
925 case WM_QUERYDRAGICON:
926 {
927 HICON hIcon = m_icon.Ok() ? GetHiconOf(m_icon)
928 : (HICON)(m_defaultIcon);
929 rc = (long)hIcon;
930 processed = rc != 0;
931 }
932 break;
933
934 case WM_SIZE:
935 processed = HandleSize(LOWORD(lParam), HIWORD(lParam), wParam);
936 break;
937 }
938
939 if ( !processed )
940 rc = wxWindow::MSWWindowProc(message, wParam, lParam);
941
942 return rc;
943*/
944 return (MRESULT)0;
945}
946