// headers
// ----------------------------------------------------------------------------
-#if defined(__GNUG__) && !defined(NO_GCC_PRAGMA)
- #pragma implementation "toplevelbase.h"
-#endif
-
// For compilers that support precompilation, includes "wx.h".
#include "wx/wxprec.h"
#include "wx/app.h"
#endif // WX_PRECOMP
+#include "wx/display.h"
+
// ----------------------------------------------------------------------------
// event table
// ----------------------------------------------------------------------------
// implementation
// ============================================================================
-IMPLEMENT_DYNAMIC_CLASS(wxTopLevelWindow, wxWindow)
+IMPLEMENT_ABSTRACT_CLASS(wxTopLevelWindow, wxWindow)
// ----------------------------------------------------------------------------
// construction/destruction
return size;
}
+void wxTopLevelWindowBase::DoCentre(int dir)
+{
+ wxRect rectCentre;
+ if ( !(dir & wxCENTRE_ON_SCREEN) && GetParent() )
+ {
+ // centre on parent window: notice that we need screen coordinates for
+ // positioning this TLW
+ rectCentre = GetParent()->GetScreenRect();
+ }
+ else
+ {
+ // we were explicitely asked to centre this window on the entire screen
+ // or if we have no parent anyhow and so can't centre on it
+#if wxUSE_DISPLAY
+ const int nDisplay = wxDisplay::GetFromWindow(this);
+ if ( nDisplay != wxNOT_FOUND )
+ {
+ rectCentre = wxDisplay(nDisplay).GetGeometry();
+ }
+ else
+#endif // wxUSE_DISPLAY
+ {
+ wxDisplaySize(&rectCentre.width, &rectCentre.height);
+ }
+ }
+
+ // window may be at -1 if it's centered on a secondary display, for example
+ SetSize(GetRect().CentreIn(rectCentre, dir), wxSIZE_ALLOW_MINUS_ONE);
+}
+
// ----------------------------------------------------------------------------
// wxTopLevelWindow size management: we exclude the areas taken by
// menu/status/toolbars from the client area, so the client area is what's
// do the window-specific processing after processing the update event
void wxTopLevelWindowBase::DoUpdateWindowUI(wxUpdateUIEvent& event)
{
- if ( event.GetSetEnabled() )
- Enable(event.GetEnabled());
+ // call inherited, but skip the wxControl's version, and call directly the
+ // wxWindow's one instead, because the only reason why we are overriding this
+ // function is that we want to use SetTitle() instead of wxControl::SetLabel()
+ wxWindowBase::DoUpdateWindowUI(event);
+ // update title
if ( event.GetSetText() )
{
if ( event.GetText() != GetTitle() )