1 ///////////////////////////////////////////////////////////////////////////////
3 // Purpose: wxPopupWindow interface declaration
4 // Author: Vadim Zeitlin
8 // Copyright: (c) 2001 Vadim Zeitlin <zeitlin@dptmaths.ens-cachan.fr>
9 // License: wxWindows license
10 ///////////////////////////////////////////////////////////////////////////////
12 #ifndef _WX_POPUPWIN_H_BASE_
13 #define _WX_POPUPWIN_H_BASE_
16 #pragma interface "popupwinbase.h"
19 #include "wx/window.h"
23 // ----------------------------------------------------------------------------
24 // wxPopupWindow: a special kind of top level window used for popup menus,
25 // combobox popups and such.
26 // ----------------------------------------------------------------------------
28 class WXDLLEXPORT wxPopupWindowBase
: public wxWindow
31 wxPopupWindowBase() { }
33 virtual ~wxPopupWindowBase() { }
36 // create the popup window
38 // style may only contain border flags
39 bool Create(wxWindow
*parent
, int style
= wxBORDER_NONE
);
41 // move the popup window to the right position, i.e. such that it is
44 // the popup is positioned at ptOrigin + size if it opens below and to the
45 // right (default), at ptOrigin - sizePopup if it opens above and to the
48 // the point must be given in screen coordinates!
49 virtual void Position(const wxPoint
& ptOrigin
,
53 // include the real class declaration
55 #include "wx/msw/popupwin.h"
57 #include "wx/gtk/popupwin.h"
59 #include "wx/mgl/popupwin.h"
61 #error "wxPopupWindow is not supported under this platform."
64 // ----------------------------------------------------------------------------
65 // wxPopupTransientWindow: a wxPopupWindow which disappears automatically
66 // when the user clicks mouse outside it or if it loses focus in any other way
67 // ----------------------------------------------------------------------------
69 class WXDLLEXPORT wxPopupTransientWindow
: public wxPopupWindow
73 wxPopupTransientWindow() { Init(); }
74 wxPopupTransientWindow(wxWindow
*parent
);
76 virtual ~wxPopupTransientWindow();
78 // popup the window (this will show it too) and keep focus at winFocus
79 // (or itself if it's NULL), dismiss the popup if we lose focus
80 virtual void Popup(wxWindow
*focus
= NULL
);
83 virtual void Dismiss();
85 // called when a mouse is pressed while the popup is shown: return TRUE
86 // from here to prevent its normal processing by the popup (which consists
87 // in dismissing it if the mouse is cilcked outside it)
88 virtual bool ProcessLeftDown(wxMouseEvent
& event
);
91 // common part of all ctors
94 // this is called when the popup is disappeared because of anything
95 // else but direct call to Dismiss()
96 virtual void OnDismiss();
98 // dismiss and notify the derived class
99 void DismissAndNotify();
101 // remove our event handlers
104 // the child of this popup if any
107 // the window which has the focus while we're shown
110 friend class wxPopupWindowHandler
;
111 friend class wxPopupFocusHandler
;
114 #if wxUSE_COMBOBOX && defined(__WXUNIVERSAL__)
116 // ----------------------------------------------------------------------------
117 // wxPopupComboWindow: wxPopupTransientWindow used by wxComboBox
118 // ----------------------------------------------------------------------------
120 class WXDLLEXPORT wxComboBox
;
121 class WXDLLEXPORT wxComboControl
;
123 class WXDLLEXPORT wxPopupComboWindow
: public wxPopupTransientWindow
126 wxPopupComboWindow(wxComboControl
*parent
);
128 bool Create(wxComboControl
*parent
);
130 // position the window correctly relatively to the combo
131 void PositionNearCombo();
134 // notify the combo here
135 virtual void OnDismiss();
137 // the parent combobox
138 wxComboControl
*m_combo
;
141 #endif // wxUSE_COMBOBOX && defined(__WXUNIVERSAL__)
143 #endif // wxUSE_POPUPWIN
145 #endif // _WX_POPUPWIN_H_BASE_